tango-app-ui-analyse-traffic 3.4.0-beta.78 → 3.4.0-beta.79
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/traffic-analysis/traffic-analysis.component.mjs +20 -13
- package/fesm2022/tango-app-ui-analyse-traffic.mjs +19 -12
- package/fesm2022/tango-app-ui-analyse-traffic.mjs.map +1 -1
- package/lib/components/traffic-analysis/traffic-analysis.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -2561,10 +2561,12 @@ line-height: 13px;">
|
|
|
2561
2561
|
buyersNoData = false;
|
|
2562
2562
|
buyersloading = false;
|
|
2563
2563
|
datasetsCard = [];
|
|
2564
|
+
processTypeNew;
|
|
2564
2565
|
selectedTabs(type) {
|
|
2565
2566
|
this.detailedCharts = false;
|
|
2566
2567
|
this.selectedTab = type;
|
|
2567
2568
|
this.objDataTraffic.processType = type;
|
|
2569
|
+
this.processTypeNew = type;
|
|
2568
2570
|
this.objDataTraffic.valueType = this.valueType;
|
|
2569
2571
|
this.objDataTraffic.storeId = this.headerData.stores.filter((store) => store.checked).map((store) => store.storeId);
|
|
2570
2572
|
if (this.selectedTab === 'traffic') {
|
|
@@ -2782,18 +2784,23 @@ line-height: 13px;">
|
|
|
2782
2784
|
value: Number(item.count),
|
|
2783
2785
|
storeId: item.storeId
|
|
2784
2786
|
}));
|
|
2785
|
-
if (this.
|
|
2786
|
-
this.objDataTraffic.processType
|
|
2787
|
-
|
|
2788
|
-
|
|
2789
|
-
this.objDataTraffic.processType
|
|
2790
|
-
|
|
2791
|
-
|
|
2792
|
-
this.
|
|
2793
|
-
|
|
2787
|
+
if (this.headerData.client === '452') {
|
|
2788
|
+
if (this.objDataTraffic.processType === "conversion") {
|
|
2789
|
+
this.processTypeNew = this.headerData?.client === '452' ? `More than ${this.featureConfig?.conversion.value} mins ` : 'Conversion';
|
|
2790
|
+
}
|
|
2791
|
+
if (this.objDataTraffic.processType === "engagers") {
|
|
2792
|
+
this.processTypeNew = this.headerData?.client === '452' ? `More than ${this.featureConfig?.bouncedLimit.value} mins` : 'Engagers';
|
|
2793
|
+
}
|
|
2794
|
+
if (this.objDataTraffic.processType === "bounced") {
|
|
2795
|
+
this.footfallValue = "bounced";
|
|
2796
|
+
this.processTypeNew = this.headerData?.client === '452' ? `Less than ${this.featureConfig?.bouncedLimit.value} mins` : 'Bounced';
|
|
2797
|
+
}
|
|
2798
|
+
if (this.objDataTraffic.processType === "missedOpportunity") {
|
|
2799
|
+
this.processTypeNew = this.headerData?.client === '452' ? `${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins` : 'Missed Opportunity';
|
|
2800
|
+
}
|
|
2794
2801
|
}
|
|
2795
|
-
|
|
2796
|
-
this.
|
|
2802
|
+
else {
|
|
2803
|
+
this.processTypeNew = this.objDataTraffic.processType;
|
|
2797
2804
|
}
|
|
2798
2805
|
// Create series
|
|
2799
2806
|
this.series = this.chart.series.push(am5xy.ColumnSeries.new(this.root, {
|
|
@@ -2803,7 +2810,7 @@ line-height: 13px;">
|
|
|
2803
2810
|
valueYField: "value",
|
|
2804
2811
|
categoryXField: "storeName",
|
|
2805
2812
|
tooltip: am5.Tooltip.new(this.root, {
|
|
2806
|
-
labelText: `${(this.
|
|
2813
|
+
labelText: `${(this.processTypeNew)}, {fullStoreName}: {valueY}`,
|
|
2807
2814
|
}),
|
|
2808
2815
|
}));
|
|
2809
2816
|
xAxis.data.setAll(data);
|
|
@@ -3858,4 +3865,4 @@ function getDaysBetweenDates(fromDate, toDate) {
|
|
|
3858
3865
|
const differenceInDays = Math.floor(differenceInMs / millisecondsPerDay);
|
|
3859
3866
|
return differenceInDays;
|
|
3860
3867
|
}
|
|
3861
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"traffic-analysis.component.js","sourceRoot":"","sources":["../../../../../../projects/tango-analyse-traffic/src/lib/components/traffic-analysis/traffic-analysis.component.ts","../../../../../../projects/tango-analyse-traffic/src/lib/components/traffic-analysis/traffic-analysis.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  OnDestroy,\r\n  NgZone,\r\n  ElementRef,\r\n  Renderer2,\r\n  ViewChild,\r\n  ChangeDetectorRef,\r\n  HostListener, AfterViewInit\r\n} from \"@angular/core\";\r\nimport * as am5 from \"@amcharts/amcharts5\";\r\nimport * as am5xy from \"@amcharts/amcharts5/xy\";\r\nimport am5themes_Animated from \"@amcharts/amcharts5/themes/Animated\";\r\nimport am5themes_Responsive from \"@amcharts/amcharts5/themes/Responsive\";\r\nimport * as am5percent from \"@amcharts/amcharts5/percent\";\r\nimport { TrafficService } from \"../../services/traffic.service\";\r\nimport { Subject, Subscription, takeUntil, filter } from 'rxjs';\r\nimport { NgbModal, NgbTooltip } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { Router } from \"@angular/router\";\r\nimport { ExcelService } from \"../../services/excel.service\";\r\nimport * as mapboxgl from 'mapbox-gl';\r\nimport { ToastService } from \"tango-app-ui-shared\";\r\nimport { VideoUrlComponent } from \"../video-url/video-url.component\";\r\nimport * as bootstrap from \"bootstrap\";\r\nimport { FormBuilder, FormControl } from \"@angular/forms\";\r\nimport dayjs from 'dayjs';\r\n\r\n@Component({\r\n  selector: \"lib-traffic-analysis\",\r\n  templateUrl: \"./traffic-analysis.component.html\",\r\n  styleUrl: \"./traffic-analysis.component.scss\",\r\n})\r\nexport class TrafficAnalysisComponent implements OnInit, OnDestroy, AfterViewInit {\r\n  private lineroot: am5.Root;\r\n  private bouncedlineroot: am5.Root;\r\n  private potentialBuyerslineroot: am5.Root;\r\n  private engagerslineroot: am5.Root;\r\n  sortedColumn: any;\r\n  sortDirection: any;\r\n  private chart: any;\r\n  private tooltipElement: HTMLElement;\r\n  private readonly destroy$ = new Subject();\r\n  getCardData: any = [];\r\n  heatMapData: any = [];\r\n  getCardGraphData: any;\r\n  getSummaryTableData: any;\r\n  itemsPerPage = 10;\r\n  currentPage = 1;\r\n  totalItems = 1;\r\n  paginationSizes:any[] = [];\r\n  pageSize = 10;\r\n  offset: number = 0;\r\n  limit: number = 10;\r\n  getRecapVideoData: any;\r\n  tableobj: any;\r\n  heatMaproot: am5.Root;\r\n  valueType=\"actual\"\r\n  dateType=\"weekly\";\r\n  points:any = [];\r\n  headerData: any;\r\n  typeValue: any ='sum';\r\n  valueConversionRate: any;\r\n  conversionValue: any='';\r\n  searchValue: any;\r\n  loading: boolean =true;\r\n  noData: boolean =false;\r\n  cardloading: boolean =true;\r\n  cardNodata: boolean =false;\r\n  heatloading = true\r\n  heatnoData = false\r\n  storeIdarray: any =[];\r\n  getRecapData: any=[];\r\n  form: any;\r\n  dateLength: number;\r\n  performancenoData: boolean =false;\r\n  performanceLoading: boolean =true;\r\n  zoneDwellTimeSplitData: any=[];\r\n  storeOperationData: any=[];\r\n  footfallName: string='Actual Footfall';\r\n  bounceLabel: any;\r\n  footfallLabel: any;\r\n  colValue: any;\r\n  recaplaoding: boolean;\r\n  recapnoData: boolean;\r\n  recapsGrouped: any[]=[];\r\n  isAverage: boolean = false; // Toggle state for the switch\r\n  isDisabled: boolean =false;\r\n  zoneLoading = true;\r\n zoneNoData = false;\r\n  clientData: any;\r\n  featureConfig: any;\r\n  nob: boolean;\r\n  forecast: any;\r\n  maxFootfall: any;\r\n  minFootfall: any;\r\n  isConversion : boolean = false;\r\n  @HostListener('document:click', ['$event'])\r\n  handleClickOutside(event: MouseEvent) {\r\n    const clickedInside = (event.target as HTMLElement).closest('.tooltip-popup, .label');\r\n    if (!clickedInside) {\r\n      this.activeTooltip = null;\r\n    }\r\n  }\r\n  activeTooltip: string | null = null;\r\n\r\n  auLocations: any[] = [];\r\n  mapOptions: google.maps.MapOptions = {\r\n    mapId: \"DEMO_MAP_ID\",\r\n    center: { lat: 0, lng: 0 },  // Initial center\r\n    zoom: 1,\r\n  };\r\n\r\n  performanceData:any = [];\r\n  mpaloading =true;\r\n  mapnoData = false;\r\n  footfalldatasets = [\r\n    { value: 'footfall', label: 'Footfall' },\r\n    { value: 'bounced', label: 'Bounced Footfall' },\r\n    { value: 'engager', label: 'Engagers' },\r\n    { value: 'missedOpportunity', label: 'Missed Opportunity' },\r\n    { value: 'potentialBuyer', label: 'Potential Buyer' },\r\n    { value: 'conversion', label: 'Conversion' }\r\n  ];\r\n  bouncedatasets = [\r\n    { value: 'footfall', label: 'Footfall' },\r\n    { value: 'bounced', label: 'Bounced Footfall' },\r\n    { value: 'engager', label: 'Engagers' },\r\n    { value: 'missedOpportunity', label: 'Missed Opportunity' },\r\n    { value: 'potentialBuyer', label: 'Potential Buyer' },\r\n    { value: 'conversion', label: 'Conversion' }\r\n  ];\r\n\r\n  constructor(\r\n    private zone: NgZone,\r\n    private el: ElementRef,\r\n    private renderer: Renderer2,private router:Router,private excelService: ExcelService,\r\n    private service: TrafficService,public gs: GlobalStateService, private fb:FormBuilder,\r\n    private cd: ChangeDetectorRef,private toast:ToastService, private modalService: NgbModal,\r\n  ) {\r\n \r\n         this.form = this.fb.group({\r\n           selectValue: new FormControl('') // Initialize as FormControl\r\n         });\r\n  }\r\n  @ViewChild(\"t\", { static: false }) tooltip: NgbTooltip;\r\n  tooltipValue: string;\r\n  bounceValue1:any;\r\n  clientAPIData:any;\r\n  users:any;\r\n   sub2:Subscription | undefined\r\n   private isInitialized: boolean = false;\r\n   processType=\"missedopportunities\"\r\n   trendtypeValue: any ='average';\r\n   normalize:any;\r\n  ngOnInit(): void {\r\n    (mapboxgl as any).accessToken = 'pk.eyJ1IjoiYmFsYWppdGFuZ28iLCJhIjoiY20wZ2xiem55MDFxYTJ3b21zb3FjNHdwayJ9.nnIIzt7OeYlYHufGE8lFWQ';\r\n    this.offset = 0;\r\n    this.limit=10;\r\n    const userData: any = JSON.parse(localStorage.getItem(\"user-info\") || \"{}\");\r\n    this.users = userData;\r\n  \r\n    // const clientData:any = JSON.parse(localStorage.getItem(\"client-details\") || \"{}\");\r\n    // this.clientData = clientData\r\n    // const clientAPIData:any = JSON.parse(localStorage.getItem(\"clientAPI-details\") || \"{}\");\r\n    // this.clientAPIData = clientAPIData\r\n      \r\n//  console.log( this.clientData,this.clientAPIData,this.nob)\r\n\r\n    this.gs?.dataRangeValue\r\n      ?.pipe(takeUntil(this.destroy$),debounceTime(300),)\r\n      .subscribe((data: any) => {\r\n        if(data){\r\n          this.headerData = data;\r\n          this.valueConversionRate='';\r\n          this.dateLength = getDaysBetweenDates(data?.date.startDate, data?.date.endDate);\r\n          if (this.dateLength > 28)\r\n            this.dateType = \"monthly\";\r\n          else if (this.dateLength > 5)\r\n            this.dateType = \"weekly\";\r\n          else if(this.dateLength === 0)\r\n            this.dateType = \"weekly\";\r\n          this.valueType=\"actual\";\r\n          this.typeValue=\"sum\"\r\n          this.isAverage = false\r\n          this.sub2 =  this.service?.getBrandDetails(this.users?.clientId ? this.users?.clientId:data?.client).pipe(takeUntil(this.destroy$)).subscribe({\r\n            next: (res:any) => {\r\n              if(res && res.code === 200){\r\n                this.clientData = res?.data;\r\n                this.featureConfig = this.clientData.featureConfigs;\r\n              this.normalize = this.clientData?.featureConfigs?.isNormalized;\r\n              this.storeIdarray = this.headerData?.stores.filter((store: any) => store.checked).map((store: any) => store.storeId)\r\n              this.tableobj = {\r\n                fromDate: data?.date.startDate,\r\n                toDate: data?.date.endDate,\r\n                storeId: data?.stores.filter((store: any) => store.checked).map((store: any) => store.storeId),\r\n                clientId: data?.client ? data?.client :'',\r\n                valueType: this.valueType,\r\n                nob:this.clientData.featureConfigs.isNOB,\r\n                dateType: this.dateType,\r\n                normalize: this.normalize\r\n                };\r\n                this.getVlues();\r\n\r\n              if (!this.isInitialized) {\r\n                this.isInitialized = true;\r\n                  this.isConversion =this.clientData.featureConfigs.isNOB\r\n            \r\n                this.service?.togglenob(this.clientData.featureConfigs.isNOB);\r\n                this.service?.toggleAverage(false);\r\n              }\r\n              // this.conversionValue = this.clientData.featureConfigs.isNOB && this.clientData?.featureConfigs?.conversionCalculation ==='footfall-count'\r\n              // ? \"footfall\"\r\n              // : this.clientData.featureConfigs.isNOB && this.clientData?.featureConfigs\r\n              //     ?.conversionCalculation === 'engagers-count'\r\n              // ? \"engagers\"\r\n              // : this.clientData.featureConfigs.isNOB && this.clientData?.featureConfigs\r\n              //     ?.conversionCalculation === 'billable-entities'? \"Potential Buyers\": \"footfall\";\r\n              this.conversionValue = this.clientData.featureConfigs.isNOB\r\n              ? \"NoB Derived\"\r\n              : this.clientData?.featureConfigs\r\n                  ?.missedOpportunityCalculation === 'engagers-conversion'\r\n              ? \"engagers\"\r\n              : \"footfall\";\r\n              this.getFunnal();\r\n              this.getTable();\r\n              this.performance();\r\n              if(this.normalize === true){  \r\n                this.zoneDwellTimeSplitData =[];\r\n                this.zoneLoading = false;\r\n                this.zoneNoData = true;\r\n                this.storeOperationData =[];\r\n                this.auLocations =[];\r\n                this.mpaloading =false;\r\n                this.mapnoData= true;\r\n              } else{\r\n              this.getZone();\r\n              this.getZoneValue();\r\n              this.getMap();\r\n              }\r\n              this.getIntial();\r\n             \r\n              \r\n              this.nob = !!this.clientData?.featureConfigs?.isNOB;\r\n          \r\n              // this.conversionValue = this.nob ? 'NoB Derived' : this.clientData?.featureConfigs?.missedOpportunityCalculation ==='\"engagers-conversion\"' ? 'conversion': 'footfall' ;\r\n              // this.conversionValue = this.nob ? 'NoB Derived' : 'footfall';\r\n           \r\n               this.objData = {\r\n                        fromDate: this.headerData?.date?.startDate,\r\n                        toDate: this.headerData?.date?.endDate,\r\n                        storeId: this.headerData?.stores.filter((store: any) => store.checked).map((store: any) => store.storeId),\r\n                        clientId: this.headerData?.client,\r\n                        processType: this.processType,\r\n                        dateType: this.type,\r\n                        filterBy: this.trendtypeValue,\r\n                        limit: 31,\r\n                        offset: 0,\r\n                        valueType: this.valueType,\r\n                        nob:this.nob,\r\n                        normalize: this.normalize\r\n                      };\r\n                      if (this.storeIdarray?.length === 1) {\r\n                        if(this.normalize === true){\r\n                          this.getRecapVideoData =[]\r\n                          this.recaplaoding =false;\r\n                          this.recapnoData =true;\r\n                        } else {\r\n                this.getRecap();\r\n                        }\r\n                        this.trendtypeValue = 'actual';\r\n                        this.service?.togglenormalize(this.normalize);\r\n                      } else {\r\n                        this.trendtypeValue = 'average';\r\n                      }\r\n                      // Call the API after objData is fully prepared\r\n                      this.footfallTrend();\r\n                    \r\n                    this.dateLength = getDaysBetweenDates(data?.date.startDate, data?.date.endDate);\r\n                    if (this.headerData?.client === '452') {\r\n                      this.datasets = this.datasets.filter(item => item.value !== 'potentialBuyer');\r\n                    \r\n                      const conversionItem = this.datasets.find(item => item.value === 'conversion');\r\n                      if (conversionItem) {\r\n                        const convValue = this.clientData?.featureConfigs?.conversion?.value ?? 'X';\r\n                        conversionItem.label = `More than ${convValue} mins`;\r\n                      }\r\n                    \r\n                      const missedItem = this.datasets.find(item => item.value === 'missedopportunities');\r\n                      if (missedItem) {\r\n                        const from = this.clientData?.featureConfigs?.missedOpportunityFrom?.value ?? 'X';\r\n                        const to = this.clientData?.featureConfigs?.missedOpportunityTo?.value ?? 'Y';\r\n                        missedItem.label = `${from} - ${to} mins`;\r\n                      }\r\n                    }\r\n                    \r\n                    const initialValue = this.getInitialValue();\r\n                    this.form.get('selectValue')?.setValue(initialValue);\r\n                      this.detailedCharts= false;\r\n                      // if(this.headerData?.client ==='459'){\r\n                      //   this.selectedTab = \"footfall\"\r\n                      //   this.footfallValue = \"footfall\";\r\n                      //   this.selctedValue ='Footfall Analysis';\r\n                      //   this.selectedTabs('footfall');\r\n                      //   this.cd.detectChanges();\r\n                      // } else {\r\n                      //   this.selectedTab = \"traffic\"\r\n                      //   this.footfallValue = \"traffic\";\r\n                      //   this.selctedValue ='Traffic Analysis';\r\n                      //   this.selectedTabs('traffic');\r\n                      // }\r\n                    this.datasetsCard = [\r\n                      { value: this.footfallValue, label: this.selctedValue },\r\n                      { value: \"demographic\", label: \"Demographic Analysis\" },\r\n                      { value: \"buyer\", label: \"Buyer Analysis\" },\r\n                    ];\r\n                    this.trafficData = [\r\n                      { value: 7, label: \"Last 7 Days\" },\r\n                      { value: 30, label: \"Last 30 Days\" },\r\n                    ];\r\n                    this.footfallDate =this.trafficData[0].value\r\n                    this.objDataTraffic = {\r\n                      fromDate: this.headerData?.date?.startDate,\r\n                      toDate: this.headerData?.date?.endDate,\r\n                      storeId: this.headerData?.stores.filter((store:any) => store.checked).map((store:any) => store.storeId),\r\n                      clientId:this.headerData?.client,\r\n                      processType: 'footfall',\r\n                      normalizedData: false,\r\n                      valueType :this.valueType,\r\n                      nob:this.nob,\r\n                      normalize: this.normalize\r\n                    };\r\n                    if(this.headerData?.client ==='459'){\r\n                      this.selectedTab = \"footfall\"\r\n                      this.footfallValue = \"footfall\";\r\n                      this.selctedValue ='Footfall Analysis';\r\n                      this.selectedTabs('footfall');\r\n                    } else {\r\n                      this.selectedTab = \"traffic\"\r\n                      this.footfallValue = \"traffic\";\r\n                      this.selctedValue ='Traffic Analysis';\r\n                      this.selectedTabs('traffic');\r\n                    }\r\n                    \r\n                    this.chartNoData = false;\r\n                    this.chartloading = true;\r\n                    \r\n                    this.cd.detectChanges();\r\n              // localStorage.setItem(\"clientAPI-details\", JSON.stringify(this.clientData?.clientApi));\r\n              }\r\n              this.sub2?.unsubscribe()\r\n            },\r\n            error: (error) => {\r\n              this.sub2?.unsubscribe()\r\n            }\r\n          })\r\n          this.cd.detectChanges();\r\n        // Only process the latest data after debounce time\r\n     \r\n       \r\n        // this.initMap();\r\n        this.tooltipValue = \"Default Tooltip Text\";\r\n\r\n          if (this.storeIdarray?.length === 1 && this.headerData?.date?.startDate === this.headerData?.date?.endDate) {\r\n            this.isDisabled = true\r\n          } else {\r\n            this.isDisabled = false\r\n          }\r\n          \r\n        }\r\n      });\r\n    \r\n  }\r\n  isRelevantConversion(value: string): boolean {\r\n    return ['footfall', 'engagers', 'Potential Buyers', 'NoB Derived'].includes(value);\r\n  }\r\n  getVlues() {\r\n    if (this.headerData?.client === '452') {\r\n      this.footfalldatasets = [\r\n        { value: 'footfall', label: 'Footfall' },\r\n        { value: 'bounced', label: `Less than ${this.featureConfig?.bouncedLimit.value} mins Footfall` },\r\n        { value: 'engager', label: `More than ${this.featureConfig?.bouncedLimit.value} mins` },\r\n        { value: 'missedOpportunity', label: `${this.featureConfig?.missedOpportunityFrom.value} - ${this.featureConfig?.missedOpportunityTo.value} mins` },\r\n        { value: 'conversion', label: `More than ${this.featureConfig?.conversion.value} mins` }\r\n      ];\r\n      this.bouncedatasets = [\r\n        { value: 'footfall', label: 'Footfall' },\r\n        { value: 'bounced', label: `Less than ${this.featureConfig?.bouncedLimit.value} mins Footfall` },\r\n        { value: 'engager', label: `More than ${this.featureConfig?.bouncedLimit.value} mins` },\r\n        { value: 'missedOpportunity', label: `${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins` },\r\n        { value: 'conversion', label: `More than ${this.featureConfig?.conversion.value} mins` }\r\n      ];\r\n    } \r\n\r\n    this.footfallValue1 = this.footfalldatasets[0].value;\r\n    this.bounceValue1 = this.bouncedatasets[1].value;\r\n    this.footfallLabel = this.footfalldatasets[0].label;\r\n    this.bounceLabel = this.bouncedatasets[1].label;\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    // Initialize tooltips after the view is initialized\r\n    const tooltipTriggerList = [].slice.call(document.querySelectorAll('[data-bs-toggle=\"tooltip\"]'));\r\n    tooltipTriggerList.forEach(function (tooltipTriggerEl) {\r\n      new bootstrap.Tooltip(tooltipTriggerEl);\r\n    });\r\n  }\r\n  getFilteredBounceDatasets() {\r\n    return this.bouncedatasets.filter(dataset => dataset.value !== this.footfallValue1);\r\n  }\r\n  \r\n  // Filter the footfall options when the bounceValue changes\r\n  getFilteredFootfallDatasets() {\r\n    return this.footfalldatasets.filter(dataset => dataset.value !== this.bounceValue1);\r\n  }\r\n  footfallValue1='footfall'\r\n  onValueChange(evt: any) {\r\n    this.footfallValue1 = evt.target.value;\r\nif(evt.target.value == 'footfall')\r\n  this.footfallLabel = 'Footfall'\r\nelse if(evt.target.value == 'bounced')\r\n  this.footfallLabel = this.headerData?.client === '452'?`Less than ${this.featureConfig?.bouncedLimit.value} mins Footfall`: 'Bounced Footfall'\r\nelse if(evt.target.value == 'engager')\r\n  this.footfallLabel = this.headerData?.client === '452'?`More than ${this.featureConfig?.bouncedLimit.value} mins`: 'Engagers'\r\nelse if(evt.target.value == 'missedOpportunity')\r\n  this.footfallLabel = this.headerData?.client === '452'?`${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins`: 'Missed Opportunity'\r\nelse if(evt.target.value == 'potentialBuyer')\r\n  this.footfallLabel = 'Potential Buyer'\r\nelse if(evt.target.value == 'conversion')\r\n  this.footfallLabel = this.headerData?.client === '452'?`More than ${this.featureConfig?.conversion.value} mins`: 'conversion'\r\n    if(this.footfallValue1 !== this.bounceValue1)\r\n      this.performance();\r\n    else \r\n    this.toast.getErrorToast('Same value not filtered')\r\n  }\r\n  onBounceChange(evt: any) {\r\n    this.bounceValue1 = evt.target.value;\r\n    if(evt.target.value == 'footfall')\r\n      this.bounceLabel = 'Footfall'\r\n    else if(evt.target.value == 'bounced')\r\n      this.bounceLabel = this.headerData?.client === '452'?`Less than ${this.featureConfig?.bouncedLimit.value} mins Footfall`: 'Bounced Footfall'\r\n    else if(evt.target.value == 'engager')\r\n      this.bounceLabel = this.headerData?.client === '452'?`More than ${this.featureConfig?.bouncedLimit.value} mins`: 'Engagers'\r\n    else if(evt.target.value == 'missedOpportunity')\r\n      this.bounceLabel = this.headerData?.client === '452'?`${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins`: 'Missed Opportunity'\r\n    else if(evt.target.value == 'potentialBuyer')\r\n      this.bounceLabel = 'Potential Buyer'\r\n    else if(evt.target.value == 'conversion')\r\n      this.bounceLabel = this.headerData?.client === '452' ? `More than ${this.featureConfig?.conversion.value} mins` : 'conversion'\r\n    if(this.footfallValue1 !== this.bounceValue1)\r\n    this.performance();\r\n  else \r\n  this.toast.getErrorToast('Same value not filtered')\r\n  }\r\n  convertPercentToPixels(percent: string, maxPercent: number, baseDimension: number): number {\r\n    // Remove the '%' sign and parse the value\r\n    const value = parseFloat(percent.replace('%', ''));\r\n    if (isNaN(value)) return 0;\r\n  \r\n    // Calculate pixel value based on the maximum percentage and base dimension\r\n    return (value / maxPercent) * baseDimension;\r\n  }\r\n  \r\n\r\n  getMaxPercentage(data: any[], field: string): number {\r\n    // Extract and return the maximum percentage value from the field\r\n    return Math.max(...data.map(item => parseFloat(item[field]) || 0));\r\n  }\r\n  \r\n  // normalizeData(data: any[]): any[] {\r\n  //   const maxTopPercent = Math.max(...data.map(item => parseFloat(item.top.replace('%', ''))));\r\n  //   const maxLeftPercent = Math.max(...data.map(item => parseFloat(item.left.replace('%', ''))));\r\n  \r\n  //   return data.map(item => ({\r\n  //     ...item,\r\n  //     top: this.scalePercent(item.top, maxTopPercent) + '%',\r\n  //     left: this.scalePercent(item.left, maxLeftPercent) + '%'\r\n  //   }));\r\n  // }\r\n  \r\n  scalePercent(percent: string, maxPercent: number): string {\r\n    const percentValue = parseFloat(percent.replace('%', ''));\r\n    return ((percentValue / maxPercent) * 100).toFixed(2);\r\n  }\r\n// Toggle the tooltip display\r\ntoggleTooltip(pointName: string) {\r\n  this.activeTooltip = this.activeTooltip === pointName ? null : pointName;\r\n}\r\n\r\nperformance(){\r\n  this.performanceLoading = true;\r\n  this.performancenoData = false;\r\n  let obj = {\r\n    clientId:this.headerData?.client,\r\n    fromDate: this.headerData?.date.startDate,\r\n    toDate: this.headerData?.date.endDate,\r\n    normalize: this.normalize,\r\n    storeId: this.headerData?.stores.filter((store:any) => store.checked).map((store:any) => store.storeId),\r\n   processtype1: this.footfallValue1,\r\n   processtype2 : this.bounceValue1\r\n  };\r\n  this.service.performanceMatrix(obj).pipe(takeUntil(this.destroy$))\r\n  ?.subscribe({\r\n    next: (res: any) => {\r\n      if (res && res.code === 200) {\r\n        this.performanceData = res?.data?.performanceData\r\n        // this.performanceData = this.normalizeData(this.performanceData);\r\n        // Calculate maximum percentages\r\n        // const maxTop = Math.max(...this.performanceData.map((item:any) => parseFloat(item.top.replace('%', ''))));\r\n        // const maxLeft = Math.max(...this.performanceData.map((item:any) => parseFloat(item.left.replace('%', ''))));\r\n        \r\n        // Convert performance data to pixel values\r\n        this.points = this.performanceData.map((data: any) => ({\r\n          name: data.storeName,\r\n          storeId: data.storeId,\r\n          avgFootfall: data.avg,\r\n          openTime: data.avgOpenTime,\r\n          closeTime: data.avgCloseTime,\r\n          top: data.top, // Assuming 500px as the base height\r\n          left: data.left  // Assuming 1000px as the base width\r\n        })); \r\n        this.performanceLoading = false;\r\n        this.performancenoData = false;\r\n      } else {\r\n        this.performanceLoading = false;\r\n        this.performancenoData = true;\r\n      }\r\n      }\r\n    })\r\n  }\r\n\r\n  getTooltipText(): string {\r\n    // Logic to determine the tooltip text\r\n    return \"Dynamic Tooltip Text \" + new Date().toLocaleTimeString();\r\n  }\r\n\r\n  getFunnal(){\r\n    this.tableobj.valueType= this.valueType,\r\n     this.tableobj.fromDate = this.headerData?.date.startDate;\r\n     this.tableobj.toDate = this.headerData?.date.endDate;\r\n     if(this.conversionValue === 'footfall'){\r\n      this.tableobj.conversiontype = 'footfall-count';\r\n     } if (this.conversionValue === 'engagers'){\r\n      this.tableobj.conversiontype = 'engagers-count';\r\n     }if (this.conversionValue === 'Potential Buyers'){\r\n      this.tableobj.conversiontype = 'billable-count';\r\n     } if (this.conversionValue === 'NoB Derived'){\r\n      this.tableobj.conversiontype = 'nob';\r\n     }\r\n     \r\n    delete this.tableobj.offset;\r\n    delete this.tableobj.recapVideoDate;\r\n    delete this.tableobj.limit; \r\n    delete this.tableobj.export;\r\n    delete this.tableobj.sort;\r\n    delete this.tableobj.sortBy;\r\n    this.heatloading = true;\r\n    this.heatnoData = false;\r\n   delete this.tableobj.dateType\r\n    this.service\r\n      .getFunnelCards(this.tableobj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            // this.getCardData = res?.data?.card;\r\n            this.heatMapData = res?.data?.funnelChart;\r\n           \r\n            this.heatMap();\r\n            this.cd.detectChanges();\r\n          } else {\r\n            this.getCardData =[];\r\n            this.heatMapData =[];\r\n          this.heatloading = false\r\n          this.heatnoData = true\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.getCardData =[];\r\n          this.heatMapData =[];\r\n          this.cd.detectChanges();\r\n        },\r\n        complete: () => {},\r\n      });\r\n  }\r\n  getFootfallCardData:any=[];\r\n  getConversionCardData:any=[];\r\n  getBouncedCardData:any =[];\r\n  getEngagersCardData:any=[];\r\n  getPotentialBuyersCardData:any =[];\r\n  getMissedOpportunityData:any =[];\r\n  getPotentialBuyersData:any=[];\r\n  getIntial(){\r\n    delete this.tableobj.recapVideoDate;\r\n    delete this.tableobj.sort;\r\n    delete this.tableobj.sortBy;\r\n    (this.tableobj.valueType = this.valueType),\r\n    (this.tableobj.fromDate = this.headerData?.date.startDate);\r\n  this.tableobj.toDate = this.headerData?.date.endDate;\r\n  this.getFootfallCard();\r\n  this.getConversionCard();\r\n  this.getBouncedCard();\r\n  this.getEngagersCard();\r\n  this.getPotentialBuyersCard();\r\n  this.getMissedOpportunityCard();\r\n  this.getPotentialBuyers();\r\n  }\r\n  footfallloading =true;\r\n  footfallNodata =false;\r\n  getFootfallCard(){\r\n    this.footfallloading =true;\r\n    this.footfallNodata =false;\r\n    delete this.tableobj.offset;\r\n    delete this.tableobj.limit;\r\n    delete this.tableobj.export;\r\n    this.tableobj.dateType= this.dateType;\r\n    this.service\r\n      .getFootdfallCardList(this.tableobj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getFootfallCardData = res?.data;\r\n          if(this.getFootfallCardData?.data?.footfall?.data.length){\r\n            this.footfalllineCharts();\r\n            this.footfallloading =false;\r\n            this.footfallNodata =false;\r\n          } else {\r\n          this.getFootfallCardData =[];\r\n          this.footfallloading =false;\r\n          this.footfallNodata =true;\r\n          }\r\n          } else { \r\n          this.getFootfallCardData =[];\r\n          this.footfallloading =false;\r\n          this.footfallNodata =true;\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.getFootfallCardData =[];\r\n        this.footfallloading =false;\r\n        this.footfallNodata =true;\r\n        this.cd.detectChanges();\r\n      }, \r\n      })\r\n  }\r\n  setConversionType(conversionValue: string): string {\r\n    const map: Record<string, string> = {\r\n      'footfall': 'footfall-count',\r\n      'engagers': 'engagers-count',\r\n      'Potential Buyers': 'billable-count',\r\n      'NoB Derived': 'nob',\r\n    };\r\n    return map[conversionValue] || '';\r\n  }\r\n  \r\n  getConversionCard(){\r\n    const { tableobj } = this;\r\n    delete tableobj.offset;\r\n    delete tableobj.limit;\r\n    delete tableobj.export;\r\n    tableobj.dateType = this.dateType;\r\n    tableobj.conversiontype = this.setConversionType(this.conversionValue);\r\n       this.service\r\n         .getConversionCardList(this.tableobj)\r\n         .pipe(takeUntil(this.destroy$))\r\n         ?.subscribe({\r\n           next: (res: any) => {\r\n             if (res && res.code === 200) {\r\n               this.getConversionCardData = res?.data;\r\n               if (this.nob) {\r\n                this.valueConversionRate = this.getConversionCardData?.conversion?.nob?.nob;\r\n                this.conversionValue = 'NoB Derived';\r\n              } else if (this.clientData?.featureConfigs?.missedOpportunityCalculation === 'engagers-conversion') {\r\n                this.valueConversionRate = this.getConversionCardData?.conversion?.engagers?.rate;\r\n                this.conversionValue = 'engagers';\r\n              } else {\r\n                this.valueConversionRate = this.getConversionCardData?.conversion?.footfall?.rate;\r\n                this.conversionValue = 'footfall';\r\n              }\r\n\r\n              // if (this.nob && this.clientData?.featureConfigs?.conversionCalculation === 'footfall-count') {\r\n              //   this.valueConversionRate = this.getConversionCardData?.conversion?.footfall?.rate;\r\n              //   this.conversionValue = 'footfall';\r\n              // } else if (this.nob && this.clientData?.featureConfigs?.conversionCalculation === 'engagers-count') {\r\n              //   this.valueConversionRate = this.getConversionCardData?.conversion?.engagers?.rate;\r\n              //   this.conversionValue = 'engagers';\r\n              // } else if (this.nob && this.clientData?.featureConfigs?.conversionCalculation === 'billable-entities') {\r\n              //   this.valueConversionRate = this.getConversionCardData?.conversion?.potentialBuyers?.rate;\r\n              //   this.conversionValue = 'Potential Buyers';\r\n              // }\r\n             } else { \r\n              this.getConversionCardData =[];\r\n           }\r\n         },\r\n         error: (err: any) => {\r\n           this.getConversionCardData =[];\r\n           this.cd.detectChanges();\r\n         }, \r\n         })\r\n     }\r\n     getConversionCard1(){\r\n      const { tableobj } = this;\r\n  delete tableobj.offset;\r\n  delete tableobj.limit;\r\n  delete tableobj.export;\r\n  tableobj.dateType = this.dateType;\r\n  tableobj.conversiontype = this.setConversionType(this.conversionValue);\r\n         this.service\r\n           .getConversionCardList(this.tableobj)\r\n           .pipe(takeUntil(this.destroy$))\r\n           ?.subscribe({\r\n             next: (res: any) => {\r\n               if (res && res.code === 200) {\r\n                 this.getConversionCardData = res?.data;\r\n                 if(this.conversionValue === 'footfall'){\r\n                  this.tableobj.conversiontype = 'footfall-count';  this.valueConversionRate = this.getConversionCardData?.conversion?.footfall?.rate;\r\n                 }  if (this.conversionValue === 'engagers'){\r\n                  this.tableobj.conversiontype = 'engagers-count'; \r\n                  this.valueConversionRate = this.getConversionCardData?.conversion?.engagers?.rate;\r\n                 }if (this.conversionValue === 'Potential Buyers'){\r\n                  this.tableobj.conversiontype = 'billable-count'; \r\n                  this.valueConversionRate = this.getConversionCardData?.conversion?.potentialBuyers?.rate;\r\n                 } if (this.conversionValue === 'NoB Derived'){\r\n                  this.tableobj.conversiontype = 'nob'; this.valueConversionRate = this.getConversionCardData?.conversion?.nob?.nob;\r\n                 }\r\n               } else { \r\n                this.getConversionCardData =[];\r\n             }\r\n           },\r\n           error: (err: any) => {\r\n             this.getConversionCardData =[];\r\n             this.cd.detectChanges();\r\n           }, \r\n           })\r\n       }\r\n     bouncedNodata =false;\r\n     getBouncedCard(){\r\n      delete this.tableobj.offset;\r\n      delete this.tableobj.limit;\r\n      delete this.tableobj.export;\r\n      this.tableobj.dateType= this.dateType;\r\n      this.service\r\n        .getBouncedCardList(this.tableobj)\r\n        .pipe(takeUntil(this.destroy$))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res.code === 200) {\r\n              this.getBouncedCardData = res?.data;\r\n              if(this.getBouncedCardData?.data?.bounced?.data.length){\r\n              this.bouncedlineCharts();\r\n              this.bouncedNodata =false;\r\n              } else{\r\n                this.getBouncedCardData =[];\r\n                this.bouncedNodata =true;\r\n              }\r\n            } else { \r\n              this.bouncedNodata =true;\r\n              this.getBouncedCardData =[];\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.getBouncedCardData =[];\r\n          this.bouncedNodata =true;\r\n          this.cd.detectChanges();\r\n        }, \r\n        }) \r\n    }\r\n    engagersNodata =false;\r\n    getEngagersCard(){\r\n      delete this.tableobj.offset;\r\n      delete this.tableobj.limit;\r\n      delete this.tableobj.export;\r\n      this.tableobj.dateType= this.dateType;\r\n      this.service\r\n        .getEngagersCardList(this.tableobj)\r\n        .pipe(takeUntil(this.destroy$))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res.code === 200) {\r\n              this.getEngagersCardData = res?.data;\r\n              if(this.getEngagersCardData?.data?.engagers?.data.length){\r\n              this.engagerslineCharts();\r\n              this.engagersNodata =false;\r\n              } else {\r\n                this.getEngagersCardData =[];\r\n              this.engagersNodata =true;\r\n              }\r\n            } else { \r\n              this.getEngagersCardData =[];\r\n              this.engagersNodata =true;\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.getEngagersCardData =[];\r\n          this.engagersNodata =true;\r\n          this.cd.detectChanges();\r\n        }, \r\n        })\r\n    }\r\n    getMissedOpportunityCard(){\r\n      delete this.tableobj.offset;\r\n      delete this.tableobj.limit;\r\n      delete this.tableobj.export;\r\n      this.tableobj.dateType= this.dateType;\r\n      this.service\r\n      .getMissedOpportunityCardList(this.tableobj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getMissedOpportunityData = res?.data;\r\n          } else { \r\n            this.getMissedOpportunityData =[];\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.getMissedOpportunityData =[];\r\n        this.cd.detectChanges();\r\n      }, \r\n      })\r\n    }\r\n    potentialNodata =false;\r\n    getPotentialBuyersCard(){\r\n      delete this.tableobj.offset;\r\n      delete this.tableobj.limit;\r\n      delete this.tableobj.export;\r\n      this.tableobj.dateType= this.dateType;\r\n      this.service\r\n        .getPotentialBuyersCardList(this.tableobj)\r\n        .pipe(takeUntil(this.destroy$))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res.code === 200) {\r\n              this.getPotentialBuyersCardData = res?.data;\r\n              if(this.getPotentialBuyersCardData?.data?.potentialBuyers?.data.length){\r\n              this.potentiallineCharts();\r\n              this.potentialNodata =false;\r\n              } else { \r\n                this.getPotentialBuyersCardData =[];\r\n                this.potentialNodata =true;\r\n            }\r\n            }  else { \r\n              this.getPotentialBuyersCardData =[];\r\n              this.potentialNodata =true;\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.getPotentialBuyersCardData =[];\r\n          this.potentialNodata =true;\r\n          this.cd.detectChanges();\r\n        }, \r\n        })\r\n    }\r\n\r\n    getPotentialBuyers(){\r\n      delete this.tableobj.offset;\r\n      delete this.tableobj.limit;\r\n      delete this.tableobj.export;\r\n      this.tableobj.dateType= this.dateType;\r\n      this.service\r\n      .getPotentialBuyersDistributionCardList(this.tableobj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getPotentialBuyersData = res?.data?.card;\r\n          }  else { \r\n            this.getPotentialBuyersData =[];\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.getPotentialBuyersData =[];\r\n        this.cd.detectChanges();\r\n      }, \r\n      })\r\n    }\r\n\r\n\r\n  getRecap() {\r\n    this.recaplaoding =true;\r\n    this.recapnoData =false;\r\n    delete this.tableobj.processType; delete this.tableobj.normalizedData;\r\n     delete this.tableobj.dateType; delete this.tableobj.fromDate;\r\n     delete this.tableobj.toDate; delete this.tableobj.valueType; delete this.tableobj.processType;\r\n     delete this.tableobj.search; delete this.tableobj.offset;\r\n     delete this.tableobj.limit; delete this.tableobj.sortBy; delete this.tableobj.sort;\r\n     delete this.tableobj.export;\r\n     delete this.tableobj.normalize;\r\n     this.tableobj.recapVideoDate = this.headerData?.date.endDate;\r\n    this.service\r\n      .getRecapVideo(this.tableobj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getRecapVideoData = res?.data;\r\n            this.getRecapData = res?.data?.recapVideoData;\r\n            this.groupRecaps();\r\n            if(!this.getRecapData.length){\r\n              this.recaplaoding =false;\r\n            this.recapnoData =true;\r\n            } else {\r\n              this.recaplaoding =false;\r\n            this.recapnoData =false;\r\n            }\r\n            this.cd.detectChanges();    \r\n          } else{\r\n            this.getRecapVideoData =[]\r\n            this.recaplaoding =false;\r\n            this.recapnoData =true;\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.cd.detectChanges();\r\n          this.recaplaoding =false;\r\n          this.recapnoData =true;\r\n        },\r\n        complete: () => {},\r\n      });\r\n  }\r\n  groupRecaps() {\r\n    this.recapsGrouped = [];\r\n    let groupSize = this.getRecapData.length === 1 ? 1 : 2;\r\n    for (let i = 0; i < this.getRecapData.length; i += groupSize) {\r\n      this.recapsGrouped.push(this.getRecapData.slice(i, i + groupSize));\r\n    }\r\n    this.colValue = this.getRecapData.length === 1 ? 'col-md-12' : 'col-md-6';\r\n  }\r\n  videoClick(obj:any){\r\n    const modalRef = this.modalService.open(VideoUrlComponent, {\r\n      centered: true,\r\n      size: \"lg\",\r\n      scrollable: true,\r\n    });\r\n    modalRef.componentInstance.videoUrl = obj;\r\n    modalRef.componentInstance.date= this.headerData?.date?.endDate\r\n    modalRef.result.then((result: any) => {});\r\n  }\r\n  previousValue: any = null;\r\n  changeValue(method: any) {\r\n      this.previousValue = method;\r\n      if (this.previousValue === 'potentialBuyers') {\r\n        this.conversionValue = 'Potential Buyers';\r\n      } else {\r\n        this.conversionValue = method;\r\n      }\r\n   \r\n      const isConversion = this.isConversion === true;\r\n      const conversionTypeMap: any = {\r\n        footfall: {\r\n          rate: this.getConversionCardData?.conversion?.footfall?.rate,\r\n          type: 'footfall-count',\r\n          nob: isConversion ? true : false\r\n        },\r\n        engagers: {\r\n          rate: this.getConversionCardData?.conversion?.engagers?.rate,\r\n          type: 'engagers-count',\r\n          nob: isConversion ? true : false\r\n        },\r\n        potentialBuyers: {\r\n          rate: this.getConversionCardData?.conversion?.potentialBuyers?.rate,\r\n          type: 'billable-count',\r\n          nob: isConversion ? true : false\r\n        },\r\n        'NoB Derived': {\r\n          rate: this.getConversionCardData?.conversion?.nob?.nob,\r\n          type: 'nob',\r\n          nob: true // always true for NoB Derived\r\n        }\r\n      };\r\n      \r\n      const data = conversionTypeMap[this.previousValue];\r\n      \r\n      if (data) {\r\n        this.valueConversionRate = data.rate;\r\n        this.tableobj.nob = data.nob;\r\n        this.objData.nob = data.nob;\r\n        this.objDataTraffic.nob = data.nob;\r\n        this.nob = data.nob;\r\n        this.tableobj.conversiontype = data.type;\r\n      }\r\n      \r\n      // this.service.togglenob(this.tableobj.nob);\r\n      this.getFunnal(); \r\n      if(this.tableobj.nob ===false)\r\n      this.getConversionCard1(); \r\n      this.tableobj.fromDate= this.headerData?.date.startDate,\r\n      this.tableobj.toDate= this.headerData?.date.endDate,\r\n      this.tableobj.search = this.searchValue;\r\n      delete this.tableobj.recapVideoDate;\r\n      this.getTable();\r\n     this.footfallTrend();\r\n     if(this.headerData?.client ==='459'){\r\n      this.selectedTab = \"footfall\"\r\n      this.footfallValue = \"footfall\";\r\n      this.selctedValue ='Footfall Analysis';\r\n      this.selectedTabs('footfall');\r\n    } else {\r\n      this.selectedTab = \"traffic\"\r\n      this.footfallValue = \"traffic\";\r\n      this.selctedValue ='Traffic Analysis';\r\n      this.selectedTabs('traffic');\r\n    }\r\n   \r\n    // }\r\n  }\r\n \r\n\r\n  getTable() {\r\n    this.limit =10;\r\n    this.tableobj.offset = this.offset = this.currentPage -1;\r\n    this.loading = true;\r\n    this.noData = false;\r\n    delete this.tableobj.processType;\r\n    delete this.tableobj.normalizedData;\r\n    delete this.tableobj.dateType;\r\n    (this.tableobj.limit = this.limit);\r\n    (this.tableobj.search = this.searchValue), \r\n     (this.tableobj.valueType = this.typeValue); \r\n     (this.tableobj.conversiontype = this.tableobj.conversiontype);\r\n     this.tableobj.export = false;\r\n    this.service\r\n      .getSummaryTableList(this.tableobj)\r\n      ?.pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            if(res?.data.summaryData.length ===0){\r\n              this.getSummaryTableData =[]\r\n              this.loading = false;\r\n              this.noData = true;\r\n              this.totalItems = 0; \r\n            } else {\r\n            this.getSummaryTableData = res?.data.summaryData;\r\n            this.totalItems = res.data?.totalCount;\r\n            this.setPaginationSizes();\r\n            this.loading = false;\r\n            this.noData = false;\r\n            }\r\n          } else {\r\n            this.getSummaryTableData =[]\r\n            this.loading = false;\r\n            this.noData = true;\r\n            this.totalItems = 0; \r\n          }\r\n          this.cd.detectChanges();\r\n        },\r\n        error: (err: any) => {\r\n          this.cd.detectChanges();\r\n        },\r\n        complete: () => {},\r\n      });\r\n  }\r\n  searchData() {\r\n    this.tableobj.fromDate= this.headerData?.date.startDate,\r\n    this.tableobj.toDate= this.headerData?.date.endDate,\r\n    this.tableobj.search = this.searchValue;\r\n    delete this.tableobj.recapVideoDate;\r\n    (this.tableobj.conversiontype = this.tableobj.conversiontype);\r\n    this.tableobj.export = false;\r\n    this.offset = 1;\r\n    this.tableobj.offset = this.offset -1;\r\n    this.limit=10;\r\n    this.getTable();\r\n  }\r\n\r\n  setPaginationSizes() {\r\n    if (this.totalItems > 10) {\r\n      this.paginationSizes = [10, 20, 30];\r\n    } else {\r\n      this.paginationSizes = [this.totalItems]; // Just one option if less than 10\r\n    }\r\n    this.pageSize = this.paginationSizes[0];\r\n  }\r\n  onPageChange(pageOffset: number) {\r\n    this.loading = true;\r\n    this.noData = false;\r\n    this.offset = Number(pageOffset);\r\n    this.tableobj.offset = this.offset -1;\r\n    (this.tableobj.limit = this.limit),\r\n    (this.tableobj.search = this.searchValue), \r\n     (this.tableobj.valueType = this.typeValue);\r\n    this.tableobj.fromDate= this.headerData?.date.startDate,\r\n    this.tableobj.toDate= this.headerData?.date.endDate,\r\n    this.tableobj.search = this.searchValue;\r\n    (this.tableobj.conversiontype = this.tableobj.conversiontype);\r\n    delete this.tableobj.recapVideoDate;\r\n    this.tableobj.export = false;\r\n    this.service\r\n    .getSummaryTableList(this.tableobj)\r\n    ?.pipe(takeUntil(this.destroy$))\r\n    ?.subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code === 200) {\r\n          if(res?.data.summaryData.length ===0){\r\n            this.getSummaryTableData =[]\r\n            this.loading = false;\r\n            this.noData = true;\r\n            this.totalItems = 0; \r\n          } else {\r\n          this.getSummaryTableData = res?.data.summaryData;\r\n          this.totalItems = res.data?.totalCount;\r\n          this.loading = false;\r\n          this.noData = false;\r\n          }\r\n        } else {\r\n          this.getSummaryTableData =[]\r\n          this.loading = false;\r\n          this.noData = true;\r\n          this.totalItems = 0; \r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.cd.detectChanges();\r\n      },\r\n      complete: () => {},\r\n    });\r\n  }\r\n\r\n  onPageSizeChange(pageSize: number) {\r\n    this.loading = true;\r\n    this.noData = false;\r\n    this.pageSize = Number(pageSize);\r\n    this.limit = Number(pageSize);\r\n    this.currentPage = 1;\r\n    this.offset = 0;\r\n    this.tableobj.offset = this.offset;\r\n    (this.tableobj.limit = this.limit),\r\n    (this.tableobj.valueType = this.typeValue);\r\n    this.tableobj.fromDate= this.headerData?.date.startDate,\r\n    this.tableobj.toDate= this.headerData?.date.endDate,\r\n    this.tableobj.search = this.searchValue;\r\n    (this.tableobj.conversiontype = this.tableobj.conversiontype);\r\n    delete this.tableobj.recapVideoDate;\r\n    this.tableobj.export = false;\r\n    this.service\r\n    .getSummaryTableList(this.tableobj)\r\n    ?.pipe(takeUntil(this.destroy$))\r\n    ?.subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code === 200) {\r\n          if(res?.data.summaryData.length ===0){\r\n            this.getSummaryTableData =[]\r\n            this.loading = false;\r\n            this.noData = true;\r\n            this.totalItems = 0; \r\n          } else {\r\n          this.getSummaryTableData = res?.data.summaryData;\r\n          this.totalItems = res.data?.totalCount;\r\n          this.loading = false;``\r\n          this.noData = false;\r\n          }\r\n        } else {\r\n          this.getSummaryTableData =[]\r\n          this.loading = false;\r\n          this.noData = true;\r\n          this.totalItems = 0; \r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.cd.detectChanges();\r\n      },\r\n      complete: () => {},\r\n    });\r\n  }\r\n\r\n  onValueType(type:any){\r\n    this.tableobj.fromDate= this.headerData.date.startDate,\r\n    this.tableobj.toDate= this.headerData.date.endDate,\r\n    delete this.tableobj.recapVideoDate;\r\n    this.tableobj.export = false;\r\n     this.typeValue =type;\r\n    this.tableobj.valueType =type;\r\n    (this.tableobj.conversiontype = this.tableobj.conversiontype);\r\n    this.getTable();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next(true);\r\n    this.destroy$.complete();\r\n    this.zone.runOutsideAngular(() => {\r\n      if (this.lineroot) {\r\n        this.lineroot.dispose();\r\n      }\r\n      if (this.bouncedlineroot) {\r\n        this.bouncedlineroot.dispose();\r\n      }\r\n      if (this.potentialBuyerslineroot) {\r\n        this.potentialBuyerslineroot.dispose();\r\n      }\r\n      if (this.engagerslineroot) {\r\n        this.engagerslineroot.dispose();\r\n      }\r\n      if (this.heatMaproot) {\r\n        this.heatMaproot.dispose();\r\n      } if (this.rootTrends) {\r\n        this.rootTrends.dispose();\r\n      }\r\n      if (this.dwellRoot) {\r\n        this.dwellRoot.dispose();\r\n      }\r\n      if (this.intervalId) {\r\n        clearInterval(this.intervalId);\r\n      }\r\n    });\r\n  }\r\n  // card line Charts Start\r\n\r\n  footfalllineCharts() {\r\n    setTimeout(() => {\r\n      const chartDiv = document.getElementById(\"Footfall\");\r\n      if (!chartDiv) {\r\n        return;\r\n      }\r\n      if (this.lineroot) {\r\n        this.lineroot.dispose();\r\n      }\r\n    let root: any;\r\n    root = am5.Root.new(\"Footfall\");\r\n    root.setThemes([\r\n      am5themes_Animated.new(root),\r\n      am5themes_Responsive.new(root),\r\n    ]);\r\n    let chart = root.container.children.push(\r\n      am5xy.XYChart.new(root, {\r\n        panX: true,\r\n        panY: true,\r\n        wheelX: \"panX\",\r\n        wheelY: \"zoomX\",\r\n        pinchZoomX: true,\r\n      })\r\n    );\r\n\r\n    // Add data\r\n    let data = this.getFootfallCardData?.data?.footfall?.data.map((item: any) => ({\r\n      date: new Date(item.date).getTime(), // Convert date string to timestamp\r\n      value: Number(item.value),\r\n    }));\r\n     // Ensure that data has at least 2 points for line chart\r\n     if (data.length === 1) {\r\n      const duplicatePoint = { ...data[0] }; // Clone the existing point\r\n      duplicatePoint.date += 1; // Add a small offset to the date\r\n      data.push(duplicatePoint); // Add the duplicate point to data\r\n    }\r\n    let cursor = chart.set(\r\n      \"cursor\",\r\n      am5xy.XYCursor.new(root, {\r\n        behavior: \"none\",\r\n      })\r\n    );\r\n    cursor.lineY.set(\"visible\", false);\r\n    // Create axes\r\n    let xAxis = chart.xAxes.push(\r\n      am5xy.DateAxis.new(root, {\r\n        maxDeviation: 0.5,\r\n        baseInterval: { timeUnit: \"day\", count: 1 },\r\n        renderer: am5xy.AxisRendererX.new(root, { }),\r\n      })\r\n    );\r\n    xAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    xAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    let yAxis = chart.yAxes.push(\r\n      am5xy.ValueAxis.new(root, {\r\n        renderer: am5xy.AxisRendererY.new(root, { }),\r\n      })\r\n    );\r\n    yAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    yAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    // Create series\r\n    let series = chart.series.push(\r\n      am5xy.LineSeries.new(root, {\r\n        name: \"Series\",\r\n        xAxis: xAxis,\r\n        yAxis: yAxis,\r\n        valueYField: \"value\",\r\n        valueXField: \"date\",\r\n        stroke: am5.color(0x00a3ff), // Set the line color here (red in this case)\r\n      })\r\n    );\r\n    series.bullets.push(function () {\r\n      let bulletCircle = am5.Circle.new(root, {\r\n        radius: 0,\r\n        fill: series.get(\"fill\")\r\n      });\r\n      return am5.Bullet.new(root, {\r\n        sprite: bulletCircle\r\n      })\r\n    })\r\n    series.data.setAll(data);\r\n    series.set(\r\n      \"tooltip\",\r\n      am5.Tooltip.new(root, {\r\n        labelText: \"{valueY}\",\r\n        getFillFromSprite: false, // Prevents the tooltip from inheriting color from the sprite\r\n        background: am5.Rectangle.new(root, {\r\n          fill: am5.color(0xdaf1ff), // Set the tooltip background color here (blue in this case)\r\n        }),\r\n      })\r\n    );\r\n    this.lineroot = root;\r\n  },0)\r\n  }\r\n  bouncedlineCharts() {\r\n    setTimeout(() => {\r\n      const chartDiv = document.getElementById(\"BouncedRate\");\r\n      if (!chartDiv) {\r\n        return;\r\n      }\r\n      if (this.bouncedlineroot) {\r\n        this.bouncedlineroot.dispose();\r\n      }\r\n    let root: any;\r\n    root = am5.Root.new(\"BouncedRate\");\r\n    root.setThemes([\r\n      am5themes_Animated.new(root),\r\n      am5themes_Responsive.new(root),\r\n    ]);\r\n    let chart = root.container.children.push(\r\n      am5xy.XYChart.new(root, {\r\n        panX: true,\r\n        panY: true,\r\n        wheelX: \"panX\",\r\n        wheelY: \"zoomX\",\r\n        pinchZoomX: true,\r\n      })\r\n    );\r\n\r\n    // Add data\r\n    let data = this.getBouncedCardData?.data?.bounced?.data.map((item: any) => ({\r\n      date: new Date(item.date).getTime(), // Convert date string to timestamp\r\n      value: Number(item.value),\r\n    }));\r\n    let cursor = chart.set(\r\n      \"cursor\",\r\n      am5xy.XYCursor.new(root, {\r\n        behavior: \"none\",\r\n      })\r\n    );\r\n    cursor.lineY.set(\"visible\", false);\r\n    // Create axes\r\n    let xAxis = chart.xAxes.push(\r\n      am5xy.DateAxis.new(root, {\r\n        maxDeviation: 0.2,\r\n        baseInterval: { timeUnit: \"day\", count: 1 },\r\n        renderer: am5xy.AxisRendererX.new(root, { minorGridEnabled: true }),\r\n      })\r\n    );\r\n    xAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    xAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    let yAxis = chart.yAxes.push(\r\n      am5xy.ValueAxis.new(root, {\r\n        renderer: am5xy.AxisRendererY.new(root, { pan: \"zoom\" }),\r\n      })\r\n    );\r\n    yAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    yAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    // Create series\r\n    let series = chart.series.push(\r\n      am5xy.LineSeries.new(root, {\r\n        name: \"Series\",\r\n        xAxis: xAxis,\r\n        yAxis: yAxis,\r\n        valueYField: \"value\",\r\n        valueXField: \"date\",\r\n        stroke: am5.color(0x00a3ff), // Set the line color here (red in this case)\r\n      })\r\n    );\r\n    series.bullets.push(function () {\r\n      let bulletCircle = am5.Circle.new(root, {\r\n        radius: 0,\r\n        fill: series.get(\"fill\")\r\n      });\r\n      return am5.Bullet.new(root, {\r\n        sprite: bulletCircle\r\n      })\r\n    })\r\n    series.data.setAll(data);\r\n    series.set(\r\n      \"tooltip\",\r\n      am5.Tooltip.new(root, {\r\n        labelText: \"{valueY}\",\r\n        getFillFromSprite: false, // Prevents the tooltip from inheriting color from the sprite\r\n        background: am5.Rectangle.new(root, {\r\n          fill: am5.color(0xdaf1ff), // Set the tooltip background color here (blue in this case)\r\n        }),\r\n      })\r\n    );\r\n    this.bouncedlineroot = root;\r\n  },0)\r\n  }\r\n\r\n  potentiallineCharts() {\r\n    setTimeout(() => {\r\n      const chartDiv = document.getElementById(\"PotentialBuyers\");\r\n      if (!chartDiv) {\r\n        return;\r\n      }\r\n      if (this.potentialBuyerslineroot) {\r\n        this.potentialBuyerslineroot.dispose();\r\n      }\r\n    let root: any;\r\n    root = am5.Root.new(\"PotentialBuyers\");\r\n    root.setThemes([\r\n      am5themes_Animated.new(root),\r\n      am5themes_Responsive.new(root),\r\n    ]);\r\n    let chart = root.container.children.push(\r\n      am5xy.XYChart.new(root, {\r\n        panX: true,\r\n        panY: true,\r\n        wheelX: \"panX\",\r\n        wheelY: \"zoomX\",\r\n        pinchZoomX: true,\r\n      })\r\n    );\r\n\r\n    // Add data\r\n    let data = this.getPotentialBuyersCardData?.data?.potentialBuyers?.data.map(\r\n      (item: any) => ({\r\n        date: new Date(item.date).getTime(), // Convert date string to timestamp\r\n        value: Number(item.value),\r\n      })\r\n    );\r\n    let cursor = chart.set(\r\n      \"cursor\",\r\n      am5xy.XYCursor.new(root, {\r\n        behavior: \"none\",\r\n      })\r\n    );\r\n    cursor.lineY.set(\"visible\", false);\r\n    // Create axes\r\n    let xAxis = chart.xAxes.push(\r\n      am5xy.DateAxis.new(root, {\r\n        maxDeviation: 0.2,\r\n        baseInterval: { timeUnit: \"day\", count: 1 },\r\n        renderer: am5xy.AxisRendererX.new(root, { minorGridEnabled: true }),\r\n      })\r\n    );\r\n    xAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    xAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    let yAxis = chart.yAxes.push(\r\n      am5xy.ValueAxis.new(root, {\r\n        renderer: am5xy.AxisRendererY.new(root, { pan: \"zoom\" }),\r\n      })\r\n    );\r\n    yAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    yAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    // Create series\r\n    let series = chart.series.push(\r\n      am5xy.LineSeries.new(root, {\r\n        name: \"Series\",\r\n        xAxis: xAxis,\r\n        yAxis: yAxis,\r\n        valueYField: \"value\",\r\n        valueXField: \"date\",\r\n        stroke: am5.color(0x00a3ff), // Set the line color here (red in this case)\r\n      })\r\n    );\r\n    series.bullets.push(function () {\r\n      let bulletCircle = am5.Circle.new(root, {\r\n        radius: 0,\r\n        fill: series.get(\"fill\")\r\n      });\r\n      return am5.Bullet.new(root, {\r\n        sprite: bulletCircle\r\n      })\r\n    })\r\n    series.data.setAll(data);\r\n    series.set(\r\n      \"tooltip\",\r\n      am5.Tooltip.new(root, {\r\n        labelText: \"{valueY}\",\r\n        getFillFromSprite: false, // Prevents the tooltip from inheriting color from the sprite\r\n        background: am5.Rectangle.new(root, {\r\n          fill: am5.color(0xdaf1ff), // Set the tooltip background color here (blue in this case)\r\n        }),\r\n      })\r\n    );\r\n    this.potentialBuyerslineroot = root;\r\n  },0)\r\n  }\r\n\r\n  engagerslineCharts() {\r\n    setTimeout(() => {\r\n      const chartDiv = document.getElementById(\"engagers\");\r\n      if (!chartDiv) {\r\n        return;\r\n      }\r\n      if (this.engagerslineroot) {\r\n        this.engagerslineroot.dispose();\r\n      }\r\n    let root: any;\r\n    root = am5.Root.new(\"engagers\");\r\n    root.setThemes([\r\n      am5themes_Animated.new(root),\r\n      am5themes_Responsive.new(root),\r\n    ]);\r\n    let chart = root.container.children.push(\r\n      am5xy.XYChart.new(root, {\r\n        panX: true,\r\n        panY: true,\r\n        wheelX: \"panX\",\r\n        wheelY: \"zoomX\",\r\n        pinchZoomX: true,\r\n      })\r\n    );\r\n\r\n    // Add data\r\n    let data = this.getEngagersCardData?.data?.engagers?.data.map((item: any) => ({\r\n      date: new Date(item.date).getTime(), // Convert date string to timestamp\r\n      value: Number(item.value),\r\n    }));\r\n    let cursor = chart.set(\r\n      \"cursor\",\r\n      am5xy.XYCursor.new(root, {\r\n        behavior: \"none\",\r\n      })\r\n    );\r\n    cursor.lineY.set(\"visible\", false);\r\n    // Create axes\r\n    let xAxis = chart.xAxes.push(\r\n      am5xy.DateAxis.new(root, {\r\n        maxDeviation: 0.2,\r\n        baseInterval: { timeUnit: \"day\", count: 1 },\r\n        renderer: am5xy.AxisRendererX.new(root, { minorGridEnabled: true }),\r\n      })\r\n    );\r\n    xAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    xAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    let yAxis = chart.yAxes.push(\r\n      am5xy.ValueAxis.new(root, {\r\n        renderer: am5xy.AxisRendererY.new(root, { pan: \"zoom\" }),\r\n      })\r\n    );\r\n    yAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    yAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    // Create series\r\n    let series = chart.series.push(\r\n      am5xy.LineSeries.new(root, {\r\n        name: \"Series\",\r\n        xAxis: xAxis,\r\n        yAxis: yAxis,\r\n        valueYField: \"value\",\r\n        valueXField: \"date\",\r\n        stroke: am5.color(0x00a3ff), // Set the line color here (red in this case)\r\n      })\r\n    );\r\n    series.bullets.push(function () {\r\n      let bulletCircle = am5.Circle.new(root, {\r\n        radius: 0,\r\n        fill: series.get(\"fill\")\r\n      });\r\n      return am5.Bullet.new(root, {\r\n        sprite: bulletCircle\r\n      })\r\n    })\r\n    series.data.setAll(data);\r\n    series.set(\r\n      \"tooltip\",\r\n      am5.Tooltip.new(root, {\r\n        labelText: \"{valueY}\",\r\n        getFillFromSprite: false, // Prevents the tooltip from inheriting color from the sprite\r\n        background: am5.Rectangle.new(root, {\r\n          fill: am5.color(0xdaf1ff), // Set the tooltip background color here (blue in this case)\r\n        }),\r\n      })\r\n    );\r\n    this.engagerslineroot = root;\r\n  },0)\r\n  }\r\n  // card line Charts End\r\n\r\n  heatMap() {\r\n    this.heatloading = false\r\n    this.heatnoData = false\r\n    setTimeout(() => {\r\n      const chartDiv = document.getElementById(\"chartdiv\");\r\n      if (!chartDiv) {\r\n        return;\r\n      }\r\n      if (this.heatMaproot) {\r\n        this.heatMaproot.dispose();\r\n      }\r\n    let root = am5.Root.new(\"chartdiv\");\r\n    root.setThemes([am5themes_Animated.new(root)]);\r\n\r\n    let chart = root.container.children.push(\r\n      am5percent.SlicedChart.new(root, {\r\n        layout: root.verticalLayout,\r\n      })\r\n    );\r\n  \r\n      let data = this.heatMapData;\r\n    if (this.headerData?.client === '452') {\r\n      data = data.filter((item: any) => item.category !== 'Potential Buyers');\r\n      data = data.map((item:any) => {\r\n        const category = item.category.toLowerCase();\r\n      \r\n        const updatedCategory =\r\n          category === 'engagers'\r\n            ? `More than ${this.featureConfig?.bouncedLimit.value} mins`\r\n            : category === 'bounced'\r\n            ? `Less than ${this.featureConfig?.bouncedLimit.value} mins`\r\n            : category === 'conversion'\r\n            ? `More than ${this.featureConfig?.conversion.value} mins`\r\n            : category === 'footfall'\r\n            ? 'Footfall'\r\n            : `${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins`;\r\n      \r\n        return {\r\n          ...item,\r\n          category: updatedCategory,\r\n        };\r\n      });\r\n      }\r\n      \r\n    data.sort((a:any, b:any) => b.value - a.value);\r\n    let series = chart.series.push(\r\n      am5percent.FunnelSeries.new(root, {\r\n        alignLabels: false,\r\n        orientation: \"horizontal\",\r\n        valueField: \"value\",\r\n        categoryField: \"category\",\r\n        bottomRatio: 1,\r\n      })\r\n    );\r\n\r\n      \r\n    series.data.setAll(data);\r\n    series.appear();\r\n    // Update the label template to include the percentage\r\n    series.labels.template.setAll({\r\n      populateText: true,\r\n      text: \"{category} ({count}%)\\n\\n{value}\",\r\n      fontSize:\"13px\",\r\n      fontWeight:\"400\",\r\n      textAlign:\"center\"\r\n    });\r\n      \r\n    this.heatMaproot = root;\r\n    chart.appear(1000, 100);\r\n  },0);\r\n\r\n  }\r\n\r\n  type: any = \"weekly\";\r\n  selectPlan(type: any) {\r\n    this.type = type;\r\n  }\r\n\r\n  // Toggle function for the switch\r\n  toggleAverage(evt:any) {\r\n    // this.tableobj.nob =true;\r\n    this.isAverage = evt.target.checked;\r\n    this.service.toggleAverage(this.isAverage);\r\n    this.service?.togglenob(this.tableobj.nob);\r\n    this.tableobj.fromDate= this.headerData.date.startDate,\r\n    this.tableobj.toDate= this.headerData.date.endDate,\r\n    delete this.tableobj.recapVideoDate;\r\n    delete this.tableobj.limit; delete this.tableobj.export;\r\n    delete this.tableobj.offset;\r\n    if(this.isAverage === true){\r\n    this.valueType = 'average';\r\n     this.footfallName = 'Avg. Footfall'\r\n   this.tableobj.valueType =this.valueType;\r\n   this.objData.valueType =this.valueType;\r\n   this.objDataTraffic.valueType =this.valueType;\r\n  //  this.conversionValue = '';\r\n   this.typeValue='average';\r\n  //  this.valueConversionRate = this.getCardData?.conversion?.rate;\r\n  }  else {\r\n     this.footfallName = 'Actual Footfall'\r\n     this.valueType='actual';\r\n    this.tableobj.valueType ='actual';\r\n    this.objData.valueType ='actual';\r\n    this.objDataTraffic.valueType ='actual';\r\n    this.typeValue='sum';\r\n\r\n    // this.valueConversionRate = this.getCardData?.conversion?.rate;\r\n  }\r\n  if(this.tableobj.nob){\r\n    this.valueConversionRate = this.getConversionCardData?.conversion?.nob.nob;\r\n  this.conversionValue ='NoB Derived'\r\n} else if (this.clientData?.featureConfigs?.missedOpportunityCalculation === 'engagers-conversion') {\r\n  this.valueConversionRate = this.getConversionCardData?.conversion?.engagers?.rate;\r\n  this.conversionValue = 'engagers';\r\n} else {\r\n  this.valueConversionRate = this.getConversionCardData?.conversion?.footfall?.rate;\r\n  this.conversionValue = 'footfall';\r\n}\r\n  this.previousValue = 'footfall'; \r\n  this.tableobj.normalize = this.normalize\r\n\r\n    this.getFunnal();\r\n    this.getFootfallCard();\r\n    this.getConversionCard();\r\n    this.getBouncedCard();\r\n    this.getEngagersCard();\r\n    this.getPotentialBuyersCard();\r\n    this.getMissedOpportunityCard();\r\n    this.getPotentialBuyers();\r\n    this.getTable();\r\n    this.footfallTrend();\r\n    if(this.headerData?.client ==='459'){\r\n      this.selectedTab = \"footfall\"\r\n      this.footfallValue = \"footfall\";\r\n      this.selctedValue ='Footfall Analysis';\r\n    this.selectedTabs('footfall');\r\n    } else {\r\n      this.selectedTab = \"traffic\"\r\n      this.footfallValue = \"traffic\";\r\n      this.selctedValue ='Traffic Analysis';\r\n      this.selectedTabs('traffic');\r\n    }\r\n   \r\n    this.cd.detectChanges();\r\n  }\r\n  toggleConversion(evt:any){\r\n    this.isConversion = evt.target.checked; \r\n    this.tableobj.normalize = this.normalize\r\n    if(this.conversionValue === 'footfall'){\r\n      this.tableobj.conversiontype = 'footfall-count';\r\n     } if (this.conversionValue === 'engagers'){\r\n      this.tableobj.conversiontype = 'engagers-count';\r\n     }if (this.conversionValue === 'Potential Buyers'){\r\n      this.tableobj.conversiontype = 'billable-count';\r\n     } if (this.conversionValue === 'NoB Derived'){\r\n      this.tableobj.conversiontype = 'nob';\r\n     }\r\n    if(this.isConversion ==true){\r\n      this.tableobj.nob = true;\r\n      this.objData.nob = true;\r\n      this.objDataTraffic.nob = true; this.nob =true;\r\n    }  else {\r\n      if(this.tableobj.conversiontype === 'nob'){\r\n        this.tableobj.nob = true;\r\n      this.objData.nob = true;\r\n      this.objDataTraffic.nob = true; this.nob =true; \r\n      } else {\r\n      this.nob =false;\r\n      this.tableobj.nob = false;\r\n      this.objData.nob = false;\r\n      this.objDataTraffic.nob = false;\r\n      }\r\n    }\r\n    this.getFunnal();    \r\n    this.getConversionCard1(); \r\n    this.getTable();\r\n    this.footfallTrend(); \r\n    this.selectedTab = \"traffic\"\r\n    this.footfallValue = \"traffic\";\r\n    this.selctedValue ='Traffic Analysis';\r\n    this.selectedTabs('traffic');\r\n  }\r\n\r\n  cameraView(){\r\n    this.storeIdarray = this.headerData?.stores.filter((store:any) => store.checked).map((store:any) => store.storeId)\r\n    let data: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"\");\r\n    data.store = this.storeIdarray[0];\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(data));\r\n    this.gs.dataRangeValue.next(data);\r\n    this.router.navigate([\"/manage/stores/cameras\"], {\r\n      queryParams: { storeId: this.storeIdarray[0]},\r\n    });\r\n  }\r\n\r\n  exportXLSX() {\r\n    this.tableobj.offset = 0;\r\n    this.tableobj.limit = 10000;\r\n    (this.tableobj.valueType = this.typeValue);\r\n    this.tableobj.fromDate= this.headerData.date.startDate,\r\n    this.tableobj.toDate= this.headerData.date.endDate,\r\n    this.tableobj.search = this.searchValue;\r\n    this.tableobj.export = true;\r\n    this.tableobj.normalize = this.normalize\r\n    delete this.tableobj.recapVideoDate;\r\n    this.service\r\n    .getSummaryTableListExport(this.tableobj)\r\n    ?.pipe(takeUntil(this.destroy$))\r\n    ?.subscribe({\r\n      next: (res: any) => {\r\n        if (res) {\r\n          this.excelService.saveAsExcelFile(res, \"Traffic Summary Table \");\r\n        } else {\r\n        }\r\n      },\r\n      error: () => {},\r\n    });\r\n    this.tableobj.limit = this.limit;\r\n    this.tableobj.export = false;\r\n  }\r\n\r\n  onSort(column: string) {\r\n    if (this.sortedColumn === column) {\r\n      this.sortDirection = this.sortDirection === 1 ? -1 : 1;\r\n    } else {\r\n      this.sortedColumn = column;\r\n      this.sortDirection = 1;\r\n    }\r\n    this.tableobj.fromDate= this.headerData.date.startDate,\r\n    this.tableobj.toDate= this.headerData.date.endDate,\r\n    delete this.tableobj.recapVideoDate;\r\n    this.tableobj.sortBy = this.sortDirection, //[1->asc, -1->DEsc]\r\n    this.tableobj.sort = this.sortedColumn, // Column Name\r\n    this.getTable();\r\n  }\r\n\r\n  getMap() {\r\n    this.mpaloading =true;\r\n    this.mapnoData= false;\r\n    const obj = {\r\n      clientId: this.headerData?.client,\r\n      storeDate: this.headerData?.date?.endDate,\r\n      storeId: this.storeIdarray\r\n    };\r\n\r\n    this.service.geMaps(obj)?.pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if(res && res.code === 200){\r\n          // if (res && res.data && res.data.storeData) {\r\n            this.auLocations = res.data.storeData;\r\n          \r\n            // Update mapOptions center if needed\r\n            if (this.auLocations.length > 0) {\r\n              const firstLocation = this.auLocations[0];\r\n              if (firstLocation && typeof firstLocation.lat === 'number' && typeof firstLocation.lng === 'number') {\r\n                this.mapOptions = {\r\n                  ...this.mapOptions,\r\n                  center: { lat: firstLocation.lat, lng: firstLocation.lng }\r\n                };\r\n                setTimeout(() => {  this.getData(); },100)\r\n                this.cd.detectChanges();\r\n              } else {}\r\n            } else {}\r\n          // }\r\n          this.mpaloading =false;\r\n          this.mapnoData= false;\r\n          } else if(res === null){\r\n            this.mapnoData= true;\r\n            this.mpaloading =false;\r\n          } else {\r\n            this.auLocations =[];\r\n            this.mpaloading =false;\r\n            this.mapnoData= true;\r\n          }\r\n        \r\n        },\r\n        error: (err) => {\r\n          this.auLocations =[];\r\n          this.mpaloading =false;\r\n            this.mapnoData= true;\r\n        }\r\n      });\r\n  }\r\n  map: mapboxgl.Map;\r\n  private checkMapContainerInterval: any;\r\n  getData() {\r\n    this.checkMapContainerInterval = setTimeout(() => {\r\n      const mapContainer = this.el.nativeElement.querySelector('#map');\r\n      if (mapContainer) {\r\n        clearInterval(this.checkMapContainerInterval);\r\n        this.initializeMap(mapContainer);\r\n      } else {\r\n        clearInterval(this.checkMapContainerInterval);\r\n        this.initializeMap(mapContainer);\r\n      }\r\n    }, 100);\r\n\r\n  }\r\n  initializeMap(mapContainer: HTMLElement){\r\n    setTimeout(() => {  \r\n      const mapContainer = document.getElementById('map');\r\n      if (!mapContainer) {\r\n        return;\r\n      }\r\n    // Check that locations exist before proceeding\r\n    if (this.auLocations?.length === 0) {\r\n      return;\r\n    }\r\n  \r\n    const geojson = {\r\n      'type': 'FeatureCollection',\r\n      'features': this.auLocations.map((store, index) => ({\r\n        'type': 'Feature',\r\n        'properties': {\r\n          'storeName': store.storeName,         // Store name\r\n          'imageId': 1011 + index,              // Dynamic image ID\r\n          'iconSize': [60, 60],                 // Adjust icon size as needed\r\n          'footfall': store.avgFootfall,        // Footfall data\r\n          'openTime': store.openTime,           // Open time\r\n          'closeTime': store.closeTime,         // Close time\r\n        },\r\n        'geometry': {\r\n          'type': 'Point',\r\n          'coordinates': [store.lng, store.lat]  // Coordinates from store data\r\n        }\r\n      }))\r\n    };\r\n  \r\n    // Dynamically set map center based on the first location\r\n    const firstLocation = this.auLocations[0];\r\n \r\n    this.map = new mapboxgl.Map({\r\n      container: 'map',\r\n      style: 'mapbox://styles/mapbox/streets-v12',\r\n      center: [firstLocation.lng, firstLocation.lat], // Center map on the first location\r\n      zoom: 10, // Adjust this value (1 = world view, 20 = building view)\r\n      maxZoom: 20, // Optional: Limit max zoom level\r\n      minZoom: 1   // Optional: Limit min zoom level\r\n    });\r\n  \r\n    // Add markers to the map\r\n    geojson.features.forEach((feature, featureIndex) => {\r\n      const { properties, geometry } = feature;\r\n      const store = this.auLocations[featureIndex];\r\n      const el = document.createElement('div');\r\n      const width = properties.iconSize[0];\r\n      const height = properties.iconSize[1];\r\n      el.className = 'marker';\r\n      el.innerHTML = `\r\n      <div class=\"marker-icon\" style=\"background-color: white; width: ${width}px; height: ${height}px; display: flex; justify-content: center; align-items: center;\r\n      color: var(--Gray-700, #344054);\r\ntext-align: center;\r\nfont-family: Inter;\r\nfont-size: 9.007px;\r\nfont-style: normal;\r\nfont-weight: 600;\r\nline-height: 13px;\">\r\n        <div class=\"marker-content\" style=\"display: flex; flex-direction: column; align-items: center;\">\r\n          <svg class=\"mb-1\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n            <path d=\"M1.33654 3.3637L1.29658 3.42611C0.877698 4.16701 1.32493 5.10335 2.12931 5.21076C2.20218 5.21967 2.26999 5.22438 2.33625 5.22438C2.77021 5.22438 3.1539 5.03821 3.42132 4.74793L3.83666 4.2971L4.25059 4.74923C4.51476 5.03778 4.89758 5.22438 5.33448 5.22438C5.76941 5.22438 6.15443 5.03752 6.41837 4.74923L6.83359 4.29568L7.24882 4.74923C7.51275 5.03752 7.89777 5.22438 8.33271 5.22438C8.76764 5.22438 9.15266 5.03752 9.4166 4.74923L9.83182 4.29568L10.247 4.74923C10.511 5.03752 10.896 5.22438 11.3309 5.22438C11.395 5.22438 11.4649 5.21966 11.5372 5.21083C12.3593 5.09875 12.808 4.11225 12.3286 3.36408C12.3286 3.36403 12.3285 3.36399 12.3285 3.36395L11.0088 1.30621L11.0081 1.30511C10.9967 1.28722 10.9686 1.26804 10.9332 1.26804H2.72942C2.69403 1.26804 2.66589 1.28722 2.65448 1.30511L2.65401 1.30584L1.33654 3.3637ZM11.0731 7.06667V9.41753V9.98049H10.5101H3.15248H2.58952V9.41753V7.06702C2.50678 7.07318 2.42308 7.07634 2.33855 7.07634C2.30679 7.07634 2.27525 7.07587 2.24392 7.07495V9.41753V10.8696C2.24392 11.3526 2.64467 11.7587 3.15248 11.7587H10.5101C11.0179 11.7587 11.4187 11.3526 11.4187 10.8696V9.41753V7.07509C11.3888 7.07591 11.3587 7.07634 11.3286 7.07634C11.2428 7.07634 11.1575 7.07308 11.0731 7.06667Z\" stroke=\"#101828\" stroke-width=\"1.12592\"/>\r\n          </svg>\r\n          <div class=\"marker-label\" style=\"font-size: 10px; text-align: center;\">\r\n            ${properties.storeName}\r\n          </div>\r\n        </div>\r\n      </div>\r\n    `;\r\n      // el.style.backgroundImage = `url(https://picsum.photos/id/${properties.imageId}/${width}/${height})`;\r\n      el.style.width = `${width}px`;\r\n      el.style.height = `${height}px`;\r\n      el.style.backgroundSize = '100%';\r\n  \r\n      // Create a popup instance with the feature properties\r\n      const popup = new mapboxgl.Popup({ offset: 25 })  \r\n      // Use the coordinates from the feature\r\n      const coordinates: [number, number] = geometry.coordinates as [number, number];\r\n      el.addEventListener('click', () => {\r\n        this.adjustLayout(store);\r\n      });\r\n      // Add markers to the map\r\n      new mapboxgl.Marker(el)\r\n        .setLngLat(coordinates)\r\n        .setPopup(popup)  // Attach the popup to the marker\r\n        .addTo(this.map);\r\n    });\r\n    \r\n  },100)\r\n  }\r\n  adjustLayout(data: any) {\r\n    const datavalue: any = JSON.parse(\r\n      localStorage.getItem(\"header-filters\") || \"{}\"\r\n    );\r\n    const matchedStores = datavalue.stores.filter((store: any) => store.checked && store.storeId === data.storeId);\r\n    // Update the balance stores (those not in the matched stores) to set their checked property to false\r\n    datavalue.stores.forEach((store: any) => {\r\n      if (!matchedStores.some((matchedStore:any) => matchedStore.storeId === store.storeId)) {\r\n        store.checked = false;\r\n      }\r\n    }); \r\n    datavalue.store = data.storeId;\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(datavalue));\r\n    this.cd.detectChanges()\r\n    this.gs.dataRangeValue.next(datavalue)\r\n    this.gs.manageRefreshTrigger.next(true);\r\n   \r\n  }\r\n  exporeView(){\r\nthis.router.navigate(['/manage/traffic/explore'])\r\n  }\r\n  dateValue(type:any){\r\n    delete this.tableobj.limit; delete this.tableobj.export;\r\n    delete this.tableobj.offset;\r\n    this.tableobj.fromDate= this.headerData.date.startDate,\r\n    this.tableobj.toDate= this.headerData.date.endDate,\r\n    delete this.tableobj.recapVideoDate;\r\n    this.dateType = type;\r\n    this.tableobj.dateType= this.dateType;\r\n    this.tableobj.valueType  = this.valueType\r\n    this.getFootfallCard();\r\n    this.getConversionCard();\r\n    this.getBouncedCard();\r\n    this.getEngagersCard();\r\n    this.getPotentialBuyersCard();\r\n    this.getMissedOpportunityCard();\r\n    this.getPotentialBuyers();\r\n  }\r\n\r\n\r\n  getZone(){\r\n    this.zoneLoading = true;\r\n    this.zoneNoData = false;\r\n    const obj = {\r\n      clientId: this.headerData?.client,\r\n      fromDate: this.headerData?.date?.startDate,\r\n    toDate: this.headerData?.date?.endDate,\r\n      storeId: this.storeIdarray\r\n    };\r\n\r\n    this.service.zoneDwellTime(obj)?.pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if(res && res.code === 200){\r\n            this.zoneDwellTimeSplitData = res.data.zoneDwellTimeSplitData;\r\n            this.zoneLoading = false;\r\n            this.zoneNoData = false;\r\n          } else{\r\n            this.zoneDwellTimeSplitData =[];\r\n            this.zoneLoading = false;\r\n            this.zoneNoData = true;\r\n          }\r\n        },\r\n        error: (err) => {\r\n          this.zoneDwellTimeSplitData=[];\r\n        }\r\n\r\n      })\r\n    \r\n  }\r\n  getZoneValue(){\r\n    const obj = {\r\n      clientId: this.headerData?.client,\r\n      fromDate: this.headerData?.date?.startDate,\r\n    toDate: this.headerData?.date?.endDate,\r\n      storeId: this.storeIdarray\r\n    };\r\n\r\n    this.service.storeOperation(obj)?.pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if(res && res.code === 200){\r\n            this.storeOperationData = res.data.storeOperationData[0];\r\n          } else{\r\n            this.storeOperationData =[];\r\n          }\r\n        },\r\n        error: (err) => {\r\n          this.storeOperationData=[];\r\n        }\r\n\r\n      })\r\n    \r\n  }\r\n  onDateChange(event:any){\r\n    this.detailedCharts = false;\r\n    this.footfallDate = event.target.value;\r\n    this.objDataTraffic.dateRange =Number(this.footfallDate);\r\n this.getDwell();\r\n this.trafficDwell();\r\n  }\r\n  storeView(data:any){\r\n    const datavalue: any = JSON.parse(\r\n      localStorage.getItem(\"header-filters\") || \"{}\"\r\n    );\r\n    const matchedStores = datavalue.stores.filter((store: any) => store.checked && store.storeId === data);\r\n    // Update the balance stores (those not in the matched stores) to set their checked property to false\r\n    datavalue.stores.forEach((store: any) => {\r\n      if (!matchedStores.some((matchedStore:any) => matchedStore.storeId === store.storeId)) {\r\n        store.checked = false;\r\n      }\r\n    }); \r\n    datavalue.store = data;\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(datavalue));\r\n    this.cd.detectChanges()\r\n    this.gs.dataRangeValue.next(datavalue)\r\n    this.gs.manageRefreshTrigger.next(true);\r\n  }\r\n  goToZone(){\r\n    this.router.navigate([\"/manage/zones/v1\"]); \r\n\r\n  }\r\n\r\n  currentIndex: number = 0;\r\n  intervalId: any;\r\n\r\n\r\n  prevSlide() {\r\n    if (this.currentIndex > 0) {\r\n      this.currentIndex--;\r\n    }\r\n  }\r\n\r\n  nextSlide() {\r\n    if (this.currentIndex < this.recapsGrouped.length - 1) {\r\n      this.currentIndex++;\r\n    }\r\n  }\r\n\r\n  goToSlide(index: number) {\r\n    if (index >= 0 && index < this.recapsGrouped.length) {\r\n      this.currentIndex = index;\r\n    }\r\n  }\r\n  \r\n  nobUpload(){\r\n    this.router.navigate([\"/manage/traffic/nob\"]); \r\n  }\r\n  goToLoss(){\r\n    this.router.navigate([\"/manage/settings/brand-detail\"]); \r\n  }\r\n\r\n// footfall trend parts\r\n\r\ngetDateValues: any;\r\nchartTrends: any;\r\nrootTrends: any;\r\nyAxis: any;\r\nxAxis: any; \r\nlegend: any;\r\n@ViewChild('tooltipContainer') tooltipContainer: ElementRef<HTMLDivElement>;\r\ntooltipData: any;\r\ngetFootfallTrendData:any=[];\r\nobjData:any;\r\ndatasets = [\r\n  { value: 'missedopportunities', label: 'Missed Opportunity' },\r\n  { value: 'potentialBuyer', label: 'Potential Buyer' },\r\n  { value: 'conversion', label: 'Conversion' },\r\n  { value: '', label: 'No Filter' }\r\n];\r\n\r\nitemsPerPageTrends = 10;\r\ncurrentPageTrends = 1;\r\ntotalItemsTrends = 1;\r\npaginationSizesTrends: number[] = [];\r\npageSizeTrends = 31;\r\noffsetTrends : number = 0;\r\nlimitTrends : number = 31;\r\nselectValue= new FormControl(\"dataset1\");\r\nloadingTrends =true;\r\nnoDataTrends =false;\r\n  getInitialValue(): string {\r\n    // For example, selecting the second item in the dataset\r\n    return this.datasets[0].value; // Change as needed\r\n  }\r\n  onValueChangetrend(selectedId: any) {\r\n    this.objData.processType = selectedId,\r\n    this.footfallTrend();\r\n  }\r\n  get selectControl(): FormControl {\r\n    return this.form.get('selectValue') as FormControl;\r\n  }\r\n  @HostListener('document:click', ['$event'])\r\n  onClick(event: MouseEvent): void {\r\n    const tooltipElement = this.tooltipContainer?.nativeElement;\r\n\r\n    // Check if the click was outside the tooltip\r\n    if (tooltipElement && !tooltipElement.contains(event.target as Node) && this.tooltipVisible) {\r\n      this.hideTooltip();\r\n    }\r\n    this.show =false;\r\n  }\r\nfootfallTrend(){ \r\n  this.offsetTrends =0;\r\n  this.limitTrends =31;\r\n  this.loadingTrends =true;\r\n  this.noDataTrends =false;\r\n  (this.objData.conversiontype = this.tableobj.conversiontype);\r\n  this.service\r\n  .getfootfallTrend(this.objData)\r\n  .pipe(takeUntil(this.destroy$))\r\n  ?.subscribe({\r\n    next: (res: any) => {\r\n      if (res && res.code === 200) {\r\n        this.getFootfallTrendData = res?.data?.footfallTrendData;\r\n        this.getDateValues = res?.data;\r\n        this.totalItemsTrends = res.data?.totalCount;\r\n        this.setPaginationSizeTrends();\r\n        this.createChart() // Call with a delay to ensure the element is in the DOM\r\n        this.cd.detectChanges(); \r\n        this.loadingTrends =false;\r\n        this.noDataTrends =false;\r\n      } else {\r\n        this.loadingTrends =false;\r\n        this.noDataTrends =true;\r\n        this.getFootfallTrendData =[];\r\n      }\r\n    },\r\n    error: (err: any) => {\r\n      this.cd.detectChanges();\r\n    },\r\n    complete: () => {},\r\n  });\r\n  \r\n}\r\nsetPaginationSizeTrends() {\r\n  if (this.totalItemsTrends > 31 ) {\r\n    if(this.objData.forecast && this.totalItemsTrends > 31){\r\n      this.paginationSizesTrends = [60];\r\n    } else {  \r\n    this.paginationSizesTrends = [31];\r\n    }\r\n  } else {\r\n    this.paginationSizesTrends = [this.totalItemsTrends]; // Just one option if less than 10\r\n  }\r\n  this.pageSizeTrends = this.paginationSizesTrends[0];\r\n}\r\nonPageChangeTrends(pageOffsetTrends: number) {\r\n  this.offsetTrends = Number(pageOffsetTrends);\r\n  this.objData.offset = this.offsetTrends -1;\r\n  this.objData.limit = this.limitTrends;\r\n  this.service\r\n  .getfootfallTrend(this.objData)\r\n  .pipe(takeUntil(this.destroy$))\r\n  ?.subscribe({\r\n    next: (res: any) => {\r\n      if (res && res.code === 200) {\r\n        this.getFootfallTrendData = res?.data.footfallTrendData;\r\n        \r\n        this.getDateValues = res?.data;\r\n        this.totalItemsTrends = res.data?.totalCount;\r\n        this.createChart() // Call with a delay to ensure the element is in the DOM\r\n        this.cd.detectChanges(); \r\n\r\n      } else {\r\n        this.loading =false;\r\n        this.noData =true;\r\n      }\r\n    },\r\n    error: (err: any) => {\r\n      this.cd.detectChanges();\r\n    },\r\n    complete: () => {},\r\n  });\r\n  \r\n}\r\n\r\nonPageSizeChangeTrends(pageSizeTrends: number) {\r\n  this.pageSizeTrends = Number(pageSizeTrends);\r\n  this.limitTrends = Number(pageSizeTrends);\r\n  this.currentPageTrends = 1;\r\n  this.offsetTrends = 0;\r\n  this.objData.offset = this.offsetTrends;\r\n  this.objData.limit = this.limitTrends;\r\n  this.footfallTrend();\r\n}\r\n createChart() {\r\n    this.loadingTrends =false;\r\n    this.noDataTrends =false;\r\n    setTimeout(() => {\r\n      const chartDiv = document.getElementById(\"Footfalltrend\");\r\n      if (!chartDiv) {\r\n        return;\r\n      }\r\n      if (this.rootTrends) {\r\n        this.rootTrends.dispose();\r\n      }\r\n    this.rootTrends  = am5.Root.new('Footfalltrend');\r\n    this.rootTrends.setThemes([am5themes_Animated.new(this.rootTrends)]);\r\n\r\n    this.chartTrends = this.rootTrends.container.children.push(\r\n      am5xy.XYChart.new(this.rootTrends, {\r\n        panX: false,\r\n        panY: false,\r\n        wheelX: 'panX',\r\n        wheelY: 'zoomX',\r\n        layout: this.rootTrends.verticalLayout\r\n      })\r\n    );\r\n\r\n    this.chartTrends.set(\"scrollbarX\", am5.Scrollbar.new(this.rootTrends, {\r\n      orientation: \"horizontal\"\r\n    }));\r\n    let xRenderer = am5xy.AxisRendererX.new(this.rootTrends, {\r\n      minGridDistance: 20,\r\n      minorGridEnabled: true,\r\n    });\r\n    xRenderer.labels.template.setAll({\r\n      rotation: -45,\r\n      centerY: am5.p50,\r\n      centerX: am5.p100,\r\n      paddingRight: 5,\r\n    });\r\n    // xRenderer.grid.template.setAll({\r\n    //   location: 1,\r\n    // });\r\n    const xAxis = this.chartTrends.xAxes.push(\r\n      am5xy.CategoryAxis.new(this.rootTrends, {\r\n        categoryField: 'storeName',\r\n        renderer:xRenderer,\r\n        tooltip: am5.Tooltip.new(this.rootTrends, { labelText: \"{fullStoreName}\"})\r\n      })\r\n    );\r\n    this.getFootfallTrendData.sort((a: any, b: any) => {\r\n      // Parse storeName as a Date and compare\r\n      const dateA = new Date(a.storeName);\r\n      const dateB = new Date(b.storeName);\r\n      \r\n      // Sort in ascending order (oldest to newest)\r\n      return dateA.getTime() - dateB.getTime();\r\n    });\r\n    this.getFootfallTrendData = this.getFootfallTrendData?.map(\r\n      (item: any) => ({\r\n        fullStoreName: item.storeName, // Full store name\r\n        storeName: item.storeName, // item.storeName.length > 20 ? item.storeName.slice(0, 20) + '...' : Shortened for xAxis\r\n        footfall: Number(item.footfall_count),\r\n        conversion: Number(item.conversion_count),\r\n        bounced: Number(item.bounced_count),\r\n        engagers: Number(item.engagers_count),\r\n        missedopportunities: Number(item.missedOpportunity_count),\r\n        potential: Number(item.potentialBuyers_count),\r\n        bounced_count:item.bounced_count,\r\n        avgDwellTime:item.avgDwellTime,\r\n        down_time:item.down_time,\r\n        engagers_count:item.engagers_count,\r\n        footfall_count:item.footfall_count,\r\n        missedOpportunity_count:item.missedOpportunity_count,\r\n        footfall_count_avg:item.footfall_count_avg,\r\n        bounced_footfall_count_avg:item.bounced_footfall_count_avg,\r\n        missedOpportunity_count_avg:item.missedOpportunity_count_avg,\r\n        engagers_count_avg:item.engagers_count_avg,\r\n        conversionRate: item.conversionRate,\r\n        forecast: item.forecast,\r\n      })\r\n    );\r\n   \r\n    xAxis.data?.setAll(this.getFootfallTrendData); \r\n    const yAxis = this.chartTrends.yAxes.push(\r\n      am5xy.ValueAxis.new(this.rootTrends, {\r\n        min:0,\r\n        renderer: am5xy.AxisRendererY.new(this.rootTrends, {})\r\n      })\r\n    );\r\n    // yAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    // yAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n    // Set the title of the y-axis\r\n    yAxis.children.unshift(am5.Label.new(this.rootTrends, {\r\n      rotation: -90,\r\n      // text: 'Footfall', //capitalizeFirstLetter(this.objData.processType), // Capitalize the first letter\r\n      y: am5.p50,\r\n      centerX: am5.p50,\r\n      fontFamily: \"Arial\", // Set font family\r\n      fontSize: \"14px\",    // Set font size\r\n      fill: am5.color(0x000000) // Set text color (optional)\r\n    }));\r\nif(this.objData.processType ==='potentialBuyer')\r\n  this.objData.processType ='potential'\r\n// if(this.objData.processType ==='missedopportunities')\r\n//   this.objData.processType ='Missed Opportunity'\r\nconst capitalizeTitle = (text: string): string => {\r\n  return text\r\n    .split(' ')\r\n    .map(word => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())\r\n    .join(' ');\r\n};\r\n\r\n// Example usage\r\nconst processTypeTitle = capitalizeTitle(this.objData.processType);\r\n    // this.createColumnSeries('Footfall', 'footfall', xAxis, yAxis, false, am5.color(0x67b7dc));\r\n    this.createColumnSeries('Bounced', 'bounced', xAxis, yAxis, true, am5.color(0x67b7dc));\r\n    this.createColumnSeries('Engagers', 'engagers', xAxis, yAxis, true, am5.color(0x6794dc));\r\n    // 6771dc\r\n    // this.createColumnSeries('Missed Opportunity', 'missedopportunities', xAxis, yAxis, true, am5.color(0x6794dc));\r\n    // this.createColumnSeries('Potential Buyer', 'potential', xAxis, yAxis, true, am5.color(0xdc69cf));\r\n    // this.createColumnSeries('Conversion', 'conversion', xAxis, yAxis, true, am5.color(0x6771dc));\r\n    if(this.objData.processType !=='' ){\r\n      const myColor = am5.color(0x00FF00);\r\n    this.createLineSeries(processTypeTitle, this.objData.processType, xAxis, yAxis, myColor);\r\n    }\r\n    const legend = this.chartTrends.children.push(\r\n      am5.Legend.new(this.rootTrends, {\r\n        centerX: am5.p50,\r\n        x: am5.p50\r\n      })\r\n    );\r\n\r\n    legend.data.setAll(this.chartTrends.series.values);\r\n\r\n    this.chartTrends.set('cursor', am5xy.XYCursor.new(this.rootTrends, {\r\n      behavior: 'none'\r\n    }));\r\n\r\n    this.chartTrends.series.each((series: any) => {\r\n      if (series.columns) {\r\n        series.columns.template.set(\"interactive\", true);\r\n        series.columns.template.events.on(\"click\", (ev: any) => {\r\n          const data = ev.target.dataItem.dataContext;\r\n          const { clientX, clientY } = ev.originalEvent;\r\n          this.showTooltip(data, clientX, clientY);\r\n        });\r\n      }\r\n    });\r\n    this.chartTrends.appear(1000, 100);\r\n  },100)\r\n  }\r\n\r\n  tooltipVisible = false;\r\n  showTooltip(data: any, x: number, y: number): void {\r\n    this.tooltipVisible = false;\r\n    this.tooltipData = data;\r\n    const tooltipElement = this.tooltipContainer?.nativeElement;\r\n  \r\n    // Set tooltip content and make it visible to calculate dimensions\r\n    tooltipElement.style.display = 'block';\r\n    tooltipElement.style.visibility = 'hidden'; // Make it invisible but still present in the DOM\r\n  \r\n    // Force a reflow to ensure dimensions are up-to-date\r\n    tooltipElement.style.position = 'absolute';\r\n    \r\n    // Wait for the next event loop to get accurate dimensions\r\n    setTimeout(() => {\r\n      const tooltipWidth = tooltipElement.offsetWidth;\r\n      const tooltipHeight = tooltipElement.offsetHeight;\r\n      const screenWidth = window.innerWidth;\r\n      const screenHeight = window.innerHeight;\r\n  \r\n      // Calculate if there is enough space on the right side, otherwise place it on the left\r\n      if (x + tooltipWidth > screenWidth) {\r\n        tooltipElement.style.left = `${x - tooltipWidth}px`;\r\n      } else {\r\n        tooltipElement.style.left = `${x}px`;\r\n      }\r\n  \r\n      // Calculate if there is enough space at the bottom, otherwise place it at the top\r\n      if (y + tooltipHeight > screenHeight) {\r\n        tooltipElement.style.top = `${y - tooltipHeight}px`;\r\n      } else {\r\n        tooltipElement.style.top = `${y}px`;\r\n      }\r\n  \r\n      tooltipElement.style.visibility = 'visible'; // Make it visible again\r\n      this.tooltipVisible = true;\r\n    }, 0);\r\n  }\r\n  selectPlanTrends(type: any) {\r\n    this.type = type;\r\n    this.objData.dateType =type;\r\n    if(type ==='monthly' && this.storeIdarray?.length === 1)\r\n    this.objData.limit= 60;\r\n  else \r\n  this.objData.limit= 31;\r\n    this.objData.offset= 0;\r\n    this.footfallTrend();\r\n    // this.updateChartData();\r\n  }\r\n  hideTooltip(): void {\r\n    this.tooltipVisible = false;\r\n    const tooltipElement = this.tooltipContainer?.nativeElement;\r\n    tooltipElement.style.display = 'none';\r\n  }\r\n\r\n  createColumnSeries(\r\n    name: string,\r\n    fieldName: string,\r\n    xAxis: am5xy.CategoryAxis<am5xy.AxisRenderer>,\r\n    yAxis: am5xy.ValueAxis<am5xy.AxisRenderer>,\r\n    stacked: boolean,\r\n    color: am5.Color\r\n  ): void {\r\n\r\n    if (this.headerData?.client === '452') {\r\n      if (name === 'Bounced') {\r\n        name = `Less than ${this.clientData?.featureConfigs?.bouncedLimit?.value ?? 'X'} mins`;\r\n      }\r\n      if (name === 'Engagers') {\r\n        name = `More than ${this.clientData?.featureConfigs?.bouncedLimit?.value ?? 'X'} mins`;\r\n      }\r\n    }\r\n    const series = this.chartTrends.series.push(\r\n      am5xy.ColumnSeries.new(this.rootTrends, {\r\n        name: name,\r\n        xAxis: xAxis,\r\n        yAxis: yAxis,\r\n        valueYField: fieldName,\r\n        categoryXField: 'storeName',\r\n        stacked: stacked,\r\n      })\r\n    );\r\n    this.getFootfallTrendData = this.getFootfallTrendData.map((item: any) => {\r\n      return {\r\n        ...item,\r\n        dynamicColumn: {\r\n          fillOpacity: item.columnSettings?.fillOpacity ?? 0.8,\r\n          strokeDasharray: Array.isArray(item.columnSettings?.strokeDasharray)\r\n            ? item.columnSettings.strokeDasharray\r\n            : item.columnSettings?.strokeDasharray ? item.columnSettings.strokeDasharray.split(',').map(Number) : [5, 5],\r\n          strokeWidth: item.columnSettings?.strokeWidth ?? 3\r\n        }\r\n      };\r\n    });\r\n  \r\n    // Set data for series\r\n    series.data.setAll(this.getFootfallTrendData);\r\n  \r\n    // Adapters to apply custom column settings\r\n    series.columns.template.adapters.add(\"fillOpacity\", (fillOpacity: any, target: any) => {\r\n      const dataItem = target.dataItem?.dataContext as any;\r\n      if (dataItem?.forecast && dataItem?.dynamicColumn) { \r\n        return dataItem.dynamicColumn.fillOpacity ?? fillOpacity; \r\n      }\r\n      return fillOpacity; // Default opacity\r\n    });\r\n  \r\n    series.columns.template.adapters.add(\"strokeDasharray\", (strokeDasharray: any, target: any) => {\r\n      const dataItem = target.dataItem?.dataContext as any;\r\n      if (dataItem?.forecast && dataItem?.dynamicColumn) { \r\n        return dataItem.dynamicColumn.strokeDasharray ?? strokeDasharray; \r\n      }\r\n      return strokeDasharray; // Default dash array\r\n    });\r\n  \r\n    series.columns.template.adapters.add(\"strokeWidth\", (strokeWidth: any, target: any) => {\r\n      const dataItem = target.dataItem?.dataContext as any;\r\n      if (dataItem?.forecast && dataItem?.dynamicColumn) { \r\n        return dataItem.dynamicColumn.strokeWidth ?? strokeWidth; \r\n      }\r\n      return strokeWidth; // Default stroke width\r\n    });\r\n  \r\n    // Set default color and stroke for the columns\r\n    series.columns.template.setAll({\r\n      fill: color, // Set fill color\r\n      stroke: color // Set stroke color\r\n    });\r\n  \r\n    // Add labels to the columns\r\n    series.bullets.push(() => {\r\n      return am5.Bullet.new(this.rootTrends, {\r\n        sprite: am5.Label.new(this.rootTrends, {\r\n          text: \"{valueY}\",\r\n          fill: this.rootTrends.interfaceColors.get(\"alternativeText\"),\r\n          centerY: am5.p50,\r\n          centerX: am5.p50,\r\n          populateText: true,\r\n          fontSize: 12  // Reduce font size\r\n        })\r\n      });\r\n    });\r\n \r\n    series.appear();\r\n  }\r\n  \r\n  \r\n\r\n\r\n\r\n  createLineSeries(\r\n    name: string,\r\n    fieldName: string,\r\n    xAxis: am5xy.CategoryAxis<am5xy.AxisRenderer>,\r\n    yAxis: am5xy.ValueAxis<am5xy.AxisRenderer>,\r\n    color: am5.Color\r\n  ): void {\r\n    if (this.headerData?.client === '452') {\r\n      if (name === 'Conversion') {\r\n        name = `More than ${this.clientData?.featureConfigs?.conversion?.value ?? 'X'} mins`;\r\n      }\r\n    \r\n      if (name === 'Missedopportunities') {\r\n        name = `${this.clientData?.featureConfigs?.missedOpportunityFrom?.value ?? 'X'} - ${this.clientData?.featureConfigs?.missedOpportunityTo?.value ?? 'Y'} mins`;\r\n      }\r\n    \r\n    } else {\r\n      if (name === 'Missedopportunities') {\r\n        name = 'Missed Opportunity';\r\n      }\r\n    \r\n      if (name === 'Potential' || name === 'potentialBuyer') {\r\n        name = 'Potential Buyer';\r\n      }\r\n    }\r\n    \r\n    const series = this.chartTrends.series.push(\r\n      am5xy.LineSeries.new(this.rootTrends, {\r\n        name: name,\r\n        xAxis: xAxis,\r\n        yAxis: yAxis,\r\n        valueYField: fieldName,\r\n        categoryXField: 'storeName',\r\n        tooltip: am5.Tooltip.new(this.rootTrends, {\r\n          pointerOrientation: \"horizontal\",\r\n          labelText: \"Total Footfall: {footfall}\\n{name}: {valueY} \",\r\n          background: am5.Rectangle.new(this.rootTrends, {\r\n            fill: am5.color(0x00FF00) // Set the desired tooltip background color\r\n          })\r\n        })\r\n      })\r\n    );\r\n  \r\n    // Apply default stroke settings for the line series\r\n    series.strokes.template.setAll({\r\n      strokeWidth: 2,\r\n      stroke: am5.color(0x00FF00), // Default stroke color\r\n      templateField: \"strokeSettings\", // Refer to strokeSettings for dynamic updates\r\n      fontSize: 12 // Reduce font size for labels\r\n    });\r\n  \r\n    // Map dynamic settings for forecast=true items\r\n    this.getFootfallTrendData = this.getFootfallTrendData.map((item: any) => {\r\n      return {\r\n        ...item,\r\n        dynamicLine: {\r\n          stroke: item.strokeSettings?.stroke ?? am5.color(0x00FF00), // Default to green if not specified\r\n          strokeWidth: item.strokeSettings?.strokeWidth ?? 5,\r\n          strokeDasharray: Array.isArray(item.strokeSettings?.strokeDasharray)\r\n            ? item.strokeSettings.strokeDasharray\r\n            : item.strokeSettings?.strokeDasharray\r\n            ? item.strokeSettings.strokeDasharray.split(',').map(Number)\r\n            : [5, 5] // Default dash array\r\n        }\r\n      };\r\n    });\r\n  \r\n    // Set data for series\r\n    series.data.setAll(this.getFootfallTrendData);\r\n  \r\n  // Adapter to apply custom stroke settings based on forecast\r\n  series.strokes.template.adapters.add(\"stroke\", (stroke: any, target: any) => {\r\n    const dataItem = target.dataItem?.dataContext as any;\r\n    if (dataItem?.forecast && dataItem?.dynamicLine) {\r\n      return dataItem.dynamicLine.stroke ?? stroke; // Apply dynamic stroke if forecast is true\r\n    }\r\n    return stroke; // Default stroke\r\n  });\r\n\r\n  series.strokes.template.adapters.add(\"strokeWidth\", (strokeWidth: any, target: any) => {\r\n    const dataItem = target.dataItem?.dataContext as any;\r\n    if (dataItem?.forecast && dataItem?.dynamicLine) {\r\n      return dataItem.dynamicLine.strokeWidth ?? strokeWidth; // Apply dynamic stroke width\r\n    }\r\n    return strokeWidth; // Default stroke width\r\n  });\r\n\r\n  series.strokes.template.adapters.add(\"strokeDasharray\", (strokeDasharray: any, target: any) => {\r\n    const dataItem = target.dataItem?.dataContext as any;\r\n    if (dataItem?.forecast && dataItem?.dynamicLine) {\r\n      // Ensure the dash array is a valid array of numbers for proper rendering\r\n      return Array.isArray(dataItem.dynamicLine.strokeDasharray)\r\n        ? dataItem.dynamicLine.strokeDasharray // Use if already in array format\r\n        : dataItem.dynamicLine.strokeDasharray\r\n        ? dataItem.dynamicLine.strokeDasharray.split(',').map(Number) // Convert string to array\r\n        : [5, 5]; // Default dash array\r\n    }\r\n    return strokeDasharray; // Default stroke dash array if no custom setting\r\n  });\r\n\r\n  \r\n    // Add bullets (markers) to the line series\r\n    series.bullets.push(() => {\r\n      return am5.Bullet.new(this.rootTrends, {\r\n        sprite: am5.Circle.new(this.rootTrends, {\r\n          strokeWidth: 1,\r\n          stroke: am5.color(0x00FF00),\r\n          radius: 3, // Increase radius for visibility\r\n          fill: this.rootTrends.interfaceColors.get(\"background\")\r\n        })\r\n      });\r\n    });\r\n  \r\n    // Trigger the appearance of the series\r\n    series.appear();\r\n  \r\n    // Log the series data for debugging\r\n  }\r\n  \r\n  show: boolean =false;\r\n  producttrailDropdown(event: MouseEvent) {\r\n    event.stopPropagation();\r\n    this.show =true;\r\n  }\r\n  changeStatus(type:any){\r\nthis.trendtypeValue = type;\r\nthis.objData.filterBy =type;\r\nthis.footfallTrend();\r\nthis.show =false;\r\n  }\r\n\r\n\r\n\r\n  // traffic overall card and charts\r\n\r\n  private root!: am5.Root;\r\n  // private chart: am5xy.XYChart;\r\n  private series: am5xy.ColumnSeries;\r\n  private root2: am5.Root;\r\n  private chart2: am5xy.XYChart;\r\n  private series2: am5xy.ColumnSeries;\r\n  detailedRoot: am5.Root;\r\n  detailedChart: am5xy.XYChart;\r\n  detailedSeries: am5xy.ColumnSeries;\r\n  dayjs =dayjs\r\n  heatMapRoot: am5.Root;\r\n  heatMapChart: am5xy.XYChart;\r\n  heatMapSeries: am5xy.ColumnSeries;\r\n  dwellRoot: am5.Root;\r\n  dwellChart: am5xy.XYChart;\r\n  dwellSeries: am5xy.ColumnSeries;\r\n  demoGraphicsData: any;\r\n  demoGraphicsroot: any;\r\n  buyersroot:any;\r\n\r\n  data: any;\r\n  currentData: any;\r\n  currentData2: any;\r\n  detailedCharts: boolean = false;\r\n  date: any;\r\n  value: any;\r\n  footfallValue: string = \"traffic\";\r\n  demoGraphicsChartInstance: any;\r\n  buyersChartInstance:any;\r\n  selectedTab: any = \"traffic\";\r\n  getOverallCardData: any = [];\r\n  // objData: any;\r\n  getOverallHourlyData: any;\r\n  getOverallChartData: any=[];\r\n  getSingleChartData: any;\r\n  buyersData: any;\r\n  getDensityDwellData: any;\r\n  trafficData:any= [];\r\n  footfallDate: any;\r\n  selctedValue:any ='Footfall Analysis';\r\n  chartNoData: boolean =false;\r\n  chartloading: boolean =true;\r\n  totalCount: any;\r\n  demoGraphicsSeries: any;\r\n\r\n  itemsPerPageTrafficCard = 10;\r\n  currentPageTrafficCard = 1;\r\n  totalItemsTrafficCard = 1;\r\n  paginationSizesTrafficCard: number[] = [];\r\n  pageSizeTrafficCard:any=20;\r\n  offsetTrafficCard: number = 0;\r\n  limitTrafficCard: number = 20;\r\n  demoNoData =false;\r\n  demoloading =false;\r\n  buyersNoData =false;\r\n  buyersloading =false;\r\n  datasetsCard:any =[];\r\n\r\n  selectedTabs(type: any) {\r\n    this.detailedCharts = false;\r\n    this.selectedTab = type;\r\n    this.objDataTraffic.processType = type;\r\n    this.objDataTraffic.valueType =this.valueType;\r\n   \r\n    this.objDataTraffic.storeId = this.headerData.stores.filter((store:any) => store.checked).map((store:any) => store.storeId);\r\n   if(this.selectedTab === 'traffic'){\r\n   this.getDwell(); this.trafficDwell();\r\n    this.cd.detectChanges();\r\n   } else{\r\n    if(this.selectedTab === \"footfall\"){\r\n      this.footfallValue = \"footfall\";\r\n      this.selctedValue ='Footfall Analysis'\r\n    } else if(this.selectedTab === \"conversion\"){\r\n      this.footfallValue = \"conversion\";\r\n      this.selctedValue = this.headerData?.client === '452' ? `More than ${this.featureConfig?.conversion.value} mins Analysis` : 'Conversion Analysis'\r\n    } else if(this.selectedTab === \"engagers\"){\r\n      this.footfallValue = \"engagers\";\r\n      this.selctedValue = this.headerData?.client === '452' ? `More than ${this.featureConfig?.bouncedLimit.value} mins Analysis` : 'Engagers Analysis'\r\n    } else if(this.selectedTab === \"bounced\"){\r\n      this.footfallValue = \"bounced\";\r\n      this.selctedValue = this.headerData?.client === '452' ? `Less than ${this.featureConfig?.bouncedLimit.value} mins Analysis` :'Bounced Analysis'\r\n    } else if(this.selectedTab === \"potentialBuyers\"){\r\n      this.footfallValue = \"potentialBuyers\";\r\n      this.selctedValue ='Potential Buyer Analysis'\r\n    } else if(this.selectedTab === \"missedOpportunity\"){\r\n      this.footfallValue = \"missedOpportunity\";\r\n      this.selctedValue = this.headerData?.client === '452' ? `${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins Analysis` :'Missed Opportunity Analysis' \r\n    } \r\n    if(this.objDataTraffic.nob === true && this.selectedTab === \"conversion\"){\r\n      this.selectedTab = \"conversion\"\r\n       this.footfallValue = \"conversion\";\r\n      this.selctedValue ='Conversion Analysis'\r\n      this.datasetsCard = [\r\n        { value: this.selectedTab, label: this.selctedValue },\r\n      ];\r\n      this.objDataTraffic.limit =20,\r\n      this.overallCard();\r\n      this.overallChart();\r\n    } else {\r\n      if (this.headerData?.client === '452') {\r\n        this.datasetsCard = [\r\n          { value: this.selectedTab, label: this.selctedValue },\r\n          { value: \"demographic\", label: \"Demographic Analysis\" }\r\n        ]\r\n      } else {\r\n        this.datasetsCard = [\r\n          { value: this.selectedTab, label: this.selctedValue },\r\n          { value: \"demographic\", label: \"Demographic Analysis\" },\r\n          { value: \"buyer\", label: \"Buyer Analysis\" },\r\n      ]\r\n    }\r\n    this.objDataTraffic.limit =20,\r\n    this.overallCard();\r\n    this.overallHourlyChart();\r\n    this.overallChart();\r\n  }\r\n  this.cd.detectChanges();\r\n  }\r\n  }\r\n  getFootfallDensityDwellData:any =[];\r\n  trafficDwell(){\r\n    this.chartNoData = false;\r\n    this.chartloading = true;\r\n    delete this.objDataTraffic.limit;\r\n    delete this.objDataTraffic.offset;\r\n    delete this.objDataTraffic.processType;\r\n    delete this.objDataTraffic.hourFormat;\r\n    delete this.objDataTraffic.normalizedData\r\n    this.objDataTraffic.dateRange =Number(this.footfallDate);\r\n    this.service\r\n      .getTrafficDensityDwell(this.objDataTraffic)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getFootfallDensityDwellData = res?.data;\r\n            this.trafficHeatChart();\r\n            this.chartNoData = false;\r\n            this.chartloading = false;\r\n            this.cd.detectChanges();\r\n          } else if(!res || res.code === 204){\r\n            this.chartNoData = true;\r\n            this.chartloading = false;\r\n            this.getFootfallDensityDwellData =[];\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.chartNoData = true;\r\n          this.chartloading = false;\r\n          this.getFootfallDensityDwellData =[];\r\n          this.cd.detectChanges();\r\n        },\r\n        complete: () => {},\r\n      }); \r\n  }\r\n  chartDwellNoData = false;\r\n      chartDwellloading = true;\r\n   getDwell(){\r\n      this.chartDwellNoData = false;\r\n      this.chartDwellloading = true;\r\n      delete this.objDataTraffic.limit;\r\n      delete this.objDataTraffic.offset;\r\n      delete this.objDataTraffic.processType;\r\n      delete this.objDataTraffic.hourFormat;\r\n      delete this.objDataTraffic.normalizedData;\r\n      this.objDataTraffic.dateRange =Number(this.footfallDate);\r\n      this.service\r\n        .getDensityDwell(this.objDataTraffic)\r\n        .pipe(takeUntil(this.destroy$))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res?.code === 200) {\r\n              this.getDensityDwellData = res?.data;\r\n              if(this.getDensityDwellData?.dwellTimeSplit?.length >0){\r\n                this.getDwellChart();\r\n                this.chartDwellNoData = false;\r\n                this.chartDwellloading = false;\r\n                this.cd.detectChanges();\r\n              } else {\r\n                this.chartDwellNoData = true;\r\n              this.chartDwellloading = false;\r\n              }\r\n            } else if(!res || res.code === 204){\r\n              this.chartDwellNoData = true;\r\n              this.chartDwellloading = false;\r\n              this.getDensityDwellData =[];\r\n            }\r\n          },\r\n          error: (err: any) => {\r\n            this.chartNoData = true;\r\n            this.chartloading = false;\r\n            this.cd.detectChanges();\r\n            this.getDensityDwellData =[];\r\n          },\r\n          complete: () => {},\r\n        });\r\n    }\r\n    initChart(): void {\r\n      this.chartNoData = false;\r\n      this.chartloading = false;\r\n      setTimeout(() => {\r\n        const chartDiv = document.getElementById(\"testGraphics\");\r\n        if (!chartDiv) {\r\n          return;\r\n        }\r\n        if (this.root) {\r\n          this.root.dispose();\r\n        }\r\n        this.root = am5.Root.new(\"testGraphics\");\r\n  \r\n        // Set themes\r\n        // this.root.setThemes([am5themes_Animated.new(this.root)]);\r\n        // const totalCount = this.totalCount;\r\n        // const dynamicWidth = Math.max(800, totalCount * 50); // Minimum 800px or 50px per item\r\n        // console.log(dynamicWidth,this.totalCount)\r\n        // Create chart\r\n        this.chart = this.root.container.children.push(\r\n          am5xy.XYChart.new(this.root, {\r\n            panX: true,\r\n            panY: true,\r\n            wheelX: \"panX\",\r\n            wheelY: \"zoomX\",\r\n            pinchZoomX: true,\r\n            paddingLeft: 0,\r\n            paddingRight: 1,\r\n            width: am5.percent(100), // Let the chart take full width\r\n          })\r\n        );\r\n        // this.chart.plotContainer.setAll({\r\n        //   minWidth: dynamicWidth, // Set dynamic min width for scrolling\r\n        // });\r\n        // Add cursor\r\n        let cursor = this.chart.set(\"cursor\", am5xy.XYCursor.new(this.root, {}));\r\n        cursor.lineY.set(\"visible\", false);\r\n  \r\n        // Create axes\r\n        let xRenderer = am5xy.AxisRendererX.new(this.root, {\r\n          minGridDistance: 30,\r\n          minorGridEnabled: true,\r\n        });\r\n  \r\n        xRenderer.labels.template.setAll({\r\n          rotation: -45,\r\n          centerY: am5.p50,\r\n          centerX: am5.p100,\r\n          paddingRight: 5,\r\n        });\r\n  \r\n        xRenderer.grid.template.setAll({\r\n          location: 1,\r\n        });\r\n        // Add scrollbar\r\n        this.chart.set(\r\n          \"scrollbarX\",\r\n          am5.Scrollbar.new(this.root, {\r\n            orientation: \"horizontal\",\r\n          })\r\n        );\r\n        let xAxis = this.chart.xAxes.push(\r\n          am5xy.CategoryAxis.new(this.root, {\r\n            maxDeviation: 0.3,\r\n            categoryField: \"storeName\",\r\n            renderer: xRenderer,\r\n            // tooltip: am5.Tooltip.new(this.root, {labelText: \"{fullStoreName}\"}),\r\n          })\r\n        );\r\n  \r\n        let yRenderer = am5xy.AxisRendererY.new(this.root, {\r\n          strokeOpacity: 0.1,\r\n        });\r\n  \r\n        let yAxis = this.chart.yAxes.push(\r\n          am5xy.ValueAxis.new(this.root, {\r\n            maxDeviation: 0.3,\r\n            renderer: yRenderer,\r\n          })\r\n        );\r\n        let data = this.getOverallChartData?.storeData?.map(\r\n          (item: any) => ({\r\n            fullStoreName: item.storeName, // Full store name\r\n      storeName:  item.storeName, // item.storeName.length > 20 ? item.storeName.slice(0, 20) + '...' : Shortened for xAxis\r\n      value: Number(item.count),\r\n      storeId: item.storeId\r\n          })\r\n        );\r\n        if(this.objDataTraffic.processType === \"conversion\"){\r\n          this.objDataTraffic.processType = this.headerData?.client === '452' ? `More than ${this.featureConfig?.conversion.value} mins ` : 'Conversion'\r\n        } if(this.objDataTraffic.processType === \"engagers\"){\r\n       \r\n          this.objDataTraffic.processType = this.headerData?.client === '452' ? `More than ${this.featureConfig?.bouncedLimit.value} mins` : 'Engagers'\r\n        } if(this.objDataTraffic.processType === \"bounced\"){\r\n          this.footfallValue = \"bounced\";\r\n          this.objDataTraffic.processType = this.headerData?.client === '452' ? `Less than ${this.featureConfig?.bouncedLimit.value} mins` :'Bounced'\r\n        }\r\n         if(this.objDataTraffic.processType === \"missedOpportunity\"){\r\n          this.objDataTraffic.processType = this.headerData?.client === '452' ? `${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins` :'Missed Opportunity' \r\n        } \r\n        // Create series\r\n        this.series = this.chart.series.push(\r\n          am5xy.ColumnSeries.new(this.root, {\r\n            name: \"Series 1\",\r\n            xAxis: xAxis,\r\n            yAxis: yAxis,\r\n            valueYField: \"value\",\r\n            categoryXField: \"storeName\",\r\n            tooltip: am5.Tooltip.new(this.root, {\r\n              labelText: `${(this.objDataTraffic.processType)}, {fullStoreName}: {valueY}`,\r\n            }),\r\n          })\r\n        );\r\n        xAxis.data.setAll(data);\r\n        this.series.columns.template.setAll({ strokeOpacity: 0 });\r\n        this.series.columns.template.events.on(\"click\", (ev: any) => {\r\n          const dataItem = ev.target.dataItem.dataContext;\r\n          this.handleBarClick(dataItem);\r\n        });\r\n  \r\n        this.series.columns.template.setAll({ strokeOpacity: 0 });\r\n  \r\n        this.series.data.setAll(data);\r\n    // Set width for chart container to enable scrolling\r\n    // const totalCount = this.totalCount;\r\n    // const itemWidth = 50; // Width of each item, adjust as needed\r\n    // const minWidth = totalCount * itemWidth; // Calculate total width\r\n    // chartDiv.style.width = `${Math.max(minWidth, 1024)}px`; // Minimum width of 800px\r\n        // Make stuff animate on load\r\n        this.series.appear(1000);\r\n        this.chart.appear(1000, 100);\r\n      }, 0);\r\n    }\r\n  \r\n    capitalizeTitle(text: string): string {\r\n      return text\r\n        .toLowerCase() // Ensure the string is in lowercase first\r\n        .split(' ')    // Split the string into words\r\n        .map(word => word.charAt(0).toUpperCase() + word.slice(1)) // Capitalize the first letter of each word\r\n        .join(' ');    // Join the words back together\r\n    }\r\n    getRangeColor(rate: number): am5.Color {\r\n      let color: am5.Color;\r\n      if (rate >= 0 && rate <= 10) {\r\n        color = am5.color(0xEAF8FF);\r\n      } else if (rate > 10 && rate <= 20) {\r\n        color = am5.color(0xCCE9FE);\r\n      } else if (rate > 20 && rate <= 30) {\r\n        color = am5.color(0xB0D6FC);\r\n      } else if (rate > 30 && rate <= 40) {\r\n        color = am5.color(0x94C2FA);\r\n      } else if (rate > 40 && rate <= 55) {\r\n        color = am5.color(0x78A9F8);\r\n      } else if (rate > 55 && rate <= 75) {\r\n        color = am5.color(0x99D2FD);  \r\n      } else if (rate > 75 && rate <= 90) {\r\n        color = am5.color(0x66BCFD);    \r\n      }  else if (rate > 90 && rate <= 100) {\r\n        color = am5.color(0x3460F3);  \r\n      } else {\r\n        color = am5.color(0xFFF);\r\n      }\r\n      return color;\r\n    }\r\n    initHeatChart() {\r\n      this.chartNoData = false;\r\n      this.chartloading = false;\r\n      setTimeout(() => {\r\n        const chartDiv = document.getElementById(\"heatmapchart\");\r\n        if (!chartDiv) {\r\n          return;\r\n        }\r\n        if (this.root2) {\r\n          this.root2.dispose();\r\n        }\r\n        // Create root element\r\n        this.root2 = am5.Root.new(\"heatmapchart\");\r\n  \r\n        this.root2.container.setAll({\r\n          width: am5.percent(100),\r\n        });\r\n  \r\n        // Set themes\r\n        this.root2.setThemes([\r\n          am5themes_Animated.new(this.root2),\r\n          am5themes_Responsive.new(this.root2),\r\n        ]);\r\n  \r\n        // Create chart\r\n        this.chart2 = this.root2.container.children.push(\r\n          am5xy.XYChart.new(this.root2, {\r\n            panX: false,\r\n            panY: false,\r\n            wheelX: \"none\",\r\n            wheelY: \"none\",\r\n            paddingLeft: 0,\r\n            layout: this.root2.verticalLayout,\r\n          })\r\n        );\r\n  \r\n        // Create axes and their renderers\r\n        const yRenderer = am5xy.AxisRendererY.new(this.root2, {\r\n          minGridDistance: 20,\r\n          inversed: true,\r\n          opposite: true,\r\n          minorGridEnabled: true,\r\n        });\r\n  \r\n        yRenderer.grid.template.set(\"visible\", false);\r\n  \r\n        const yAxis = this.chart2.yAxes.push(\r\n          am5xy.CategoryAxis.new(this.root2, {\r\n            renderer: yRenderer,\r\n            categoryField: \"time\",\r\n          })\r\n        );\r\n  \r\n        const xRenderer = am5xy.AxisRendererX.new(this.root2, {\r\n          minGridDistance: 30,\r\n          opposite: true,\r\n          minorGridEnabled: true,\r\n        });\r\n  \r\n        xRenderer.grid.template.set(\"visible\", false);\r\n  \r\n        const xAxis = this.chart2.xAxes.push(\r\n          am5xy.CategoryAxis.new(this.root2, {\r\n            renderer: xRenderer,\r\n            categoryField: \"weekday\",\r\n          })\r\n        );\r\n  \r\n        // Create series\r\n        this.series2 = this.chart2.series.push(\r\n          am5xy.ColumnSeries.new(this.root2, {\r\n            calculateAggregates: true,\r\n            stroke: am5.color(0xffffff),\r\n            clustered: false,\r\n            xAxis: xAxis,\r\n            yAxis: yAxis,\r\n            categoryXField: \"weekday\",\r\n            categoryYField: \"time\",\r\n            valueField: \"rate\",\r\n          })\r\n        );\r\n        this.series2.columns.template.setAll({\r\n          tooltipText: \"{rate}%\",\r\n          strokeOpacity: 1,\r\n          strokeWidth: 2,\r\n          width: am5.percent(100),\r\n          height: am5.percent(100),\r\n          fill: am5.color(0xffffff), // Default color for columns\r\n        });\r\n        \r\n        // Apply range-based color rules for each data item\r\n        this.series2.columns.template.adapters.add(\"fill\", (fill, target) => {\r\n          const dataItem = target.dataItem?.dataContext as ChartDataItem; // Cast dataContext to ChartDataItem\r\n          if (dataItem && dataItem.rate !== undefined) {\r\n            return this.getRangeColor(dataItem.rate); // Get color based on rate\r\n          }\r\n          return fill;\r\n        });\r\n  \r\n        this.series2.bullets.push(() => {\r\n          return am5.Bullet.new(this.root2, {\r\n            sprite: am5.Label.new(this.root2, {\r\n              text: \"{rate.formatNumber('#.#')}%\",\r\n              fill: am5.color(0x000000),\r\n              centerY: am5.p50,\r\n              centerX: am5.p50,\r\n              populateText: true,\r\n              fontSize: 12, // Reduce font size\r\n            }),\r\n          });\r\n        });\r\n  \r\n        // Set data\r\n        const data = this.getOverallHourlyData?.map((item: any) => ({\r\n          ...item,\r\n          weekday: \"Hourly Data\",\r\n        }));\r\n        this.series2.data.setAll(data);\r\n  \r\n        // Auto-populate X and Y axis category data\r\n        const times: string[] = [];\r\n        am5.array.each(data, function (row: any) {\r\n          if (times.indexOf(row.time) === -1) {\r\n            times.push(row.time);\r\n          }\r\n        });\r\n  \r\n        xAxis.data.setAll([{ weekday: \"Hourly Data\" }]); // Set single category for x-axis\r\n        yAxis.data.setAll(\r\n          times.map(function (item) {\r\n            return { time: item };\r\n          })\r\n        );\r\n  \r\n        this.chart2.appear(1000, 100);\r\n      }, 0);\r\n    }\r\n  \r\n    onDatasetChange(event: any): void {\r\n      this.detailedCharts = false;\r\n      // const target = event.target as HTMLSelectElement;\r\n      this.footfallValue = event;\r\n      if (this.footfallValue === \"footfall\" ||  this.footfallValue === \"conversion\"\r\n        ||  this.footfallValue === \"engagers\" ||  this.footfallValue === \"bounced\"\r\n        ||  this.footfallValue === \"potentialBuyer\" ||  this.footfallValue === \"missedOpportunity\") {\r\n        if (this.root) {\r\n          this.root.dispose();\r\n        }\r\n        this.overallHourlyChart();\r\n        this.overallChart();\r\n      } else if (this.footfallValue === \"demographic\") {\r\n        // Dispose of any previous charts to avoid duplicates\r\n        if (this.demoGraphicsroot) {\r\n          this.demoGraphicsroot.dispose();\r\n        }\r\n        this.getDemoGraphics();\r\n      } \r\n      else if (this.footfallValue === \"buyer\") {\r\n        // Dispose of any previous charts to avoid duplicates\r\n        if (this.buyersroot) {\r\n          this.buyersroot.dispose();\r\n        }\r\n        this.getBuyers();\r\n      } \r\n      this.cd.detectChanges();\r\n    }\r\n  \r\n   backToFootfall() {\r\n    this.objDataTraffic.limit =20,\r\n     this.objDataTraffic.storeId = this.headerData.stores.filter((store:any) => store.checked).map((store:any) => store.storeId),\r\n     this.detailedCharts = false;\r\n     this.overallHourlyChart();\r\n     this.overallChart();\r\n   }\r\n \r\n   getDemoGraphics(){\r\n     delete this.objDataTraffic.limit;\r\n     delete this.objDataTraffic.offset;\r\n     this.demoNoData =false;\r\n     this.demoloading = true;\r\n     this.service\r\n     .getDemoGraphicsChart(this.objDataTraffic)\r\n     .pipe(takeUntil(this.destroy$))\r\n     ?.subscribe({\r\n       next: (res: any) => {\r\n         if (res && res.code === 200) {\r\n           this.demoGraphicsData = res?.data.demographicData;\r\n           \r\n           this.demoGraphicsChart();\r\n           this.cd.detectChanges(); \r\n           // Call with a delay to ensure the element is in the DOM\r\n            this.demoNoData =false;\r\n            this.demoloading = false;\r\n         } else {\r\n           this.demoNoData =true;\r\n           this.demoloading = false;\r\n         }\r\n       },\r\n       error: (err: any) => {\r\n         this.cd.detectChanges();\r\n       },\r\n       complete: () => {},\r\n     });\r\n     \r\n   }\r\n   demoGraphicsChart(): void {\r\n     this.chartNoData = false;\r\n     this.chartloading = false;\r\n     this.demoNoData =false;\r\n     this.demoloading = false;\r\n     setTimeout(() => {\r\n       const demoGraphicsDiv = document.getElementById(\"demoGraphics\");\r\n       if (!demoGraphicsDiv) {\r\n         return;\r\n       }\r\n       // Dispose of previous chart if it exists\r\n       if (this.demoGraphicsroot) {\r\n         this.demoGraphicsroot.dispose();\r\n       }\r\n \r\n       // Create a new chart\r\n       this.demoGraphicsroot = am5.Root.new(demoGraphicsDiv);\r\n       this.demoGraphicsroot.setThemes([\r\n         am5themes_Animated.new(this.demoGraphicsroot),\r\n       ]);\r\n \r\n       this.demoGraphicsChartInstance =\r\n         this.demoGraphicsroot.container.children.push(\r\n           am5xy.XYChart.new(this.demoGraphicsroot, {\r\n             panX: false,\r\n             panY: false,\r\n             paddingLeft: 0,\r\n             wheelX: \"panX\",\r\n             wheelY: \"zoomX\",\r\n             layout: this.demoGraphicsroot.verticalLayout,\r\n           })\r\n         );\r\n \r\n       let xRenderer = am5xy.AxisRendererX.new(this.demoGraphicsroot, {\r\n         cellStartLocation: 0.1,\r\n         cellEndLocation: 0.9,\r\n         minorGridEnabled: true,\r\n       });\r\n \r\n       let xAxis = this.demoGraphicsChartInstance.xAxes.push(\r\n         am5xy.CategoryAxis.new(this.demoGraphicsroot, {\r\n           categoryField: \"age\",\r\n           renderer: xRenderer,\r\n           tooltip: am5.Tooltip.new(this.demoGraphicsroot, {}),\r\n         })\r\n       );\r\n       this.demoGraphicsData = this.demoGraphicsData?.map(\r\n         (item: any) => ({\r\n           age: item.age,\r\n           count: Number(item.count),\r\n           maleCount: Number(item.maleCount),\r\n           femaleCount: Number(item.femaleCount),\r\n         })\r\n       );\r\n       xRenderer.grid.template.setAll({ location: 1 });\r\n       xAxis.data.setAll(this.demoGraphicsData);\r\n \r\n       let yAxis = this.demoGraphicsChartInstance.yAxes.push(\r\n         am5xy.ValueAxis.new(this.demoGraphicsroot, {\r\n           renderer: am5xy.AxisRendererY.new(this.demoGraphicsroot, {\r\n             strokeOpacity: 0.1,\r\n           }),\r\n         })\r\n       );\r\n      // Add legend\r\n     let legend = this.demoGraphicsChartInstance.children.push(\r\n       am5.Legend.new(this.demoGraphicsroot, {\r\n         x: am5.p100,    // Align to 100% width (right side)\r\n         y: am5.p0,      // Align to the top\r\n         centerX: am5.p100,  // Align the center of the legend to its right\r\n         centerY: am5.p0,    // Align the top of the legend to the top of the chart\r\n       })\r\n     );\r\n \r\n     // Create the series and add each to the legend\r\n     const maleSeries = this.makeSeries(\"Male\", \"maleCount\", xAxis, yAxis);\r\n     const femaleSeries = this.makeSeries(\"Female\", \"femaleCount\", xAxis, yAxis);\r\n \r\n     legend.data.setAll([maleSeries, femaleSeries]);\r\n       this.demoGraphicsChartInstance.appear(1000, 100);\r\n \r\n     },\r\n            0);\r\n \r\n   }\r\n   makeSeries(\r\n     name: any,\r\n     fieldName: any,\r\n     xAxis: am5xy.CategoryAxis<am5xy.AxisRenderer>,\r\n     yAxis: am5xy.ValueAxis<am5xy.AxisRenderer>\r\n   ) {\r\n     let series = this.demoGraphicsChartInstance.series.push(\r\n       am5xy.ColumnSeries.new(this.demoGraphicsroot, {\r\n         name: name,\r\n         xAxis: xAxis,\r\n         yAxis: yAxis,\r\n         valueYField: fieldName,\r\n         categoryXField: \"age\",\r\n       })\r\n     );\r\n   \r\n     series.columns.template.setAll({\r\n       tooltipText: \"{name}, {categoryX}: {valueY}\",\r\n       width: am5.percent(90),\r\n       tooltipY: 0,\r\n       strokeOpacity: 0,\r\n     });\r\n   \r\n     series.data.setAll(this.demoGraphicsData);\r\n     series.appear();\r\n   \r\n     return series;  // Return the series to add it to the legend\r\n   }\r\n   getBuyers(){\r\n     delete this.objDataTraffic.limit;\r\n     delete this.objDataTraffic.offset;\r\n     this.buyersloading = true;\r\n     this.buyersNoData =false;\r\n     this.service\r\n     .getBuyersChart(this.objDataTraffic)\r\n     .pipe(takeUntil(this.destroy$))\r\n     ?.subscribe({\r\n       next: (res: any) => {\r\n         if (res && res.code === 200) {\r\n           this.buyersData = res?.data.buyerData;\r\n          \r\n          this.getBuyersChart(); // Call with a delay to ensure the element is in the DOM\r\n          this.cd.detectChanges(); \r\n          this.buyersNoData =false;\r\n          this.buyersloading = false;\r\n         } else{\r\n           this.buyersloading = false;\r\n           this.buyersNoData =true;\r\n         }\r\n       },\r\n       error: (err: any) => {\r\n         this.cd.detectChanges();\r\n       },\r\n       complete: () => {},\r\n     });\r\n   }\r\n   getBuyersChart(): void {\r\n     this.chartNoData = false;\r\n     this.chartloading = false;\r\n     this.buyersNoData =false;\r\n     this.buyersloading = false;\r\n     setTimeout(() => {\r\n     const buyersDiv = document.getElementById(\"buyersCharts\");\r\n     if (!buyersDiv) {\r\n       return;\r\n     }\r\n \r\n     // Dispose of previous chart if it exists\r\n     if (this.buyersroot) {\r\n       this.buyersroot.dispose();\r\n     }\r\n \r\n     // Create a new chart\r\n     this.buyersroot = am5.Root.new(buyersDiv);\r\n     this.buyersroot.setThemes([\r\n       am5themes_Animated.new(this.buyersroot),\r\n     ]);\r\n \r\n     this.buyersChartInstance =\r\n       this.buyersroot.container.children.push(\r\n         am5xy.XYChart.new(this.buyersroot, {\r\n           panX: false,\r\n           panY: false,\r\n           paddingLeft: 0,\r\n           wheelX: \"panX\",\r\n           wheelY: \"zoomX\",\r\n           layout: this.buyersroot.verticalLayout,\r\n         })\r\n       );\r\n \r\n     let xRenderer = am5xy.AxisRendererX.new(this.buyersroot, {\r\n       cellStartLocation: 0.1,\r\n       cellEndLocation: 0.9,\r\n       minorGridEnabled: true,\r\n     });\r\n \r\n     let xAxis = this.buyersChartInstance.xAxes.push(\r\n       am5xy.CategoryAxis.new(this.buyersroot, {\r\n         categoryField: \"age\",\r\n         renderer: xRenderer,\r\n         tooltip: am5.Tooltip.new(this.buyersroot, {}),\r\n       })\r\n     );\r\n     this.buyersData = this.buyersData?.map(\r\n       (item: any) => ({\r\n         age: item.age,\r\n         singleCount: Number(item.singleCount),\r\n         groupCount: Number(item.groupCount),\r\n       })\r\n     );\r\n     xRenderer.grid.template.setAll({ location: 1 });\r\n     xAxis.data.setAll(this.buyersData);\r\n \r\n     let yAxis = this.buyersChartInstance.yAxes.push(\r\n       am5xy.ValueAxis.new(this.buyersroot, {\r\n         renderer: am5xy.AxisRendererY.new(this.buyersroot, {\r\n           strokeOpacity: 0.1,\r\n         }),\r\n       })\r\n     );\r\n     let legend = this.buyersChartInstance.children.push(\r\n       am5.Legend.new(this.buyersroot, {\r\n         x: am5.p100,    // Align to 100% width (right side)\r\n     y: am5.p0,      // Align to the top\r\n     centerX: am5.p100,  // Align the center of the legend to its right\r\n     centerY: am5.p0,    // Align the top of the legend to the top of the chart\r\n       })\r\n     );\r\n     \r\n   const singleCount =  this.getBuyerSeries(\"Single\", \"singleCount\", xAxis, yAxis);\r\n   const groupCount =  this.getBuyerSeries(\"Group\", \"groupCount\", xAxis, yAxis);\r\n     legend.data.setAll([singleCount, groupCount]);\r\n     this.buyersChartInstance.appear(1000, 100);\r\n   },0);\r\n }\r\n getBuyerSeries(\r\n   name: string,\r\n   fieldName: string,\r\n   xAxis: am5xy.CategoryAxis<am5xy.AxisRenderer>,\r\n   yAxis: am5xy.ValueAxis<am5xy.AxisRenderer>\r\n ) {\r\n   let series = this.buyersChartInstance.series.push(\r\n     am5xy.ColumnSeries.new(this.buyersroot, {\r\n       name: name,\r\n       xAxis: xAxis,\r\n       yAxis: yAxis,\r\n       valueYField: fieldName,\r\n       categoryXField: \"age\",  // Assuming \"age\" is the category field\r\n     })\r\n   );\r\n \r\n   series.columns.template.setAll({\r\n     tooltipText: \"{name}: {valueY}\",\r\n     width: am5.percent(90),\r\n     tooltipY: 0,\r\n     strokeOpacity: 0,\r\n   });\r\n \r\n   series.data.setAll(this.buyersData);  // Assuming you have buyersData\r\n \r\n   return series;  // Return the series for legend\r\n \r\n }\r\n objDataTraffic:any={};\r\n    overallCard() {\r\n      (this.objDataTraffic.limit = 10), (this.objDataTraffic.offset = 0);\r\n      (this.objDataTraffic.conversiontype = this.tableobj.conversiontype);\r\n      delete this.objDataTraffic.normalizedData;\r\n      delete this.objDataTraffic.revenue;\r\n      delete this.objDataTraffic.hourFormat;\r\n      delete this.objDataTraffic.dateRange;\r\n      this.service\r\n        .getOverallCards(this.objDataTraffic)\r\n        .pipe(takeUntil(this.destroy$))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res.code === 200) {\r\n              this.getOverallCardData = res?.data;\r\n            }\r\n          },\r\n          error: (err: any) => {\r\n            this.cd.detectChanges();\r\n          },\r\n          complete: () => {},\r\n        });\r\n    }\r\n  \r\n    overallHourlyChart() {\r\n      this.chartNoData = false;\r\n      this.chartloading = true;\r\n      (this.objDataTraffic.limit = 10), (this.objDataTraffic.offset = 0);\r\n      delete this.objDataTraffic.normalizedData;\r\n      delete this.objDataTraffic.revenue;\r\n  delete this.objDataTraffic.hourFormat\r\n      delete this.objDataTraffic.dateRange;\r\n      this.service\r\n        .getOverallHourlyChart(this.objDataTraffic)\r\n        .pipe(takeUntil(this.destroy$))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res.code === 200) {\r\n              this.chartNoData = false;\r\n              this.chartloading = false;\r\n              this.getOverallHourlyData = res?.data?.hourlyData;\r\n              this.initHeatChart();\r\n              this.cd.detectChanges();\r\n            } else {\r\n              this.chartNoData = true;\r\n              this.chartloading = false;\r\n            }\r\n          },\r\n          error: (err: any) => {\r\n            this.cd.detectChanges();\r\n          },\r\n          complete: () => {},\r\n        });\r\n    }\r\n    overallChart() {\r\n      this.offsetTrafficCard =0;\r\n      this.limitTrafficCard =20;\r\n      this.chartNoData = false;\r\n      this.chartloading = true;\r\n      (this.objDataTraffic.limit = 20), (this.objDataTraffic.offset = 0);\r\n      delete this.objDataTraffic.normalizedData;\r\n      delete this.objDataTraffic.revenue;\r\n      delete this.objDataTraffic.hourFormat;\r\n      delete this.objDataTraffic.dateRange;\r\n      this.service\r\n        .getOverallChart(this.objDataTraffic)\r\n        .pipe(takeUntil(this.destroy$),debounceTime(300))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res.code === 200) {\r\n              this.getOverallChartData = res?.data;\r\n              this.totalItemsTrafficCard = res.data.totalCount\r\n              this.chartNoData = false;\r\n              this.chartloading = false;\r\n              this.initChart();\r\n        this.setPaginationSizesTrafficCard();\r\n              this.cd.detectChanges();\r\n            } else {\r\n              this.chartNoData = true;\r\n              this.chartloading = false;\r\n            }\r\n          },\r\n          error: (err: any) => {\r\n            this.cd.detectChanges();\r\n          },\r\n          complete: () => {},\r\n        });\r\n    }\r\n    setPaginationSizesTrafficCard() {\r\n      if (this.totalItemsTrafficCard > 20) {\r\n        this.paginationSizesTrafficCard = [20];\r\n      } else {\r\n        this.paginationSizesTrafficCard = [this.totalItemsTrafficCard]; // Just one option if less than 10\r\n      }\r\n      this.pageSizeTrafficCard = this.paginationSizesTrafficCard[0];\r\n    }\r\n    onPageChangeTrafficCard(pageOffset: number) {\r\n      this.offsetTrafficCard = Number(pageOffset);\r\n      this.objDataTraffic.offset = this.offsetTrafficCard -1;\r\n      this.objDataTraffic.limit = this.limitTrafficCard;\r\n      delete this.objDataTraffic.normalizedData;\r\n      delete this.objDataTraffic.revenue;\r\n      delete this.objDataTraffic.hourFormat;\r\n      delete this.objDataTraffic.dateRange;\r\n      this.service\r\n      .getOverallChart(this.objDataTraffic)\r\n      .pipe(takeUntil(this.destroy$),debounceTime(300))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getOverallChartData = res?.data;\r\n            this.totalItemsTrafficCard = res.data.totalCount\r\n            this.chartNoData = false;\r\n            this.chartloading = false;\r\n            this.initChart();\r\n            this.cd.detectChanges();\r\n          } else {\r\n            this.chartNoData = true;\r\n            this.chartloading = false;\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.cd.detectChanges();\r\n        },\r\n        complete: () => {},\r\n      });\r\n    }\r\n  \r\n    onPageSizeChangeTrafficCard(pageSize: number) {\r\n      this.pageSizeTrafficCard = Number(pageSize);\r\n      this.limitTrafficCard = Number(pageSize);\r\n      this.currentPageTrafficCard = 1;\r\n      this.offsetTrafficCard = 0;\r\n      this.objDataTraffic.offset = this.offsetTrafficCard;\r\n      this.objDataTraffic.limit = this.limitTrafficCard;\r\n      this.overallChart();\r\n    }\r\n\r\n    trafficHeatChart() {\r\n      this.chartNoData = false;\r\n      this.chartloading = false;\r\n    \r\n      setTimeout(() => {\r\n        const chartDiv = document.getElementById(\"trafficHeatmapChart\");\r\n        if (!chartDiv) {\r\n          return;\r\n        }\r\n    \r\n        // Dispose of the previous chart instance if it exists\r\n        if (this.heatMapRoot) {\r\n          this.heatMapRoot.dispose();\r\n        }\r\n    \r\n        // Initialize the chart root\r\n        this.heatMapRoot = am5.Root.new(\"trafficHeatmapChart\");\r\n        this.heatMapRoot.container.setAll({\r\n          width: am5.percent(100),\r\n        });\r\n    \r\n        // Apply themes\r\n        this.heatMapRoot.setThemes([\r\n          am5themes_Animated.new(this.heatMapRoot),\r\n          am5themes_Responsive.new(this.heatMapRoot),\r\n        ]);\r\n    \r\n        // Create the chart\r\n        this.heatMapChart = this.heatMapRoot.container.children.push(\r\n          am5xy.XYChart.new(this.heatMapRoot, {\r\n            panX: false,\r\n            panY: false,\r\n            wheelX: \"none\",\r\n            wheelY: \"none\",\r\n            paddingLeft: 0,\r\n            layout: this.heatMapRoot.verticalLayout,\r\n          })\r\n        );\r\n    \r\n        // Create Y-axis\r\n        const yRenderer = am5xy.AxisRendererY.new(this.heatMapRoot, {\r\n          visible: false,\r\n          minGridDistance: 30,\r\n          inversed: true,\r\n          minorGridEnabled: true,\r\n        });\r\n        yRenderer.grid.template.set(\"visible\", false);\r\n    \r\n        const yAxis = this.heatMapChart.yAxes.push(\r\n          am5xy.CategoryAxis.new(this.heatMapRoot, {\r\n            maxDeviation: 0,\r\n            renderer: yRenderer,\r\n            categoryField: \"hour\",\r\n          })\r\n        );\r\n    \r\n        // Create X-axis\r\n        const xRenderer = am5xy.AxisRendererX.new(this.heatMapRoot, {\r\n          visible: false,\r\n          minGridDistance: 30,\r\n          minorGridEnabled: true,\r\n        });\r\n        xRenderer.grid.template.set(\"visible\", false);\r\n    \r\n        const xAxis = this.heatMapChart.xAxes.push(\r\n          am5xy.CategoryAxis.new(this.heatMapRoot, {\r\n            renderer: xRenderer,\r\n            categoryField: \"weekday\",\r\n          })\r\n        );\r\n    \r\n        // Add Y-axis label\r\n        yAxis.children.unshift(\r\n          am5.Label.new(this.heatMapRoot, {\r\n            rotation: -90,\r\n            text: \"Hours\",\r\n            y: am5.p50,\r\n            centerX: am5.p50,\r\n            fontFamily: \"Arial\",\r\n            fontSize: \"14px\",\r\n            fill: am5.color(0x000000),\r\n          })\r\n        );\r\n    \r\n        // Create series\r\n        this.heatMapSeries = this.heatMapChart.series.push(\r\n          am5xy.ColumnSeries.new(this.heatMapRoot, {\r\n            calculateAggregates: true,\r\n            stroke: am5.color(0xffffff),\r\n            clustered: false,\r\n            xAxis: xAxis,\r\n            yAxis: yAxis,\r\n            categoryXField: \"weekday\",\r\n            categoryYField: \"hour\",\r\n            valueField: \"value\",\r\n          })\r\n        );\r\n        \r\n        // Configure column appearance\r\n        this.heatMapSeries.columns.template.setAll({\r\n          tooltipText: \"{value}\",\r\n          strokeOpacity: 1,\r\n          strokeWidth: 2,\r\n          width: am5.percent(100),\r\n          height: am5.percent(100),\r\n        });\r\n\r\n        this.heatMapSeries.columns.template.adapters.add(\"fill\", (fill, target) => {\r\n          const dataItem = target.dataItem?.dataContext as { value: number };\r\n          return dataItem && dataItem.value !== undefined ? this.getRangeColorDynamic(dataItem.value) : fill;\r\n        });\r\n    \r\n        // Set column color based on value\r\n            // this.heatMapSeries.columns.template.adapters.add(\"fill\", (fill, target) => {\r\n            //   const dataItem = target.dataItem?.dataContext as { value: number };\r\n            //   return dataItem && dataItem.value !== undefined ? this.getRangeColor1(dataItem.value) : fill;\r\n            // });\r\n        \r\n    \r\n        // Add bullet for value labels\r\n        this.heatMapSeries.bullets.push(() => {\r\n          return am5.Bullet.new(this.heatMapRoot, {\r\n            sprite: am5.Label.new(this.heatMapRoot, {\r\n              text: \"{value}\",\r\n              fill: am5.color(0x000000),\r\n              centerY: am5.p50,\r\n              centerX: am5.p50,\r\n              populateText: true,\r\n              fontSize: 12,\r\n            }),\r\n          });\r\n        });\r\n    \r\n        // Prepare and sort data for the chart\r\n        const heatMapData: any[] = [];\r\n        if (this.getFootfallDensityDwellData && this.getFootfallDensityDwellData.trafficDensity) {\r\n          Object.keys(this.getFootfallDensityDwellData.trafficDensity).forEach(hour => {\r\n            this.getFootfallDensityDwellData.trafficDensity[hour].forEach((dayData: any) => {\r\n              heatMapData.push({\r\n                hour: dayData.time,\r\n                weekday: dayData.day,\r\n                value: parseInt(dayData.footfallCount, 10), // Ensure integer parsing\r\n              });\r\n            });\r\n          });\r\n        } else {\r\n          console.error(\"Traffic density data is undefined or null.\");\r\n        }\r\n        \r\n        // Set data to the series\r\n        this.heatMapSeries.data.setAll(heatMapData);\r\n\r\n        const visibleValues = this.heatMapSeries.data.values.map((d:any) => d.value);\r\n\r\n        this.maxFootfall = Math.max(...visibleValues);\r\n        this.minFootfall = Math.min(...visibleValues);\r\n\r\n        // Extract unique weekdays and hours, sorted\r\n        const weekdays: string[] = Array.from(new Set(heatMapData.map(row => row.weekday)));\r\n        const hours: string[] = Array.from(new Set(heatMapData.map(row => row.hour)))\r\n          .sort((a, b) => a.localeCompare(b));\r\n    \r\n        // Set axis data\r\n        xAxis.data.setAll(\r\n          weekdays.map(item => ({ weekday: item }))\r\n        );\r\n    \r\n        yAxis.data.setAll(\r\n          hours.map(item => ({ hour: item }))\r\n        );\r\n    \r\n        // Finalize chart appearance\r\n        this.heatMapChart.appear(1000, 100);\r\n    \r\n        // Ensure the root is assigned correctly\r\n        this.heatMapRoot = this.heatMapRoot;\r\n    \r\n      }, 0);\r\n  }\r\n  \r\n\r\n  getRangeColorDynamic(footfallCount: number): am5.Color {\r\n    let minFootfall = this.minFootfall ?? 0;\r\n    let maxFootfall = this.maxFootfall ?? 1;\r\n  \r\n    if (maxFootfall === minFootfall) return am5.color(0x008edf); // Prevent division by zero\r\n    const normalizedValue = (footfallCount - minFootfall) / (maxFootfall - minFootfall);\r\n    const clampedValue = Math.min(Math.max(normalizedValue, 0), 0.5);\r\n    const adjustedValue = Math.pow(clampedValue, 0.5);  // Increase power to darken faster\r\n    const baseColor = am5.color(0x008edf);  // Starting color (light blue)\r\n    const adjustedColor = am5.Color.lighten(baseColor, 1 - adjustedValue);\r\n    return adjustedColor;\r\n  }\r\n\r\n\r\n    getRangeColor1(footfallCount: number): am5.Color {\r\n      let maxFootfall:any;\r\n      const minFootfall = 0;  // minimum expected footfall\r\n      if(this.objDataTraffic.dateRange =30)\r\n      maxFootfall = 3500;\r\n    else \r\n    maxFootfall = 750;\r\n      const normalizedValue = (footfallCount - minFootfall) / (maxFootfall - minFootfall);\r\n      const clampedValue = Math.min(Math.max(normalizedValue, 0), 0.5);\r\n      const adjustedValue = Math.pow(clampedValue, 0.5);  // Increase power to darken faster\r\n      const baseColor = am5.color(0x008edf);  // Starting color (light blue)\r\n      const adjustedColor = am5.Color.lighten(baseColor, 1 - adjustedValue);\r\n      return adjustedColor;\r\n    }\r\n    \r\n    \r\n      getDwellChart() {\r\n        this.chartDwellNoData = false;\r\n      this.chartDwellloading = true;\r\n        setTimeout(() => {\r\n          const chartDiv = document.getElementById(\"dwellBarChart\");\r\n          if (!chartDiv) {\r\n            return;\r\n          }\r\n          if (this.dwellRoot) {\r\n            this.dwellRoot.dispose();\r\n          }\r\n          // Create root element\r\n          this.dwellRoot = am5.Root.new(\"dwellBarChart\");\r\n    \r\n          // Set themes\r\n          this.dwellRoot.setThemes([am5themes_Animated.new(this.dwellRoot)]);\r\n    \r\n          // Create chart\r\n          this.dwellChart = this.dwellRoot.container.children.push(\r\n            am5xy.XYChart.new(this.dwellRoot, {\r\n              panX: false,\r\n              panY: false,\r\n              wheelX: \"panX\",\r\n              wheelY: \"zoomX\",\r\n              paddingLeft: 0,\r\n              layout: this.dwellRoot.verticalLayout,\r\n            })\r\n          );\r\n    \r\n         let data = this.getDensityDwellData.dwellTimeSplit?.map(\r\n            (item: any) => ({\r\n              year: (item.dwell_time) + \" Mins\",\r\n              maleCount: Number(item.maleCount_value),\r\n              maleCustom: Number(item.maleCount),\r\n              femaleCount: Number(item.femaleCount_value),\r\n              femaleCustom: Number(item.femaleCount)\r\n            })\r\n          );\r\n              \r\n          // Create axes\r\n          let xRenderer = am5xy.AxisRendererX.new(this.dwellRoot, {\r\n            minGridDistance: 30,\r\n            minorGridEnabled: true,\r\n          });\r\n          let xAxis = this.dwellChart.xAxes.push(\r\n            am5xy.CategoryAxis.new(this.dwellRoot, {\r\n              categoryField: \"year\",\r\n              renderer: xRenderer,\r\n              tooltip: am5.Tooltip.new(this.dwellRoot, {}),\r\n            })\r\n          );\r\n    \r\n          xRenderer.grid.template.setAll({\r\n            location: 1,\r\n          });\r\n    \r\n          xAxis.data?.setAll(data);\r\n    \r\n          let yAxis = this.dwellChart.yAxes.push(\r\n            am5xy.ValueAxis.new(this.dwellRoot, {\r\n              min: 0,\r\n              renderer: am5xy.AxisRendererY.new(this.dwellRoot, {\r\n                strokeOpacity: 0.1,\r\n              }),\r\n            })\r\n          );\r\n    \r\n          // Add legend\r\n          let legend = this.dwellChart.children.push(\r\n            am5.Legend.new(this.dwellRoot, {\r\n              centerX: am5.p50,\r\n              x: am5.p50,\r\n            })\r\n          );\r\n    \r\n          // Add series\r\n          // const \r\n         \r\n          this.makeSeries1(\"Male\", \"maleCount\", xAxis, yAxis, data, legend);\r\n          this.makeSeries1(\"Female\", \"femaleCount\", xAxis, yAxis, data, legend);\r\n          // Make stuff animate on load\r\n          this.dwellChart.appear(1000, 100);\r\n        }, 100);\r\n      }\r\n      makeSeries1(name: string, fieldName: string, xAxis: any, yAxis: any, data: any, legend: any) {\r\n        let series = this.dwellChart.series.push(\r\n          am5xy.ColumnSeries.new(this.dwellRoot, {\r\n            name: name,\r\n            stacked: true,\r\n            xAxis: xAxis,\r\n            yAxis: yAxis,\r\n            valueYField: fieldName,\r\n            categoryXField: \"year\",\r\n          })\r\n        );\r\n      \r\n        series.columns.template.setAll({\r\n          tooltipText: `[bold]{name}[/]\\n{categoryX},\\nFootfall %: {customValue}%`,\r\n          tooltipY: am5.percent(10),\r\n        });\r\n      \r\n        if (data?.length) {\r\n          const enhancedData = data.map((d: any) => ({\r\n            ...d,\r\n            customValue: d[fieldName === \"maleCount\" ? \"maleCustom\" : \"femaleCustom\"]\r\n          }));\r\n          series.data.setAll(enhancedData);\r\n        }\r\n      \r\n        series.bullets.push(() => {\r\n          let label = am5.Label.new(this.dwellRoot, {\r\n            text: \"{valueY}\",\r\n            fill: this.dwellRoot.interfaceColors.get(\"alternativeText\"),\r\n            centerY: am5.p50,\r\n            centerX: am5.p50,\r\n            populateText: true,\r\n          });\r\n      \r\n          label.adapters.add(\"visible\", (visible, target) => {\r\n            const value = (target.dataItem?.dataContext as any)?.[fieldName];\r\n            return value !== 0;\r\n          });\r\n      \r\n          return am5.Bullet.new(this.dwellRoot, {\r\n            sprite: label,\r\n          });\r\n        });\r\n      \r\n        if (legend) {\r\n          legend.data.push(series);\r\n        }\r\n      }\r\n      \r\n      \r\n      \r\n      storeName:any;\r\n      storeId:any;\r\n      formatDate(dateString: string): string {\r\n        return this.dayjs(dateString).format('DD MMM');  // Output: '01 Jan'\r\n      }\r\n        handleBarClick(dataItem: any): void {\r\n          this.storeName = dataItem.fullStoreName;\r\n          this.storeId = dataItem.storeId\r\n          this.objDataTraffic.storeId =[dataItem.storeId],\r\n          this.objDataTraffic.limit =31,\r\n          this.service\r\n            .getSingleStoreChart(this.objDataTraffic)\r\n            .pipe(takeUntil(this.destroy$))\r\n            ?.subscribe({\r\n              next: (res: any) => {\r\n                if (res && res.code === 200) {\r\n                  this.getSingleChartData = res?.data.storeData;\r\n                  this.detailedCharts = true;\r\n                  this.cd.detectChanges(); \r\n                  setTimeout(() => this.getSingleStore(), 0); // Call with a delay to ensure the element is in the DOM\r\n                }\r\n              },\r\n              error: (err: any) => {\r\n                this.cd.detectChanges();\r\n              },\r\n              complete: () => {},\r\n            });\r\n            \r\n        }\r\n\r\n        getSingleStore(){\r\n            const chartDiv = document.getElementById(\"detailedChartDiv\");\r\n            if (!chartDiv) {\r\n              return;\r\n            }\r\n        \r\n            if (this.detailedRoot) {\r\n              this.detailedRoot.dispose();\r\n            }\r\n          \r\n            this.detailedRoot = am5.Root.new(\"detailedChartDiv\");\r\n            this.detailedRoot.setThemes([\r\n              am5themes_Animated.new(this.detailedRoot),\r\n            ]);\r\n        \r\n            this.detailedChart = this.detailedRoot.container.children.push(\r\n              am5xy.XYChart.new(this.detailedRoot, {\r\n                panX: false,\r\n                panY: false,\r\n                wheelX: \"panX\",\r\n                wheelY: \"zoomX\",\r\n                paddingLeft: 0,\r\n              })\r\n            );\r\n        \r\n            // Add cursor\r\n            let cursor = this.detailedChart.set(\r\n              \"cursor\",\r\n              am5xy.XYCursor.new(this.detailedRoot, {})\r\n            );\r\n            cursor.lineY.set(\"visible\", false);\r\n        \r\n            // Create axes\r\n            let xRenderer = am5xy.AxisRendererX.new(this.detailedRoot, {\r\n              minGridDistance: 30,\r\n              minorGridEnabled: true,\r\n            });\r\n        \r\n            xRenderer.labels.template.setAll({\r\n              rotation: -90,\r\n              centerY: am5.p50,\r\n              centerX: am5.p100,\r\n              paddingRight: 15,\r\n            });\r\n        \r\n            xRenderer.grid.template.setAll({\r\n              location: 1,\r\n            });\r\n            // Add scrollbar\r\n            this.detailedChart.set(\r\n              \"scrollbarX\",\r\n              am5.Scrollbar.new(this.detailedRoot, {\r\n                orientation: \"horizontal\",\r\n              })\r\n            );\r\n            let xAxis = this.detailedChart.xAxes.push(\r\n              am5xy.CategoryAxis.new(this.detailedRoot, {\r\n                maxDeviation: 0.3,\r\n                categoryField: \"date\",\r\n                renderer: xRenderer,\r\n                tooltip: am5.Tooltip.new(this.detailedRoot, {}),\r\n              })\r\n            );\r\n        \r\n            let yRenderer = am5xy.AxisRendererY.new(this.detailedRoot, {\r\n              strokeOpacity: 0.1,\r\n            });\r\n        \r\n            let yAxis = this.detailedChart.yAxes.push(\r\n              am5xy.ValueAxis.new(this.detailedRoot, {\r\n                maxDeviation: 0.3,\r\n                renderer: yRenderer,\r\n              })\r\n            );\r\n            \r\n            let data = this.getSingleChartData.map((item: any) => ({\r\n              date: this.formatDate(item.date), // Convert date string to timestamp\r\n              value: Number(item.count), // Use `count` as `value`\r\n            }));\r\n            data.sort((a: any, b: any) => {\r\n              // Parse storeName as a Date and compare\r\n              const dateA = new Date(a.date);\r\n              const dateB = new Date(b.date);\r\n              \r\n              // Sort in ascending order (oldest to newest)\r\n              return dateA.getTime() - dateB.getTime();\r\n            });\r\n            // Create series\r\n            this.detailedSeries = this.detailedChart.series.push(\r\n              am5xy.ColumnSeries.new(this.detailedRoot, {\r\n                name: \"Series 2\",\r\n                xAxis: xAxis,\r\n                yAxis: yAxis,\r\n                valueYField: \"value\",\r\n                sequencedInterpolation: true,\r\n                categoryXField: \"date\",\r\n                tooltip: am5.Tooltip.new(this.detailedRoot, {\r\n                  labelText: \"{valueY}\",\r\n                }),\r\n              })\r\n            );\r\n            this.detailedSeries.columns.template.setAll({ strokeOpacity: 0 });\r\n            xAxis.data.setAll(data);\r\n            this.detailedSeries.data.setAll(data);\r\n            this.detailedSeries.appear(1000);\r\n            this.detailedChart.appear(1000, 100);\r\n        }\r\n\r\n        forecastApi(evt:any){\r\n          if(evt.target.checked){\r\n            this.objData.forecast = true\r\n            this.objData.normalize = false\r\n            this.objData.nob = false\r\n            this.objData.filterBy = 'average'\r\n          } else {\r\n            this.objData.forecast = false\r\n            this.objData.normalize = this.clientData?.featureConfigs?.isNormalized\r\n            this.objData.nob = false\r\n            this.objData.filterBy = 'average'\r\n          }\r\n          this.footfallTrend();\r\n        }\r\n        \r\n\r\n        toggleNormalize(evt:any){\r\n          this.normalize =evt.target.checked;\r\n          this.tableobj.normalize = this.normalize\r\n          this.objData.normalize = this.normalize\r\n          this.objDataTraffic.normalize = this.normalize\r\n          // this.tableobj.forecast = false\r\n          this.objData.forecast = false;\r\n          this.forecast =false;\r\n          // this.objDataTraffic.forecast = false\r\n          this.conversionValue = this.nob\r\n              ? \"NoB Derived\"\r\n              : this.clientData?.featureConfigs\r\n                  ?.missedOpportunityCalculation === 'engagers-conversion'\r\n              ? \"engagers\"\r\n              : \"footfall\";\r\n          this.getFunnal();\r\n          this.getFootfallCard();\r\n          this.getConversionCard();\r\n          this.getBouncedCard();\r\n          this.getEngagersCard();\r\n          this.getPotentialBuyersCard();\r\n          this.getMissedOpportunityCard();\r\n          this.getPotentialBuyers();\r\n          this.performance();\r\n          this.getTable();\r\n          this.footfallTrend();\r\n          if(this.headerData?.client ==='459'){\r\n            this.selectedTab = \"footfall\"\r\n            this.footfallValue = \"footfall\";\r\n            this.selctedValue ='Footfall Analysis';\r\n            this.selectedTabs('footfall');\r\n          } else {\r\n            this.selectedTab = \"traffic\"\r\n            this.footfallValue = \"traffic\";\r\n            this.selctedValue ='Traffic Analysis';\r\n            this.selectedTabs('traffic');\r\n          }\r\n          if(this.normalize === true){\r\n          this.zoneDwellTimeSplitData =[];\r\n            this.zoneLoading = false;\r\n            this.zoneNoData = true;\r\n            this.storeOperationData =[];\r\n            this.auLocations =[];\r\n            this.mpaloading =false;\r\n            this.mapnoData= true;\r\n            this.forecast =false;\r\n            this.objData.forecast = false;\r\n            if(this.storeIdarray.length === 1){\r\n            this.getRecapVideoData =[]\r\n            this.recaplaoding =false;\r\n            this.recapnoData =true;\r\n            this.service?.togglenormalize(this.normalize);\r\n            }\r\n          } else {\r\n            this.getZone(); this.getZoneValue();\r\n            this.getMap();\r\n            if(this.storeIdarray.length === 1){\r\n            this.getRecap();\r\n            this.service?.togglenormalize(this.normalize);\r\n            }\r\n          }\r\n          this.cd.detectChanges();\r\n        }\r\n\r\n\r\n        \r\n}\r\n\r\n\r\n\r\n\r\n\r\n\r\ninterface DataContext {\r\n  category: string;\r\n  value: number;\r\n  count: number;\r\n}\r\nfunction getDaysBetweenDates(fromDate: string, toDate: string): number {\r\n  // Parse the date strings into Date objects\r\n  const start = new Date(fromDate);\r\n  const end = new Date(toDate);\r\n\r\n  // Calculate the difference in milliseconds\r\n  const differenceInMs = end.getTime() - start.getTime();\r\n\r\n  // Convert milliseconds to days (1 day = 86400000 milliseconds)\r\n  const millisecondsPerDay = 86400000;\r\n  const differenceInDays = Math.floor(differenceInMs / millisecondsPerDay);\r\n\r\n  return differenceInDays;\r\n}\r\n\r\ninterface ChartDataItem {\r\n  rate: number;\r\n  count: number;\r\n  time: string;\r\n}\r\n\r\n\r\n\r\n\r\n\r\n// getCard() {\r\n//   this.tableobj.valueType= this.valueType,\r\n//   this.tableobj.fromDate = this.headerData?.date.startDate;\r\n//   this.tableobj.toDate = this.headerData?.date.endDate;\r\n//  delete this.tableobj.offset;\r\n//  delete this.tableobj.recapVideoDate;\r\n//  delete this.tableobj.limit; \r\n//  delete this.tableobj.sort;\r\n//  delete this.tableobj.sortBy;\r\n//  delete this.tableobj.export;\r\n//   this.heatloading = true;\r\n//   this.heatnoData = false;\r\n//  delete this.tableobj.dateType\r\n//   this.service\r\n//     .getCardList(this.tableobj)\r\n//     .pipe(takeUntil(this.destroy$))\r\n//     ?.subscribe({\r\n//       next: (res: any) => {\r\n//         if (res && res.code === 200) {\r\n//           this.getCardData = res?.data?.card;\r\n//           // this.heatMapData = res?.data?.funnelChart;\r\n         \r\n//           this.cd.detectChanges();\r\n//         } else {\r\n//           this.getCardData =[];\r\n//           this.heatMapData =[];\r\n//         this.heatloading = false\r\n//         this.heatnoData = true\r\n//         }\r\n//       },\r\n//       error: (err: any) => {\r\n//         this.getCardData =[];\r\n//         this.heatMapData =[];\r\n//         this.cd.detectChanges();\r\n//       },\r\n//       complete: () => {},\r\n//     });\r\n// }\r\n\r\n// getCardGraph() {\r\n//   this.cardloading =true;\r\n//   this.cardNodata =false;\r\n//   delete this.tableobj.normalizedData;\r\n//   delete this.tableobj.processType;\r\n//   this.tableobj.dateType = this.dateType;\r\n//   delete this.tableobj.sort;\r\n//   delete this.tableobj.sortBy;\r\n//   this.service\r\n//     .getCardGraphList(this.tableobj)\r\n//     .pipe(takeUntil(this.destroy$))\r\n//     ?.subscribe({\r\n//       next: (res: any) => {\r\n//         if (res && res.code === 200) {\r\n//           this.getCardGraphData = res?.data;\r\n//           if(this.nob){\r\n//             this.valueConversionRate = this.getCardGraphData?.conversion?.nob.nob;\r\n//           this.conversionValue ='NoB Derived'\r\n//           }else { \r\n//           this.valueConversionRate =  this.getCardGraphData?.conversion?.footfall.rate;\r\n//            this.conversionValue ='footfall'\r\n//           }\r\n//           this.cardloading =false;\r\n//           this.cardNodata =false;           \r\n//           this.cd.detectChanges();\r\n//         } else if(!res || res.code === 204){\r\n//           this.getCardGraphData=[];\r\n//           this.cardloading =false;\r\n//           this.cardNodata =true;\r\n//         }\r\n//       },\r\n//       error: (err: any) => {\r\n//         this.cd.detectChanges();\r\n//       },\r\n//       complete: () => {},\r\n//     });\r\n// }\r\n","<script>\r\n    (g=>{var h,a,k,p=\"The Google Maps JavaScript API\",c=\"google\",l=\"importLibrary\",q=\"__ib__\",m=document,b=window;b=b[c]||(b[c]={});var d=b.maps||(b.maps={}),r=new Set,e=new URLSearchParams,u=()=>h||(h=new Promise(async(f,n)=>{await (a=m.createElement(\"script\"));e.set(\"libraries\",[...r]+\"\");for(k in g)e.set(k.replace(/[A-Z]/g,t=>\"_\"+t[0].toLowerCase()),g[k]);e.set(\"callback\",c+\".maps.\"+q);a.src=`https://maps.${c}apis.com/maps/api/js?`+e;d[q]=f;a.onerror=()=>h=n(Error(p+\" could not load.\"));a.nonce=m.querySelector(\"script[nonce]\")?.nonce||\"\";m.head.append(a)}));d[l]?console.warn(p+\" only loads once. Ignoring:\",g):d[l]=(f,...n)=>r.add(f)&&u().then(()=>d[l](f,...n))})({\r\n      v: \"weekly\",\r\n      key: \"AIzaSyDlOezgwQO0JviD0aizrCuN1FY9tcWfR3o\"\r\n    });\r\n  </script>\r\n  <link href='https://api.mapbox.com/mapbox-gl-js/v2.15.0/mapbox-gl.css' rel='stylesheet' />\r\n  <script src='https://api.mapbox.com/mapbox-gl-js/v2.15.0/mapbox-gl.js'></script>\r\n\r\n<div class=\"row\">\r\n    <div *ngIf=\"(gs.userAccess | async)?.userType === 'tango' || clientData?.featureConfigs?.isNormalized\" class=\"col-md-12 text-end\">\r\n       <div class=\"form-check form-switch my-2\" style=\"float: right !important;\">\r\n            <input class=\"form-check-input cursor-pointer\"  type=\"checkbox\" id=\"flexSwitchCheckDefault\" \r\n            [checked]=\"normalize\" (change)=\"toggleNormalize($event)\"><span class=\"normalize-text\">View Normalized Data</span>\r\n          </div>\r\n    </div>\r\n    <div class=\"col-md-7 h-100\">\r\n        <div class=\"row\">\r\n            <div class=\"col-md-8 \">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"row position-relative\">\r\n                        <div class=\"col-md-6\"  >\r\n                            <div class=\"px-0\">\r\n                                <div class=\"card-header ellipse1 border-0 px-3\" >\r\n                                    <!-- -->\r\n                                    <h3  class=\"card-title align-items-start flex-column\" [ngbTooltip]=\"footfallTooltip\" placement=\"right\">\r\n                                      <!-- Display footfall count or '--' if not available -->\r\n                                      <span class=\"card-label header\">{{ getFootfallCardData?.card?.footfall?.count ? getFootfallCardData?.card?.footfall?.count.toLocaleString('en-IN') : '--' }}</span>\r\n                                      <span class=\"sub-header\">{{footfallName}}</span>\r\n                                    </h3>\r\n                                    \r\n                                    <!-- Switch toggle -->\r\n                                    <div class=\"card-toolbar\">\r\n                                        <div class=\"col-md-12 text-end\">\r\n                                      <div class=\"form-check form-switch text-end\">\r\n                                        <input class=\"form-check-input mt-1 cursor-pointer\" type=\"checkbox\" id=\"flexSwitchCheckDefault\" \r\n                                        [(ngModel)]=\"isAverage\" (change)=\"toggleAverage($event)\" [disabled]=\"isDisabled\">\r\n                                      </div>\r\n                                      <div *ngIf=\"isAverage\" class=\"form-check-label mt-5\">Average</div>\r\n                                      <div *ngIf=\"!isAverage\" class=\"form-check-label mt-5\">Actual</div>\r\n                                      </div>\r\n                                    </div>\r\n                                  </div>\r\n                                  <ng-template #footfallTooltip>\r\n                                    <div class=\"tooltip-content\">\r\n                                      <h5 class=\"tooltip-title text-start\">Footfall</h5>\r\n                                      <p class=\"text-start\">Total unique walk-ins into the selected stores.</p>\r\n                                      <h4 class=\"text-start\">{{getCardData?.footfall?.count}}</h4>\r\n                                    </div>\r\n                                  </ng-template>\r\n                                <div class=\"card-body p-0\">\r\n                              \r\n                                    <section >\r\n                                        <div class=\"row\">\r\n                                            <div class=\"col-md-10 pe-0\">\r\n                                                <div *ngIf=\"footfallloading\" class=\"text-center\">\r\n                                                    <img class=\"loader-img\" src=\"assets/tango/layout/Loader.gif\">\r\n                                                </div>\r\n                                                <div *ngIf=\"footfallNodata\" class=\"row\">\r\n                                                   \r\n                                                        <div class=\"card-body pb-0 px-0 d-flex justify-content-center align-items-center flex-column\">\r\n                                                            <img class=\"footimg-nodata1\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                                            <div class=\"nodata-title1\">No data found</div>\r\n                                                            <!-- <div class=\"nodata-sub\">There is no result for this conversion funnel</div> -->\r\n                                                        </div>\r\n                                                \r\n                                                </div>\r\n                                    <div *ngIf=\"!footfallNodata\" class=\"text-center\" id=\"Footfall\"></div>\r\n                                    </div>\r\n                                    <div class=\"col-md-2 mt-3\">\r\n                                        <div  class=\"mt-1 cursor-pointer fs-5\" [ngClass]=\"dateType ==='daily' ? 'text-primary' :''\" (click)=\"dateValue('daily')\">1D</div>\r\n                                        <div  class=\"mt-1 cursor-pointer fs-5\"  [ngClass]=\"dateType ==='weekly' ? 'text-primary' :''\"  (click)=\"dateValue('weekly')\">1W</div>\r\n                                        <div  class=\"mt-1 cursor-pointer fs-5\"  [ngClass]=\"dateType ==='monthly' ? 'text-primary' :''\"  (click)=\"dateValue('monthly')\">1M</div>\r\n                                    </div>\r\n                                    </div>\r\n                                    </section>\r\n                                </div>\r\n                                <div class=\"card-footer ms-2 p-0\">\r\n                                    <div class=\"col-md-12 mt-3\">\r\n                                        <span class=\"mt-2\">\r\n                                            <svg *ngIf=\"!getFootfallCardData?.data?.footfall?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                            height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                                <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <clipPath id=\"clip0_2328_4654\">\r\n                                                    <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                </clipPath>\r\n                                            </defs>\r\n                                        </svg>\r\n                                        <svg *ngIf=\"getFootfallCardData?.data?.footfall?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                            viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_3216_118)\">\r\n                                                <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <clipPath id=\"clip0_3216_118\">\r\n                                                    <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                </clipPath>\r\n                                            </defs>\r\n                                        </svg>\r\n                                        </span>\r\n                                        <span *ngIf=\"getFootfallCardData?.data?.footfall?.PreviousData ===0\" class=\"percent-value ms-2\">0%</span>\r\n                                        <span  class=\"mt-2 ms-2\"><span class=\"percent-value\" *ngIf=\"getFootfallCardData?.data?.footfall?.PreviousData !==0\">{{getFootfallCardData?.data?.footfall?.PreviousData ? getFootfallCardData?.data?.footfall?.PreviousData:'--'}}%</span><span\r\n                                                class=\"week-font\"> vs Previous <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span> </span>\r\n\r\n                                        </span>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                            <!-- <div>\r\n                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                        <path d=\"M6 12L10 8L6 4\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                        </svg>\r\n                        </div> -->\r\n                        </div>\r\n                        <div class=\"position-absolute left-50\">\r\n                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                <path d=\"M6 12L10 8L6 4\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                </svg>\r\n                                </div>\r\n                        <div class=\"col-md-6\">\r\n\r\n                            <div class=\"px-0\">\r\n                                <div class=\"card-header ellipse1 border-0 ps-2\" >\r\n                                    <div class=\"row\">\r\n                                        <div class=\"col-md-10 text-nowrap pe-0\" >\r\n                                    <h3 class=\" card-title align-items-start flex-column\" [ngbTooltip]=\"conversionTooltip\" placement=\"right\">\r\n                                        <span class=\"card-label header\" *ngIf=\"valueConversionRate === 0\">0%</span>\r\n                                        <span class=\"card-label header\" *ngIf=\"valueConversionRate !== 0\">{{valueConversionRate  ? valueConversionRate : '--'}}%</span>\r\n                                        <span class=\"sub-header\"><span *ngIf=\"headerData?.client === '452'\">More than {{clientData?.featureConfigs?.conversion?.value}} mins Rate</span>\r\n                                        <!-- <span *ngIf=\"headerData?.client !== '452'\">Conversion</span>   -->\r\n                                            <!-- <ng-container *ngIf=\"headerData?.client !== '452'\">\r\n                                            <span *ngIf=\"conversionValue === 'footfall' || conversionValue === 'engagers' || conversionValue === 'Potential Buyers' || conversionValue === 'NoB Derived'\"> \r\n                                                - <span *ngIf=\"conversionValue === 'NoB Derived'; else otherValues\">\r\n                                                    NoB Derived\r\n                                                  </span>\r\n                                                  <ng-template #otherValues>\r\n                                                    {{ conversionValue | titlecase }}\r\n                                                  </ng-template>\r\n                                              </span>\r\n                                              </ng-container> -->\r\n                                              </span>\r\n                                              <ng-container *ngIf=\"headerData?.client !== '452'\">\r\n                                        <span *ngIf=\"!isConversion\" class=\"sub-header\"> Conversion\r\n                                     \r\n                                                <span *ngIf=\"conversionValue === 'footfall' || conversionValue === 'engagers' || conversionValue === 'Potential Buyers' || conversionValue === 'NoB Derived'\"> \r\n                                                     - <span *ngIf=\"conversionValue === 'NoB Derived'; else otherValues\">\r\n                                                        NoB Derived\r\n                                                      </span>\r\n                                                      <ng-template #otherValues>\r\n                                                        {{ conversionValue | titlecase }}\r\n                                                      </ng-template>\r\n                                                     \r\n                                                  </span>\r\n                                      \r\n                                            </span><span *ngIf=\"isConversion\" class=\"sub-header\">\r\n                                     \r\n                                                <span *ngIf=\"conversionValue === 'footfall' || conversionValue === 'engagers' || conversionValue === 'Potential Buyers' || conversionValue === 'NoB Derived'\"> \r\n                                                     <span *ngIf=\"conversionValue === 'NoB Derived'; else otherValues\">\r\n                                                     Conversion - NoB Derived\r\n                                                      </span>\r\n                                                      <ng-template #otherValues>\r\n                                                        {{ conversionValue | titlecase }} - NoB Derived\r\n                                                      </ng-template>\r\n                                                     \r\n                                                  </span>\r\n                                      \r\n                                            </span></ng-container>\r\n                                    </h3>\r\n                                    </div>\r\n                                    <div *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\" class=\"col-md-2 px-0\">\r\n                                        <div class=\"text-end\">\r\n                                      <div class=\"form-check form-switch cursor-pointer\">\r\n                                        <input class=\"form-check-input cursor-pointer\" type=\"checkbox\" id=\"Conversion\" \r\n                                        [(ngModel)]=\"isConversion\" (change)=\"toggleConversion($event)\">\r\n                                        <div  class=\"form-check-label mt-3\"></div>\r\n                                      </div>\r\n                                     \r\n                                      </div>\r\n                                    </div>\r\n                                    </div>\r\n                                </div>\r\n                               <ng-template #conversionTooltip>\r\n                                    <div class=\"tooltip-content\">\r\n                                      <h5 class=\"tooltip-title text-start\" *ngIf=\"headerData?.client !== '452'\">Conversion Rate</h5>\r\n                                      <p class=\"text-start\">Total % of {{conversionValue}} who spent more than {{clientData?.featureConfigs?.conversion?.value}} mins in the store.</p>\r\n                                      <!-- <h4 class=\"text-start\">{{valueConversionRate}}</h4> -->\r\n                                       <!-- <footer class=\"tooltip-footer text-start\"> <span class=\"mt-2\">\r\n                                        <svg *ngIf=\"!getCardGraphData?.conversion?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                        height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                        <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                            <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                                stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </g>\r\n                                        <defs>\r\n                                            <clipPath id=\"clip0_2328_4654\">\r\n                                                <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                            </clipPath>\r\n                                        </defs>\r\n                                    </svg>\r\n                                    <svg *ngIf=\"getCardGraphData?.conversion?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                        viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                        <g clip-path=\"url(#clip0_3216_118)\">\r\n                                            <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                                stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </g>\r\n                                        <defs>\r\n                                            <clipPath id=\"clip0_3216_118\">\r\n                                                <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                            </clipPath>\r\n                                        </defs>\r\n                                    </svg>\r\n                                    </span>\r\n                                    <span class=\"mt-2 ms-2\">\r\n                                        <span *ngIf=\"conversionValue ==='footfall' && getCardGraphData?.conversion?.footfall.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                        <span *ngIf=\"conversionValue ==='footfall' && getCardGraphData?.conversion?.footfall.PreviousData !==0\" class=\"percent-value\">{{getCardGraphData?.conversion?.footfall.PreviousData ? getCardGraphData?.conversion?.footfall.PreviousData:'--'}}%</span>\r\n                                        <span *ngIf=\"conversionValue ==='engagers' && getCardGraphData?.conversion?.engagers.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                      \r\n                                        <span *ngIf=\"conversionValue ==='engagers' && getCardGraphData?.conversion?.engagers.PreviousData !==0\" class=\"percent-value\">{{getCardGraphData?.conversion?.engagers.PreviousData ? getCardGraphData?.conversion?.engagers.PreviousData:'--'}}%</span>\r\n\r\n                                        <span *ngIf=\"conversionValue ==='Potential Buyers' && getCardGraphData?.conversion?.potentialBuyers.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                        <span *ngIf=\"conversionValue ==='Potential Buyers' && getCardGraphData?.conversion?.potentialBuyers.PreviousData !==0\" class=\"percent-value\">{{getCardGraphData?.conversion?.potentialBuyers.PreviousData ? getCardGraphData?.conversion?.potentialBuyers.PreviousData:'--'}}%</span>\r\n                                        <span *ngIf=\"conversionValue ==='NoB Derived'\" class=\"percent-value\">--%</span>\r\n                                        <span *ngIf=\"conversionValue ==='' && getCardGraphData?.conversion?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n\r\n                                            <span *ngIf=\"conversionValue ==='' && getCardGraphData?.conversion?.PreviousData !==0\"  class=\"percent-value\">{{getCardGraphData?.conversion?.PreviousData ? getCardGraphData?.conversion?.PreviousData:'--'}}%</span>\r\n                          \r\n                                        <span\r\n                                            class=\"week-font\"> vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                                    </span>\r\n                            </footer>-->\r\n                                    </div>\r\n                                  </ng-template> \r\n                                <div class=\"card-body p-0\">\r\n                            <div class=\"h-100px pt-10 px-3 row\">\r\n                                <span class=\"h-50px col-md-3\">\r\n                                    <svg class=\"cursor-pointer\" *ngIf=\"conversionValue !=='footfall'\" placement=\"top\" \r\n                                    ngbTooltip=\"Footfall\"\r\n                                    (click)=\"changeValue('footfall')\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path\r\n                                            d=\"M4 18H9.5V19.25C9.5 19.9793 9.21027 20.6788 8.69454 21.1945C8.17882 21.7103 7.47935 22 6.75 22C6.02065 22 5.32118 21.7103 4.80546 21.1945C4.28973 20.6788 4 19.9793 4 19.25V18ZM8 6.11999C10 6.11999 11 8.99999 11 11C11 12 10.5 13 10 14.5L9.5 16H4C4 15 3.5 13.5 3.5 11C3.5 8.49999 5.498 6.11999 8 6.11999ZM20.054 14.098L19.837 15.329C19.7023 16.0396 19.2931 16.6686 18.698 17.0796C18.1029 17.4907 17.3698 17.6508 16.6576 17.5252C15.9453 17.3996 15.3111 16.9984 14.8925 16.4086C14.4739 15.8188 14.3045 15.0878 14.421 14.374L14.637 13.144L20.054 14.098ZM18.178 1.70499C20.642 2.13899 22.196 4.82999 21.762 7.29199C21.328 9.75399 20.575 11.144 20.402 12.129L14.985 11.174L14.753 9.60999C14.521 8.04599 14.203 6.97399 14.376 5.98999C14.723 4.01999 16.208 1.35799 18.178 1.70499Z\"\r\n                                            fill=\"#98A2B3\" />\r\n                                    </svg>\r\n                                    <svg placement=\"top\" ngbTooltip=\"Footfall\" *ngIf=\"conversionValue ==='footfall'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path d=\"M4 18H9.5V19.25C9.5 19.9793 9.21027 20.6788 8.69454 21.1945C8.17882 21.7103 7.47935 22 6.75 22C6.02065 22 5.32118 21.7103 4.80546 21.1945C4.28973 20.6788 4 19.9793 4 19.25V18ZM8 6.11999C10 6.11999 11 8.99999 11 11C11 12 10.5 13 10 14.5L9.5 16H4C4 15 3.5 13.5 3.5 11C3.5 8.49999 5.498 6.11999 8 6.11999ZM20.054 14.098L19.837 15.329C19.7023 16.0396 19.2931 16.6686 18.698 17.0796C18.1029 17.4907 17.3698 17.6508 16.6576 17.5252C15.9453 17.3996 15.3111 16.9984 14.8925 16.4086C14.4739 15.8188 14.3045 15.0878 14.421 14.374L14.637 13.144L20.054 14.098ZM18.178 1.70499C20.642 2.13899 22.196 4.82999 21.762 7.29199C21.328 9.75399 20.575 11.144 20.402 12.129L14.985 11.174L14.753 9.60999C14.521 8.04599 14.203 6.97399 14.376 5.98999C14.723 4.01999 16.208 1.35799 18.178 1.70499Z\" fill=\"#00A3FF\"/>\r\n                                      </svg>\r\n                                </span>\r\n                                <span class=\"h-50px col-md-3\">\r\n                                    <svg placement=\"top\" [ngbTooltip]=\"headerData?.client === '452' ? 'More than '+ featureConfig?.bouncedLimit.value +' mins' : 'Engagers'\" class=\"cursor-pointer\" *ngIf=\"conversionValue !=='engagers'\" (click)=\"changeValue('engagers')\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path \r\n                                            d=\"M17 21V19C17 17.9391 16.5786 16.9217 15.8284 16.1716C15.0783 15.4214 14.0609 15 13 15H5C3.93913 15 2.92172 15.4214 2.17157 16.1716C1.42143 16.9217 1 17.9391 1 19V21M23 21V19C22.9993 18.1137 22.7044 17.2528 22.1614 16.5523C21.6184 15.8519 20.8581 15.3516 20 15.13M16 3.13C16.8604 3.3503 17.623 3.8507 18.1676 4.55231C18.7122 5.25392 19.0078 6.11683 19.0078 7.005C19.0078 7.89317 18.7122 8.75608 18.1676 9.45769C17.623 10.1593 16.8604 10.6597 16 10.88M13 7C13 9.20914 11.2091 11 9 11C6.79086 11 5 9.20914 5 7C5 4.79086 6.79086 3 9 3C11.2091 3 13 4.79086 13 7Z\"\r\n                                            stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                    </svg>\r\n                                    <svg placement=\"top\" [ngbTooltip]=\"headerData?.client === '452' ? 'More than '+ featureConfig?.bouncedLimit.value +' mins' : 'Engagers'\" *ngIf=\"conversionValue ==='engagers'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path d=\"M17 21V19C17 17.9391 16.5786 16.9217 15.8284 16.1716C15.0783 15.4214 14.0609 15 13 15H5C3.93913 15 2.92172 15.4214 2.17157 16.1716C1.42143 16.9217 1 17.9391 1 19V21M23 21V19C22.9993 18.1137 22.7044 17.2528 22.1614 16.5523C21.6184 15.8519 20.8581 15.3516 20 15.13M16 3.13C16.8604 3.3503 17.623 3.8507 18.1676 4.55231C18.7122 5.25392 19.0078 6.11683 19.0078 7.005C19.0078 7.89317 18.7122 8.75608 18.1676 9.45769C17.623 10.1593 16.8604 10.6597 16 10.88M13 7C13 9.20914 11.2091 11 9 11C6.79086 11 5 9.20914 5 7C5 4.79086 6.79086 3 9 3C11.2091 3 13 4.79086 13 7Z\" stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                        </svg>\r\n                                </span>\r\n                                <span *ngIf=\"headerData?.client !== '452'\" class=\"h-50px col-md-3\">\r\n                                    <svg placement=\"top\" ngbTooltip=\"Potential Buyers\" class=\"cursor-pointer\" *ngIf=\"conversionValue !=='Potential Buyers'\" (click)=\"changeValue('potentialBuyers')\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path opacity=\"0.3\"\r\n                                            d=\"M20.0039 18.002H4.00391C3.40391 18.002 3.00391 17.602 3.00391 17.002V7.00195C3.00391 6.40195 3.40391 6.00195 4.00391 6.00195H20.0039C20.6039 6.00195 21.0039 6.40195 21.0039 7.00195V17.002C21.0039 17.602 20.6039 18.002 20.0039 18.002ZM12.0039 8.00195C10.3039 8.00195 9.00391 9.80195 9.00391 12.002C9.00391 14.202 10.3039 16.002 12.0039 16.002C13.7039 16.002 15.0039 14.202 15.0039 12.002C15.0039 9.80195 13.7039 8.00195 12.0039 8.00195Z\"\r\n                                            fill=\"#98A2B3\" />\r\n                                        <path\r\n                                            d=\"M18.0039 6.00195H20.0039C20.6039 6.00195 21.0039 6.40195 21.0039 7.00195V9.00195C19.3039 9.00195 18.0039 7.70195 18.0039 6.00195ZM6.00391 6.00195H4.00391C3.40391 6.00195 3.00391 6.40195 3.00391 7.00195V9.00195C4.70391 9.00195 6.00391 7.70195 6.00391 6.00195ZM21.0039 17.002V15.002C19.3039 15.002 18.0039 16.302 18.0039 18.002H20.0039C20.6039 18.002 21.0039 17.602 21.0039 17.002ZM3.00391 15.002V17.002C3.00391 17.602 3.40391 18.002 4.00391 18.002H6.00391C6.00391 16.302 4.70391 15.002 3.00391 15.002Z\"\r\n                                            fill=\"#98A2B3\" />\r\n                                    </svg>\r\n                                    <svg placement=\"top\" ngbTooltip=\"Potential Buyers\" *ngIf=\"conversionValue ==='Potential Buyers'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path opacity=\"0.3\" d=\"M20.0039 18.002H4.00391C3.40391 18.002 3.00391 17.602 3.00391 17.002V7.00195C3.00391 6.40195 3.40391 6.00195 4.00391 6.00195H20.0039C20.6039 6.00195 21.0039 6.40195 21.0039 7.00195V17.002C21.0039 17.602 20.6039 18.002 20.0039 18.002ZM12.0039 8.00195C10.3039 8.00195 9.00391 9.80195 9.00391 12.002C9.00391 14.202 10.3039 16.002 12.0039 16.002C13.7039 16.002 15.0039 14.202 15.0039 12.002C15.0039 9.80195 13.7039 8.00195 12.0039 8.00195Z\" fill=\"#00A3FF\"/>\r\n                                        <path d=\"M18.0039 6.00195H20.0039C20.6039 6.00195 21.0039 6.40195 21.0039 7.00195V9.00195C19.3039 9.00195 18.0039 7.70195 18.0039 6.00195ZM6.00391 6.00195H4.00391C3.40391 6.00195 3.00391 6.40195 3.00391 7.00195V9.00195C4.70391 9.00195 6.00391 7.70195 6.00391 6.00195ZM21.0039 17.002V15.002C19.3039 15.002 18.0039 16.302 18.0039 18.002H20.0039C20.6039 18.002 21.0039 17.602 21.0039 17.002ZM3.00391 15.002V17.002C3.00391 17.602 3.40391 18.002 4.00391 18.002H6.00391C6.00391 16.302 4.70391 15.002 3.00391 15.002Z\" fill=\"#00A3FF\"/>\r\n                                        </svg>\r\n                                </span>\r\n                                <span class=\"h-50px col-md-3\">\r\n                                    <svg placement=\"top\" ngbTooltip=\"NoB Derived\" class=\"cursor-pointer\" *ngIf=\"conversionValue !=='NoB Derived'\" (click)=\"changeValue('NoB Derived')\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path opacity=\"0.3\"\r\n                                            d=\"M18.0039 21.6005C16.3039 21.6005 15.0039 20.3005 15.0039 18.6005V2.5005C15.0039 2.2005 14.6039 2.00045 14.3039 2.20045L13.0039 3.60048L11.7039 2.30049C11.3039 1.90049 10.7039 1.90049 10.3039 2.30049L9.00391 3.60048L7.70392 2.30049C7.30392 1.90049 6.7039 1.90049 6.3039 2.30049L5.00391 3.60048L3.70392 2.30049C3.50392 2.10049 3.00391 2.2005 3.00391 3.5005V18.6005C3.00391 20.3005 4.30391 21.6005 6.00391 21.6005H18.0039Z\"\r\n                                            fill=\"#98A2B3\" />\r\n                                        <path\r\n                                            d=\"M12.0059 12.5972H11.0059C10.4059 12.5972 10.0059 12.1972 10.0059 11.5972C10.0059 10.9972 10.4059 10.5972 11.0059 10.5972H12.0059C12.6059 10.5972 13.0059 10.9972 13.0059 11.5972C13.0059 12.1972 12.6059 12.5972 12.0059 12.5972ZM9.00586 11.5972C9.00586 10.9972 8.60586 10.5972 8.00586 10.5972H6.00586C5.40586 10.5972 5.00586 10.9972 5.00586 11.5972C5.00586 12.1972 5.40586 12.5972 6.00586 12.5972H8.00586C8.60586 12.5972 9.00586 12.1972 9.00586 11.5972ZM9.00586 7.59717C9.00586 6.99717 8.60586 6.59717 8.00586 6.59717H6.00586C5.40586 6.59717 5.00586 6.99717 5.00586 7.59717C5.00586 8.19717 5.40586 8.59717 6.00586 8.59717H8.00586C8.60586 8.59717 9.00586 8.19717 9.00586 7.59717ZM13.0059 7.59717C13.0059 6.99717 12.6059 6.59717 12.0059 6.59717H11.0059C10.4059 6.59717 10.0059 6.99717 10.0059 7.59717C10.0059 8.19717 10.4059 8.59717 11.0059 8.59717H12.0059C12.6059 8.59717 13.0059 8.19717 13.0059 7.59717ZM13.0059 15.5972C13.0059 14.9972 12.6059 14.5972 12.0059 14.5972H10.0059C9.40586 14.5972 9.00586 14.9972 9.00586 15.5972C9.00586 16.1972 9.40586 16.5972 10.0059 16.5972H12.0059C12.6059 16.5972 13.0059 16.1972 13.0059 15.5972Z\"\r\n                                            fill=\"#98A2B3\" />\r\n                                        <path\r\n                                            d=\"M15.002 18.5971C15.002 20.2971 16.302 21.5971 18.002 21.5971C19.702 21.5971 21.002 20.2971 21.002 18.5971V12.4971C21.002 12.1971 20.602 11.9971 20.302 12.1971L19.002 13.5971L17.702 12.2971C17.302 11.8971 16.702 11.8971 16.302 12.2971L15.002 13.5971V18.5971Z\"\r\n                                            fill=\"#98A2B3\" />\r\n                                    </svg>\r\n                                    <svg placement=\"top\" ngbTooltip=\"NoB Derived\" *ngIf=\"conversionValue ==='NoB Derived'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path opacity=\"0.3\"\r\n                                            d=\"M18.0039 21.6005C16.3039 21.6005 15.0039 20.3005 15.0039 18.6005V2.5005C15.0039 2.2005 14.6039 2.00045 14.3039 2.20045L13.0039 3.60048L11.7039 2.30049C11.3039 1.90049 10.7039 1.90049 10.3039 2.30049L9.00391 3.60048L7.70392 2.30049C7.30392 1.90049 6.7039 1.90049 6.3039 2.30049L5.00391 3.60048L3.70392 2.30049C3.50392 2.10049 3.00391 2.2005 3.00391 3.5005V18.6005C3.00391 20.3005 4.30391 21.6005 6.00391 21.6005H18.0039Z\"\r\n                                            fill=\"#00A3FF\" />\r\n                                        <path\r\n                                            d=\"M12.0059 12.5972H11.0059C10.4059 12.5972 10.0059 12.1972 10.0059 11.5972C10.0059 10.9972 10.4059 10.5972 11.0059 10.5972H12.0059C12.6059 10.5972 13.0059 10.9972 13.0059 11.5972C13.0059 12.1972 12.6059 12.5972 12.0059 12.5972ZM9.00586 11.5972C9.00586 10.9972 8.60586 10.5972 8.00586 10.5972H6.00586C5.40586 10.5972 5.00586 10.9972 5.00586 11.5972C5.00586 12.1972 5.40586 12.5972 6.00586 12.5972H8.00586C8.60586 12.5972 9.00586 12.1972 9.00586 11.5972ZM9.00586 7.59717C9.00586 6.99717 8.60586 6.59717 8.00586 6.59717H6.00586C5.40586 6.59717 5.00586 6.99717 5.00586 7.59717C5.00586 8.19717 5.40586 8.59717 6.00586 8.59717H8.00586C8.60586 8.59717 9.00586 8.19717 9.00586 7.59717ZM13.0059 7.59717C13.0059 6.99717 12.6059 6.59717 12.0059 6.59717H11.0059C10.4059 6.59717 10.0059 6.99717 10.0059 7.59717C10.0059 8.19717 10.4059 8.59717 11.0059 8.59717H12.0059C12.6059 8.59717 13.0059 8.19717 13.0059 7.59717ZM13.0059 15.5972C13.0059 14.9972 12.6059 14.5972 12.0059 14.5972H10.0059C9.40586 14.5972 9.00586 14.9972 9.00586 15.5972C9.00586 16.1972 9.40586 16.5972 10.0059 16.5972H12.0059C12.6059 16.5972 13.0059 16.1972 13.0059 15.5972Z\"\r\n                                            fill=\"#00A3FF\" />\r\n                                        <path\r\n                                            d=\"M15.002 18.5971C15.002 20.2971 16.302 21.5971 18.002 21.5971C19.702 21.5971 21.002 20.2971 21.002 18.5971V12.4971C21.002 12.1971 20.602 11.9971 20.302 12.1971L19.002 13.5971L17.702 12.2971C17.302 11.8971 16.702 11.8971 16.302 12.2971L15.002 13.5971V18.5971Z\"\r\n                                            fill=\"#00A3FF\" />\r\n                                    </svg>\r\n                                    </span>\r\n                            </div>\r\n                                </div>\r\n                                <div class=\"card-footer ms-3 p-0\">\r\n                                    <div class=\"col-md-12\">\r\n                                        <div class=\"row pe-0\">\r\n                                        <span class=\"mt-2 col-md-1\">\r\n                                            <svg *ngIf=\"(conversionValue ==='footfall' && !getConversionCardData?.conversion?.footfall.PreviousVariation) || (conversionValue ==='engagers' && !getConversionCardData?.conversion?.engagers.PreviousVariation) || (conversionValue ==='Potential Buyers' && !getConversionCardData?.conversion?.potentialBuyers.PreviousVariation) || (conversionValue ==='NoB Derived' && !getConversionCardData?.conversion?.nob.PreviousVariation)\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                            height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                                <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <clipPath id=\"clip0_2328_4654\">\r\n                                                    <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                </clipPath>\r\n                                            </defs>\r\n                                        </svg>\r\n                                        <svg *ngIf=\"(conversionValue ==='footfall' && getConversionCardData?.conversion?.footfall.PreviousVariation) || (conversionValue ==='engagers' && getConversionCardData?.conversion?.engagers.PreviousVariation) || (conversionValue ==='Potential Buyers' && getConversionCardData?.conversion?.potentialBuyers.PreviousVariation) || (conversionValue ==='NoB Derived' && getConversionCardData?.conversion?.nob.PreviousVariation)\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                            viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_3216_118)\">\r\n                                                <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <clipPath id=\"clip0_3216_118\">\r\n                                                    <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                </clipPath>\r\n                                            </defs>\r\n                                        </svg>\r\n                                        </span>\r\n                                       \r\n                                        <span class=\"mt-2 col-md-9 pe-0\">\r\n                                            <span *ngIf=\"conversionValue ==='footfall' && getConversionCardData?.conversion?.footfall.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                            <span *ngIf=\"conversionValue ==='footfall' && getConversionCardData?.conversion?.footfall.PreviousData !==0\" class=\"percent-value\">{{getConversionCardData?.conversion?.footfall.PreviousData ? getConversionCardData?.conversion?.footfall.PreviousData:'--'}}%</span>\r\n                                            <span *ngIf=\"conversionValue ==='engagers' && getConversionCardData?.conversion?.engagers.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                          \r\n                                            <span *ngIf=\"conversionValue ==='engagers' && getConversionCardData?.conversion?.engagers.PreviousData !==0\" class=\"percent-value\">{{getConversionCardData?.conversion?.engagers.PreviousData ? getConversionCardData?.conversion?.engagers.PreviousData:'--'}}%</span>\r\n\r\n                                            <span *ngIf=\"conversionValue ==='Potential Buyers' && getConversionCardData?.conversion?.potentialBuyers.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                            <span *ngIf=\"conversionValue ==='Potential Buyers' && getConversionCardData?.conversion?.potentialBuyers.PreviousData !==0\" class=\"percent-value\">{{getConversionCardData?.conversion?.potentialBuyers.PreviousData ? getConversionCardData?.conversion?.potentialBuyers.PreviousData:'--'}}%</span>\r\n                                            <span *ngIf=\"conversionValue ==='NoB Derived' && getConversionCardData?.conversion?.nob.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                            <span *ngIf=\"conversionValue ==='NoB Derived' && getConversionCardData?.conversion?.nob.PreviousData !==0\" class=\"percent-value\">{{getConversionCardData?.conversion?.nob.PreviousData ? getConversionCardData?.conversion?.nob.PreviousData:'--'}}%</span>\r\n                                            <!-- <span *ngIf=\"conversionValue ==='NoB Derived'\" class=\"percent-value\">--%</span> -->\r\n                                            <!-- <span *ngIf=\"conversionValue ==='' && getConversionCardData?.conversion?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n\r\n                                                <span *ngIf=\"conversionValue ==='' && getConversionCardData?.conversion?.PreviousData !==0\"  class=\"percent-value\">{{getCardGraphData?.conversion?.PreviousData ? getCardGraphData?.conversion?.PreviousData:'--'}}%</span> -->\r\n                              \r\n                                            <span\r\n                                                class=\"week-font\"> vs Previous <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                                        </span>\r\n                                        <span *ngIf=\"clientData?.featureConfigs?.isNOB && conversionValue ==='NoB Derived'\" class=\"col-md-2 px-0 cursor-pointer\" (click)=\"nobUpload()\"><svg placement=\"top\" ngbTooltip=\"Upload NoB\" width=\"32\" height=\"32\" viewBox=\"0 0 32 32\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <g filter=\"url(#filter0_d_6160_4394)\">\r\n                                            <rect x=\"2\" y=\"1\" width=\"28\" height=\"28\" rx=\"6.22222\" fill=\"#EAF8FF\"/>\r\n                                            <rect x=\"2.38889\" y=\"1.38889\" width=\"27.2222\" height=\"27.2222\" rx=\"5.83333\" stroke=\"#EAF8FF\" stroke-width=\"0.777778\"/>\r\n                                            <g clip-path=\"url(#clip0_6160_4394)\">\r\n                                            <path d=\"M18.5929 17.5926L16.0003 15M16.0003 15L13.4077 17.5926M16.0003 15V20.8333M21.4382 19.1417C22.0704 18.797 22.5698 18.2517 22.8576 17.5917C23.1454 16.9317 23.2052 16.1947 23.0276 15.4969C22.85 14.7992 22.4451 14.1804 21.8768 13.7384C21.3085 13.2963 20.6092 13.056 19.8892 13.0556H19.0725C18.8763 12.2967 18.5107 11.5923 18.003 10.9951C17.4954 10.3979 16.859 9.92362 16.1416 9.60782C15.4243 9.29201 14.6447 9.14293 13.8615 9.17179C13.0782 9.20065 12.3117 9.40669 11.6196 9.77443C10.9274 10.1422 10.3276 10.662 9.86531 11.2949C9.40299 11.9278 9.09016 12.6573 8.95035 13.4285C8.81054 14.1997 8.84738 14.9926 9.0581 15.7475C9.26881 16.5024 9.64793 17.1997 10.1669 17.7871\" stroke=\"#009BF3\" stroke-width=\"1.29889\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </g>\r\n                                            </g>\r\n                                            <defs>\r\n                                            <filter id=\"filter0_d_6160_4394\" x=\"0.444444\" y=\"0.222222\" width=\"31.1111\" height=\"31.1111\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n                                            <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\r\n                                            <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\r\n                                            <feOffset dy=\"0.777778\"/>\r\n                                            <feGaussianBlur stdDeviation=\"0.777778\"/>\r\n                                            <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\"/>\r\n                                            <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_6160_4394\"/>\r\n                                            <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_6160_4394\" result=\"shape\"/>\r\n                                            </filter>\r\n                                            <clipPath id=\"clip0_6160_4394\">\r\n                                            <rect width=\"15.5556\" height=\"15.5556\" fill=\"white\" transform=\"translate(8.22266 7.22223)\"/>\r\n                                            </clipPath>\r\n                                            </defs>\r\n                                            </svg></span>\r\n                                            </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n\r\n                        </div>\r\n                       \r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-4\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"card-header ellipse1 border-0 px-3\"  [ngbTooltip]=\"bouncedTooltip\" placement=\"right\">\r\n                        <!-- -->\r\n                        <h3 class=\"card-title align-items-start flex-column \">\r\n                            <span class=\"card-label header\">{{getBouncedCardData?.card?.bounced?.rate ? getBouncedCardData?.card?.bounced?.rate :'--'}}%</span>\r\n                            <span class=\"sub-header\"><span *ngIf=\"headerData?.client !== '452'\">Bounced </span> <span *ngIf=\"headerData?.client === '452'\">Less than {{clientData?.featureConfigs?.bouncedLimit?.value}} mins </span> Rate</span>\r\n                        </h3>\r\n                    </div>\r\n                    <ng-template #bouncedTooltip>\r\n                        <div class=\"tooltip-content\">\r\n                          <h5 class=\"tooltip-title text-start\" *ngIf=\"headerData?.client !== '452'\">Bounced Rate</h5>\r\n                          <p class=\"text-start\">Total walk-ins who spent less than {{clientData?.featureConfigs?.bouncedLimit?.value}} mins.</p>\r\n                       \r\n                        </div>\r\n                      </ng-template>\r\n                    <div class=\"card-body p-0\">\r\n                        <div *ngIf=\"bouncedNodata\" class=\"row\">\r\n                            <div class=\"col-lg-12 mb-3\">\r\n                                <div class=\"card-body pb-0 px-0 d-flex justify-content-center align-items-center flex-column\">\r\n                                    <img class=\"img-nodata1\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                    <div class=\"nodata-title1\">No data found</div>\r\n                                    <!-- <div class=\"nodata-sub\">There is no result for this conversion funnel</div> -->\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"!bouncedNodata\" class=\"text-center\" id=\"BouncedRate\"></div>\r\n                    </div>\r\n                    <div class=\"card-footer ms-2 p-0\">\r\n                        <div class=\"col-md-12\">\r\n                            <span class=\"mt-2\">\r\n                                <svg *ngIf=\"!getBouncedCardData?.data?.bounced?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                    <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <clipPath id=\"clip0_2328_4654\">\r\n                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                    </clipPath>\r\n                                </defs>\r\n                            </svg>\r\n                            <svg *ngIf=\"getBouncedCardData?.data?.bounced?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                <g clip-path=\"url(#clip0_3216_118)\">\r\n                                    <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <clipPath id=\"clip0_3216_118\">\r\n                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                    </clipPath>\r\n                                </defs>\r\n                            </svg>\r\n                            </span>\r\n                            <span class=\"mt-2 ms-2\">\r\n                                <span *ngIf=\"getBouncedCardData?.data?.bounced?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                <span *ngIf=\"getBouncedCardData?.data?.bounced?.PreviousData !==0\" class=\"percent-value\">{{getBouncedCardData?.data?.bounced?.PreviousData ? getBouncedCardData?.data?.bounced?.PreviousData:'--'}}%</span>\r\n                                <span class=\"week-font\">\r\n                                    vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                            </span>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-4 mt-3\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"card-header ellipse1 border-0 px-3\"  [ngbTooltip]=\"engagersTooltip\" placement=\"right\">\r\n                        <!--  -->\r\n                        <h3 class=\"card-title align-items-start flex-column \" >\r\n                            <span class=\"card-label header\">{{getEngagersCardData?.card?.engagers?.rate ? getEngagersCardData?.card?.engagers?.rate :'--'}}%</span>\r\n                            <span class=\"sub-header\"><span *ngIf=\"headerData?.client !== '452'\">Engagers</span> <span *ngIf=\"headerData?.client === '452'\">More than {{clientData?.featureConfigs?.bouncedLimit?.value}} mins</span> Rate</span>\r\n                        </h3>\r\n                    </div>\r\n                    <ng-template #engagersTooltip>\r\n                        <div class=\"tooltip-content\">\r\n                          <h5 class=\"tooltip-title text-start\" *ngIf=\"headerData?.client !== '452'\">Engagers Rate</h5>\r\n                          <p class=\"text-start\">Total walk-ins who spent more than {{clientData?.featureConfigs?.bouncedLimit?.value}} mins into the selected stores.</p>                        \r\n                        </div>\r\n                      </ng-template>\r\n                    <div class=\"card-body p-0\">\r\n                        <div *ngIf=\"engagersNodata\" class=\"row\">\r\n                            <div class=\"col-lg-12 mb-3\">\r\n                                <div class=\"card-body pb-0 px-0 d-flex justify-content-center align-items-center flex-column\">\r\n                                    <img class=\"img-nodata1\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                    <div class=\"nodata-title1\">No data found</div>\r\n                                    <!-- <div class=\"nodata-sub\">There is no result for this conversion funnel</div> -->\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"!engagersNodata\" class=\"text-center\" id=\"engagers\"></div>\r\n                    </div>\r\n                    <div class=\"card-footer ms-2 p-0\">\r\n                        <div class=\"col-md-12\">\r\n                            <span class=\"mt-2\">\r\n                                <svg *ngIf=\"!getEngagersCardData?.data?.engagers?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                    height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                    <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                        <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                            stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                    </g>\r\n                                    <defs>\r\n                                        <clipPath id=\"clip0_2328_4654\">\r\n                                            <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                        </clipPath>\r\n                                    </defs>\r\n                                </svg>\r\n                                <svg *ngIf=\"getEngagersCardData?.data?.engagers?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                    viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                    <g clip-path=\"url(#clip0_3216_118)\">\r\n                                        <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                            stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                    </g>\r\n                                    <defs>\r\n                                        <clipPath id=\"clip0_3216_118\">\r\n                                            <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                        </clipPath>\r\n                                    </defs>\r\n                                </svg>\r\n                            </span>\r\n                            <span class=\"mt-2 ms-2\">\r\n                                <span *ngIf=\"getEngagersCardData?.data?.engagers?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                <span *ngIf=\"getEngagersCardData?.data?.engagers?.PreviousData !==0\" class=\"percent-value\">{{getEngagersCardData?.data?.engagers?.PreviousData ? getEngagersCardData?.data?.engagers?.PreviousData:'--'}}%</span>\r\n                                <span class=\"week-font\">\r\n                                    vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                            </span>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-4 mt-3\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div *ngIf=\"headerData?.client === '452'\" class=\"card-header ellipse1 border-0 px-3\" > \r\n                        <h3 class=\"card-title align-items-start flex-column\"  >\r\n                            <span class=\"card-label header\">{{getMissedOpportunityData?.card?.missedopportunities?.rate ? getMissedOpportunityData?.card?.missedopportunities?.rate :'--'}}%</span>\r\n                            <span class=\"sub-header\"><span *ngIf=\"headerData?.client !== '452'\">Missed Opportunities</span><span *ngIf=\"headerData?.client === '452'\">{{clientData?.featureConfigs?.missedOpportunityFrom?.value}} - {{clientData?.featureConfigs?.missedOpportunityTo?.value}} mins</span></span>\r\n                        </h3>\r\n                    </div>\r\n                    <div *ngIf=\"headerData?.client !== '452'\" class=\"card-header ellipse1 border-0 px-3\" [ngbTooltip]=\"missedTooltip\" placement=\"right\"> \r\n                        <h3 class=\"card-title align-items-start flex-column\"  >\r\n                            <span class=\"card-label header\">{{getMissedOpportunityData?.card?.missedopportunities?.rate ? getMissedOpportunityData?.card?.missedopportunities?.rate :'--'}}%</span>\r\n                            <span class=\"sub-header\"><span *ngIf=\"headerData?.client !== '452'\">Missed Opportunities</span><span *ngIf=\"headerData?.client === '452'\">{{clientData?.featureConfigs?.missedOpportunityFrom?.value}} - {{clientData?.featureConfigs?.missedOpportunityTo?.value}} mins</span></span>\r\n                        </h3>\r\n                    </div>\r\n                    <ng-template #missedTooltip>\r\n                        <div class=\"tooltip-content\">\r\n                          <h5 class=\"tooltip-title text-start\" *ngIf=\"headerData?.client !== '452'\">Missed Opportunities</h5>\r\n                        <p *ngIf=\"headerData?.client !== '452'\" class=\"text-start\">The difference between <span *ngIf=\"clientData?.featureConfigs?.missedOpportunityCalculation === 'engagers-conversion' || \r\n                                                    clientData?.featureConfigs?.missedOpportunityCalculation === 'group-conversion'\">\r\n                                {{ clientData?.featureConfigs?.missedOpportunityCalculation === 'engagers-conversion' ? 'engagers and conversions,' : 'potential and conversions,' }}\r\n                            </span>\r\n                            showing potential loss.</p>\r\n                        <p *ngIf=\"headerData?.client === '452'\" class=\"text-start\">The difference between <span *ngIf=\"clientData?.featureConfigs?.missedOpportunityCalculation === 'engagers-conversion' || \r\n                            clientData?.featureConfigs?.missedOpportunityCalculation === 'group-conversion'\">\r\n                            {{\r\n                                clientData?.featureConfigs?.missedOpportunityCalculation === 'engagers-conversion'\r\n                                  ? ('More than ' + featureConfig?.bouncedLimit?.value + ' mins and More than ' + featureConfig?.conversion?.value + ' mins')\r\n                                  : ('potential and More than '+ featureConfig?.conversion?.value+ ' mins')\r\n                              }}\r\n                        </span>\r\n                        showing potential loss.</p>\r\n                         \r\n                        </div>\r\n                      </ng-template>\r\n                    <div class=\"card-body p-0 h-90px mt-3 mx-3\">\r\n                        <div *ngIf=\"headerData?.client !=='452'\" class=\"row\">\r\n                         <div class=\"col-md-9\"><!--{{getCardData?.revenue?.value ?? '--'}} -->\r\n                        <div class=\"my-2\" *ngIf=\"getMissedOpportunityData?.card?.revenue?.currency ==='dollar'\"><span class=\"card-label header\"><span class=\"me-1\">$</span> {{getMissedOpportunityData?.card?.revenue?.value.toLocaleString('en-IN') ?? '--'}}</span></div>\r\n                        <div class=\"my-2\" *ngIf=\"getMissedOpportunityData?.card?.revenue?.currency ==='aed'\"> <span class=\"card-label header\"><span class=\"me-1\">د.إ</span> {{getMissedOpportunityData?.card?.revenue?.value.toLocaleString('en-IN') ?? '--'}}</span></div>  \r\n                        <div class=\"my-2\" *ngIf=\"getMissedOpportunityData?.card?.revenue?.currency ==='inr'\"> <span class=\"card-label header1\"  [ngStyle]=\"{\r\n                                    'font-size': (getMissedOpportunityData?.card?.revenue?.value.toLocaleString('en-IN')?.length > 6 ? '18px' : '20px')}\"><span class=\"me-1\">₹</span>{{getMissedOpportunityData?.card?.revenue?.value.toLocaleString('en-IN') ?? '--'}}</span></div>\r\n                        <div class=\"my-1\"><span class=\"sub-header\" *ngIf=\"headerData?.client !== '452'\">Potential Loss Revenue</span></div>\r\n                        </div>\r\n                        <div class=\"col-md-3 mt-5\" ><svg class=\"cursor-pointer\" (click)=\"goToLoss()\"  xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\r\n                            <g filter=\"url(#filter0_d_3885_2531)\">\r\n                            <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"#EAF8FF\"/>\r\n                            <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#EAF8FF\"/>\r\n                            <g clip-path=\"url(#clip0_3885_2531)\">\r\n                            <path d=\"M27.4585 17.2251C27.8133 18.8556 27.6707 20.5614 27.0505 22.1027L25.8593 21.3838L26.017 26.097L30 23.8834L28.717 23.1086C30.7171 18.4823 29.0726 12.9333 24.7799 10.3407C23.3328 9.46633 21.6918 9.00406 20.0206 9.00003C18.3494 8.99599 16.7064 9.45033 15.2555 10.3177L16.2049 12.0544C17.5933 11.2249 19.1953 10.8712 20.7858 11.043C22.3764 11.2149 23.8754 11.9036 25.0723 13.0125C26.2692 14.1214 27.1037 15.5946 27.4585 17.2251Z\" fill=\"#00A3FF\"/>\r\n                            <path d=\"M12.5402 20.7759C12.1854 19.1452 12.3282 17.4392 12.9485 15.8978L14.1398 16.6167L13.982 11.9035L10 14.1181L11.283 14.8909C9.28199 19.5182 10.9264 25.0662 15.2192 27.6588C16.6661 28.5333 18.3071 28.9958 19.9783 29C21.6495 29.0042 23.2926 28.55 24.7435 27.6828L23.7951 25.9461C22.4067 26.776 20.8045 27.13 19.2138 26.9583C17.623 26.7867 16.1237 26.0979 14.9267 24.989C13.7296 23.88 12.895 22.4066 12.5402 20.7759Z\" fill=\"#00A3FF\"/>\r\n                            <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.0372 13.003C21.0372 12.5514 20.6871 12.1852 20.2552 12.1852C19.8234 12.1852 19.4733 12.5514 19.4733 13.003V14.3659H18.952C18.2607 14.3659 17.5978 14.653 17.109 15.1642C16.6201 15.6754 16.3455 16.3687 16.3455 17.0916C16.3455 17.8146 16.6201 18.5079 17.109 19.0191C17.5978 19.5302 18.2607 19.8174 18.952 19.8174H19.4733V21.998H17.1275C16.6956 21.998 16.3455 22.3641 16.3455 22.8158C16.3455 23.2674 16.6956 23.6335 17.1275 23.6335H19.4733V24.9964C19.4733 25.448 19.8234 25.8141 20.2552 25.8141C20.6871 25.8141 21.0372 25.448 21.0372 24.9964V23.6335H21.5585C22.2498 23.6335 22.9127 23.3463 23.4015 22.8351C23.8903 22.324 24.1649 21.6306 24.1649 20.9077C24.1649 20.1848 23.8903 19.4915 23.4015 18.9803C22.9127 18.4691 22.2498 18.182 21.5585 18.182H21.0372V16.0013H22.8617C23.2936 16.0013 23.6437 15.6352 23.6437 15.1836C23.6437 14.732 23.2936 14.3659 22.8617 14.3659H21.0372V13.003ZM18.952 16.0013H19.4733V18.182H18.952C18.6755 18.182 18.4103 18.0671 18.2148 17.8626C18.0193 17.6581 17.9094 17.3808 17.9094 17.0916C17.9094 16.8025 18.0193 16.5252 18.2148 16.3207C18.4103 16.1162 18.6755 16.0013 18.952 16.0013ZM21.0372 21.998V19.8174H21.5585C21.835 19.8174 22.1002 19.9323 22.2957 20.1368C22.4912 20.3412 22.6011 20.6186 22.6011 20.9077C22.6011 21.1969 22.4912 21.4742 22.2957 21.6787C22.1002 21.8832 21.835 21.998 21.5585 21.998H21.0372Z\" fill=\"#00A3FF\"/>\r\n                            </g>\r\n                            </g>\r\n                            <defs>\r\n                            <filter id=\"filter0_d_3885_2531\" x=\"0\" y=\"0\" width=\"40\" height=\"40\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n                            <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\r\n                            <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\r\n                            <feOffset dy=\"1\"/>\r\n                            <feGaussianBlur stdDeviation=\"1\"/>\r\n                            <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\"/>\r\n                            <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_3885_2531\"/>\r\n                            <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_3885_2531\" result=\"shape\"/>\r\n                            </filter>\r\n                            <clipPath id=\"clip0_3885_2531\">\r\n                            <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(10 9)\"/>\r\n                            </clipPath>\r\n                            </defs>\r\n                            </svg></div>\r\n                            </div>\r\n                    </div>\r\n                    <div class=\"card-footer ms-2 p-0\">\r\n                        <div class=\"col-md-12\">\r\n                            <span class=\"mt-2\">\r\n                                <svg *ngIf=\"!getMissedOpportunityData?.data?.missedopportunities?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                    <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <clipPath id=\"clip0_2328_4654\">\r\n                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                    </clipPath>\r\n                                </defs>\r\n                            </svg>\r\n                            <svg *ngIf=\"getMissedOpportunityData?.data?.missedopportunities?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                <g clip-path=\"url(#clip0_3216_118)\">\r\n                                    <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <clipPath id=\"clip0_3216_118\">\r\n                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                    </clipPath>\r\n                                </defs>\r\n                            </svg>\r\n                            </span>\r\n                            <span class=\"ms-2 mt-2\">\r\n                                <span *ngIf=\"getMissedOpportunityData?.data?.missedopportunities?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                <span *ngIf=\"getMissedOpportunityData?.data?.missedopportunities?.PreviousData !==0\" class=\"percent-value\">{{getMissedOpportunityData?.data?.missedopportunities?.PreviousData ? getMissedOpportunityData?.data?.missedopportunities?.PreviousData:'--'}}%</span>\r\n                            <span class=\"week-font\">\r\n                                    vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                            </span>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-4 mt-3 h-100\">\r\n                <div class=\"card card-border mb-5 py-0\">\r\n                    <div class=\"card-body p-0 h-90px mt-3 mx-3\" [ngbTooltip]=\"dwellTooltip\" placement=\"right\">\r\n                        <div class=\"d-flex align-items-center me-2\">\r\n                            <div class=\"mt-3 flex-shrink-0\">\r\n                                    <svg width=\"40\" height=\"41\" viewBox=\"0 0 40 41\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                                        <rect y=\"0.5\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\"/>\r\n                                        <path d=\"M17.6382 12.8922C17.6382 12.6835 17.7212 12.4833 17.8688 12.3357C18.0164 12.1881 18.2165 12.1052 18.4253 12.1052H21.5734C21.7822 12.1052 21.9823 12.1881 22.1299 12.3357C22.2775 12.4833 22.3605 12.6835 22.3605 12.8922C22.3605 13.1009 22.2775 13.3011 22.1299 13.4487C21.9823 13.5963 21.7822 13.6792 21.5734 13.6792H20.7864V14.7286L20.7853 14.7716C22.1156 14.9174 23.3767 15.4398 24.4204 16.2775L24.4277 16.2712L25.2148 15.4842C25.311 15.3806 25.4333 15.3048 25.569 15.2649C25.7046 15.2251 25.8485 15.2225 25.9855 15.2575C26.1224 15.2925 26.2474 15.3638 26.3472 15.4639C26.4471 15.564 26.5181 15.6892 26.5527 15.8263C26.5877 15.9631 26.5852 16.1068 26.5455 16.2423C26.5058 16.3778 26.4304 16.5002 26.3271 16.5965L25.5401 17.3836L25.5338 17.3909C26.3662 18.4331 26.8875 19.6891 27.0377 21.0144C27.1878 22.3397 26.9607 23.6805 26.3824 24.8825C25.8042 26.0845 24.8983 27.0987 23.7691 27.8086C22.6399 28.5184 21.3332 28.895 19.9993 28.895C18.6655 28.895 17.3588 28.5184 16.2296 27.8086C15.1004 27.0987 14.1945 26.0845 13.6163 24.8825C13.038 23.6805 12.8109 22.3397 12.961 21.0144C13.1112 19.6891 13.6325 18.4331 14.4649 17.3909L14.4586 17.3836L13.6716 16.5965C13.5324 16.4474 13.4566 16.25 13.4601 16.046C13.4636 15.842 13.5462 15.6473 13.6905 15.5031C13.8347 15.3588 14.0294 15.2762 14.2334 15.2727C14.4374 15.2692 14.6348 15.345 14.7839 15.4842L15.571 16.2712L15.5783 16.2775C16.6217 15.44 17.8824 14.9176 19.2123 14.7716V13.6792H18.4253C18.2165 13.6792 18.0164 13.5963 17.8688 13.4487C17.7212 13.3011 17.6382 13.1009 17.6382 12.8922ZM19.9993 27.3212C21.4606 27.3211 22.862 26.7404 23.8952 25.7071C24.9284 24.6737 25.5087 23.2722 25.5086 21.8109C25.5085 20.3496 24.9278 18.9482 23.8945 17.915C22.8611 16.8819 21.4596 16.3015 19.9983 16.3016C18.537 16.3018 17.1356 16.8824 16.1025 17.9158C15.0693 18.9492 14.4889 20.3507 14.489 21.8119C14.4892 23.2732 15.0698 24.6746 16.1032 25.7078C17.1366 26.741 18.5381 27.3213 19.9993 27.3212ZM20.4076 20.2903L21.8032 18.8947C21.8758 18.8195 21.9626 18.7595 22.0586 18.7182C22.1546 18.6769 22.2579 18.6551 22.3624 18.6542C22.4669 18.6532 22.5705 18.6731 22.6673 18.7126C22.764 18.7521 22.8519 18.8105 22.9259 18.8844C22.9998 18.9582 23.0583 19.0461 23.0979 19.1428C23.1375 19.2395 23.1575 19.3431 23.1566 19.4476C23.1557 19.5521 23.1341 19.6554 23.0929 19.7515C23.0517 19.8475 22.9918 19.9344 22.9166 20.007L21.521 21.4037C21.583 21.6371 21.5906 21.8815 21.5432 22.1182C21.4958 22.355 21.3948 22.5777 21.2478 22.7692C21.1008 22.9607 20.9118 23.1159 20.6953 23.2228C20.4789 23.3298 20.2408 23.3856 19.9993 23.386C19.7766 23.3841 19.5567 23.3349 19.3544 23.2416C19.1521 23.1483 18.9718 23.0131 18.8257 22.845C18.6795 22.6768 18.5707 22.4796 18.5066 22.2662C18.4424 22.0528 18.4243 21.8283 18.4534 21.6074C18.4825 21.3865 18.5582 21.1743 18.6755 20.9849C18.7928 20.7955 18.949 20.6332 19.1338 20.5086C19.3185 20.3841 19.5276 20.3003 19.7472 20.2626C19.9668 20.225 20.1919 20.2344 20.4076 20.2903Z\" fill=\"#667085\"/>\r\n                                        </svg>\r\n                            </div>\r\n                            <div class=\"mx-3 mt-1\" >\r\n                                <div class=\"my-1 card-label header\" *ngIf=\"getMissedOpportunityData?.card?.avgDwellTime === 0\">0 mins</div>\r\n                                <div class=\"my-1 card-label header\"  *ngIf=\"getMissedOpportunityData?.card?.avgDwellTime !== 0\">{{getMissedOpportunityData?.card?.avgDwellTime ? getMissedOpportunityData?.card?.avgDwellTime :'--'}} mins</div>\r\n                                <div class=\"sub-header\">Avg Dwell Time</div>\r\n                            </div>\r\n                            \r\n                        </div>\r\n                        \r\n                    </div>\r\n                    <ng-template #dwellTooltip>\r\n                        <div class=\"tooltip-content\">\r\n                          <h5 class=\"tooltip-title text-start\">Avg Dwell Time</h5>\r\n                          <p class=\"text-start\">Average time spent by {{headerData?.client === '452' ? 'More than '+ featureConfig?.bouncedLimit.value +' mins' : 'engagers'}} in the selected stores.</p>\r\n                          </div>\r\n                          </ng-template>\r\n                    </div>\r\n                    <div class=\"card card-border py-0\">\r\n                        <div class=\"card-body p-0 h-90px mt-3 mx-3\"  [ngbTooltip]=\"downTooltip\" placement=\"right\">\r\n                            <div class=\"d-flex align-items-center me-2\">\r\n                                <div class=\"flex-shrink-0 mt-3\">\r\n                                    <svg width=\"40\" height=\"41\" viewBox=\"0 0 40 41\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                                        <rect y=\"0.5\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\"/>\r\n                                        <path d=\"M21.9004 12.1675C22.9958 12.1675 24.0423 12.3918 24.9977 12.7987C25.9889 13.2207 26.8809 13.8402 27.6279 14.6087C28.3734 15.3756 28.9756 16.2931 29.3857 17.3162C29.7813 18.299 29.9993 19.3756 29.9993 20.5008C29.9993 21.6277 29.7813 22.7043 29.3857 23.6871C28.9756 24.7068 28.3734 25.6244 27.6263 26.3929C26.8809 27.1598 25.9889 27.7793 24.9945 28.2012C24.0391 28.6081 22.9925 28.8325 21.8988 28.8325C20.8034 28.8325 19.7568 28.6081 18.8014 28.2012C17.8102 27.7793 16.9183 27.1598 16.1729 26.3929L16.1712 26.3912C15.4242 25.6227 14.8236 24.7052 14.4134 23.6871C14.2865 23.3707 14.1774 23.0459 14.0879 22.7127C14.2572 22.7294 14.4297 22.7378 14.6038 22.7378C14.9342 22.7378 15.2565 22.7076 15.5706 22.649C15.6227 22.8098 15.6797 22.9688 15.7415 23.1246C16.0785 23.9617 16.5732 24.7152 17.1885 25.3481C17.8037 25.981 18.5378 26.49 19.3499 26.8366C20.1328 27.1698 20.9938 27.3557 21.8988 27.3557C22.8037 27.3557 23.6631 27.1715 24.4476 26.8366C25.2614 26.49 25.9938 25.981 26.6091 25.3481C27.2243 24.7152 27.7191 23.9601 28.056 23.1246C28.3799 22.3192 28.5605 21.4334 28.5605 20.5025C28.5605 19.5715 28.3815 18.6875 28.056 17.8804C27.7191 17.0432 27.2243 16.2898 26.6091 15.6569C25.9938 15.024 25.2598 14.5149 24.4476 14.1684C23.6647 13.8352 22.8037 13.6493 21.8988 13.6493C20.9938 13.6493 20.1344 13.8335 19.3499 14.1684C19.2799 14.1985 19.21 14.2303 19.1416 14.2621C18.8747 13.8301 18.5524 13.4383 18.1829 13.0984C18.3848 12.9913 18.5915 12.8925 18.8014 12.8021C19.7601 12.3918 20.805 12.1675 21.9004 12.1675ZM20.971 16.5393C20.971 16.335 21.0524 16.1508 21.181 16.0169C21.3112 15.8829 21.4902 15.8009 21.6888 15.8009C21.8874 15.8009 22.0664 15.8829 22.1966 16.0169C22.3268 16.1508 22.4066 16.335 22.4066 16.5393V20.4271L25.2305 22.1501C25.3997 22.2539 25.5137 22.4196 25.5592 22.6021C25.6048 22.7847 25.5837 22.9856 25.4827 23.1597V23.1614C25.3818 23.3355 25.2207 23.4527 25.0433 23.4996C24.8659 23.5465 24.6706 23.5247 24.5013 23.4209H24.4997L21.3405 21.4937C21.2314 21.4318 21.1419 21.3413 21.0768 21.2342C21.0101 21.122 20.971 20.9897 20.971 20.8491V16.5393Z\" fill=\"#667085\"/>\r\n                                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M14.3913 12.6095C16.8164 12.6095 18.7826 14.6321 18.7826 17.1269C18.7826 19.6218 16.8164 21.6444 14.3913 21.6444C11.9661 21.6444 10 19.6218 10 17.1269C10 14.6321 11.9661 12.6095 14.3913 12.6095ZM14.3913 19.7172L16.748 16.7201H15.2848V15.1261H13.4977V16.7201H12.0345L14.3913 19.7172Z\" fill=\"#F04438\"/>\r\n                                        </svg>\r\n                                </div>\r\n                                <div class=\"mx-3 mt-1\" >\r\n                                    <div class=\"my-1 card-label header\" *ngIf=\"getMissedOpportunityData?.card?.avgDownTime === 0\">0 mins</div>\r\n                                    <div class=\"my-1 card-label header\"  *ngIf=\"getMissedOpportunityData?.card?.avgDownTime !== 0\">{{getMissedOpportunityData?.card?.avgDownTime ? getMissedOpportunityData?.card?.avgDownTime :'--'}} mins</div>\r\n                                    <div class=\"sub-header\">Avg Down Time</div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <ng-template #downTooltip>\r\n                            <div class=\"tooltip-content\">\r\n                              <h5 class=\"tooltip-title text-start\">Avg Down Time</h5>\r\n                              <p class=\"text-start\">Average camera & network downtime for the selected stores.</p>\r\n                              </div>\r\n                              </ng-template>\r\n                    </div>\r\n            </div>\r\n            <div *ngIf=\"headerData?.client !== '452'\" class=\"col-md-4 mt-3 position-relative\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"card-header ellipse1 border-0 px-3\" [ngbTooltip]=\"potentialTooltip\" placement=\"right\">\r\n                        <h3 class=\"card-title align-items-start flex-column \">\r\n                            <span class=\"card-label header\">{{getPotentialBuyersCardData?.card?.potentialBuyers?.rate ? getPotentialBuyersCardData?.card?.potentialBuyers?.rate :'--'}}%</span>\r\n                            <span class=\"sub-header \">Potential Buyers</span>\r\n                        </h3>\r\n                    </div>\r\n                    <ng-template #potentialTooltip>\r\n                        <div class=\"tooltip-content\">\r\n                          <h5 class=\"tooltip-title text-start\">Potential Buyers</h5>\r\n                          <p class=\"text-start\">Number of groups entering the store.</p>\r\n                          </div>\r\n                          </ng-template>\r\n                    <div class=\"card-body p-0\">\r\n                        <div *ngIf=\"potentialNodata\" class=\"row\">\r\n                            <div class=\"col-lg-12 mb-3\">\r\n                                <div class=\"card-body pb-0 px-0 d-flex justify-content-center align-items-center flex-column\">\r\n                                    <img class=\"img-nodata1\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                    <div class=\"nodata-title1\">No data found</div>\r\n                                    <!-- <div class=\"nodata-sub\">There is no result for this conversion funnel</div> -->\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"!potentialNodata\" class=\"text-center\" id=\"PotentialBuyers\"></div>\r\n                    </div>\r\n                    <div class=\"card-footer ms-2 p-0\">\r\n                        <div class=\"col-md-12\">\r\n                            <span class=\"mt-2\">\r\n                                <svg *ngIf=\"!getPotentialBuyersCardData?.data?.potentialBuyers?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                    <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <clipPath id=\"clip0_2328_4654\">\r\n                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                    </clipPath>\r\n                                </defs>\r\n                            </svg>\r\n                            <svg *ngIf=\"getPotentialBuyersCardData?.data?.potentialBuyers?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                <g clip-path=\"url(#clip0_3216_118)\">\r\n                                    <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <clipPath id=\"clip0_3216_118\">\r\n                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                    </clipPath>\r\n                                </defs>\r\n                            </svg>\r\n                            </span>\r\n                            <span class=\"mt-2 ms-2\">\r\n                                <span *ngIf=\"getPotentialBuyersCardData?.data?.potentialBuyers?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                <span *ngIf=\"getPotentialBuyersCardData?.data?.potentialBuyers?.PreviousData !==0\" class=\"percent-value\">{{getPotentialBuyersCardData?.data?.potentialBuyers?.PreviousData ? getPotentialBuyersCardData?.data?.potentialBuyers?.PreviousData:'--'}}%</span>\r\n                                <span class=\"week-font\">\r\n                                    vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                            </span>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"position-absolute end-0\">\r\n                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                        <path d=\"M6 12L10 8L6 4\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                        </svg>\r\n                        </div>\r\n            </div>\r\n            <div *ngIf=\"headerData?.client !== '452'\" class=\"col-md-8 mt-3\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"row\">\r\n                        <div class=\"col-md-12\">\r\n                            <div class=\"px-2\">\r\n                                <div class=\"card-header ellipse1 border-0 px-3\" [ngbTooltip]=\"potentialBuyerTooltip\" placement=\"right\">\r\n                                    <h3 class=\"card-title align-items-start flex-column \">\r\n                                        <span class=\"card-label header\">Potential Buyer Distribution</span>\r\n                                        <span class=\"sub-header\">Category-wise</span>\r\n                                    </h3>   \r\n                                </div>\r\n                                <ng-template #potentialBuyerTooltip>\r\n                                    <div class=\"tooltip-content\">\r\n                                      <h5 class=\"tooltip-title text-start\">Potential Buyer Distribution</h5>\r\n                                      <p class=\"text-start\">Average group size, along with the count of individuals versus groups entering the store.</p>\r\n                                      </div>\r\n                                      </ng-template>\r\n                                <div class=\"row\">\r\n                                    <div class=\"col-md-9\">\r\n                                        <div class=\"row\">\r\n                                <div class=\"col-md-6 px-0\">\r\n                                <div class=\"card-body p-0\">\r\n                                   <div class=\"text-start ms-10  mt-7 mb-3\"><span><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"25\" height=\"24\" viewBox=\"0 0 25 24\" fill=\"none\">\r\n                                    <path d=\"M20.25 21V19C20.25 17.9391 19.8286 16.9217 19.0784 16.1716C18.3283 15.4214 17.3109 15 16.25 15H8.25C7.18913 15 6.17172 15.4214 5.42157 16.1716C4.67143 16.9217 4.25 17.9391 4.25 19V21M16.25 7C16.25 9.20914 14.4591 11 12.25 11C10.0409 11 8.25 9.20914 8.25 7C8.25 4.79086 10.0409 3 12.25 3C14.4591 3 16.25 4.79086 16.25 7Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                  </svg></span><span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.count !== 0\" class=\"left-card-count mt-2 ms-1\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.count ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.count.toLocaleString('en-IN'):'--'}}</span> \r\n                                  <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.count === 0\" class=\"left-card-count mt-2 ms-1\">0</span><span class=\"left-card-count-header ms-1\">Single</span></div>\r\n                                  <div class=\"text-start ms-15 mb-3\"><span class=\"badge badge-light-default week-font\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.ageGroup ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.ageGroup:'--'}} age</span></div>\r\n                                </div>\r\n                                <div class=\"card-footer ms-2 p-0\">\r\n                                    <div class=\"col-md-12\">\r\n                                        <span class=\"mt-2\">\r\n                                            <svg *ngIf=\"!getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                            height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                                <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <clipPath id=\"clip0_2328_4654\">\r\n                                                    <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                </clipPath>\r\n                                            </defs>\r\n                                        </svg>\r\n                                        <svg *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                            viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_3216_118)\">\r\n                                                <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <clipPath id=\"clip0_3216_118\">\r\n                                                    <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                </clipPath>\r\n                                            </defs>\r\n                                        </svg>\r\n                                        </span>\r\n                                        <span class=\"mt-2 ms-2\">\r\n                                            <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                            <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.PreviousData !==0\" class=\"percent-value\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.PreviousData ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.PreviousData:'--'}}%</span>\r\n                                            <span\r\n                                                class=\"week-font\"> vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                                        </span>\r\n                                    </div>\r\n                                </div>\r\n                                </div>\r\n                                <div class=\"col-md-6 px-0 position-relative\">\r\n                                    <div class=\"card-body p-0\">\r\n                                        <div class=\"text-start ms-10 mt-7 mb-3\"><span> <svg width=\"26\" height=\"24\" viewBox=\"0 0 26 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <rect width=\"26\" height=\"24\" fill=\"#DCDCDC\"/>\r\n                                            <rect x=\"-460.5\" y=\"-340.5\" width=\"783\" height=\"1947\" rx=\"4.5\" stroke=\"#9747FF\" stroke-dasharray=\"10 5\"/>\r\n                                            <mask id=\"path-2-inside-1_707_13106\" fill=\"white\">\r\n                                            <path d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\"/>\r\n                                            </mask>\r\n                                            <path d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\" fill=\"white\"/>\r\n                                            <path d=\"M-190 -89C-190 -96.1797 -184.18 -102 -177 -102H294C301.18 -102 307 -96.1797 307 -89C307 -95.0751 301.627 -100 295 -100H-177C-183.075 -100 -188 -95.0751 -188 -89H-190ZM307 85C307 92.1797 301.18 98 294 98H-177C-184.18 98 -190 92.1797 -190 85H-188C-188 91.0751 -183.075 96 -177 96H295C301.627 96 307 91.0751 307 85ZM-177 98C-184.18 98 -190 92.1797 -190 85V-89C-190 -96.1797 -184.18 -102 -177 -102V-100C-183.075 -100 -188 -95.0751 -188 -89V85C-188 91.0751 -183.075 96 -177 96V98ZM307 -101V97V-101Z\" fill=\"#D0D5DD\" mask=\"url(#path-2-inside-1_707_13106)\"/>\r\n                                            <mask id=\"path-6-inside-2_707_13106\" fill=\"white\">\r\n                                            <path d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\"/>\r\n                                            </mask>\r\n                                            <path d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\" stroke=\"#98A2B3\" stroke-width=\"3\" mask=\"url(#path-6-inside-2_707_13106)\"/>\r\n                                            </svg></span><span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.count !==0\" class=\"left-card-count ms-1 mt-2\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.count ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.count.toLocaleString('en-IN'):'--'}}</span> \r\n                                            <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.count ===0\" class=\"left-card-count ms-1 mt-2\">0</span>\r\n                                            <span class=\"left-card-count-header ms-1\">Group</span></div>\r\n                                       <div class=\"text-start ms-15 mb-3\"><span class=\"badge badge-light-default week-font\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.ageGroup ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.ageGroup:'--'}} age</span></div>\r\n                                      \r\n                                     </div>\r\n                                    <div class=\"card-footer ms-2 p-0\">\r\n                                        <div class=\"col-md-12\">\r\n                                            <span class=\"mt-2\">\r\n                                                <svg *ngIf=\"!getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                                height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                                    <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2328_4654\">\r\n                                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                            <svg *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                                viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_3216_118)\">\r\n                                                    <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_3216_118\">\r\n                                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                            </span>\r\n                                            <span class=\"mt-2 ms-2\">\r\n                                                <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                                <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.PreviousData !==0\" class=\"percent-value\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.PreviousData ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.PreviousData:'--'}}%</span>\r\n                                                <span\r\n                                                    class=\"week-font\"> vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n    \r\n                                            </span>\r\n                                        </div>\r\n                                    </div>\r\n\r\n                                    <div class=\"position-absolute mt-5 end-0\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path d=\"M6 12L10 8L6 4\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                            </div>\r\n                                    </div>\r\n                                    </div>\r\n                                    </div>\r\n                                    <div class=\"col-md-3 px-0\">\r\n                                        <div class=\"card-body p-0\">\r\n                                            <div class=\"text-center mt-7 mb-3\"><span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersPersons?.count !== 0\" class=\"left-card-count mt-2\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersPersons?.count ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersPersons?.count.toLocaleString('en-IN'):'--'}}</span> \r\n                                                <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersPersons?.count === 0\" class=\"left-card-count mt-2\">0</span><span class=\"left-card-count-header ms-1\">Persons</span></div>\r\n\r\n                                           <div class=\"text-center mb-3\"><span class=\"badge badge-light-default week-font\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersPersons?.ageGroup ? getPotentialBuyersData.potentialBuyers?.potentialBuyersPersons?.ageGroup:'--'}} age</span>\r\n                                        </div>\r\n                                          \r\n                                         </div>\r\n                                        <div class=\"card-footer text-center p-0\">\r\n                                            <div class=\"col-md-12\">\r\n                                                <span class=\"mt-2 ms-2\"><span class=\"percent-value\"></span><span\r\n                                                        class=\"ms-2 week-font\"> Avg. Group size</span>\r\n        \r\n                                                </span>\r\n                                            </div>\r\n                                        </div>\r\n                                        </div>\r\n                                        </div>\r\n                            </div>\r\n                            <!-- <div>\r\n                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                        <path d=\"M6 12L10 8L6 4\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                        </svg>\r\n                        </div> -->\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n         \r\n        </div>\r\n\r\n    </div>\r\n    <div class=\"col-md-5 h-100\">\r\n        <div class=\"card mb-3\">\r\n            <div class=\"card-header border-0 pt-3 ps-5\">\r\n                <h3 class=\"card-title align-items-start flex-column\">\r\n                    <span class=\"title-text\"><span *ngIf=\"headerData?.client !== '452'\">Conversion</span> Funnel \r\n                       <span *ngIf=\"headerData?.client !== '452'\"> <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" \r\n                        placement=\"top\" \r\n                        ngbTooltip=\"Total opportunity of sales conversion versus total walkins\">\r\n                        <g clip-path=\"url(#clip0_1432_80035)\">\r\n                        <path d=\"M8.00065 10.6666V7.99992M8.00065 5.33325H8.00732M14.6673 7.99992C14.6673 11.6818 11.6826 14.6666 8.00065 14.6666C4.31875 14.6666 1.33398 11.6818 1.33398 7.99992C1.33398 4.31802 4.31875 1.33325 8.00065 1.33325C11.6826 1.33325 14.6673 4.31802 14.6673 7.99992Z\" stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                        </g>\r\n                        <defs>\r\n                        <clipPath id=\"clip0_1432_80035\">\r\n                        <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n                        </clipPath>\r\n                        </defs>\r\n                        </svg></span>\r\n                        <span *ngIf=\"headerData?.client === '452'\">\r\n                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" \r\n                        placement=\"top\" \r\n                        [ngbTooltip]=\"'Total opportunity of sales More than ' + clientData?.featureConfigs?.conversion?.value + ' mins versus total walkins'\">\r\n                        <g clip-path=\"url(#clip0_1432_80035)\">\r\n                        <path d=\"M8.00065 10.6666V7.99992M8.00065 5.33325H8.00732M14.6673 7.99992C14.6673 11.6818 11.6826 14.6666 8.00065 14.6666C4.31875 14.6666 1.33398 11.6818 1.33398 7.99992C1.33398 4.31802 4.31875 1.33325 8.00065 1.33325C11.6826 1.33325 14.6673 4.31802 14.6673 7.99992Z\" stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                        </g>\r\n                        <defs>\r\n                        <clipPath id=\"clip0_1432_80035\">\r\n                        <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n                        </clipPath>\r\n                        </defs>\r\n                        </svg>\r\n                        </span>\r\n                    </span>\r\n                    <span class=\"text-sub mb-2\">{{headerData?.date?.startDate | date:'dd MMM, yyyy'}} – {{headerData?.date?.endDate | date:'dd MMM, yyyy'}}</span>\r\n                </h3>\r\n        \r\n            </div>\r\n\r\n            <div class=\"card-body p-0\" >\r\n                <div *ngIf=\"heatloading\" class=\"row loader d-flex justify-content-center align-items-center h-275px\">\r\n                    <div class=\"shimmer pt-0\">\r\n                        <div class=\"wrapper\">\r\n                            <div class=\"stroke animate title\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n                            <div class=\"stroke animate title\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div *ngIf=\"heatnoData\" class=\"row\">\r\n                    <div class=\"col-lg-12 mb-3\">\r\n                        <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                            <img class=\"img-nodata\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                            <div class=\"nodata-title\">No data found</div>\r\n                            <div class=\"nodata-sub\">There is no result for this <span *ngIf=\"headerData?.client !=='452'\">conversion</span> funnel</div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div *ngIf=\"!heatloading && !heatnoData\" class=\"text-center mb-3\" id=\"chartdiv\"></div>\r\n            </div>\r\n            </div>\r\n           \r\n            <div *ngIf=\"mpaloading && storeIdarray?.length > 1 || mapnoData && storeIdarray?.length > 1 || !storeIdarray?.length\" class=\"card\">\r\n                <div class=\"card-header border-0 pt-3 ps-7 pe-0\">\r\n                    <h3 class=\"card-title align-items-start flex-column\">\r\n                        <span class=\"title-text\" >Explore</span>  \r\n                    </h3>\r\n               \r\n                        </div>\r\n                        <div *ngIf=\"mpaloading\" class=\"row loader d-flex justify-content-center align-items-center h-225px\">\r\n                            <div class=\"shimmer pt-0\">\r\n                                <div class=\"wrapper\">\r\n                                    <div class=\"stroke animate title\"></div>\r\n                                    <div class=\"stroke animate link\"></div>\r\n                                    <div class=\"stroke animate title\"></div>\r\n                                    <div class=\"stroke animate link\"></div>\r\n\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"mapnoData\"  class=\"row px-3\">\r\n                            <div class=\"col-md-12\">\r\n                                <div *ngIf=\"normalize\" class=\"card-body d-flex justify-content-center mb-10 align-items-center flex-column\">\r\n                                    <img class=\"img-map1\" src=\"./assets/tango/Icons/not-applicable.svg\" alt=\"\">\r\n                                    <div class=\"nodata-title mt-3\">Data Not Found</div>\r\n                                    <div class=\"nodata-sub\">Normalized data is not applicable</div>\r\n                                </div>\r\n                                <div *ngIf=\"!normalize\" class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                                    <img class=\"img-map\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                    <div  class=\"nodata-title\">No data found</div>\r\n                                    <div class=\"nodata-sub\">There is no result for this Store map</div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        </div>\r\n            <div *ngIf=\"!mpaloading && !mapnoData && storeIdarray?.length > 1\" class=\"card\">\r\n                <div  class=\"card-header border-0 pt-3 ps-7 pe-0\">\r\n                    <h3 class=\"card-title align-items-start flex-column\">\r\n                        <span class=\"title-text\" >Explore</span>  \r\n                    </h3>\r\n                    <div class=\"card-toolbar mt-0\">\r\n                       \r\n                        <button *ngIf=\"!mpaloading && !mapnoData\" type=\"button\" (click)=\"exporeView()\"\r\n                        class=\"btn me-8 btn-light-primary1 rounded-3 text-nowrap border-val\">\r\n                        <span class=\"ms-2\">Explore</span>\r\n                    </button>\r\n                    </div>\r\n            \r\n                </div>\r\n              \r\n                <div *ngIf=\"!mapnoData\" class=\"card-body col-md-12 pt-0 pb-5 ps-7\">\r\n                  <div id=\"map\" class=\"w-100\" ></div>\r\n                  </div>\r\n            </div>\r\n            <div *ngIf=\"storeIdarray?.length === 1\" class=\"card pb-2\">\r\n                <div class=\"card-header border-0 pt-3 ps-5 pe-0\">\r\n                    <h3 class=\"card-title align-items-start flex-column\">\r\n                        <span class=\"title-text\">Recap Video \r\n                            <svg placement=\"right\"\r\n                            ngbTooltip=\"A quick recap of the store activity along with the avg tech infrastructure downtime status\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                            <g clip-path=\"url(#clip0_1432_80035)\">\r\n                            <path d=\"M8.00065 10.6666V7.99992M8.00065 5.33325H8.00732M14.6673 7.99992C14.6673 11.6818 11.6826 14.6666 8.00065 14.6666C4.31875 14.6666 1.33398 11.6818 1.33398 7.99992C1.33398 4.31802 4.31875 1.33325 8.00065 1.33325C11.6826 1.33325 14.6673 4.31802 14.6673 7.99992Z\" stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                            </g>\r\n                            <defs>\r\n                            <clipPath id=\"clip0_1432_80035\">\r\n                            <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n                            </clipPath>\r\n                            </defs>\r\n                            </svg>\r\n                           \r\n                       \r\n                        </span>\r\n                      \r\n                        <span class=\"text-sub mb-2\">Dated: {{headerData?.date?.endDate | date:' dd MMM,yyyy'}}</span>\r\n                    </h3>\r\n                    <div class=\"card-toolbar mt-0\">\r\n                        <button type=\"button\" \r\n                        class=\"btn btn-default btn-outline btn-outline-default rounded-3 text-nowrap border-val text-start disabled-button\">\r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"14\" viewBox=\"0 0 16 14\" fill=\"none\">\r\n                            <g id=\"Group\">\r\n                            <path id=\"Vector\" d=\"M9.51953 0.333984C10.3958 0.333984 11.2331 0.513477 11.9974 0.838974C12.7904 1.17653 13.5039 1.67214 14.1016 2.28697C14.6979 2.90046 15.1797 3.6345 15.5078 4.45293C15.8242 5.23922 15.9987 6.10051 15.9987 7.00065C15.9987 7.90213 15.8242 8.76343 15.5078 9.54971C15.1797 10.3655 14.6979 11.0995 14.1003 11.7143C13.5039 12.3278 12.7904 12.8234 11.9948 13.161C11.2305 13.4865 10.3932 13.666 9.51823 13.666C8.64193 13.666 7.80469 13.4865 7.04036 13.161C6.2474 12.8234 5.53385 12.3278 4.9375 11.7143L4.9362 11.713C4.33854 11.0982 3.85807 10.3641 3.52995 9.54971C3.42839 9.29655 3.34115 9.03668 3.26953 8.77013C3.40495 8.78352 3.54297 8.79022 3.68229 8.79022C3.94661 8.79022 4.20443 8.76611 4.45573 8.71922C4.4974 8.84782 4.54297 8.97507 4.59245 9.09964C4.86198 9.76939 5.25781 10.3722 5.75 10.8785C6.24219 11.3848 6.82943 11.792 7.47917 12.0693C8.10547 12.3359 8.79427 12.4845 9.51823 12.4845C10.2422 12.4845 10.9297 12.3372 11.5573 12.0693C12.2083 11.792 12.7943 11.3848 13.2865 10.8785C13.7786 10.3722 14.1745 9.76805 14.444 9.09964C14.7031 8.45534 14.8477 7.74675 14.8477 7.00199C14.8477 6.25723 14.7044 5.54998 14.444 4.90434C14.1745 4.23459 13.7786 3.63182 13.2865 3.12549C12.7943 2.61916 12.207 2.21196 11.5573 1.93468C10.931 1.66812 10.2422 1.51944 9.51823 1.51944C8.79427 1.51944 8.10677 1.66678 7.47917 1.93468C7.42318 1.95879 7.36719 1.98424 7.3125 2.00969C7.09896 1.6641 6.84115 1.35066 6.54557 1.07874C6.70703 0.993016 6.8724 0.913986 7.04036 0.841653C7.80729 0.513477 8.64323 0.333984 9.51953 0.333984ZM8.77604 3.83141C8.77604 3.66799 8.84115 3.52064 8.94401 3.41348C9.04818 3.30632 9.19141 3.24069 9.35026 3.24069C9.50911 3.24069 9.65234 3.30632 9.75651 3.41348C9.86068 3.52064 9.92448 3.66799 9.92448 3.83141V6.94171L12.1836 8.32005C12.319 8.4031 12.4102 8.53571 12.4466 8.68172C12.4831 8.82772 12.4661 8.98846 12.3854 9.12777V9.12911C12.3047 9.26842 12.1758 9.36218 12.0339 9.39969C11.8919 9.43719 11.7357 9.41978 11.6003 9.33673H11.599L9.07161 7.79497C8.98438 7.74541 8.91276 7.67308 8.86068 7.58735C8.80729 7.4976 8.77604 7.39178 8.77604 7.27927V3.83141Z\" fill=\"#667085\"/>\r\n                            <path id=\"Vector_2\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M3.51302 0.687622C5.45312 0.687622 7.02604 2.30573 7.02604 4.30158C7.02604 6.29743 5.45312 7.91554 3.51302 7.91554C1.57292 7.91554 0 6.29743 0 4.30158C0 2.30573 1.57292 0.687622 3.51302 0.687622ZM3.51302 6.37378L5.39844 3.97608H4.22786V2.70088H2.79818V3.97608H1.6276L3.51302 6.37378Z\" fill=\"#F04438\"/>\r\n                            </g>\r\n                            </svg>\r\n                        <span class=\"ms-2\">{{getRecapVideoData?.downTime ?? '--'}} Mins</span>\r\n                    </button>\r\n                    <button type=\"button\" \r\n                        class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val disabled-button\">\r\n                        <svg *ngIf=\"getRecapVideoData?.health ==='GOOD'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                            <g id=\"Frame\">\r\n                            <path id=\"Vector\" d=\"M13.4349 2.5C14.8238 2.5 15.9871 3.01389 16.9249 4.04167C17.8627 5.06944 18.3313 6.29167 18.3307 7.70833C18.3307 7.95833 18.3168 8.205 18.2891 8.44833C18.2613 8.69167 18.2127 8.93111 18.1432 9.16667H12.9349L11.5182 7.04167C11.4488 6.93056 11.3516 6.84028 11.2266 6.77083C11.1016 6.70139 10.9696 6.66667 10.8307 6.66667C10.6502 6.66667 10.4868 6.72222 10.3407 6.83333C10.1946 6.94444 10.0941 7.08333 10.0391 7.25L8.91406 10.625L8.1849 9.54167C8.11545 9.43056 8.01823 9.34028 7.89323 9.27083C7.76823 9.20139 7.63628 9.16667 7.4974 9.16667H1.85156C1.78212 8.93056 1.73351 8.69083 1.70573 8.4475C1.67795 8.20417 1.66406 7.96472 1.66406 7.72917C1.66406 6.29861 2.12934 5.06944 3.0599 4.04167C3.99045 3.01389 5.15017 2.5 6.53906 2.5C7.20573 2.5 7.83434 2.63194 8.4249 2.89583C9.01545 3.15972 9.53962 3.52778 9.9974 4C10.4418 3.52778 10.9593 3.15972 11.5499 2.89583C12.1405 2.63194 12.7688 2.5 13.4349 2.5ZM9.9974 17.5C9.7474 17.5 9.50767 17.4547 9.27823 17.3642C9.04878 17.2736 8.84406 17.1383 8.66406 16.9583L3.08073 11.3542C2.9974 11.2708 2.92101 11.1875 2.85156 11.1042C2.78212 11.0208 2.71267 10.9306 2.64323 10.8333H7.03906L8.45573 12.9583C8.52517 13.0694 8.6224 13.1597 8.7474 13.2292C8.8724 13.2986 9.00434 13.3333 9.14323 13.3333C9.32378 13.3333 9.49045 13.2778 9.64323 13.1667C9.79601 13.0556 9.90017 12.9167 9.95573 12.75L11.0807 9.375L11.7891 10.4583C11.8724 10.5694 11.9766 10.6597 12.1016 10.7292C12.2266 10.7986 12.3585 10.8333 12.4974 10.8333H17.3307L17.1224 11.0833L16.9141 11.3333L11.3099 16.9583C11.1293 17.1389 10.928 17.2744 10.7057 17.365C10.4835 17.4556 10.2474 17.5006 9.9974 17.5Z\" fill=\"#12B76A\"/>\r\n                            </g>\r\n                            </svg>\r\n                            <svg *ngIf=\"getRecapVideoData?.health ==='AVERAGE'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                                <g id=\"Frame\">\r\n                                <path id=\"Vector\" d=\"M13.4349 2.5C14.8238 2.5 15.9871 3.01389 16.9249 4.04167C17.8627 5.06944 18.3313 6.29167 18.3307 7.70833C18.3307 7.95833 18.3168 8.205 18.2891 8.44833C18.2613 8.69167 18.2127 8.93111 18.1432 9.16667H12.9349L11.5182 7.04167C11.4488 6.93056 11.3516 6.84028 11.2266 6.77083C11.1016 6.70139 10.9696 6.66667 10.8307 6.66667C10.6502 6.66667 10.4868 6.72222 10.3407 6.83333C10.1946 6.94444 10.0941 7.08333 10.0391 7.25L8.91406 10.625L8.1849 9.54167C8.11545 9.43056 8.01823 9.34028 7.89323 9.27083C7.76823 9.20139 7.63628 9.16667 7.4974 9.16667H1.85156C1.78212 8.93056 1.73351 8.69083 1.70573 8.4475C1.67795 8.20417 1.66406 7.96472 1.66406 7.72917C1.66406 6.29861 2.12934 5.06944 3.0599 4.04167C3.99045 3.01389 5.15017 2.5 6.53906 2.5C7.20573 2.5 7.83434 2.63194 8.4249 2.89583C9.01545 3.15972 9.53962 3.52778 9.9974 4C10.4418 3.52778 10.9593 3.15972 11.5499 2.89583C12.1405 2.63194 12.7688 2.5 13.4349 2.5ZM9.9974 17.5C9.7474 17.5 9.50767 17.4547 9.27823 17.3642C9.04878 17.2736 8.84406 17.1383 8.66406 16.9583L3.08073 11.3542C2.9974 11.2708 2.92101 11.1875 2.85156 11.1042C2.78212 11.0208 2.71267 10.9306 2.64323 10.8333H7.03906L8.45573 12.9583C8.52517 13.0694 8.6224 13.1597 8.7474 13.2292C8.8724 13.2986 9.00434 13.3333 9.14323 13.3333C9.32378 13.3333 9.49045 13.2778 9.64323 13.1667C9.79601 13.0556 9.90017 12.9167 9.95573 12.75L11.0807 9.375L11.7891 10.4583C11.8724 10.5694 11.9766 10.6597 12.1016 10.7292C12.2266 10.7986 12.3585 10.8333 12.4974 10.8333H17.3307L17.1224 11.0833L16.9141 11.3333L11.3099 16.9583C11.1293 17.1389 10.928 17.2744 10.7057 17.365C10.4835 17.4556 10.2474 17.5006 9.9974 17.5Z\" fill=\"#FACC15\"/>\r\n                                </g>\r\n                                </svg>\r\n                                <svg *ngIf=\"getRecapVideoData?.health ==='BAD'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                                    <g id=\"Frame\">\r\n                                    <path id=\"Vector\" d=\"M13.4349 2.5C14.8238 2.5 15.9871 3.01389 16.9249 4.04167C17.8627 5.06944 18.3313 6.29167 18.3307 7.70833C18.3307 7.95833 18.3168 8.205 18.2891 8.44833C18.2613 8.69167 18.2127 8.93111 18.1432 9.16667H12.9349L11.5182 7.04167C11.4488 6.93056 11.3516 6.84028 11.2266 6.77083C11.1016 6.70139 10.9696 6.66667 10.8307 6.66667C10.6502 6.66667 10.4868 6.72222 10.3407 6.83333C10.1946 6.94444 10.0941 7.08333 10.0391 7.25L8.91406 10.625L8.1849 9.54167C8.11545 9.43056 8.01823 9.34028 7.89323 9.27083C7.76823 9.20139 7.63628 9.16667 7.4974 9.16667H1.85156C1.78212 8.93056 1.73351 8.69083 1.70573 8.4475C1.67795 8.20417 1.66406 7.96472 1.66406 7.72917C1.66406 6.29861 2.12934 5.06944 3.0599 4.04167C3.99045 3.01389 5.15017 2.5 6.53906 2.5C7.20573 2.5 7.83434 2.63194 8.4249 2.89583C9.01545 3.15972 9.53962 3.52778 9.9974 4C10.4418 3.52778 10.9593 3.15972 11.5499 2.89583C12.1405 2.63194 12.7688 2.5 13.4349 2.5ZM9.9974 17.5C9.7474 17.5 9.50767 17.4547 9.27823 17.3642C9.04878 17.2736 8.84406 17.1383 8.66406 16.9583L3.08073 11.3542C2.9974 11.2708 2.92101 11.1875 2.85156 11.1042C2.78212 11.0208 2.71267 10.9306 2.64323 10.8333H7.03906L8.45573 12.9583C8.52517 13.0694 8.6224 13.1597 8.7474 13.2292C8.8724 13.2986 9.00434 13.3333 9.14323 13.3333C9.32378 13.3333 9.49045 13.2778 9.64323 13.1667C9.79601 13.0556 9.90017 12.9167 9.95573 12.75L11.0807 9.375L11.7891 10.4583C11.8724 10.5694 11.9766 10.6597 12.1016 10.7292C12.2266 10.7986 12.3585 10.8333 12.4974 10.8333H17.3307L17.1224 11.0833L16.9141 11.3333L11.3099 16.9583C11.1293 17.1389 10.928 17.2744 10.7057 17.365C10.4835 17.4556 10.2474 17.5006 9.9974 17.5Z\" fill=\"#F04438\"/>\r\n                                    </g>\r\n                                    </svg>\r\n                        <span class=\"ms-2\">{{getRecapVideoData?.health ?? '--'}}</span>\r\n                    </button>\r\n                        <!-- <button type=\"button\" (click)=\"cameraView()\"\r\n                        class=\"btn mx-2 btn-light-primary1 rounded-3 text-nowrap border-val\">\r\n                        <span class=\"ms-2\">Live View</span>\r\n                    </button> -->\r\n                    </div>\r\n            \r\n                </div>\r\n                <div *ngIf=\"recaplaoding\" class=\"row loader d-flex justify-content-center align-items-center h-225px\">\r\n                    <div class=\"shimmer pt-0\">\r\n                        <div class=\"wrapper\">\r\n                            <div class=\"stroke animate title\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n                            <div class=\"stroke animate title\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div *ngIf=\"recapnoData\"  class=\"row px-3\">\r\n                    <div class=\"col-md-12\">\r\n                        <div *ngIf=\"normalize\" class=\"card-body d-flex justify-content-center mb-10 align-items-center flex-column\">\r\n                            <img class=\"img-map1\" src=\"./assets/tango/Icons/not-applicable.svg\" alt=\"\">\r\n                            <div class=\"nodata-title mt-3\">Data Not Found</div>\r\n                            <div class=\"nodata-sub\">Normalized data is not applicable</div>\r\n                        </div>\r\n                        <div *ngIf=\"!normalize\" class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                            <img class=\"img-map-recap\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                            <div class=\"nodata-title\">No data found</div>\r\n                            <div class=\"nodata-sub\">There is no result for this Recap video</div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div *ngIf=\"!recaplaoding && !recapnoData\" class=\"card-body p-0\">\r\n                    <div class=\"row mx-3\">\r\n                \r\n                        <div class=\"carousel\">\r\n                            <div class=\"carousel-inner\">\r\n                              <div\r\n                                class=\"carousel-item\"\r\n                                *ngFor=\"let group of recapsGrouped; let i = index\"\r\n                                [class.active]=\"i === currentIndex\"\r\n                              >\r\n                                <div class=\"row\">\r\n                                  <div *ngFor=\"let pair of group\" [ngClass]=\"colValue\">\r\n                                    <img [src]=\"pair.thumbImage\"\r\n                                         (click)=\"videoClick(pair)\"\r\n                                         class=\"image-thumb mb-8 d-block w-100 cursor-pointer\"\r\n                                         alt=\"Image {{ i + 1 }}\" />\r\n                                  </div>\r\n                                </div>\r\n                              </div>\r\n                            </div>\r\n                          \r\n                            <!-- Conditionally display Previous button -->\r\n                            <button class=\"carousel-control-prev\" *ngIf=\"currentIndex > 0\" (click)=\"prevSlide()\">\r\n                              <span class=\"carousel-control-prev-icon\"></span>\r\n                            </button>\r\n                          \r\n                            <!-- Conditionally display Next button -->\r\n                            <button class=\"carousel-control-next\" *ngIf=\"currentIndex < recapsGrouped.length - 1\" (click)=\"nextSlide()\">\r\n                              <span class=\"carousel-control-next-icon\"></span>\r\n                            </button>\r\n                          \r\n                            <!-- Navigation Dots -->\r\n                            <div *ngIf=\"recapsGrouped.length > 1\" class=\"row\">\r\n                              <ul class=\"carousel-indicators\">\r\n                                <li *ngFor=\"let group of recapsGrouped; let i = index\"\r\n                                    [class.active]=\"i === currentIndex\"\r\n                                    (click)=\"goToSlide(i)\">\r\n                                </li>\r\n                              </ul>\r\n                            </div>\r\n\r\n                          </div>\r\n                          \r\n                          \r\n                        <!-- <video controls autoplay class=\"recap-img p-3\" [src]=\"getRecapData?.videoURL\"> -->\r\n                            <!-- <source  type=\"video/mp4\"> -->\r\n                            <!-- <source [src]=\"getRecapData?.videoURL\" type=\"video/ogg\"> -->\r\n                          <!-- </video> -->\r\n                        <!-- <div #mapContainer style=\"height:230px;\"></div> -->\r\n                        <!-- <div class=\"col-md-6 mb-3\"><img src=\"assets/tango/Images/recap.svg\" alt=\"\" class=\"recap-img\"></div>\r\n                        <div class=\"col-md-6 mb-3\"><img src=\"assets/tango/Images/recap.svg\" alt=\"\" class=\"recap-img\"></div> -->\r\n\r\n                    </div>\r\n                </div>\r\n                </div>\r\n    \r\n    </div>\r\n    <div  class=\"col-md-12 mt-3\">\r\n\r\n        <!-- footfall trend charts -->\r\n        <div *ngIf=\"storeIdarray[0] !=='459-2'\" class=\"card\">\r\n            <div class=\"card-header border-0 pt-3\">\r\n                <h3 class=\"card-title align-items-start flex-column\">\r\n                    <span class=\"card-label1 mb-2\">Footfall Trend</span>\r\n                    <span class=\"text-sub mb-2\">Based on {{getDateValues?.fromDate | date:'dd MMM, yyyy'}} – {{getDateValues?.toDate | date:'dd MMM, yyyy'}}</span>\r\n                </h3>\r\n                <div class=\"card-toolbar text-nowrap\">\r\n                    <div class=\"d-flex\">\r\n                        <div class=\"d-flex align-items-center position-relative my-1\">\r\n                            <!--begin::Nav group-->\r\n                            <div class=\"nav-group nav-group-outline border-1 btn-group p-0\">\r\n                                <button class=\"btn btn-outline px-6 py-3\"\r\n                                    [ngClass]=\"type === 'daily' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n                                    (click)=\"selectPlanTrends('daily')\">\r\n                                    Day\r\n                                </button>\r\n                             <!-- Month Button -->\r\n        \r\n        \r\n        <!-- Week Button -->\r\n        <button  class=\"btn btn-outline px-6 py-3\"\r\n            [ngClass]=\"type === 'weekly' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n            (click)=\"selectPlanTrends('weekly')\">\r\n            Week\r\n        </button>\r\n        \r\n        <!-- Day Button, visible only if dateLength is valid and type is either 'weekly' or 'daily' -->\r\n        <button class=\"btn btn-outline px-6 py-3\"\r\n            [ngClass]=\"type === 'monthly' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n            (click)=\"selectPlanTrends('monthly')\">\r\n            Month\r\n        </button>\r\n        \r\n                            </div>\r\n                            <!--end::Nav group-->\r\n                            <div class=\"d-flex\">\r\n                                <span class=\"mx-2 mt-3 dropselect\">Trend</span>\r\n        \r\n                                <form [formGroup]=\"form\">\r\n                                    <lib-reactive-select\r\n                                      [formControl]=\"selectControl\" \r\n                                      [idField]=\"'value'\"\r\n                                      [nameField]=\"'label'\"\r\n                                      [data]=\"datasets\"\r\n                                      class=\"w-100\"\r\n                                      (valueChange)=\"onValueChangetrend($event)\">\r\n                                    </lib-reactive-select>\r\n                                  </form>\r\n                                <!-- <select class=\"form-select form-select-sm\" (change)=\"onDatasetChange($event)\">\r\n                                    <option *ngFor=\"let dataset of datasets\" [value]=\"dataset.value\">{{ dataset.label }}\r\n                                    </option>\r\n                                </select> -->\r\n                            </div>\r\n                            <div class=\"d-flex mt-1 ms-3\">\r\n                                <section *ngIf=\"storeIdarray?.length === 1\">\r\n                                <span  class=\"d-flex ms-1 dropselect mt-2 cursor-pointer text-nowrap fs-5\">Forecast\r\n                                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                        fill=\"none\">\r\n                                        <g clip-path=\"url(#clip0_2645_27459)\">\r\n                                            <path\r\n                                                d=\"M3.33398 1.33331L3.46065 1.95998C3.55142 2.40998 3.75683 2.82893 4.05699 3.17628C4.35715 3.52362 4.74189 3.78759 5.17398 3.94265L5.33398 3.99998L5.17398 4.05731C4.74189 4.21237 4.35715 4.47634 4.05699 4.82368C3.75683 5.17103 3.55142 5.58998 3.46065 6.03998L3.33398 6.66665L3.20732 6.03998C3.11654 5.58998 2.91114 5.17103 2.61098 4.82368C2.31082 4.47634 1.92607 4.21237 1.49398 4.05731L1.33398 3.99998L1.49398 3.94265C1.92607 3.78759 2.31082 3.52362 2.61098 3.17628C2.91114 2.82893 3.11654 2.40998 3.20732 1.95998L3.33398 1.33331ZM5.33398 10.6666L5.48732 11.5173C5.52713 11.7392 5.62256 11.9474 5.76468 12.1224C5.9068 12.2974 6.09098 12.4335 6.29998 12.518L6.66732 12.6666L6.29998 12.8153C6.09094 12.8997 5.90668 13.0356 5.76445 13.2105C5.62221 13.3854 5.52663 13.5935 5.48665 13.8153L5.33398 14.6666L5.18065 13.816C5.14084 13.5941 5.04541 13.3859 4.90329 13.2109C4.76117 13.0359 4.57699 12.8998 4.36798 12.8153L4.00065 12.6666L4.36798 12.518C4.57703 12.4336 4.76129 12.2977 4.90352 12.1228C5.04576 11.9479 5.14133 11.7398 5.18132 11.518L5.33398 10.6666ZM10.6673 1.99998L11.038 3.76931C11.2269 4.67137 11.6463 5.50908 12.2554 6.20076C12.8645 6.89244 13.6424 7.41448 14.5133 7.71598L15.334 7.99998L14.5133 8.28398C13.6424 8.58548 12.8645 9.10752 12.2554 9.7992C11.6463 10.4909 11.2269 11.3286 11.038 12.2306L10.6673 14L10.2967 12.2306C10.1077 11.3286 9.6883 10.4909 9.07922 9.7992C8.47015 9.10752 7.69223 8.58548 6.82132 8.28398L6.00065 7.99998L6.82132 7.71598C7.69223 7.41448 8.47015 6.89244 9.07922 6.20076C9.6883 5.50908 10.1077 4.67137 10.2967 3.76931L10.6673 1.99998Z\"\r\n                                                stroke=\"#344054\" stroke-width=\"1.5\" stroke-linecap=\"round\"\r\n                                                stroke-linejoin=\"round\" />\r\n                                        </g>\r\n                                        <defs>\r\n                                            <clipPath id=\"clip0_2645_27459\">\r\n                                                <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                                            </clipPath>\r\n                                        </defs>\r\n                                    </svg>\r\n        \r\n                                    <span class=\"form-check form-switch mx-3\">\r\n                                        <input class=\"form-check-input  cursor-pointer\" type=\"checkbox\" [(ngModel)]=\"forecast\" (click)=\"forecastApi($event)\">\r\n                                    </span>\r\n        \r\n                                </span>\r\n        </section>\r\n                                <div *ngIf=\"!objData?.forecast\" class=\"position-relative cursor-pointer\">\r\n                                    <div class=\"ms-1\" (click)=\"producttrailDropdown($event)\">\r\n                                        <svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\"\r\n                                        xmlns=\"http://www.w3.org/2000/svg\">\r\n                                        <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"1.66667\"\r\n                                            stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                    </svg>  \r\n                                       \r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"show\"\r\n                                    class=\"card py-2 w-200px position-absolute productdrop top-20 end-1 mt-10 z-1\">\r\n                                    <ul *ngIf=\"!objData?.forecast\"  class=\"list-unstyled mb-2\">\r\n                                        <!-- <li class=\"producttext px-5 items cursor-pointer py-4\" [ngClass]=\"trendtypeValue ==='normalize' ? 'bg-forcast':''\" type=\"button\"\r\n                                        (click)=\"changeStatus('normalize')\">Normalize\r\n                                            <svg class=\"text-end ms-20\" *ngIf=\"trendtypeValue ==='normalize' ? 'bg-forcast':''\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                                                width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                <path d=\"M13.3327 4L5.99935 11.3333L2.66602 8\" stroke=\"#344054\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </svg>\r\n                                       </li> -->\r\n                                       <li  *ngIf=\"storeIdarray?.length === 1\" class=\"producttext px-5 items cursor-pointer py-4\" [ngClass]=\"trendtypeValue ==='actual' ? 'bg-forcast':''\" type=\"button\"\r\n                                       (click)=\"changeStatus('actual')\">Actual\r\n                                           <svg class=\"text-end ms-20\" *ngIf=\"trendtypeValue ==='actual' ? 'bg-forcast':''\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                                               width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                               <path d=\"M13.3327 4L5.99935 11.3333L2.66602 8\" stroke=\"#344054\" stroke-width=\"1.5\"\r\n                                                   stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                           </svg>\r\n                                      </li>\r\n                                    <li *ngIf=\"storeIdarray?.length > 1\" class=\"producttext px-5 items cursor-pointer py-4\" [ngClass]=\"trendtypeValue ==='average' ? 'bg-forcast':''\" type=\"button\"\r\n                                        (click)=\"changeStatus('average')\">Average\r\n                                           <span> <svg class=\"text-end ms-20\" *ngIf=\"trendtypeValue ==='average' ? 'bg-forcast':''\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                                                width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                <path d=\"M13.3327 4L5.99935 11.3333L2.66602 8\" stroke=\"#344054\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </svg></span>\r\n                                        </li>\r\n                                    <!-- <li class=\"producttext px-5 items cursor-pointer py-4\" [ngClass]=\"trendtypeValue ==='target' ? 'bg-forcast':''\" type=\"button\"\r\n                                    (click)=\"changeStatus('target')\">Target\r\n                                            <svg class=\"text-end ms-20\" *ngIf=\"trendtypeValue ==='target' ? 'bg-forcast':''\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                                            width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path d=\"M13.3327 4L5.99935 11.3333L2.66602 8\" stroke=\"#344054\" stroke-width=\"1.5\" stroke-linecap=\"round\"\r\n                                                stroke-linejoin=\"round\" />\r\n                                        </svg></li> -->\r\n                                   \r\n                                    <li class=\"producttext px-5 items cursor-pointer py-4\" [ngClass]=\"trendtypeValue ==='weekends' ? 'bg-forcast':''\" type=\"button\"\r\n                                    (click)=\"changeStatus('weekends')\">Weekends\r\n                                            <svg class=\"text-end ms-20\" *ngIf=\"trendtypeValue ==='weekends' ? 'bg-forcast':''\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                                            width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path d=\"M13.3327 4L5.99935 11.3333L2.66602 8\" stroke=\"#344054\" stroke-width=\"1.5\" stroke-linecap=\"round\"\r\n                                                stroke-linejoin=\"round\" />\r\n                                        </svg></li>\r\n                                   \r\n                                    <li class=\"producttext px-5 items cursor-pointer py-4\" [ngClass]=\"trendtypeValue ==='weekdays' ? 'bg-forcast':''\" type=\"button\"\r\n                                    (click)=\"changeStatus('weekdays')\">Weekdays\r\n                                            <svg class=\"text-end ms-20\" *ngIf=\"trendtypeValue ==='weekdays' ? 'bg-forcast':''\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                                                width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                <path d=\"M13.3327 4L5.99935 11.3333L2.66602 8\" stroke=\"#344054\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </svg>\r\n                                        </li>\r\n                                    </ul>\r\n                                </div>\r\n                            </div>\r\n        \r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"loadingTrends\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                <div class=\"shimmer\">\r\n                    <div class=\"wrapper\">\r\n                        <div class=\"stroke animate title\"></div>\r\n                        <div class=\"stroke animate link\"></div>\r\n                        <div class=\"stroke animate description\"></div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"shimmer\">\r\n                    <div class=\"wrapper\">\r\n                        <div class=\"stroke animate title\"></div>\r\n                        <div class=\"stroke animate link\"></div>\r\n                        <div class=\"stroke animate description\"></div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"noDataTrends\" class=\"row\">\r\n                <div class=\"col-lg-12 mb-3\">\r\n                    <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                        <img class=\"img-nodata\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                        <div class=\"nodata-title\">No data found</div>\r\n                        <div class=\"nodata-sub\">There is no result for this footfall trend</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"card-body p-0\" *ngIf=\"!noDataTrends && !loadingTrends\">\r\n                <div class=\"text-center px-3\" id=\"Footfalltrend\"></div>\r\n        \r\n                \r\n                <div #tooltipContainer class=\"tooltip-container\" >\r\n                    <div class=\"tooltip-content\" *ngIf=\"tooltipData\">\r\n                        <div class=\"content p-5\">\r\n                          <!-- <div class=\"container\">\r\n                            <span class=\"title text-start\">{{tooltipData.fullStoreName}}</Span>\r\n                            <span>Sum</span>\r\n                            <span>Avg</span>\r\n                          </div> -->\r\n                          \r\n                          <!-- Table for counts and rates in horizontal format -->\r\n                          <table class=\"table table-horizontal trens\">\r\n                            <thead>\r\n                              <tr>\r\n                              <th class=\"title text-start px-3\">{{tooltipData.fullStoreName}}</th>\r\n                            <th class=\"title text-end\">Sum</th>\r\n                            \r\n                            <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                            <th *ngIf=\"type !== 'daily'\" class=\"title text-end\">Avg</th>\r\n                        </ng-container>\r\n                              </tr>\r\n                            </thead>\r\n                            <tbody>\r\n                              <!-- Counts Section -->\r\n                              <tr >\r\n                                <td class=\"trend-label\"  style=\"line-height: 10px !important\">Total Footfall</td>\r\n                                <td class=\"value\"  style=\"line-height: 10px !important\">{{tooltipData.footfall_count}}</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value\"  style=\"line-height: 10px !important\">{{tooltipData.footfall_count_avg}}</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                              <tr >\r\n                                <td class=\"trend-label\"  style=\"line-height: 10px !important\"><span *ngIf=\"headerData?.client === '452'\">Less than {{clientData?.featureConfigs?.bouncedLimit?.value}} mins</span> <span *ngIf=\"headerData?.client !== '452'\">Bounced Footfall</span></td>\r\n                                <td class=\"value\"  style=\"line-height: 10px !important\">{{tooltipData.bounced_count}}</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value\"  style=\"line-height: 10px !important\">{{tooltipData.bounced_footfall_count_avg}}</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                              <tr>\r\n                                <td class=\"trend-label\" style=\"line-height: 10px !important\"><span *ngIf=\"headerData?.client === '452'\">More than {{clientData?.featureConfigs?.bouncedLimit?.value}} mins</span> <span *ngIf=\"headerData?.client !== '452'\">Engagers</span></td>\r\n                                <td class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.engagers_count}}</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.engagers_count_avg}}</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                              <tr>\r\n                                <td class=\"trend-label\" style=\"line-height: 10px !important\"><span *ngIf=\"headerData?.client === '452'\">{{clientData?.featureConfigs?.missedOpportunityFrom?.value}} - {{clientData?.featureConfigs?.missedOpportunityTo?.value}} mins</span> <span *ngIf=\"headerData?.client !== '452'\">Missed Opportunities</span></td>\r\n                                <td class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.missedOpportunity_count}}</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.missedOpportunity_count_avg}}</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                              <tr style=\"line-height: 10px !important\">\r\n                                <td class=\"trend-label\" style=\"line-height: 10px !important\">Down Time</td>\r\n                                <td class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.down_time ? tooltipData.down_time :'--'}}</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.down_time}}</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                      \r\n                              <!-- Rates Section -->\r\n                              <tr >\r\n                                <td class=\"trend-label\" style=\"line-height: 10px !important\">Dwell Time</td>\r\n                                <td class=\"value text-nowrap\" style=\"line-height: 10px !important\">{{tooltipData.avgDwellTime.toFixed(0)}} Mins</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value text-nowrap\" style=\"line-height: 10px !important\">{{tooltipData.avgDwellTime.toFixed(0)}} Mins</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                              <tr >\r\n                                <td class=\"trend-label\" style=\"line-height: 10px !important\"><span *ngIf=\"headerData?.client === '452'\"> More than {{clientData?.featureConfigs?.conversion?.value}} mins Rate</span><span *ngIf=\"headerData?.client !== '452'\">Conversion</span></td>\r\n                                <td class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.conversionRate.toFixed(0)}}%</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.conversionRate.toFixed(0)}}%</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                            </tbody>\r\n                          </table>\r\n                        </div>\r\n                      </div>\r\n                      \r\n                  </div>\r\n        \r\n        \r\n                  <lib-pagination [itemsPerPage]=\"pageSizeTrends\" [currentPage]=\"offsetTrends\" [totalItems]=\"totalItemsTrends\"\r\n                  [paginationSizes]=\"paginationSizesTrends\" [pageSize]=\"pageSizeTrends\" (pageChange)=\"onPageChangeTrends($event)\"\r\n                  (pageSizeChange)=\"onPageSizeChangeTrends($event)\"></lib-pagination>\r\n               \r\n            </div>\r\n        </div>\r\n\r\n        <!-- <lib-traffic-charts class=\"my-2\"></lib-traffic-charts> -->\r\n        <div *ngIf=\"storeIdarray[0] !=='459-2'\" class=\"card mt-3\">\r\n            <div class=\"card-header my-3 mx-2\">\r\n                <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\r\n                    <li *ngIf=\"this.headerData?.client !=='459'\" class=\"nav-item nav-item1\" (click)=\"selectedTabs('traffic')\"><a\r\n                            [ngClass]=\"selectedTab ==='traffic' ? 'active' :''\"\r\n                            class=\"nav-link nav-link1 cursor-pointer no-border me-6 \">Traffic & Dwell</a>\r\n                    </li>\r\n                    <li class=\"nav-item nav-item1\" (click)=\"selectedTabs('footfall')\">\r\n                        <a [ngClass]=\"selectedTab ==='footfall' ? 'active' :''\"\r\n                            class=\"nav-link nav-link1 cursor-pointer me-6\">Footfall</a>\r\n                    </li>\r\n                    <li class=\"nav-item nav-item1\" (click)=\"selectedTabs('bounced')\"><a\r\n                        [ngClass]=\"selectedTab ==='bounced' ? 'active' :''\"\r\n                        class=\"nav-link nav-link1 cursor-pointer no-border me-6 \">{{headerData?.client ==='452' ? 'Less than '+ featureConfig?.bouncedLimit.value+ ' mins' : 'Bounced'}} Footfall</a>\r\n                </li>\r\n                <li class=\"nav-item nav-item1\" (click)=\"selectedTabs('engagers')\">\r\n                    <a [ngClass]=\"selectedTab ==='engagers' ? 'active' :''\"\r\n                        class=\"nav-link nav-link1 cursor-pointer me-6\">{{headerData?.client ==='452' ? 'More than '+ featureConfig?.bouncedLimit.value +' mins' : 'Engagers'}}</a>\r\n                </li>\r\n              \r\n                   \r\n                    <li class=\"nav-item nav-item1\" (click)=\"selectedTabs('missedOpportunity')\">\r\n                        <a [ngClass]=\"selectedTab ==='missedOpportunity' ? 'active' :''\"\r\n                            class=\"nav-link nav-link1 cursor-pointer me-6\">{{headerData?.client ==='452' ? featureConfig?.missedOpportunityFrom.value+' - '+ featureConfig?.missedOpportunityTo.value+ ' mins':'Missed Opportunity'}}</a>\r\n                    </li>\r\n                    <li *ngIf=\"headerData?.client !== '452'\" class=\"nav-item nav-item1\" (click)=\"selectedTabs('potentialBuyers')\">\r\n                        <a [ngClass]=\"selectedTab ==='potentialBuyers' ? 'active' :''\"\r\n                            class=\"nav-link nav-link1 cursor-pointer me-6\">Potential Buyer</a>\r\n                    </li>\r\n                    <li class=\"nav-item nav-item1\" (click)=\"selectedTabs('conversion')\"><a\r\n                        [ngClass]=\"selectedTab ==='conversion' ? 'active' :''\"\r\n                        class=\"nav-link nav-link1 cursor-pointer no-border me-6 \">{{headerData?.client === '452' ? 'More than '+ featureConfig?.conversion.value + ' mins':'Conversion'}}</a>\r\n                </li>\r\n                </ul>\r\n            </div>\r\n        \r\n            <div class=\"card-body\">\r\n                <div *ngIf=\"chartloading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                    <div class=\"shimmer\">\r\n                        <div class=\"wrapper\">\r\n                            <div class=\"stroke animate title\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n                            <div class=\"stroke animate description\"></div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"shimmer\">\r\n                        <div class=\"wrapper\">\r\n                            <div class=\"stroke animate title\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n                            <div class=\"stroke animate description\"></div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div *ngIf=\"chartNoData\" class=\"row\">\r\n                    <div class=\"col-lg-12 mb-3\">\r\n                        <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                            <img class=\"img-nodata\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                            <div class=\"nodata-title\">No data found</div>\r\n                            <div class=\"nodata-sub\">There is no result for this <span>{{headerData?.client ==='452' ? 'Analysis' : selctedValue}}</span></div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"row\" >\r\n                    <div class=\"col-md-2 h-100\" *ngIf=\"!chartloading && !chartNoData\">\r\n                        <div *ngIf=\"selectedTab ==='traffic'\" class=\"left-bar\">\r\n                            \r\n                            <div class=\"my-7\">\r\n                                <div class=\"d-flex align-items-center my-10 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <span class=\"w-100\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"25\" viewBox=\"0 0 24 25\" fill=\"none\">\r\n                                            <path d=\"M13 2.125L3 14.125H12L11 22.125L21 10.125H12L13 2.125Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg></span>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getDensityDwellData?.densityDwellCard?.busiestDay ?\r\n                                            getDensityDwellData?.densityDwellCard?.busiestDay :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Busiest Day</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-10 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <span class=\"w-100\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"25\" viewBox=\"0 0 24 25\" fill=\"none\">\r\n                                            <path d=\"M13 2.125L3 14.125H12L11 22.125L21 10.125H12L13 2.125Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg></span>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getDensityDwellData?.densityDwellCard?.busiestTime ?\r\n                                            getDensityDwellData?.densityDwellCard?.busiestTime :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Busiest Time</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-10 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <span class=\"w-100\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"25\" viewBox=\"0 0 24 25\" fill=\"none\">\r\n                                            <path d=\"M13 2.125L3 14.125H12L11 22.125L21 10.125H12L13 2.125Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg></span>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getDensityDwellData?.densityDwellCard?.avgDwellTime ?\r\n                                            getDensityDwellData?.densityDwellCard?.avgDwellTime :'--'}} Mins</div>\r\n                                        <div class=\"left-card-count-header\">Avg Dwell Time</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-10 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <span class=\"w-100\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"25\" viewBox=\"0 0 24 25\" fill=\"none\">\r\n                                            <path d=\"M13 2.125L3 14.125H12L11 22.125L21 10.125H12L13 2.125Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg></span>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getDensityDwellData?.densityDwellCard?.maleRate ?\r\n                                            getDensityDwellData?.densityDwellCard?.maleRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">Male</div>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getDensityDwellData?.densityDwellCard?.femaleRate ?\r\n                                            getDensityDwellData?.densityDwellCard?.femaleRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">Female</div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"selectedTab ==='footfall'\" class=\"left-bar\">\r\n                            <div class=\"top-header text-center\">\r\n                                <div class=\"left-bar-count\"  [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.footfallCard?.footfallCount.toLocaleString()?.length > 5 ? '24px' : '36px') \r\n                                  }\" >\r\n                                        {{getOverallCardData?.footfallCard?.footfallCount ?\r\n                                    getOverallCardData?.footfallCard?.footfallCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                <div class=\"left-bar-title\">Footfall Count</div>\r\n        \r\n                            </div>\r\n                            <span class=\"w-100\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"174\" height=\"2\"\r\n                                    viewBox=\"0 0 194 2\" fill=\"none\">\r\n                                    <path opacity=\"0.4\" d=\"M1 1L193 1\" stroke=\"#99DAFF\" stroke-linecap=\"round\" />\r\n                                </svg></span>\r\n                            <div class=\"my-5\">\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M20 21V19C20 17.9391 19.5786 16.9217 18.8284 16.1716C18.0783 15.4214 17.0609 15 16 15H8C6.93913 15 5.92172 15.4214 5.17157 16.1716C4.42143 16.9217 4 17.9391 4 19V21M16 7C16 9.20914 14.2091 11 12 11C9.79086 11 8 9.20914 8 7C8 4.79086 9.79086 3 12 3C14.2091 3 16 4.79086 16 7Z\"\r\n                                                stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                stroke-linejoin=\"round\" />\r\n                                        </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.footfallCard?.singleCount ?\r\n                                            getOverallCardData?.footfallCard?.singleCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Single</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"headerData.client !=='452'\" class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg width=\"26\" height=\"24\" viewBox=\"0 0 26 24\" fill=\"none\"\r\n                                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <rect width=\"26\" height=\"24\" fill=\"#DCDCDC\" />\r\n                                            <rect x=\"-460.5\" y=\"-340.5\" width=\"783\" height=\"1947\" rx=\"4.5\" stroke=\"#9747FF\"\r\n                                                stroke-dasharray=\"10 5\" />\r\n                                            <mask id=\"path-2-inside-1_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\"\r\n                                                fill=\"white\" />\r\n                                            <path\r\n                                                d=\"M-190 -89C-190 -96.1797 -184.18 -102 -177 -102H294C301.18 -102 307 -96.1797 307 -89C307 -95.0751 301.627 -100 295 -100H-177C-183.075 -100 -188 -95.0751 -188 -89H-190ZM307 85C307 92.1797 301.18 98 294 98H-177C-184.18 98 -190 92.1797 -190 85H-188C-188 91.0751 -183.075 96 -177 96H295C301.627 96 307 91.0751 307 85ZM-177 98C-184.18 98 -190 92.1797 -190 85V-89C-190 -96.1797 -184.18 -102 -177 -102V-100C-183.075 -100 -188 -95.0751 -188 -89V85C-188 91.0751 -183.075 96 -177 96V98ZM307 -101V97V-101Z\"\r\n                                                fill=\"#D0D5DD\" mask=\"url(#path-2-inside-1_707_13106)\" />\r\n                                            <mask id=\"path-6-inside-2_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\"\r\n                                                stroke=\"#98A2B3\" stroke-width=\"3\" mask=\"url(#path-6-inside-2_707_13106)\" />\r\n                                        </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.footfallCard?.groupCount ?\r\n                                            getOverallCardData?.footfallCard?.groupCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Group Footfall</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg width=\"26\" height=\"24\" viewBox=\"0 0 26 24\" fill=\"none\"\r\n                                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <rect width=\"26\" height=\"24\" fill=\"#DCDCDC\" />\r\n                                            <rect x=\"-460.5\" y=\"-340.5\" width=\"783\" height=\"1947\" rx=\"4.5\" stroke=\"#9747FF\"\r\n                                                stroke-dasharray=\"10 5\" />\r\n                                            <mask id=\"path-2-inside-1_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\"\r\n                                                fill=\"white\" />\r\n                                            <path\r\n                                                d=\"M-190 -89C-190 -96.1797 -184.18 -102 -177 -102H294C301.18 -102 307 -96.1797 307 -89C307 -95.0751 301.627 -100 295 -100H-177C-183.075 -100 -188 -95.0751 -188 -89H-190ZM307 85C307 92.1797 301.18 98 294 98H-177C-184.18 98 -190 92.1797 -190 85H-188C-188 91.0751 -183.075 96 -177 96H295C301.627 96 307 91.0751 307 85ZM-177 98C-184.18 98 -190 92.1797 -190 85V-89C-190 -96.1797 -184.18 -102 -177 -102V-100C-183.075 -100 -188 -95.0751 -188 -89V85C-188 91.0751 -183.075 96 -177 96V98ZM307 -101V97V-101Z\"\r\n                                                fill=\"#D0D5DD\" mask=\"url(#path-2-inside-1_707_13106)\" />\r\n                                            <mask id=\"path-6-inside-2_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\"\r\n                                                stroke=\"#98A2B3\" stroke-width=\"3\" mask=\"url(#path-6-inside-2_707_13106)\" />\r\n                                        </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.footfallCard?.ageGroup ?\r\n                                            getOverallCardData?.footfallCard?.ageGroup :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Most Common Age</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg width=\"26\" height=\"24\" viewBox=\"0 0 26 24\" fill=\"none\"\r\n                                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <rect width=\"26\" height=\"24\" fill=\"#DCDCDC\" />\r\n                                            <rect x=\"-460.5\" y=\"-340.5\" width=\"783\" height=\"1947\" rx=\"4.5\" stroke=\"#9747FF\"\r\n                                                stroke-dasharray=\"10 5\" />\r\n                                            <mask id=\"path-2-inside-1_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\"\r\n                                                fill=\"white\" />\r\n                                            <path\r\n                                                d=\"M-190 -89C-190 -96.1797 -184.18 -102 -177 -102H294C301.18 -102 307 -96.1797 307 -89C307 -95.0751 301.627 -100 295 -100H-177C-183.075 -100 -188 -95.0751 -188 -89H-190ZM307 85C307 92.1797 301.18 98 294 98H-177C-184.18 98 -190 92.1797 -190 85H-188C-188 91.0751 -183.075 96 -177 96H295C301.627 96 307 91.0751 307 85ZM-177 98C-184.18 98 -190 92.1797 -190 85V-89C-190 -96.1797 -184.18 -102 -177 -102V-100C-183.075 -100 -188 -95.0751 -188 -89V85C-188 91.0751 -183.075 96 -177 96V98ZM307 -101V97V-101Z\"\r\n                                                fill=\"#D0D5DD\" mask=\"url(#path-2-inside-1_707_13106)\" />\r\n                                            <mask id=\"path-6-inside-2_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\"\r\n                                                stroke=\"#98A2B3\" stroke-width=\"3\" mask=\"url(#path-6-inside-2_707_13106)\" />\r\n                                        </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.footfallCard?.maleRate ?\r\n                                            getOverallCardData?.footfallCard?.maleRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">Male</div>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.footfallCard?.femaleRate ?\r\n                                            getOverallCardData?.footfallCard?.femaleRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">Female</div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"selectedTab ==='conversion'\" class=\"left-bar\">\r\n                            <div class=\"top-header text-center\">\r\n                                <div class=\"left-bar-count\" [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.conversionCard?.conversionCount.toLocaleString()?.length > 5 ? '24px' : '36px') \r\n                                  }\">{{getOverallCardData?.conversionCard?.conversionCount ?\r\n                                    getOverallCardData?.conversionCard?.conversionCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                <div class=\"left-bar-title\">{{headerData?.client ==='452' ? 'More than '+ featureConfig?.conversion.value+ ' mins' :'Conversion'}} Count</div>\r\n        \r\n                            </div>\r\n                            <span class=\"w-100\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"174\" height=\"2\"\r\n                                    viewBox=\"0 0 194 2\" fill=\"none\">\r\n                                    <path opacity=\"0.4\" d=\"M1 1L193 1\" stroke=\"#99DAFF\" stroke-linecap=\"round\" />\r\n                                </svg></span>\r\n                            <div class=\"my-5\">\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.conversionCard?.conversionRate ?\r\n                                            getOverallCardData?.conversionCard?.conversionRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">{{headerData?.client ==='452' ? 'More than ' + featureConfig?.conversion.value + ' mins' :'Conversion'}} Rate</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"this.objDataTraffic.nob === false\" class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.conversionCard?.minRate ?\r\n                                            getOverallCardData?.conversionCard?.minRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">5 - 15 Mins</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"this.objDataTraffic.nob === false\" class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.conversionCard?.maxRate ?\r\n                                            getOverallCardData?.conversionCard?.maxRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">15 - 60 Mins</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"this.objDataTraffic.nob === false\" class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.conversionCard?.averageRate ?\r\n                                            getOverallCardData?.conversionCard?.averageRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">1 Hr or more</div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"selectedTab ==='engagers'\" class=\"left-bar\">\r\n                            <div class=\"top-header text-center\">\r\n                                <div class=\"left-bar-count\" [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.engagersCard?.engagersCount.toLocaleString()?.length > 5 ? '24px' : '36px') \r\n                                  }\">{{getOverallCardData?.engagersCard?.engagersCount ?\r\n                                    getOverallCardData?.engagersCard?.engagersCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                <div class=\"left-bar-title\">{{headerData?.client ==='452' ? 'More than ' + featureConfig?.bouncedLimit.value + ' mins' :'Engagers'}} Count</div>\r\n        \r\n                            </div>\r\n                            <div class=\"my-5\">\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.engagersCard?.engagersRate ?\r\n                                            getOverallCardData?.engagersCard?.engagersRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">{{headerData?.client ==='452' ? 'More than ' + featureConfig?.bouncedLimit.value + ' mins' :'Engagers'}} Rate</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.engagersCard?.avgDwellTime ?\r\n                                            getOverallCardData?.engagersCard?.avgDwellTime :'--'}} Mins</div>\r\n                                        <div class=\"left-card-count-header\">Avg dwell Time</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.engagersCard?.highEngagementZone ?\r\n                                            getOverallCardData?.engagersCard?.highEngagementZone :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">High Engagement Zone</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.engagersCard?.lowEngagementZone ?\r\n                                            getOverallCardData?.engagersCard?.lowEngagementZone :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Low Engagement Zone</div>\r\n                                    </div>\r\n                                   \r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"selectedTab ==='bounced'\" class=\"left-bar\">\r\n                            <div class=\"top-header text-center\">\r\n                                <div class=\"left-bar-count\" [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.bouncedCard?.bouncedCount.toLocaleString()?.length > 5 ? '24px' : '36px') \r\n                                  }\">{{getOverallCardData?.bouncedCard?.bouncedCount ?\r\n                                    getOverallCardData?.bouncedCard?.bouncedCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                <div class=\"left-bar-title\">{{headerData?.client ==='452' ? 'Less than ' + featureConfig?.bouncedLimit.value + ' mins':'Bounced'}} Count</div>\r\n        \r\n                            </div>\r\n                            <div class=\"my-5\">\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.bouncedCard?.bouncedRate ?\r\n                                            getOverallCardData?.bouncedCard?.bouncedRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">{{headerData?.client ==='452' ? 'Less than ' + featureConfig?.bouncedLimit.value+' mins':'Bounced'}} Rate</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.bouncedCard?.peakBouncedHour ?\r\n                                            getOverallCardData?.bouncedCard?.peakBouncedHour :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Peak {{headerData?.client ==='452' ? 'Less than '+ featureConfig?.bouncedLimit.value + ' mins':'Bounced'}}</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.bouncedCard?.mostCommonAge ?\r\n                                            getOverallCardData?.bouncedCard?.mostCommonAge :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Most Common Age</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.bouncedCard?.maleRate ?\r\n                                            getOverallCardData?.bouncedCard?.maleRate :'--'}} %</div>\r\n                                        <div class=\"left-card-count-header\">Male</div>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.bouncedCard?.femaleRate ?\r\n                                            getOverallCardData?.bouncedCard?.femaleRate :'--'}} %</div>\r\n                                        <div class=\"left-card-count-header\">Female</div>\r\n                                    </div>\r\n                                   \r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"selectedTab ==='potentialBuyers'\" class=\"left-bar\">\r\n                            <div class=\"top-header text-center\">\r\n                                <div class=\"left-bar-count\" [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.potentialBuyersCard?.potentialBuyersCount.toLocaleString()?.length > 5 ? '24px' : '36px') \r\n                                  }\">{{getOverallCardData?.potentialBuyersCard?.potentialBuyersCount ?\r\n                                    getOverallCardData?.potentialBuyersCard?.potentialBuyersCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                <div class=\"left-bar-title\">Potential Buyers</div>\r\n        \r\n                            </div>\r\n                            <div class=\"my-5\">\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.potentialBuyersCard?.potentialBuyersRate ?\r\n                                            getOverallCardData?.potentialBuyersCard?.potentialBuyersRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">Buyers Rate</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M20 21V19C20 17.9391 19.5786 16.9217 18.8284 16.1716C18.0783 15.4214 17.0609 15 16 15H8C6.93913 15 5.92172 15.4214 5.17157 16.1716C4.42143 16.9217 4 17.9391 4 19V21M16 7C16 9.20914 14.2091 11 12 11C9.79086 11 8 9.20914 8 7C8 4.79086 9.79086 3 12 3C14.2091 3 16 4.79086 16 7Z\"\r\n                                                stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                stroke-linejoin=\"round\" />\r\n                                        </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.potentialBuyersCard?.singleCount ?\r\n                                            getOverallCardData?.potentialBuyersCard?.singleCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Single</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg width=\"26\" height=\"24\" viewBox=\"0 0 26 24\" fill=\"none\"\r\n                                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <rect width=\"26\" height=\"24\" fill=\"#DCDCDC\" />\r\n                                            <rect x=\"-460.5\" y=\"-340.5\" width=\"783\" height=\"1947\" rx=\"4.5\" stroke=\"#9747FF\"\r\n                                                stroke-dasharray=\"10 5\" />\r\n                                            <mask id=\"path-2-inside-1_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\"\r\n                                                fill=\"white\" />\r\n                                            <path\r\n                                                d=\"M-190 -89C-190 -96.1797 -184.18 -102 -177 -102H294C301.18 -102 307 -96.1797 307 -89C307 -95.0751 301.627 -100 295 -100H-177C-183.075 -100 -188 -95.0751 -188 -89H-190ZM307 85C307 92.1797 301.18 98 294 98H-177C-184.18 98 -190 92.1797 -190 85H-188C-188 91.0751 -183.075 96 -177 96H295C301.627 96 307 91.0751 307 85ZM-177 98C-184.18 98 -190 92.1797 -190 85V-89C-190 -96.1797 -184.18 -102 -177 -102V-100C-183.075 -100 -188 -95.0751 -188 -89V85C-188 91.0751 -183.075 96 -177 96V98ZM307 -101V97V-101Z\"\r\n                                                fill=\"#D0D5DD\" mask=\"url(#path-2-inside-1_707_13106)\" />\r\n                                            <mask id=\"path-6-inside-2_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\"\r\n                                                stroke=\"#98A2B3\" stroke-width=\"3\" mask=\"url(#path-6-inside-2_707_13106)\" />\r\n                                        </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.potentialBuyersCard?.groupCount ?\r\n                                            getOverallCardData?.potentialBuyersCard?.groupCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Group</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.potentialBuyersCard?.mostCommonAge ?\r\n                                            getOverallCardData?.potentialBuyersCard?.mostCommonAge :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Most Common Age</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.potentialBuyersCard?.maleRate ?\r\n                                            getOverallCardData?.potentialBuyersCard?.maleRate :'--'}} %</div>\r\n                                        <div class=\"left-card-count-header\">Male</div>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.potentialBuyersCard?.femaleRate ?\r\n                                            getOverallCardData?.potentialBuyersCard?.femaleRate :'--'}} %</div>\r\n                                        <div class=\"left-card-count-header\">Female</div>\r\n                                    </div>\r\n                                   \r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"selectedTab ==='missedOpportunity'\" class=\"left-bar\">\r\n                            <div class=\"top-header text-center\">\r\n                                <div class=\"left-bar-count\" [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.missedOpportunityCard?.missedOpportunityCount.toLocaleString()?.length > 5 ? '24px' : '36px') \r\n                                  }\">{{getOverallCardData?.missedOpportunityCard?.missedOpportunityCount ?\r\n                                    getOverallCardData?.missedOpportunityCard?.missedOpportunityCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                <div class=\"left-bar-title\">{{headerData?.client ==='452' ?  featureConfig?.missedOpportunityFrom.value+' - '+ featureConfig?.missedOpportunityTo.value + ' mins' :'Missed opportunity'}} Count</div>\r\n        \r\n                            </div>\r\n                            <div class=\"my-5\">\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.missedOpportunityCard?.missedOpportunityRate ?\r\n                                            getOverallCardData?.missedOpportunityCard?.missedOpportunityRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">{{headerData?.client ==='452' ?  featureConfig?.missedOpportunityFrom.value+ ' - ' +featureConfig?.missedOpportunityTo.value + ' mins' :'Missed opportunity'}} Rate</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"headerData?.client !=='452'\" class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\" [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.missedOpportunityCard?.potentialRevenueLoss.toLocaleString()?.length > 8 ? '16px' : '18px')}\"><span class=\"me-1\" *ngIf=\"getOverallCardData?.missedOpportunityCard?.currency ==='inr'\">₹</span>\r\n                                            <span class=\"me-1\" *ngIf=\"getOverallCardData?.missedOpportunityCard?.currency ==='dollar'\">$</span>\r\n                                            <span class=\"me-1\" *ngIf=\"getOverallCardData?.missedOpportunityCard?.currency ==='aed'\">د.إ</span>\r\n                                            {{getOverallCardData?.missedOpportunityCard?.potentialRevenueLoss ?\r\n                                            getOverallCardData?.missedOpportunityCard?.potentialRevenueLoss.toLocaleString('en-IN') :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Potential Loss Revenue</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.missedOpportunityCard?.lowConversionZone ?\r\n                                            getOverallCardData?.missedOpportunityCard?.lowConversionZone :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Low Conversion Zone</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.missedOpportunityCard?.mostCommonAge ?\r\n                                            getOverallCardData?.missedOpportunityCard?.mostCommonAge :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Most Common Age</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.missedOpportunityCard?.maleRate ?\r\n                                            getOverallCardData?.missedOpportunityCard?.maleRate :'--'}} %</div>\r\n                                        <div class=\"left-card-count-header\">Male</div>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.missedOpportunityCard?.femaleRate ?\r\n                                            getOverallCardData?.missedOpportunityCard?.femaleRate :'--'}} %</div>\r\n                                        <div class=\"left-card-count-header\">Female</div>\r\n                                    </div>\r\n                                   \r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                  \r\n                    <div *ngIf=\"selectedTab ==='traffic' && !chartloading && !chartNoData\" class=\"col-md-10 h-100 \">\r\n                        <div class=\"row px-0\">\r\n                            \r\n                            <div class=\"col-md-6 mt-3 px-0\">\r\n                               \r\n                            <div class=\"card-header border-0 pt-3\">\r\n                                <h3 class=\"card-title align-items-start flex-column\">\r\n                                    <span class=\"card-label\">Traffic Density <svg placement=\"right\"\r\n                                        ngbTooltip=\"Traffic analysis distribution across the days\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                        <g clip-path=\"url(#clip0_3352_688)\">\r\n                                        <path d=\"M7.9987 10.6667V8.00004M7.9987 5.33337H8.00536M14.6654 8.00004C14.6654 11.6819 11.6806 14.6667 7.9987 14.6667C4.3168 14.6667 1.33203 11.6819 1.33203 8.00004C1.33203 4.31814 4.3168 1.33337 7.9987 1.33337C11.6806 1.33337 14.6654 4.31814 14.6654 8.00004Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                        </g>\r\n                                        <defs>\r\n                                        <clipPath id=\"clip0_3352_688\">\r\n                                        <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n                                        </clipPath>\r\n                                        </defs>\r\n                                        </svg></span>\r\n                                    <span class=\"text-sub mb-2\">Based on {{getDensityDwellData?.fromDate | date:'dd MMM, yyyy'}} – {{getDensityDwellData?.toDate | date:'dd MMM, yyyy'}} </span>\r\n            \r\n                                </h3>\r\n                                \r\n                            </div>\r\n                                <div id=\"trafficHeatmapChart\"></div>\r\n                            </div>\r\n                            <div class=\"col-md-6 mt-3 px-0\">\r\n                                <div class=\"card-header border-0 pt-3\">\r\n                                    <h3 class=\"card-title align-items-start flex-column\">\r\n                                        <span class=\"card-label\">Dwell Time Split <svg placement=\"right\"\r\n                                            ngbTooltip=\"Time-distributed footfall with demographics\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_3352_688)\">\r\n                                            <path d=\"M7.9987 10.6667V8.00004M7.9987 5.33337H8.00536M14.6654 8.00004C14.6654 11.6819 11.6806 14.6667 7.9987 14.6667C4.3168 14.6667 1.33203 11.6819 1.33203 8.00004C1.33203 4.31814 4.3168 1.33337 7.9987 1.33337C11.6806 1.33337 14.6654 4.31814 14.6654 8.00004Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </g>\r\n                                            <defs>\r\n                                            <clipPath id=\"clip0_3352_688\">\r\n                                            <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n                                            </clipPath>\r\n                                            </defs>\r\n                                            </svg></span>\r\n                                        <span class=\"text-sub mb-2\">Based on {{getDensityDwellData?.fromDate | date:'dd MMM, yyyy'}} – {{getDensityDwellData?.toDate | date:'dd MMM, yyyy'}} </span>\r\n                \r\n                                    </h3>\r\n                                    <div class=\"card-toolbar text-nowrap\">\r\n                                        <select class=\"form-select form-select-sm w-auto dropselect\" id=\"dateSelect\"\r\n                                        (change)=\"onDateChange($event)\" [(ngModel)]=\"footfallDate\">\r\n                                        <option *ngFor=\"let dataset of trafficData\" [value]=\"dataset.value\">{{ dataset.label }}</option>\r\n                                    </select>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"!chartDwellNoData && !chartDwellloading\">\r\n                                <div id=\"dwellBarChart\"></div>\r\n                                </div>\r\n                                <div *ngIf=\"chartDwellNoData\" class=\"row\">\r\n                                    <div class=\"col-lg-12 mt-20 mb-6\">\r\n                                        <div class=\" mt-20 card-body d-flex justify-content-center align-items-center flex-column\">\r\n                                            <img class=\"img-nodata-table\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                            <div class=\"nodata-title\">No data found</div>\r\n                                            <div class=\"nodata-sub\">There is no result for this Dwell Time Split</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                    <div *ngIf=\"!chartloading && !chartNoData && (selectedTab ==='footfall' || selectedTab ==='conversion' || selectedTab ==='engagers' || selectedTab ==='bounced' || selectedTab ==='potentialBuyers' || selectedTab ==='missedOpportunity')\" class=\"col-md-10 h-100 right-bar border-1\">\r\n                        \r\n        \r\n                        <div *ngIf=\"(footfallValue ==='footfall' || footfallValue ==='conversion' || footfallValue ==='engagers'\r\n                        || footfallValue ==='missedOpportunity' || footfallValue ==='potentialBuyers' || footfallValue ==='bounced' || footfallValue ==='demographic' || footfallValue ==='buyer') && !detailedCharts\"\r\n                            class=\"row\">\r\n                           <div *ngIf=\"selectedTab !=='potentialBuyers'\">\r\n                            <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap my-2 mx-2\">\r\n                            <li class=\"nav-item nav-item1\" *ngFor=\"let dataset of datasetsCard\" (click)=\"onDatasetChange(dataset.value)\">\r\n                                <a [ngClass]=\"footfallValue ===dataset.value ? 'active' :''\"\r\n                                    class=\"nav-link nav-link1 cursor-pointer me-6\">{{ dataset.label }}</a>\r\n                            </li>\r\n                            </ul>\r\n                            <!-- <ul class=\"nav nav-tabs\">\r\n                                <li class=\"nav-item\" >\r\n                                    <a class=\"nav-link\" [class.active]=\"selectedTab === dataset.label\">{{ dataset.label }}</a>\r\n                                </li>\r\n                            </ul> -->\r\n                            <!-- <select class=\"form-select form-select-sm w-auto m-3 dropselect\" id=\"datasetSelect\" [(ngModel)]=\"footfallValue\"\r\n                            (change)=\"onDatasetChange($event)\">\r\n                            <option *ngFor=\"let dataset of datasets\" [value]=\"dataset.value\">{{ dataset.label }}</option>\r\n                        </select>  -->\r\n                       \r\n                        </div> \r\n                        <div class=\"left-bar-title fw-bold mt-5 mb-2 ms-3\" *ngIf=\"selectedTab ==='potentialBuyers'\">{{selctedValue}}</div>\r\n                            <span class=\"ms-3 text-sub\">Based on {{headerData?.date?.startDate | date:'dd MMM, yyyy'}} – {{headerData?.date?.endDate | date:'dd MMM, yyyy'}} </span>\r\n                            <div *ngIf=\"footfallValue ==='demographic' && !detailedCharts\" class=\"col-md-12\">\r\n                                <div *ngIf=\"!demoNoData && !demoloading\">\r\n                                    <div class=\"text-center\" id=\"demoGraphics\"></div>\r\n                                </div>                     \r\n                                <div *ngIf=\"demoloading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                                    <div class=\"shimmer\">\r\n                                        <div class=\"wrapper\">\r\n                                            <div class=\"stroke animate title\"></div>\r\n                                            <div class=\"stroke animate link\"></div>\r\n                                            <div class=\"stroke animate description\"></div>\r\n                                        </div>\r\n                                    </div>\r\n                                    <div class=\"shimmer\">\r\n                                        <div class=\"wrapper\">\r\n                                            <div class=\"stroke animate title\"></div>\r\n                                            <div class=\"stroke animate link\"></div>\r\n                                            <div class=\"stroke animate description\"></div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"demoNoData\" class=\"row\">\r\n                                    <div class=\"col-lg-12 mb-3\">\r\n                                        <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                                            <img class=\"demo-img-nodata\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                            <div class=\"nodata-title\">No data found</div>\r\n                                            <div class=\"nodata-sub\">There is no result for this Demographic Analysis</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                            <div *ngIf=\"footfallValue ==='buyer' && !detailedCharts\" class=\"col-md-12\">\r\n                                <div *ngIf=\"!buyersNoData && !buyersloading\">\r\n                                    <div class=\"text-center\" id=\"buyersCharts\"></div>\r\n        \r\n                                </div>                     \r\n                                <div *ngIf=\"buyersloading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                                    <div class=\"shimmer\">\r\n                                        <div class=\"wrapper\">\r\n                                            <div class=\"stroke animate title\"></div>\r\n                                            <div class=\"stroke animate link\"></div>\r\n                                            <div class=\"stroke animate description\"></div>\r\n                                        </div>\r\n                                    </div>\r\n                                    <div class=\"shimmer\">\r\n                                        <div class=\"wrapper\">\r\n                                            <div class=\"stroke animate title\"></div>\r\n                                            <div class=\"stroke animate link\"></div>\r\n                                            <div class=\"stroke animate description\"></div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"buyersNoData\" class=\"row\">\r\n                                    <div class=\"col-lg-12 mb-3\">\r\n                                        <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                                            <img class=\"demo-img-nodata\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                            <div class=\"nodata-title\">No data found</div>\r\n                                            <div class=\"nodata-sub\">There is no result for this Buyer Analysis</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                            <section *ngIf=\"this.objDataTraffic.nob === true && selectedTab ==='conversion'\">\r\n                                <div class=\"text-center mt-3 mx-3\" id=\"testGraphics\"></div>\r\n                                <lib-pagination [itemsPerPage]=\"pageSizeTrafficCard\" [currentPage]=\"offsetTrafficCard\" [totalItems]=\"totalItemsTrafficCard\"\r\n                                [paginationSizes]=\"paginationSizesTrafficCard\" [pageSize]=\"pageSizeTrafficCard\" (pageChange)=\"onPageChangeTrafficCard($event)\"\r\n                                (pageSizeChange)=\"onPageSizeChangeTrafficCard($event)\"></lib-pagination>\r\n                            </section>\r\n        <section *ngIf=\"(this.objDataTraffic.nob === true && selectedTab !=='conversion' || this.objDataTraffic.nob === false) \">\r\n                            <div *ngIf=\"footfallValue ==='footfall' || footfallValue ==='conversion' || footfallValue ==='engagers' \r\n                            || footfallValue ==='missedOpportunity' || footfallValue ==='potentialBuyers' || footfallValue ==='bounced' && !detailedCharts\" \r\n                            class=\"chart-container px-3 mt-3\">\r\n                        <div class=\"text-center\" id=\"testGraphics\"></div>\r\n                        <lib-pagination [itemsPerPage]=\"pageSizeTrafficCard\" [currentPage]=\"offsetTrafficCard\" [totalItems]=\"totalItemsTrafficCard\"\r\n                        [paginationSizes]=\"paginationSizesTrafficCard\" [pageSize]=\"pageSizeTrafficCard\" (pageChange)=\"onPageChangeTrafficCard($event)\"\r\n                        (pageSizeChange)=\"onPageSizeChangeTrafficCard($event)\"></lib-pagination>\r\n                    </div>\r\n                    <div *ngIf=\"footfallValue ==='footfall' || footfallValue ==='conversion' || footfallValue ==='engagers' \r\n                            || footfallValue ==='missedOpportunity' || footfallValue ==='potentialBuyers' || footfallValue ==='bounced' && !detailedCharts\" \r\n                            class=\"heatmap-container element\">\r\n                        <div id=\"heatmapchart\"></div>\r\n                    </div>\r\n                    </section>\r\n                    \r\n                            <!-- <div *ngIf=\"footfallValue ==='footfall' || footfallValue ==='conversion' || footfallValue ==='engagers'\r\n                        || footfallValue ==='missedOpportunity' || footfallValue ==='potentialBuyers' || footfallValue ==='bounced' && !detailedCharts\" class=\"col-md-9 chart-container mt-3\">\r\n                                <div class=\"text-center\" id=\"testGraphics\"></div>\r\n                            </div>\r\n                            <div *ngIf=\"footfallValue ==='footfall' || footfallValue ==='conversion' || footfallValue ==='engagers'\r\n                        || footfallValue ==='missedOpportunity' || footfallValue ==='potentialBuyers' || footfallValue ==='bounced' && !detailedCharts\" class=\"col-md-3 mt-3 me-0 pe-0\">\r\n                                <div id=\"heatmapchart\"></div>\r\n                            </div> -->\r\n        \r\n                        </div>\r\n                        <div *ngIf=\"detailedCharts\" class=\"row\">\r\n                            <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                <div class=\"flex-shrink-0 mt-3\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"backToFootfall()\">\r\n                                        <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\"\r\n                                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <g filter=\"url(#filter0_d_2585_7036)\">\r\n                                                <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\r\n                                                <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\r\n                                                <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\r\n                                                    stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                                    stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\r\n                                                    filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n                                                    <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\r\n                                                    <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\r\n                                                        values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\r\n                                                    <feOffset dy=\"1\" />\r\n                                                    <feGaussianBlur stdDeviation=\"1\" />\r\n                                                    <feColorMatrix type=\"matrix\"\r\n                                                        values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\r\n                                                    <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\r\n                                                        result=\"effect1_dropShadow_2585_7036\" />\r\n                                                    <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\r\n                                                        result=\"shape\" />\r\n                                                </filter>\r\n                                            </defs>\r\n                                        </svg>\r\n                                    </span>\r\n                                </div>\r\n                                <div class=\"mx-3 mt-1\">\r\n                                    <div class=\"my-1 card-label left-card-count\"><span class=\"text-primary cursor-pointer text-decoration-underline\" (click)=\"storeView(storeId)\">{{storeName}}</span><span class=\"ms-2\">Footfall Trend</span></div>\r\n                                    <div class=\"left-card-count-header text-sub\">Based on {{headerData?.date?.startDate | date:'dd MMM, yyyy'}} - {{headerData?.date?.endDate | date:'dd MMM, yyyy'}}</div>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"col-md-12 mx-5\">\r\n                                <div class=\"text-center\" id=\"detailedChartDiv\"></div>\r\n                            </div>\r\n                        </div>\r\n               \r\n                    </div>\r\n                </div>\r\n        \r\n            </div>\r\n        </div>\r\n        <!-- <lib-traffic-card-charts class=\"my-2\"></lib-traffic-card-charts> -->\r\n         <div *ngIf=\"headerData?.client !=='452'\">\r\n        <lib-image-doc *ngIf=\"storeIdarray?.length === 1 && (clientData?.featureConfigs?.isFootfallDirectory || (gs.userAccess | async)?.userType === 'tango')\" class=\"my-2\"></lib-image-doc>\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"storeIdarray?.length > 1\" class=\"col-md-6 mt-3\">\r\n        <div class=\"card h-100\">\r\n            <div class=\"card-header border-0 pt-3\">\r\n                <h3 class=\"card-title align-items-start flex-column\">\r\n                    <span class=\"title-text mb-2\">Performance Matrix\r\n                         <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\"\r\n                            height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" placement=\"right\"\r\n                            ngbTooltip=\"Store performance based on metrics selected\">\r\n                            <g clip-path=\"url(#clip0_1432_80035)\">\r\n                                <path\r\n                                    d=\"M8.00065 10.6666V7.99992M8.00065 5.33325H8.00732M14.6673 7.99992C14.6673 11.6818 11.6826 14.6666 8.00065 14.6666C4.31875 14.6666 1.33398 11.6818 1.33398 7.99992C1.33398 4.31802 4.31875 1.33325 8.00065 1.33325C11.6826 1.33325 14.6673 4.31802 14.6673 7.99992Z\"\r\n                                    stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                            </g>\r\n                            <defs>\r\n                                <clipPath id=\"clip0_1432_80035\">\r\n                                    <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                                </clipPath>\r\n                            </defs>\r\n                        </svg>\r\n                    </span>\r\n                    <span class=\"text-sub mb-2\">{{headerData?.date?.startDate | date:'dd MMM, yyyy'}} – {{headerData?.date?.endDate | date:'dd MMM, yyyy'}}</span>\r\n                </h3>\r\n                <div class=\"card-toolbar\">\r\n                    \r\n                </div>\r\n            </div>\r\n            <div class=\"row mx-3 align-items-center w-75\">\r\n                <div class=\"d-flex align-items-center ms-3\">\r\n                  <select class=\"form-select-sm form-select me-2 dropselect\" [(ngModel)]=\"footfallValue1\" (change)=\"onValueChange($event)\">\r\n                    <option *ngFor=\"let obj of getFilteredFootfallDatasets()\" [id]=\"obj.label\" [value]=\"obj.value\">{{obj.label}}</option>\r\n                  </select>\r\n                  <span class=\"mx-2\">Vs</span>\r\n                  <select class=\"form-select-sm form-select ms-2 dropselect\" [(ngModel)]=\"bounceValue1\" (change)=\"onBounceChange($event)\">\r\n                    <option *ngFor=\"let obj of getFilteredBounceDatasets()\" [id]=\"obj.label\" [value]=\"obj.value\">{{obj.label}}</option>\r\n\r\n                  </select>\r\n                </div>\r\n              </div>\r\n              <div *ngIf=\"performanceLoading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                <div class=\"shimmer\">\r\n                    <div class=\"wrapper\">\r\n                        <div class=\"stroke animate title\"></div>\r\n                        <div class=\"stroke animate link\"></div>\r\n                        <div class=\"stroke animate description\"></div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"shimmer\">\r\n                    <div class=\"wrapper\">\r\n                        <div class=\"stroke animate title\"></div>\r\n                        <div class=\"stroke animate link\"></div>\r\n                        <div class=\"stroke animate description\"></div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"performancenoData\" class=\"row\">\r\n                <div class=\"col-lg-12 mt-20 mb-6\">\r\n                    <div class=\" mt-20 card-body d-flex justify-content-center align-items-center flex-column\">\r\n                        <img class=\"img-nodata-table\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                        <div class=\"nodata-title\">No data found</div>\r\n                        <div *ngIf=\"headerData?.client !=='452'\" class=\"nodata-sub\">There is no result for this {{footfallLabel | titlecase}} vs {{bounceLabel | titlecase}}</div>\r\n                        <div *ngIf=\"headerData?.client ==='452'\" class=\"nodata-sub\">There is no result for this Performance Matrix</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"!performanceLoading && !performancenoData\" class=\"card-body\">\r\n               \r\n            <div class=\"quadrant-chart z-1\">\r\n                <div class=\"axis-labels\">\r\n                    <!-- X Axis Label -->\r\n                    <div class=\"x-axis-label\">\r\n                      <span>{{bounceLabel | titlecase}} -></span>\r\n                    </div>\r\n                    <!-- Y Axis Label -->\r\n                    <div class=\"y-axis-label\">\r\n                      <span>{{footfallLabel | titlecase}} -></span>\r\n                    </div>\r\n                  </div>\r\n   <!-- Top Left Quadrant -->\r\n   <div class=\"quadrant\" id=\"q1\">\r\n    <span  *ngIf=\"headerData?.client !=='452'\" class=\"label1\">High <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, Low <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel | titlecase}}</span></span> \r\n            <span *ngIf=\"headerData?.client ==='452'\" class=\"label1\"><span *ngIf=\"footfallLabel==='Footfall'\">High </span> <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, <span *ngIf=\"bounceLabel==='Footfall'\">Low </span> <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel | titlecase}}</span></span>\r\n</div>\r\n\r\n<!-- Top Right Quadrant -->\r\n<div class=\"quadrant\" id=\"q2\">\r\n    <span *ngIf=\"headerData?.client !=='452'\" class=\"label1\">High <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, High <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel | titlecase}}</span></span>\r\n            <span *ngIf=\"headerData?.client ==='452'\" class=\"label1\"><span *ngIf=\"footfallLabel==='Footfall'\">High </span> <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, <span *ngIf=\"bounceLabel==='Footfall'\">High </span> <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel | titlecase}}</span></span>        \r\n</div>\r\n\r\n<!-- Bottom Left Quadrant -->\r\n<div class=\"quadrant\" id=\"q3\">\r\n    <span *ngIf=\"headerData?.client !=='452'\"  class=\"label1\">Low <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, Low <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel | titlecase}}</span></span>\r\n            <span *ngIf=\"headerData?.client ==='452'\" class=\"label1\"><span *ngIf=\"footfallLabel==='Footfall'\">Low </span>  <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, <span *ngIf=\"bounceLabel==='Footfall'\">Low </span> <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel | titlecase}}</span></span>\r\n\r\n</div>\r\n\r\n<!-- Bottom Right Quadrant -->\r\n<div class=\"quadrant\" id=\"q4\">\r\n    <span *ngIf=\"headerData?.client !=='452'\"  class=\"label1\">Low <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, High <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel| titlecase}}</span></span>\r\n            <span *ngIf=\"headerData?.client ==='452'\" class=\"label1\"><span *ngIf=\"footfallLabel==='Footfall'\">Low </span> <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, <span *ngIf=\"bounceLabel==='Footfall'\">High </span> <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel| titlecase}}</span></span>\r\n</div>\r\n  \r\n                <div *ngFor=\"let point of points\" class=\"point\" [ngStyle]=\"{'top': point.top + '%', 'left': point.left + '%'}\">\r\n                    <div class=\"text-center\" (click)=\"toggleTooltip(point.name)\">\r\n                    <div class=\"dot\" ></div>\r\n                    <!-- Clickable label that toggles the tooltip -->\r\n                    <div class=\"label z-1 mt-4\"  style=\"font-size: 10px !important;\" >\r\n                      {{ point.name }}\r\n                    </div>\r\n                </div>\r\n                    <!-- Custom Tooltip Popup -->\r\n                    <div class=\"tooltip-popup z-5\" *ngIf=\"activeTooltip === point.name\">\r\n                      <div class=\"tooltip-content\">\r\n                        <h3 class=\"text-white cursor-pointer\" (click)=\"storeView(point.storeId)\">{{ point.name }}</h3>\r\n                        <p>Avg {{footfallLabel | titlecase}}: {{ point.avgFootfall }}</p>\r\n                        <p class=\"my-2\">Open Time: <strong>{{ point.openTime }}</strong></p>\r\n                        <p>Close Time: <strong>{{ point.closeTime }}</strong></p>\r\n                      </div>\r\n                      <div class=\"tooltip-arrow\"></div>\r\n                    </div>\r\n                  </div>\r\n                <!-- Add more points here -->\r\n              </div>\r\n              \r\n              </div>\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"storeIdarray?.length > 1\" class=\"col-md-6 mt-3\">\r\n        <div class=\"card\">\r\n            <div class=\"card-header px-5 border-0 pt-3\">\r\n                <h3 class=\"card-title align-items-start flex-column\">\r\n                    <span class=\"title-text mb-2\">Zone Dwell Time Split \r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\"\r\n                            height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\"\r\n                            placement=\"right\"\r\n                            ngbTooltip=\"Overall zone concentration and average dwell time across selected stores\">\r\n                            <g clip-path=\"url(#clip0_1432_80035)\">\r\n                                <path\r\n                                    d=\"M8.00065 10.6666V7.99992M8.00065 5.33325H8.00732M14.6673 7.99992C14.6673 11.6818 11.6826 14.6666 8.00065 14.6666C4.31875 14.6666 1.33398 11.6818 1.33398 7.99992C1.33398 4.31802 4.31875 1.33325 8.00065 1.33325C11.6826 1.33325 14.6673 4.31802 14.6673 7.99992Z\"\r\n                                    stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                            </g>\r\n                            <defs>\r\n                                <clipPath id=\"clip0_1432_80035\">\r\n                                    <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                                </clipPath>\r\n                            </defs>\r\n                        </svg>\r\n                    </span>\r\n                    <span class=\"text-sub mb-2\">{{headerData?.date?.startDate | date:'dd MMM, yyyy'}} – {{headerData?.date?.endDate | date:'dd MMM, yyyy'}}</span>\r\n                </h3>\r\n                <div class=\"card-toolbar\">\r\n                    <button  type=\"button\" (click)=\"goToZone()\"\r\n                    class=\"btn btn-light-primary1 rounded-3 text-nowrap border-val\">\r\n                    <span class=\"ms-2\">Go to Zones</span>\r\n                </button>\r\n                   \r\n                </div>\r\n            </div>\r\n            <div calss=\"card-body\">\r\n                <div *ngIf=\"!zoneLoading && !zoneNoData\" class=\"image-container position-relative\">\r\n                    <img  src=\"assets/tango/Images/zone-img.svg\" alt=\"Store Layout\" class=\"px-5 img-src my-3 background-image\" />\r\n                    <!-- <img *ngIf=\"zoneDwellTimeSplitData[0]?.zoneName ==='Overall Store'\" src=\"assets/tango/Images/zone-img1.svg\" alt=\"Store Layout\" class=\"px-5 img-src my-3 background-image\" /> -->\r\n                    <!-- <div class=\"centered\">Centered</div> -->\r\n                    <!-- <div class=\"overlay-content\" *ngFor=\"let point of zoneDwellTimeSplitData\"> -->\r\n                      <div *ngIf=\"zoneDwellTimeSplitData[0]?.zoneName !=='Overall Store'\" class=\"top-zone\">\r\n                       <div class=\"text-center text-zone\">{{zoneDwellTimeSplitData[0]?.zoneName ? zoneDwellTimeSplitData[0]?.zoneName :'Front'}}</div>\r\n                       <span class=\"text-zone-val\"> Conc: {{ zoneDwellTimeSplitData[0]?.concentrationRate ? zoneDwellTimeSplitData[0]?.concentrationRate:'--' }}% </span>\r\n                       <span class=\"text-zone-val\">Dwell time: {{ zoneDwellTimeSplitData[0]?.dwellTime ? zoneDwellTimeSplitData[0]?.dwellTime :'--' }} Mins</span>\r\n                      </div>\r\n                      <div *ngIf=\"zoneDwellTimeSplitData[0]?.zoneName ==='Overall Store'\" class=\"centered-zone\">\r\n                        <div class=\"text-center text-zone\">{{zoneDwellTimeSplitData[0]?.zoneName ? zoneDwellTimeSplitData[0]?.zoneName :'Front'}}</div>\r\n                        <span class=\"text-zone-val\"> Conc: {{ zoneDwellTimeSplitData[0]?.concentrationRate ? zoneDwellTimeSplitData[0]?.concentrationRate:'--' }}% </span>\r\n                        <span class=\"text-zone-val\">Dwell time: {{ zoneDwellTimeSplitData[0]?.dwellTime ? zoneDwellTimeSplitData[0]?.dwellTime:'--' }} Mins</span>\r\n                       </div>\r\n                       <div *ngIf=\"zoneDwellTimeSplitData[0]?.zoneName !=='Overall Store'\" class=\"bottom-zone \">\r\n                        <div class=\"text-center text-zone\">{{zoneDwellTimeSplitData[1]?.zoneName ? zoneDwellTimeSplitData[2]?.zoneName  : 'Back'}}</div>\r\n                        <span class=\"text-zone-val\"> Conc: {{ zoneDwellTimeSplitData[1]?.concentrationRate ? zoneDwellTimeSplitData[2]?.concentrationRate:'--' }}% </span>\r\n                        <span class=\"text-zone-val\">Dwell time: {{ zoneDwellTimeSplitData[1]?.dwellTime ? zoneDwellTimeSplitData[2]?.dwellTime:'--'}} Mins</span>\r\n                       </div>\r\n                    <!-- </div> -->\r\n                    </div>\r\n                    <div *ngIf=\"zoneLoading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                        <div class=\"shimmer\">\r\n                            <div class=\"wrapper\">\r\n                                <div class=\"stroke animate title\"></div>\r\n                                <div class=\"stroke animate link\"></div>\r\n                                <div class=\"stroke animate description\"></div>\r\n                            </div>\r\n                        </div>\r\n                        <div class=\"shimmer\">\r\n                            <div class=\"wrapper\">\r\n                                <div class=\"stroke animate title\"></div>\r\n                                <div class=\"stroke animate link\"></div>\r\n                                <div class=\"stroke animate description\"></div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                    <div *ngIf=\"zoneNoData\" class=\"row\">\r\n                        <div class=\"col-lg-12 mb-6 \">\r\n                            <div *ngIf=\"normalize\" class=\"mt-5 card-body right-bar py-20 mx-5 d-flex justify-content-center align-items-center flex-column\">\r\n                                <img class=\"img-nodata-zone\" src=\"./assets/tango/Icons/not-applicable.svg\" alt=\"\">\r\n                                <div class=\"nodata-title mt-3\">Data Not Found</div>\r\n                                <div class=\"nodata-sub\">Normalized data is not applicable</div>\r\n                            </div>\r\n                            <div *ngIf=\"!normalize\" class=\"mt-5 card-body right-bar py-20 mx-5 d-flex justify-content-center align-items-center flex-column\">\r\n                                <img class=\"img-nodata-zone\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                <div class=\"nodata-title\">No data found</div>\r\n                                <div  class=\"nodata-sub\">There is no result for this Zone Dwell Time Split</div>\r\n\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                <!-- <img class=\"px-5 img-src mb-3\" src=\"assets/tango/Images/zone-img.svg\" alt=\"\"> -->\r\n    </div>\r\n    <div class=\"card-header px-5 border-0 pt-3\">\r\n        <h3 class=\"card-title align-items-start flex-column\">\r\n            <span class=\"title-text mb-2\">Store Operations\r\n                <span > \r\n                <svg ngbTooltip=\"Avg store open & close time across the selected stores\" placement=\"top\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\"\r\n                    height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" >\r\n                    <g clip-path=\"url(#clip0_1432_80035)\">\r\n                        <path\r\n                            d=\"M8.00065 10.6666V7.99992M8.00065 5.33325H8.00732M14.6673 7.99992C14.6673 11.6818 11.6826 14.6666 8.00065 14.6666C4.31875 14.6666 1.33398 11.6818 1.33398 7.99992C1.33398 4.31802 4.31875 1.33325 8.00065 1.33325C11.6826 1.33325 14.6673 4.31802 14.6673 7.99992Z\"\r\n                            stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                    </g>\r\n                    <defs>\r\n                        <clipPath id=\"clip0_1432_80035\">\r\n                            <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                        </clipPath>\r\n                    </defs>\r\n                </svg>\r\n                </span>\r\n            </span>\r\n            <span class=\"text-sub mb-2\">{{headerData?.date?.startDate | date:'dd MMM, yyyy'}} – {{headerData?.date?.endDate | date:'dd MMM, yyyy'}}</span>\r\n        </h3>\r\n        <div class=\"card-toolbar\">\r\n            <!-- <button  type=\"button\"\r\n            class=\"btn btn-light-primary1 rounded-3 text-nowrap border-val\">\r\n            <span class=\"ms-2\">Go to Trax</span>\r\n        </button> -->\r\n        </div>\r\n    </div>\r\n    <div class=\"card-body\">\r\n        <div class=\"row\">\r\n            <div class=\"col-md-3 text-center mb-3\">\r\n                <div class=\"row\">\r\n                    <div class=\"col-md-12\"><!--{{getCardData?.revenue?.value ?? '--'}} -->\r\n                        <div class=\"my-2\"> <span class=\"left-card-count-title\">{{storeOperationData?.overall?.avgOpenTime\r\n                                ?storeOperationData?.overall?.avgOpenTime:'--' }}</span></div>\r\n                        <div class=\"\"><span class=\"sub-header\">Avg. Open Time</span></div>\r\n                    </div>\r\n    \r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-6 mt-5 mb-3\">\r\n                <svg width=\"326\" height=\"2\" viewBox=\"0 0 326 2\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                    <line y1=\"0.75\" x2=\"356\" y2=\"0.75\" stroke=\"#D0D5DD\" />\r\n                </svg>\r\n            </div>\r\n            <div class=\"col-md-3 text-center mb-3\">\r\n                <div class=\"row\">\r\n                    <div class=\"col-md-12\"><!--{{getCardData?.revenue?.value ?? '--'}} -->\r\n                        <div class=\"my-2\"> <span class=\"left-card-count-title\">{{storeOperationData?.overall?.avgCloseTime\r\n                                ?storeOperationData?.overall?.avgCloseTime:'--' }}</span></div>\r\n                        <div class=\"\"><span class=\"sub-header\">Avg. Close Time</span></div>\r\n                    </div>\r\n    \r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-6 mt-3\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"card-header ellipse1 border-0 px-3\">\r\n                        <h3 class=\"card-title align-items-start flex-column \">\r\n                            <span class=\"left-card-count-header1 text-decoration-underline cursor-pointer\"  (click)=\"storeView(storeOperationData?.topLateOpen?.storeId)\">{{storeOperationData?.topLateOpen?.storeName ?\r\n                                storeOperationData?.topLateOpen?.storeName :'--'}}</span>\r\n                            <span class=\"sub-header mt-2\">Top Late Open</span>\r\n                        </h3>\r\n                    </div>\r\n                    <div class=\"card-body p-0 h-75px mt-3 mx-3\">\r\n                        <div class=\"row\">\r\n                            <div class=\"col-md-12\"><!--{{getCardData?.revenue?.value ?? '--'}} -->\r\n                                <div class=\"my-1\"> <span\r\n                                        class=\"left-card-count-header1\">{{storeOperationData?.topLateOpen?.avgStoreOpenTime\r\n                                        ?storeOperationData?.topLateOpen?.avgStoreOpenTime:'--' }}</span></div>\r\n                                <span class=\"sub-header\">Avg. Store Opening Time</span>\r\n                            </div>\r\n    \r\n                        </div>\r\n                    </div>\r\n    \r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-6 mt-3\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"card-header ellipse1 border-0 px-3\">\r\n                        <h3 class=\"card-title align-items-start flex-column \">\r\n                            <span class=\"left-card-count-header1 text-decoration-underline cursor-pointer\" (click)=\"storeView(storeOperationData?.topEarlyClose?.storeId)\">{{storeOperationData?.topEarlyClose?.storeName ?\r\n                                storeOperationData?.topEarlyClose?.storeName :'--'}}</span>\r\n                            <span class=\"sub-header mt-2\">Top Early Close</span>\r\n                        </h3>\r\n                    </div>\r\n                    <div class=\"card-body p-0 h-75px mt-3 mx-3\">\r\n                        <div class=\"row\">\r\n                            <div class=\"col-md-12\"><!--{{getCardData?.revenue?.value ?? '--'}} -->\r\n                                <div class=\"my-1\"> <span\r\n                                        class=\"left-card-count-header1\">{{storeOperationData?.topEarlyClose?.avgStoreCloseTime\r\n                                        ?storeOperationData?.topEarlyClose?.avgStoreCloseTime:'--' }}</span></div>\r\n                                <span class=\"sub-header\">Avg. Store Closing Time</span>\r\n                            </div>\r\n    \r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"storeIdarray[0] !=='459-2'\" class=\"col-md-12 mt-3\">\r\n        <div class=\"card mb-5\">\r\n            <div class=\"card-header border-0 pt-3\">\r\n                <h3 class=\"card-title align-items-start flex-column\">\r\n                    <span class=\"title-text mb-2\">Summary Table</span>\r\n                    <span class=\"text-sub mb-2\">{{headerData?.date?.startDate | date:'dd MMM, yyyy'}} – {{headerData?.date?.endDate | date:'dd MMM, yyyy'}}</span>\r\n                </h3>\r\n                <div class=\"card-toolbar\">\r\n                    <div class=\"d-flex\">\r\n                        <div class=\"d-flex align-items-center position-relative my-1\">\r\n                            <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n                                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\"\r\n                                    fill=\"none\">\r\n                                    <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\" height=\"2\" rx=\"1\"\r\n                                        transform=\"rotate(45 17.0365 15.1223)\" fill=\"currentColor\"></rect>\r\n                                    <path\r\n                                        d=\"M11 19C6.55556 19 3 15.4444 3 11C3 6.55556 6.55556 3 11 3C15.4444 3 19 6.55556 19 11C19 15.4444 15.4444 19 11 19ZM11 5C7.53333 5 5 7.53333 5 11C5 14.4667 7.53333 17 11 17C14.4667 17 17 14.4667 17 11C17 7.53333 14.4667 5 11 5Z\"\r\n                                        fill=\"currentColor\"></path>\r\n                                </svg>\r\n                            </span>\r\n                            <input (change)=\"searchData()\" [(ngModel)]=\"searchValue\" type=\"text\" class=\"form-control ps-14 me-2\" autocomplete=\"off\" placeholder=\"Search\" />\r\n                            <!-- filter Start -->\r\n                            <!-- <lib-filters [dataObject]=\"dataObject\" (appliedFilters)=\"applyFilters($event)\"></lib-filters> -->\r\n                            <!-- filter End -->\r\n                         <!-- Sum Button -->\r\n                         <section *ngIf=\"(storeIdarray?.length > 1 && headerData?.date?.startDate !== headerData?.date?.endDate) && !noData && !loading\">\r\n                            <button type=\"button\" (click)=\"onValueType('sum')\"\r\n                              class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\"\r\n                              [ngClass]=\"{'btn-light btn-primary text-white': typeValue === 'sum'}\">\r\n                              <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\"\r\n                                [ngStyle]=\"{'stroke': typeValue === 'sum' ? '#FFFFFF' : '#344054'}\">\r\n                                <path d=\"M9.99935 4.16675V15.8334M4.16602 10.0001H15.8327\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                  stroke-linejoin=\"round\" />\r\n                              </svg>\r\n                              <span class=\"ms-2\" [ngClass]=\"{'text-white': typeValue === 'sum'}\">Sum</span>\r\n                            </button>\r\n                          </section>\r\n                          \r\n<!-- Average Button -->\r\n <section *ngIf=\"(storeIdarray?.length > 1 && headerData?.date?.startDate !== headerData?.date?.endDate) \r\n && !noData && !loading\">\r\n<button type=\"button\" (click)=\"onValueType('average')\"\r\nclass=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\"\r\n[ngClass]=\"{'btn-light btn-primary text-white': typeValue === 'average'}\">\r\n<svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n  [ngStyle]=\"{'stroke': typeValue === 'average' ? '#FFFFFF' : '#101828'}\">\r\n  <path d=\"M17.5 17.5H8.33333C5.58333 17.5 4.20833 17.5 3.35417 16.6458C2.5 15.7917 2.5 14.4167 2.5 11.6667V2.5M5 10H5.0075M7.49917 10H7.50583M9.9975 10H10.0042M12.4958 10H12.5033M14.9942 10H15.0017M17.4925 10H17.5\"\r\n    stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n  <path\r\n    d=\"M5 5.83341C5.56083 4.89841 6.3225 4.16675 7.49417 4.16675C12.4467 4.16675 9.6625 14.1667 14.985 14.1667C16.165 14.1667 16.9217 13.4301 17.5 12.5001\"\r\n    stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n</svg>\r\n<span class=\"ms-2\" [ngClass]=\"{'text-white': typeValue === 'average'}\">Average</span>\r\n</button>\r\n</section>\r\n                          \r\n                            <button *ngIf=\"!noData && !loading\" type=\"button\" (click)=\"exportXLSX()\"\r\n                                class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\"><svg\r\n                                    xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\"\r\n                                    fill=\"none\">\r\n                                    <path\r\n                                        d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n                                        stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                        stroke-linejoin=\"round\" />\r\n                                </svg><span class=\"ms-2\">Export</span> </button>\r\n    \r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"loading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                <div class=\"shimmer\">\r\n                    <div class=\"wrapper\">\r\n                        <div class=\"stroke animate title\"></div>\r\n                        <div class=\"stroke animate link\"></div>\r\n                        <div class=\"stroke animate description\"></div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"shimmer\">\r\n                    <div class=\"wrapper\">\r\n                        <div class=\"stroke animate title\"></div>\r\n                        <div class=\"stroke animate link\"></div>\r\n                        <div class=\"stroke animate description\"></div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"noData\" class=\"row\">\r\n                <div class=\"col-lg-12 mb-3\">\r\n                    <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                        <img class=\"img-nodata-table\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                        <div class=\"nodata-title\">No data found</div>\r\n                        <div class=\"nodata-sub\">There is no result for this summary table</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"!noData && !loading\" calss=\"card-body\">\r\n                <div class=\"table-responsive\">\r\n                    <table class=\"w-100 table bottom-border text-nowrap\">\r\n                        <thead>\r\n                            <tr>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('storeName')\">Store Name <svg \r\n                                        [ngClass]=\"sortedColumn === 'storeName' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'storeName' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('storeId')\">Store ID <svg  [ngClass]=\"sortedColumn === 'storeId' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'storeId' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"storeIdarray?.length === 1\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('date')\">Date <svg [ngClass]=\"sortedColumn === 'date' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'date' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('footfallCount')\">Footfall <svg [ngClass]=\"sortedColumn === 'footfallCount' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'footfallCount' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('bouncedCount')\">{{headerData?.client ==='452'?'Less than '+ this.featureConfig?.bouncedLimit.value +' mins':'Bounced'}} Footfall<svg [ngClass]=\"sortedColumn === 'bouncedCount' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'bouncedCount' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('engagersCount')\">{{headerData?.client ==='452'? 'More than '+ featureConfig?.bouncedLimit.value +' mins':'Engagers'}} <svg [ngClass]=\"sortedColumn === 'engagersCount' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                            fill=\"none\"> \r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'engagersCount' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('missedOpportunityCount')\">{{headerData?.client ==='452'? featureConfig?.missedOpportunityFrom.value + ' - ' +featureConfig?.missedOpportunityTo.value +' mins':'Missed Opportunity'}}<svg [ngClass]=\"sortedColumn === 'missedOpportunityCount' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'missedOpportunityCount' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"headerData?.client !=='452'\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('potentialBuyersCount')\">Potential Buyers <svg [ngClass]=\"sortedColumn === 'potentialBuyersCount' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'potentialBuyersCount' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('conversionRate')\">{{headerData?.client ==='452'?'More than '+ featureConfig?.conversion.value + ' mins':'Conversion'}} Rate <svg [ngClass]=\"sortedColumn === 'conversionRate' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'conversionRate' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('NOBCount')\">NOB Count <svg [ngClass]=\"sortedColumn === 'NOBCount' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'NOBCount' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('avgDwellTime')\">Avg.Dwell Time <svg [ngClass]=\"sortedColumn === 'avgDwellTime' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'avgDwellTime' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('avgInfraDowntime')\">Avg.Infra DownTime <svg [ngClass]=\"sortedColumn === 'avgInfraDowntime' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'avgInfraDowntime' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('passerBy_count')\">Passer By<svg [ngClass]=\"sortedColumn === 'passerBy_count' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'passerBy_count' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('below12')\">Below12 <svg [ngClass]=\"sortedColumn === 'below12' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'below12' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('13-19')\">13-19 <svg [ngClass]=\"sortedColumn === '13-19' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '13-19' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('20-30')\">20-30 <svg [ngClass]=\"sortedColumn === '20-30' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '20-30' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"headerData?.client ==='193'\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('31-40')\">31-40 <svg [ngClass]=\"sortedColumn === '31-40' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '31-40' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"headerData?.client ==='193'\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('41-50')\">41-50 <svg [ngClass]=\"sortedColumn === '41-50' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '41-50' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"headerData?.client ==='193'\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('51-60')\">51-60 <svg [ngClass]=\"sortedColumn === '51-60' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '51-60' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"headerData?.client !=='193'\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('31-45')\">31-45 <svg [ngClass]=\"sortedColumn === '31-45' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '31-45' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"headerData?.client !=='193'\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('46-59')\">46-59 <svg [ngClass]=\"sortedColumn === '46-59' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '46-59' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('60 above')\">60 above <svg [ngClass]=\"sortedColumn === '60 above' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '60 above' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('male')\">Male <svg [ngClass]=\"sortedColumn === 'male' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'male' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('female')\">Female <svg \r\n                                        [ngClass]=\"sortedColumn === 'female' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'female' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                            </tr>\r\n                        </thead>\r\n                        <tbody>\r\n                            <tr *ngFor=\"let obj of getSummaryTableData;let i=index;\">\r\n                                <!-- (click)=\"storeView(obj)\" -->\r\n                                <td class=\"text-primary text-capitalize text-decoration-underline cursor-pointer\" (click)=\"storeView(obj.storeId)\">{{obj.storeName}}</td>\r\n                                <td>{{obj.storeId}}</td>\r\n                                <td *ngIf=\"obj?.date\">{{obj?.date | date:'MMM dd, yyyy'}}</td>\r\n                                <td>{{obj.footfallCount}}</td>\r\n                                <td>{{obj.bouncedCount}}</td>\r\n                                <td>{{obj.engagersCount}}</td>\r\n                                <td>{{obj.missedOpportunityCount}}</td>\r\n                                <td *ngIf=\"headerData?.client !=='452'\">{{obj.potentialBuyersCount}}</td>\r\n                                <td>{{obj.conversionRate}}%</td>\r\n                                <td>{{obj.NOBCount}}</td>\r\n                                <td>{{obj.avgDwellTime}}</td>\r\n                                <td>{{obj.avgInfraDowntime}}</td>\r\n                                <td>{{obj.passerBy_count}}</td>\r\n                                <td>{{obj.below12}}</td>\r\n                                <td>{{obj['13-19']}}</td>\r\n                                <td>{{obj['20-30']}}</td>\r\n                                <td *ngIf=\"headerData?.client ==='193'\">{{obj['31-40']}}</td>\r\n                                <td *ngIf=\"headerData?.client ==='193'\">{{obj[\"41-50\"]}}</td>\r\n                                <td *ngIf=\"headerData?.client ==='193'\">{{obj[\"51-60\"]}}</td>\r\n                                <td *ngIf=\"headerData?.client !=='193'\">{{obj['31-45']}}</td>\r\n                                <td *ngIf=\"headerData?.client !=='193'\">{{obj[\"46-59\"]}}</td>\r\n                                <td>{{obj[\"60 above\"]}}</td>\r\n                                <td>{{obj.male}}</td>\r\n                                <td>{{obj.female}}</td>\r\n                            </tr>\r\n                        </tbody>\r\n                    </table>\r\n                </div>\r\n                <lib-pagination [itemsPerPage]=\"pageSize\" [currentPage]=\"offset\" [totalItems]=\"totalItems\"\r\n                [paginationSizes]=\"paginationSizes\" [pageSize]=\"pageSize\" (pageChange)=\"onPageChange($event)\"\r\n                (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n            </div>\r\n        </div>\r\n    </div>\r\n\r\n</div>\r\n"]}
|
|
3868
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"traffic-analysis.component.js","sourceRoot":"","sources":["../../../../../../projects/tango-analyse-traffic/src/lib/components/traffic-analysis/traffic-analysis.component.ts","../../../../../../projects/tango-analyse-traffic/src/lib/components/traffic-analysis/traffic-analysis.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  OnDestroy,\r\n  NgZone,\r\n  ElementRef,\r\n  Renderer2,\r\n  ViewChild,\r\n  ChangeDetectorRef,\r\n  HostListener, AfterViewInit\r\n} from \"@angular/core\";\r\nimport * as am5 from \"@amcharts/amcharts5\";\r\nimport * as am5xy from \"@amcharts/amcharts5/xy\";\r\nimport am5themes_Animated from \"@amcharts/amcharts5/themes/Animated\";\r\nimport am5themes_Responsive from \"@amcharts/amcharts5/themes/Responsive\";\r\nimport * as am5percent from \"@amcharts/amcharts5/percent\";\r\nimport { TrafficService } from \"../../services/traffic.service\";\r\nimport { Subject, Subscription, takeUntil, filter } from 'rxjs';\r\nimport { NgbModal, NgbTooltip } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { Router } from \"@angular/router\";\r\nimport { ExcelService } from \"../../services/excel.service\";\r\nimport * as mapboxgl from 'mapbox-gl';\r\nimport { ToastService } from \"tango-app-ui-shared\";\r\nimport { VideoUrlComponent } from \"../video-url/video-url.component\";\r\nimport * as bootstrap from \"bootstrap\";\r\nimport { FormBuilder, FormControl } from \"@angular/forms\";\r\nimport dayjs from 'dayjs';\r\n\r\n@Component({\r\n  selector: \"lib-traffic-analysis\",\r\n  templateUrl: \"./traffic-analysis.component.html\",\r\n  styleUrl: \"./traffic-analysis.component.scss\",\r\n})\r\nexport class TrafficAnalysisComponent implements OnInit, OnDestroy, AfterViewInit {\r\n  private lineroot: am5.Root;\r\n  private bouncedlineroot: am5.Root;\r\n  private potentialBuyerslineroot: am5.Root;\r\n  private engagerslineroot: am5.Root;\r\n  sortedColumn: any;\r\n  sortDirection: any;\r\n  private chart: any;\r\n  private tooltipElement: HTMLElement;\r\n  private readonly destroy$ = new Subject();\r\n  getCardData: any = [];\r\n  heatMapData: any = [];\r\n  getCardGraphData: any;\r\n  getSummaryTableData: any;\r\n  itemsPerPage = 10;\r\n  currentPage = 1;\r\n  totalItems = 1;\r\n  paginationSizes:any[] = [];\r\n  pageSize = 10;\r\n  offset: number = 0;\r\n  limit: number = 10;\r\n  getRecapVideoData: any;\r\n  tableobj: any;\r\n  heatMaproot: am5.Root;\r\n  valueType=\"actual\"\r\n  dateType=\"weekly\";\r\n  points:any = [];\r\n  headerData: any;\r\n  typeValue: any ='sum';\r\n  valueConversionRate: any;\r\n  conversionValue: any='';\r\n  searchValue: any;\r\n  loading: boolean =true;\r\n  noData: boolean =false;\r\n  cardloading: boolean =true;\r\n  cardNodata: boolean =false;\r\n  heatloading = true\r\n  heatnoData = false\r\n  storeIdarray: any =[];\r\n  getRecapData: any=[];\r\n  form: any;\r\n  dateLength: number;\r\n  performancenoData: boolean =false;\r\n  performanceLoading: boolean =true;\r\n  zoneDwellTimeSplitData: any=[];\r\n  storeOperationData: any=[];\r\n  footfallName: string='Actual Footfall';\r\n  bounceLabel: any;\r\n  footfallLabel: any;\r\n  colValue: any;\r\n  recaplaoding: boolean;\r\n  recapnoData: boolean;\r\n  recapsGrouped: any[]=[];\r\n  isAverage: boolean = false; // Toggle state for the switch\r\n  isDisabled: boolean =false;\r\n  zoneLoading = true;\r\n zoneNoData = false;\r\n  clientData: any;\r\n  featureConfig: any;\r\n  nob: boolean;\r\n  forecast: any;\r\n  maxFootfall: any;\r\n  minFootfall: any;\r\n  isConversion : boolean = false;\r\n  @HostListener('document:click', ['$event'])\r\n  handleClickOutside(event: MouseEvent) {\r\n    const clickedInside = (event.target as HTMLElement).closest('.tooltip-popup, .label');\r\n    if (!clickedInside) {\r\n      this.activeTooltip = null;\r\n    }\r\n  }\r\n  activeTooltip: string | null = null;\r\n\r\n  auLocations: any[] = [];\r\n  mapOptions: google.maps.MapOptions = {\r\n    mapId: \"DEMO_MAP_ID\",\r\n    center: { lat: 0, lng: 0 },  // Initial center\r\n    zoom: 1,\r\n  };\r\n\r\n  performanceData:any = [];\r\n  mpaloading =true;\r\n  mapnoData = false;\r\n  footfalldatasets = [\r\n    { value: 'footfall', label: 'Footfall' },\r\n    { value: 'bounced', label: 'Bounced Footfall' },\r\n    { value: 'engager', label: 'Engagers' },\r\n    { value: 'missedOpportunity', label: 'Missed Opportunity' },\r\n    { value: 'potentialBuyer', label: 'Potential Buyer' },\r\n    { value: 'conversion', label: 'Conversion' }\r\n  ];\r\n  bouncedatasets = [\r\n    { value: 'footfall', label: 'Footfall' },\r\n    { value: 'bounced', label: 'Bounced Footfall' },\r\n    { value: 'engager', label: 'Engagers' },\r\n    { value: 'missedOpportunity', label: 'Missed Opportunity' },\r\n    { value: 'potentialBuyer', label: 'Potential Buyer' },\r\n    { value: 'conversion', label: 'Conversion' }\r\n  ];\r\n\r\n  constructor(\r\n    private zone: NgZone,\r\n    private el: ElementRef,\r\n    private renderer: Renderer2,private router:Router,private excelService: ExcelService,\r\n    private service: TrafficService,public gs: GlobalStateService, private fb:FormBuilder,\r\n    private cd: ChangeDetectorRef,private toast:ToastService, private modalService: NgbModal,\r\n  ) {\r\n \r\n         this.form = this.fb.group({\r\n           selectValue: new FormControl('') // Initialize as FormControl\r\n         });\r\n  }\r\n  @ViewChild(\"t\", { static: false }) tooltip: NgbTooltip;\r\n  tooltipValue: string;\r\n  bounceValue1:any;\r\n  clientAPIData:any;\r\n  users:any;\r\n   sub2:Subscription | undefined\r\n   private isInitialized: boolean = false;\r\n   processType=\"missedopportunities\"\r\n   trendtypeValue: any ='average';\r\n   normalize:any;\r\n  ngOnInit(): void {\r\n    (mapboxgl as any).accessToken = 'pk.eyJ1IjoiYmFsYWppdGFuZ28iLCJhIjoiY20wZ2xiem55MDFxYTJ3b21zb3FjNHdwayJ9.nnIIzt7OeYlYHufGE8lFWQ';\r\n    this.offset = 0;\r\n    this.limit=10;\r\n    const userData: any = JSON.parse(localStorage.getItem(\"user-info\") || \"{}\");\r\n    this.users = userData;\r\n  \r\n    // const clientData:any = JSON.parse(localStorage.getItem(\"client-details\") || \"{}\");\r\n    // this.clientData = clientData\r\n    // const clientAPIData:any = JSON.parse(localStorage.getItem(\"clientAPI-details\") || \"{}\");\r\n    // this.clientAPIData = clientAPIData\r\n      \r\n//  console.log( this.clientData,this.clientAPIData,this.nob)\r\n\r\n    this.gs?.dataRangeValue\r\n      ?.pipe(takeUntil(this.destroy$),debounceTime(300),)\r\n      .subscribe((data: any) => {\r\n        if(data){\r\n          this.headerData = data;\r\n          this.valueConversionRate='';\r\n          this.dateLength = getDaysBetweenDates(data?.date.startDate, data?.date.endDate);\r\n          if (this.dateLength > 28)\r\n            this.dateType = \"monthly\";\r\n          else if (this.dateLength > 5)\r\n            this.dateType = \"weekly\";\r\n          else if(this.dateLength === 0)\r\n            this.dateType = \"weekly\";\r\n          this.valueType=\"actual\";\r\n          this.typeValue=\"sum\"\r\n          this.isAverage = false\r\n          this.sub2 =  this.service?.getBrandDetails(this.users?.clientId ? this.users?.clientId:data?.client).pipe(takeUntil(this.destroy$)).subscribe({\r\n            next: (res:any) => {\r\n              if(res && res.code === 200){\r\n                this.clientData = res?.data;\r\n                this.featureConfig = this.clientData.featureConfigs;\r\n              this.normalize = this.clientData?.featureConfigs?.isNormalized;\r\n              this.storeIdarray = this.headerData?.stores.filter((store: any) => store.checked).map((store: any) => store.storeId)\r\n              this.tableobj = {\r\n                fromDate: data?.date.startDate,\r\n                toDate: data?.date.endDate,\r\n                storeId: data?.stores.filter((store: any) => store.checked).map((store: any) => store.storeId),\r\n                clientId: data?.client ? data?.client :'',\r\n                valueType: this.valueType,\r\n                nob:this.clientData.featureConfigs.isNOB,\r\n                dateType: this.dateType,\r\n                normalize: this.normalize\r\n                };\r\n                this.getVlues();\r\n\r\n              if (!this.isInitialized) {\r\n                this.isInitialized = true;\r\n                  this.isConversion =this.clientData.featureConfigs.isNOB\r\n            \r\n                this.service?.togglenob(this.clientData.featureConfigs.isNOB);\r\n                this.service?.toggleAverage(false);\r\n              }\r\n              // this.conversionValue = this.clientData.featureConfigs.isNOB && this.clientData?.featureConfigs?.conversionCalculation ==='footfall-count'\r\n              // ? \"footfall\"\r\n              // : this.clientData.featureConfigs.isNOB && this.clientData?.featureConfigs\r\n              //     ?.conversionCalculation === 'engagers-count'\r\n              // ? \"engagers\"\r\n              // : this.clientData.featureConfigs.isNOB && this.clientData?.featureConfigs\r\n              //     ?.conversionCalculation === 'billable-entities'? \"Potential Buyers\": \"footfall\";\r\n              this.conversionValue = this.clientData.featureConfigs.isNOB\r\n              ? \"NoB Derived\"\r\n              : this.clientData?.featureConfigs\r\n                  ?.missedOpportunityCalculation === 'engagers-conversion'\r\n              ? \"engagers\"\r\n              : \"footfall\";\r\n              this.getFunnal();\r\n              this.getTable();\r\n              this.performance();\r\n              if(this.normalize === true){  \r\n                this.zoneDwellTimeSplitData =[];\r\n                this.zoneLoading = false;\r\n                this.zoneNoData = true;\r\n                this.storeOperationData =[];\r\n                this.auLocations =[];\r\n                this.mpaloading =false;\r\n                this.mapnoData= true;\r\n              } else{\r\n              this.getZone();\r\n              this.getZoneValue();\r\n              this.getMap();\r\n              }\r\n              this.getIntial();\r\n             \r\n              \r\n              this.nob = !!this.clientData?.featureConfigs?.isNOB;\r\n          \r\n              // this.conversionValue = this.nob ? 'NoB Derived' : this.clientData?.featureConfigs?.missedOpportunityCalculation ==='\"engagers-conversion\"' ? 'conversion': 'footfall' ;\r\n              // this.conversionValue = this.nob ? 'NoB Derived' : 'footfall';\r\n           \r\n               this.objData = {\r\n                        fromDate: this.headerData?.date?.startDate,\r\n                        toDate: this.headerData?.date?.endDate,\r\n                        storeId: this.headerData?.stores.filter((store: any) => store.checked).map((store: any) => store.storeId),\r\n                        clientId: this.headerData?.client,\r\n                        processType: this.processType,\r\n                        dateType: this.type,\r\n                        filterBy: this.trendtypeValue,\r\n                        limit: 31,\r\n                        offset: 0,\r\n                        valueType: this.valueType,\r\n                        nob:this.nob,\r\n                        normalize: this.normalize\r\n                      };\r\n                      if (this.storeIdarray?.length === 1) {\r\n                        if(this.normalize === true){\r\n                          this.getRecapVideoData =[]\r\n                          this.recaplaoding =false;\r\n                          this.recapnoData =true;\r\n                        } else {\r\n                this.getRecap();\r\n                        }\r\n                        this.trendtypeValue = 'actual';\r\n                        this.service?.togglenormalize(this.normalize);\r\n                      } else {\r\n                        this.trendtypeValue = 'average';\r\n                      }\r\n                      // Call the API after objData is fully prepared\r\n                      this.footfallTrend();\r\n                    \r\n                    this.dateLength = getDaysBetweenDates(data?.date.startDate, data?.date.endDate);\r\n                    if (this.headerData?.client === '452') {\r\n                      this.datasets = this.datasets.filter(item => item.value !== 'potentialBuyer');\r\n                    \r\n                      const conversionItem = this.datasets.find(item => item.value === 'conversion');\r\n                      if (conversionItem) {\r\n                        const convValue = this.clientData?.featureConfigs?.conversion?.value ?? 'X';\r\n                        conversionItem.label = `More than ${convValue} mins`;\r\n                      }\r\n                    \r\n                      const missedItem = this.datasets.find(item => item.value === 'missedopportunities');\r\n                      if (missedItem) {\r\n                        const from = this.clientData?.featureConfigs?.missedOpportunityFrom?.value ?? 'X';\r\n                        const to = this.clientData?.featureConfigs?.missedOpportunityTo?.value ?? 'Y';\r\n                        missedItem.label = `${from} - ${to} mins`;\r\n                      }\r\n                    }\r\n                    \r\n                    const initialValue = this.getInitialValue();\r\n                    this.form.get('selectValue')?.setValue(initialValue);\r\n                      this.detailedCharts= false;\r\n                      // if(this.headerData?.client ==='459'){\r\n                      //   this.selectedTab = \"footfall\"\r\n                      //   this.footfallValue = \"footfall\";\r\n                      //   this.selctedValue ='Footfall Analysis';\r\n                      //   this.selectedTabs('footfall');\r\n                      //   this.cd.detectChanges();\r\n                      // } else {\r\n                      //   this.selectedTab = \"traffic\"\r\n                      //   this.footfallValue = \"traffic\";\r\n                      //   this.selctedValue ='Traffic Analysis';\r\n                      //   this.selectedTabs('traffic');\r\n                      // }\r\n                    this.datasetsCard = [\r\n                      { value: this.footfallValue, label: this.selctedValue },\r\n                      { value: \"demographic\", label: \"Demographic Analysis\" },\r\n                      { value: \"buyer\", label: \"Buyer Analysis\" },\r\n                    ];\r\n                    this.trafficData = [\r\n                      { value: 7, label: \"Last 7 Days\" },\r\n                      { value: 30, label: \"Last 30 Days\" },\r\n                    ];\r\n                    this.footfallDate =this.trafficData[0].value\r\n                    this.objDataTraffic = {\r\n                      fromDate: this.headerData?.date?.startDate,\r\n                      toDate: this.headerData?.date?.endDate,\r\n                      storeId: this.headerData?.stores.filter((store:any) => store.checked).map((store:any) => store.storeId),\r\n                      clientId:this.headerData?.client,\r\n                      processType: 'footfall',\r\n                      normalizedData: false,\r\n                      valueType :this.valueType,\r\n                      nob:this.nob,\r\n                      normalize: this.normalize\r\n                    };\r\n                    if(this.headerData?.client ==='459'){\r\n                      this.selectedTab = \"footfall\"\r\n                      this.footfallValue = \"footfall\";\r\n                      this.selctedValue ='Footfall Analysis';\r\n                      this.selectedTabs('footfall');\r\n                    } else {\r\n                      this.selectedTab = \"traffic\"\r\n                      this.footfallValue = \"traffic\";\r\n                      this.selctedValue ='Traffic Analysis';\r\n                      this.selectedTabs('traffic');\r\n                    }\r\n                    \r\n                    this.chartNoData = false;\r\n                    this.chartloading = true;\r\n                    \r\n                    this.cd.detectChanges();\r\n              // localStorage.setItem(\"clientAPI-details\", JSON.stringify(this.clientData?.clientApi));\r\n              }\r\n              this.sub2?.unsubscribe()\r\n            },\r\n            error: (error) => {\r\n              this.sub2?.unsubscribe()\r\n            }\r\n          })\r\n          this.cd.detectChanges();\r\n        // Only process the latest data after debounce time\r\n     \r\n       \r\n        // this.initMap();\r\n        this.tooltipValue = \"Default Tooltip Text\";\r\n\r\n          if (this.storeIdarray?.length === 1 && this.headerData?.date?.startDate === this.headerData?.date?.endDate) {\r\n            this.isDisabled = true\r\n          } else {\r\n            this.isDisabled = false\r\n          }\r\n          \r\n        }\r\n      });\r\n    \r\n  }\r\n  isRelevantConversion(value: string): boolean {\r\n    return ['footfall', 'engagers', 'Potential Buyers', 'NoB Derived'].includes(value);\r\n  }\r\n  getVlues() {\r\n    if (this.headerData?.client === '452') {\r\n      this.footfalldatasets = [\r\n        { value: 'footfall', label: 'Footfall' },\r\n        { value: 'bounced', label: `Less than ${this.featureConfig?.bouncedLimit.value} mins Footfall` },\r\n        { value: 'engager', label: `More than ${this.featureConfig?.bouncedLimit.value} mins` },\r\n        { value: 'missedOpportunity', label: `${this.featureConfig?.missedOpportunityFrom.value} - ${this.featureConfig?.missedOpportunityTo.value} mins` },\r\n        { value: 'conversion', label: `More than ${this.featureConfig?.conversion.value} mins` }\r\n      ];\r\n      this.bouncedatasets = [\r\n        { value: 'footfall', label: 'Footfall' },\r\n        { value: 'bounced', label: `Less than ${this.featureConfig?.bouncedLimit.value} mins Footfall` },\r\n        { value: 'engager', label: `More than ${this.featureConfig?.bouncedLimit.value} mins` },\r\n        { value: 'missedOpportunity', label: `${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins` },\r\n        { value: 'conversion', label: `More than ${this.featureConfig?.conversion.value} mins` }\r\n      ];\r\n    } \r\n\r\n    this.footfallValue1 = this.footfalldatasets[0].value;\r\n    this.bounceValue1 = this.bouncedatasets[1].value;\r\n    this.footfallLabel = this.footfalldatasets[0].label;\r\n    this.bounceLabel = this.bouncedatasets[1].label;\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    // Initialize tooltips after the view is initialized\r\n    const tooltipTriggerList = [].slice.call(document.querySelectorAll('[data-bs-toggle=\"tooltip\"]'));\r\n    tooltipTriggerList.forEach(function (tooltipTriggerEl) {\r\n      new bootstrap.Tooltip(tooltipTriggerEl);\r\n    });\r\n  }\r\n  getFilteredBounceDatasets() {\r\n    return this.bouncedatasets.filter(dataset => dataset.value !== this.footfallValue1);\r\n  }\r\n  \r\n  // Filter the footfall options when the bounceValue changes\r\n  getFilteredFootfallDatasets() {\r\n    return this.footfalldatasets.filter(dataset => dataset.value !== this.bounceValue1);\r\n  }\r\n  footfallValue1='footfall'\r\n  onValueChange(evt: any) {\r\n    this.footfallValue1 = evt.target.value;\r\nif(evt.target.value == 'footfall')\r\n  this.footfallLabel = 'Footfall'\r\nelse if(evt.target.value == 'bounced')\r\n  this.footfallLabel = this.headerData?.client === '452'?`Less than ${this.featureConfig?.bouncedLimit.value} mins Footfall`: 'Bounced Footfall'\r\nelse if(evt.target.value == 'engager')\r\n  this.footfallLabel = this.headerData?.client === '452'?`More than ${this.featureConfig?.bouncedLimit.value} mins`: 'Engagers'\r\nelse if(evt.target.value == 'missedOpportunity')\r\n  this.footfallLabel = this.headerData?.client === '452'?`${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins`: 'Missed Opportunity'\r\nelse if(evt.target.value == 'potentialBuyer')\r\n  this.footfallLabel = 'Potential Buyer'\r\nelse if(evt.target.value == 'conversion')\r\n  this.footfallLabel = this.headerData?.client === '452'?`More than ${this.featureConfig?.conversion.value} mins`: 'conversion'\r\n    if(this.footfallValue1 !== this.bounceValue1)\r\n      this.performance();\r\n    else \r\n    this.toast.getErrorToast('Same value not filtered')\r\n  }\r\n  onBounceChange(evt: any) {\r\n    this.bounceValue1 = evt.target.value;\r\n    if(evt.target.value == 'footfall')\r\n      this.bounceLabel = 'Footfall'\r\n    else if(evt.target.value == 'bounced')\r\n      this.bounceLabel = this.headerData?.client === '452'?`Less than ${this.featureConfig?.bouncedLimit.value} mins Footfall`: 'Bounced Footfall'\r\n    else if(evt.target.value == 'engager')\r\n      this.bounceLabel = this.headerData?.client === '452'?`More than ${this.featureConfig?.bouncedLimit.value} mins`: 'Engagers'\r\n    else if(evt.target.value == 'missedOpportunity')\r\n      this.bounceLabel = this.headerData?.client === '452'?`${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins`: 'Missed Opportunity'\r\n    else if(evt.target.value == 'potentialBuyer')\r\n      this.bounceLabel = 'Potential Buyer'\r\n    else if(evt.target.value == 'conversion')\r\n      this.bounceLabel = this.headerData?.client === '452' ? `More than ${this.featureConfig?.conversion.value} mins` : 'conversion'\r\n    if(this.footfallValue1 !== this.bounceValue1)\r\n    this.performance();\r\n  else \r\n  this.toast.getErrorToast('Same value not filtered')\r\n  }\r\n  convertPercentToPixels(percent: string, maxPercent: number, baseDimension: number): number {\r\n    // Remove the '%' sign and parse the value\r\n    const value = parseFloat(percent.replace('%', ''));\r\n    if (isNaN(value)) return 0;\r\n  \r\n    // Calculate pixel value based on the maximum percentage and base dimension\r\n    return (value / maxPercent) * baseDimension;\r\n  }\r\n  \r\n\r\n  getMaxPercentage(data: any[], field: string): number {\r\n    // Extract and return the maximum percentage value from the field\r\n    return Math.max(...data.map(item => parseFloat(item[field]) || 0));\r\n  }\r\n  \r\n  // normalizeData(data: any[]): any[] {\r\n  //   const maxTopPercent = Math.max(...data.map(item => parseFloat(item.top.replace('%', ''))));\r\n  //   const maxLeftPercent = Math.max(...data.map(item => parseFloat(item.left.replace('%', ''))));\r\n  \r\n  //   return data.map(item => ({\r\n  //     ...item,\r\n  //     top: this.scalePercent(item.top, maxTopPercent) + '%',\r\n  //     left: this.scalePercent(item.left, maxLeftPercent) + '%'\r\n  //   }));\r\n  // }\r\n  \r\n  scalePercent(percent: string, maxPercent: number): string {\r\n    const percentValue = parseFloat(percent.replace('%', ''));\r\n    return ((percentValue / maxPercent) * 100).toFixed(2);\r\n  }\r\n// Toggle the tooltip display\r\ntoggleTooltip(pointName: string) {\r\n  this.activeTooltip = this.activeTooltip === pointName ? null : pointName;\r\n}\r\n\r\nperformance(){\r\n  this.performanceLoading = true;\r\n  this.performancenoData = false;\r\n  let obj = {\r\n    clientId:this.headerData?.client,\r\n    fromDate: this.headerData?.date.startDate,\r\n    toDate: this.headerData?.date.endDate,\r\n    normalize: this.normalize,\r\n    storeId: this.headerData?.stores.filter((store:any) => store.checked).map((store:any) => store.storeId),\r\n   processtype1: this.footfallValue1,\r\n   processtype2 : this.bounceValue1\r\n  };\r\n  this.service.performanceMatrix(obj).pipe(takeUntil(this.destroy$))\r\n  ?.subscribe({\r\n    next: (res: any) => {\r\n      if (res && res.code === 200) {\r\n        this.performanceData = res?.data?.performanceData\r\n        // this.performanceData = this.normalizeData(this.performanceData);\r\n        // Calculate maximum percentages\r\n        // const maxTop = Math.max(...this.performanceData.map((item:any) => parseFloat(item.top.replace('%', ''))));\r\n        // const maxLeft = Math.max(...this.performanceData.map((item:any) => parseFloat(item.left.replace('%', ''))));\r\n        \r\n        // Convert performance data to pixel values\r\n        this.points = this.performanceData.map((data: any) => ({\r\n          name: data.storeName,\r\n          storeId: data.storeId,\r\n          avgFootfall: data.avg,\r\n          openTime: data.avgOpenTime,\r\n          closeTime: data.avgCloseTime,\r\n          top: data.top, // Assuming 500px as the base height\r\n          left: data.left  // Assuming 1000px as the base width\r\n        })); \r\n        this.performanceLoading = false;\r\n        this.performancenoData = false;\r\n      } else {\r\n        this.performanceLoading = false;\r\n        this.performancenoData = true;\r\n      }\r\n      }\r\n    })\r\n  }\r\n\r\n  getTooltipText(): string {\r\n    // Logic to determine the tooltip text\r\n    return \"Dynamic Tooltip Text \" + new Date().toLocaleTimeString();\r\n  }\r\n\r\n  getFunnal(){\r\n    this.tableobj.valueType= this.valueType,\r\n     this.tableobj.fromDate = this.headerData?.date.startDate;\r\n     this.tableobj.toDate = this.headerData?.date.endDate;\r\n     if(this.conversionValue === 'footfall'){\r\n      this.tableobj.conversiontype = 'footfall-count';\r\n     } if (this.conversionValue === 'engagers'){\r\n      this.tableobj.conversiontype = 'engagers-count';\r\n     }if (this.conversionValue === 'Potential Buyers'){\r\n      this.tableobj.conversiontype = 'billable-count';\r\n     } if (this.conversionValue === 'NoB Derived'){\r\n      this.tableobj.conversiontype = 'nob';\r\n     }\r\n     \r\n    delete this.tableobj.offset;\r\n    delete this.tableobj.recapVideoDate;\r\n    delete this.tableobj.limit; \r\n    delete this.tableobj.export;\r\n    delete this.tableobj.sort;\r\n    delete this.tableobj.sortBy;\r\n    this.heatloading = true;\r\n    this.heatnoData = false;\r\n   delete this.tableobj.dateType\r\n    this.service\r\n      .getFunnelCards(this.tableobj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            // this.getCardData = res?.data?.card;\r\n            this.heatMapData = res?.data?.funnelChart;\r\n           \r\n            this.heatMap();\r\n            this.cd.detectChanges();\r\n          } else {\r\n            this.getCardData =[];\r\n            this.heatMapData =[];\r\n          this.heatloading = false\r\n          this.heatnoData = true\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.getCardData =[];\r\n          this.heatMapData =[];\r\n          this.cd.detectChanges();\r\n        },\r\n        complete: () => {},\r\n      });\r\n  }\r\n  getFootfallCardData:any=[];\r\n  getConversionCardData:any=[];\r\n  getBouncedCardData:any =[];\r\n  getEngagersCardData:any=[];\r\n  getPotentialBuyersCardData:any =[];\r\n  getMissedOpportunityData:any =[];\r\n  getPotentialBuyersData:any=[];\r\n  getIntial(){\r\n    delete this.tableobj.recapVideoDate;\r\n    delete this.tableobj.sort;\r\n    delete this.tableobj.sortBy;\r\n    (this.tableobj.valueType = this.valueType),\r\n    (this.tableobj.fromDate = this.headerData?.date.startDate);\r\n  this.tableobj.toDate = this.headerData?.date.endDate;\r\n  this.getFootfallCard();\r\n  this.getConversionCard();\r\n  this.getBouncedCard();\r\n  this.getEngagersCard();\r\n  this.getPotentialBuyersCard();\r\n  this.getMissedOpportunityCard();\r\n  this.getPotentialBuyers();\r\n  }\r\n  footfallloading =true;\r\n  footfallNodata =false;\r\n  getFootfallCard(){\r\n    this.footfallloading =true;\r\n    this.footfallNodata =false;\r\n    delete this.tableobj.offset;\r\n    delete this.tableobj.limit;\r\n    delete this.tableobj.export;\r\n    this.tableobj.dateType= this.dateType;\r\n    this.service\r\n      .getFootdfallCardList(this.tableobj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getFootfallCardData = res?.data;\r\n          if(this.getFootfallCardData?.data?.footfall?.data.length){\r\n            this.footfalllineCharts();\r\n            this.footfallloading =false;\r\n            this.footfallNodata =false;\r\n          } else {\r\n          this.getFootfallCardData =[];\r\n          this.footfallloading =false;\r\n          this.footfallNodata =true;\r\n          }\r\n          } else { \r\n          this.getFootfallCardData =[];\r\n          this.footfallloading =false;\r\n          this.footfallNodata =true;\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.getFootfallCardData =[];\r\n        this.footfallloading =false;\r\n        this.footfallNodata =true;\r\n        this.cd.detectChanges();\r\n      }, \r\n      })\r\n  }\r\n  setConversionType(conversionValue: string): string {\r\n    const map: Record<string, string> = {\r\n      'footfall': 'footfall-count',\r\n      'engagers': 'engagers-count',\r\n      'Potential Buyers': 'billable-count',\r\n      'NoB Derived': 'nob',\r\n    };\r\n    return map[conversionValue] || '';\r\n  }\r\n  \r\n  getConversionCard(){\r\n    const { tableobj } = this;\r\n    delete tableobj.offset;\r\n    delete tableobj.limit;\r\n    delete tableobj.export;\r\n    tableobj.dateType = this.dateType;\r\n    tableobj.conversiontype = this.setConversionType(this.conversionValue);\r\n       this.service\r\n         .getConversionCardList(this.tableobj)\r\n         .pipe(takeUntil(this.destroy$))\r\n         ?.subscribe({\r\n           next: (res: any) => {\r\n             if (res && res.code === 200) {\r\n               this.getConversionCardData = res?.data;\r\n               if (this.nob) {\r\n                this.valueConversionRate = this.getConversionCardData?.conversion?.nob?.nob;\r\n                this.conversionValue = 'NoB Derived';\r\n              } else if (this.clientData?.featureConfigs?.missedOpportunityCalculation === 'engagers-conversion') {\r\n                this.valueConversionRate = this.getConversionCardData?.conversion?.engagers?.rate;\r\n                this.conversionValue = 'engagers';\r\n              } else {\r\n                this.valueConversionRate = this.getConversionCardData?.conversion?.footfall?.rate;\r\n                this.conversionValue = 'footfall';\r\n              }\r\n\r\n              // if (this.nob && this.clientData?.featureConfigs?.conversionCalculation === 'footfall-count') {\r\n              //   this.valueConversionRate = this.getConversionCardData?.conversion?.footfall?.rate;\r\n              //   this.conversionValue = 'footfall';\r\n              // } else if (this.nob && this.clientData?.featureConfigs?.conversionCalculation === 'engagers-count') {\r\n              //   this.valueConversionRate = this.getConversionCardData?.conversion?.engagers?.rate;\r\n              //   this.conversionValue = 'engagers';\r\n              // } else if (this.nob && this.clientData?.featureConfigs?.conversionCalculation === 'billable-entities') {\r\n              //   this.valueConversionRate = this.getConversionCardData?.conversion?.potentialBuyers?.rate;\r\n              //   this.conversionValue = 'Potential Buyers';\r\n              // }\r\n             } else { \r\n              this.getConversionCardData =[];\r\n           }\r\n         },\r\n         error: (err: any) => {\r\n           this.getConversionCardData =[];\r\n           this.cd.detectChanges();\r\n         }, \r\n         })\r\n     }\r\n     getConversionCard1(){\r\n      const { tableobj } = this;\r\n  delete tableobj.offset;\r\n  delete tableobj.limit;\r\n  delete tableobj.export;\r\n  tableobj.dateType = this.dateType;\r\n  tableobj.conversiontype = this.setConversionType(this.conversionValue);\r\n         this.service\r\n           .getConversionCardList(this.tableobj)\r\n           .pipe(takeUntil(this.destroy$))\r\n           ?.subscribe({\r\n             next: (res: any) => {\r\n               if (res && res.code === 200) {\r\n                 this.getConversionCardData = res?.data;\r\n                 if(this.conversionValue === 'footfall'){\r\n                  this.tableobj.conversiontype = 'footfall-count';  this.valueConversionRate = this.getConversionCardData?.conversion?.footfall?.rate;\r\n                 }  if (this.conversionValue === 'engagers'){\r\n                  this.tableobj.conversiontype = 'engagers-count'; \r\n                  this.valueConversionRate = this.getConversionCardData?.conversion?.engagers?.rate;\r\n                 }if (this.conversionValue === 'Potential Buyers'){\r\n                  this.tableobj.conversiontype = 'billable-count'; \r\n                  this.valueConversionRate = this.getConversionCardData?.conversion?.potentialBuyers?.rate;\r\n                 } if (this.conversionValue === 'NoB Derived'){\r\n                  this.tableobj.conversiontype = 'nob'; this.valueConversionRate = this.getConversionCardData?.conversion?.nob?.nob;\r\n                 }\r\n               } else { \r\n                this.getConversionCardData =[];\r\n             }\r\n           },\r\n           error: (err: any) => {\r\n             this.getConversionCardData =[];\r\n             this.cd.detectChanges();\r\n           }, \r\n           })\r\n       }\r\n     bouncedNodata =false;\r\n     getBouncedCard(){\r\n      delete this.tableobj.offset;\r\n      delete this.tableobj.limit;\r\n      delete this.tableobj.export;\r\n      this.tableobj.dateType= this.dateType;\r\n      this.service\r\n        .getBouncedCardList(this.tableobj)\r\n        .pipe(takeUntil(this.destroy$))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res.code === 200) {\r\n              this.getBouncedCardData = res?.data;\r\n              if(this.getBouncedCardData?.data?.bounced?.data.length){\r\n              this.bouncedlineCharts();\r\n              this.bouncedNodata =false;\r\n              } else{\r\n                this.getBouncedCardData =[];\r\n                this.bouncedNodata =true;\r\n              }\r\n            } else { \r\n              this.bouncedNodata =true;\r\n              this.getBouncedCardData =[];\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.getBouncedCardData =[];\r\n          this.bouncedNodata =true;\r\n          this.cd.detectChanges();\r\n        }, \r\n        }) \r\n    }\r\n    engagersNodata =false;\r\n    getEngagersCard(){\r\n      delete this.tableobj.offset;\r\n      delete this.tableobj.limit;\r\n      delete this.tableobj.export;\r\n      this.tableobj.dateType= this.dateType;\r\n      this.service\r\n        .getEngagersCardList(this.tableobj)\r\n        .pipe(takeUntil(this.destroy$))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res.code === 200) {\r\n              this.getEngagersCardData = res?.data;\r\n              if(this.getEngagersCardData?.data?.engagers?.data.length){\r\n              this.engagerslineCharts();\r\n              this.engagersNodata =false;\r\n              } else {\r\n                this.getEngagersCardData =[];\r\n              this.engagersNodata =true;\r\n              }\r\n            } else { \r\n              this.getEngagersCardData =[];\r\n              this.engagersNodata =true;\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.getEngagersCardData =[];\r\n          this.engagersNodata =true;\r\n          this.cd.detectChanges();\r\n        }, \r\n        })\r\n    }\r\n    getMissedOpportunityCard(){\r\n      delete this.tableobj.offset;\r\n      delete this.tableobj.limit;\r\n      delete this.tableobj.export;\r\n      this.tableobj.dateType= this.dateType;\r\n      this.service\r\n      .getMissedOpportunityCardList(this.tableobj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getMissedOpportunityData = res?.data;\r\n          } else { \r\n            this.getMissedOpportunityData =[];\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.getMissedOpportunityData =[];\r\n        this.cd.detectChanges();\r\n      }, \r\n      })\r\n    }\r\n    potentialNodata =false;\r\n    getPotentialBuyersCard(){\r\n      delete this.tableobj.offset;\r\n      delete this.tableobj.limit;\r\n      delete this.tableobj.export;\r\n      this.tableobj.dateType= this.dateType;\r\n      this.service\r\n        .getPotentialBuyersCardList(this.tableobj)\r\n        .pipe(takeUntil(this.destroy$))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res.code === 200) {\r\n              this.getPotentialBuyersCardData = res?.data;\r\n              if(this.getPotentialBuyersCardData?.data?.potentialBuyers?.data.length){\r\n              this.potentiallineCharts();\r\n              this.potentialNodata =false;\r\n              } else { \r\n                this.getPotentialBuyersCardData =[];\r\n                this.potentialNodata =true;\r\n            }\r\n            }  else { \r\n              this.getPotentialBuyersCardData =[];\r\n              this.potentialNodata =true;\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.getPotentialBuyersCardData =[];\r\n          this.potentialNodata =true;\r\n          this.cd.detectChanges();\r\n        }, \r\n        })\r\n    }\r\n\r\n    getPotentialBuyers(){\r\n      delete this.tableobj.offset;\r\n      delete this.tableobj.limit;\r\n      delete this.tableobj.export;\r\n      this.tableobj.dateType= this.dateType;\r\n      this.service\r\n      .getPotentialBuyersDistributionCardList(this.tableobj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getPotentialBuyersData = res?.data?.card;\r\n          }  else { \r\n            this.getPotentialBuyersData =[];\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.getPotentialBuyersData =[];\r\n        this.cd.detectChanges();\r\n      }, \r\n      })\r\n    }\r\n\r\n\r\n  getRecap() {\r\n    this.recaplaoding =true;\r\n    this.recapnoData =false;\r\n    delete this.tableobj.processType; delete this.tableobj.normalizedData;\r\n     delete this.tableobj.dateType; delete this.tableobj.fromDate;\r\n     delete this.tableobj.toDate; delete this.tableobj.valueType; delete this.tableobj.processType;\r\n     delete this.tableobj.search; delete this.tableobj.offset;\r\n     delete this.tableobj.limit; delete this.tableobj.sortBy; delete this.tableobj.sort;\r\n     delete this.tableobj.export;\r\n     delete this.tableobj.normalize;\r\n     this.tableobj.recapVideoDate = this.headerData?.date.endDate;\r\n    this.service\r\n      .getRecapVideo(this.tableobj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getRecapVideoData = res?.data;\r\n            this.getRecapData = res?.data?.recapVideoData;\r\n            this.groupRecaps();\r\n            if(!this.getRecapData.length){\r\n              this.recaplaoding =false;\r\n            this.recapnoData =true;\r\n            } else {\r\n              this.recaplaoding =false;\r\n            this.recapnoData =false;\r\n            }\r\n            this.cd.detectChanges();    \r\n          } else{\r\n            this.getRecapVideoData =[]\r\n            this.recaplaoding =false;\r\n            this.recapnoData =true;\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.cd.detectChanges();\r\n          this.recaplaoding =false;\r\n          this.recapnoData =true;\r\n        },\r\n        complete: () => {},\r\n      });\r\n  }\r\n  groupRecaps() {\r\n    this.recapsGrouped = [];\r\n    let groupSize = this.getRecapData.length === 1 ? 1 : 2;\r\n    for (let i = 0; i < this.getRecapData.length; i += groupSize) {\r\n      this.recapsGrouped.push(this.getRecapData.slice(i, i + groupSize));\r\n    }\r\n    this.colValue = this.getRecapData.length === 1 ? 'col-md-12' : 'col-md-6';\r\n  }\r\n  videoClick(obj:any){\r\n    const modalRef = this.modalService.open(VideoUrlComponent, {\r\n      centered: true,\r\n      size: \"lg\",\r\n      scrollable: true,\r\n    });\r\n    modalRef.componentInstance.videoUrl = obj;\r\n    modalRef.componentInstance.date= this.headerData?.date?.endDate\r\n    modalRef.result.then((result: any) => {});\r\n  }\r\n  previousValue: any = null;\r\n  changeValue(method: any) {\r\n      this.previousValue = method;\r\n      if (this.previousValue === 'potentialBuyers') {\r\n        this.conversionValue = 'Potential Buyers';\r\n      } else {\r\n        this.conversionValue = method;\r\n      }\r\n   \r\n      const isConversion = this.isConversion === true;\r\n      const conversionTypeMap: any = {\r\n        footfall: {\r\n          rate: this.getConversionCardData?.conversion?.footfall?.rate,\r\n          type: 'footfall-count',\r\n          nob: isConversion ? true : false\r\n        },\r\n        engagers: {\r\n          rate: this.getConversionCardData?.conversion?.engagers?.rate,\r\n          type: 'engagers-count',\r\n          nob: isConversion ? true : false\r\n        },\r\n        potentialBuyers: {\r\n          rate: this.getConversionCardData?.conversion?.potentialBuyers?.rate,\r\n          type: 'billable-count',\r\n          nob: isConversion ? true : false\r\n        },\r\n        'NoB Derived': {\r\n          rate: this.getConversionCardData?.conversion?.nob?.nob,\r\n          type: 'nob',\r\n          nob: true // always true for NoB Derived\r\n        }\r\n      };\r\n      \r\n      const data = conversionTypeMap[this.previousValue];\r\n      \r\n      if (data) {\r\n        this.valueConversionRate = data.rate;\r\n        this.tableobj.nob = data.nob;\r\n        this.objData.nob = data.nob;\r\n        this.objDataTraffic.nob = data.nob;\r\n        this.nob = data.nob;\r\n        this.tableobj.conversiontype = data.type;\r\n      }\r\n      \r\n      // this.service.togglenob(this.tableobj.nob);\r\n      this.getFunnal(); \r\n      if(this.tableobj.nob ===false)\r\n      this.getConversionCard1(); \r\n      this.tableobj.fromDate= this.headerData?.date.startDate,\r\n      this.tableobj.toDate= this.headerData?.date.endDate,\r\n      this.tableobj.search = this.searchValue;\r\n      delete this.tableobj.recapVideoDate;\r\n      this.getTable();\r\n     this.footfallTrend();\r\n     if(this.headerData?.client ==='459'){\r\n      this.selectedTab = \"footfall\"\r\n      this.footfallValue = \"footfall\";\r\n      this.selctedValue ='Footfall Analysis';\r\n      this.selectedTabs('footfall');\r\n    } else {\r\n      this.selectedTab = \"traffic\"\r\n      this.footfallValue = \"traffic\";\r\n      this.selctedValue ='Traffic Analysis';\r\n      this.selectedTabs('traffic');\r\n    }\r\n   \r\n    // }\r\n  }\r\n \r\n\r\n  getTable() {\r\n    this.limit =10;\r\n    this.tableobj.offset = this.offset = this.currentPage -1;\r\n    this.loading = true;\r\n    this.noData = false;\r\n    delete this.tableobj.processType;\r\n    delete this.tableobj.normalizedData;\r\n    delete this.tableobj.dateType;\r\n    (this.tableobj.limit = this.limit);\r\n    (this.tableobj.search = this.searchValue), \r\n     (this.tableobj.valueType = this.typeValue); \r\n     (this.tableobj.conversiontype = this.tableobj.conversiontype);\r\n     this.tableobj.export = false;\r\n    this.service\r\n      .getSummaryTableList(this.tableobj)\r\n      ?.pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            if(res?.data.summaryData.length ===0){\r\n              this.getSummaryTableData =[]\r\n              this.loading = false;\r\n              this.noData = true;\r\n              this.totalItems = 0; \r\n            } else {\r\n            this.getSummaryTableData = res?.data.summaryData;\r\n            this.totalItems = res.data?.totalCount;\r\n            this.setPaginationSizes();\r\n            this.loading = false;\r\n            this.noData = false;\r\n            }\r\n          } else {\r\n            this.getSummaryTableData =[]\r\n            this.loading = false;\r\n            this.noData = true;\r\n            this.totalItems = 0; \r\n          }\r\n          this.cd.detectChanges();\r\n        },\r\n        error: (err: any) => {\r\n          this.cd.detectChanges();\r\n        },\r\n        complete: () => {},\r\n      });\r\n  }\r\n  searchData() {\r\n    this.tableobj.fromDate= this.headerData?.date.startDate,\r\n    this.tableobj.toDate= this.headerData?.date.endDate,\r\n    this.tableobj.search = this.searchValue;\r\n    delete this.tableobj.recapVideoDate;\r\n    (this.tableobj.conversiontype = this.tableobj.conversiontype);\r\n    this.tableobj.export = false;\r\n    this.offset = 1;\r\n    this.tableobj.offset = this.offset -1;\r\n    this.limit=10;\r\n    this.getTable();\r\n  }\r\n\r\n  setPaginationSizes() {\r\n    if (this.totalItems > 10) {\r\n      this.paginationSizes = [10, 20, 30];\r\n    } else {\r\n      this.paginationSizes = [this.totalItems]; // Just one option if less than 10\r\n    }\r\n    this.pageSize = this.paginationSizes[0];\r\n  }\r\n  onPageChange(pageOffset: number) {\r\n    this.loading = true;\r\n    this.noData = false;\r\n    this.offset = Number(pageOffset);\r\n    this.tableobj.offset = this.offset -1;\r\n    (this.tableobj.limit = this.limit),\r\n    (this.tableobj.search = this.searchValue), \r\n     (this.tableobj.valueType = this.typeValue);\r\n    this.tableobj.fromDate= this.headerData?.date.startDate,\r\n    this.tableobj.toDate= this.headerData?.date.endDate,\r\n    this.tableobj.search = this.searchValue;\r\n    (this.tableobj.conversiontype = this.tableobj.conversiontype);\r\n    delete this.tableobj.recapVideoDate;\r\n    this.tableobj.export = false;\r\n    this.service\r\n    .getSummaryTableList(this.tableobj)\r\n    ?.pipe(takeUntil(this.destroy$))\r\n    ?.subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code === 200) {\r\n          if(res?.data.summaryData.length ===0){\r\n            this.getSummaryTableData =[]\r\n            this.loading = false;\r\n            this.noData = true;\r\n            this.totalItems = 0; \r\n          } else {\r\n          this.getSummaryTableData = res?.data.summaryData;\r\n          this.totalItems = res.data?.totalCount;\r\n          this.loading = false;\r\n          this.noData = false;\r\n          }\r\n        } else {\r\n          this.getSummaryTableData =[]\r\n          this.loading = false;\r\n          this.noData = true;\r\n          this.totalItems = 0; \r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.cd.detectChanges();\r\n      },\r\n      complete: () => {},\r\n    });\r\n  }\r\n\r\n  onPageSizeChange(pageSize: number) {\r\n    this.loading = true;\r\n    this.noData = false;\r\n    this.pageSize = Number(pageSize);\r\n    this.limit = Number(pageSize);\r\n    this.currentPage = 1;\r\n    this.offset = 0;\r\n    this.tableobj.offset = this.offset;\r\n    (this.tableobj.limit = this.limit),\r\n    (this.tableobj.valueType = this.typeValue);\r\n    this.tableobj.fromDate= this.headerData?.date.startDate,\r\n    this.tableobj.toDate= this.headerData?.date.endDate,\r\n    this.tableobj.search = this.searchValue;\r\n    (this.tableobj.conversiontype = this.tableobj.conversiontype);\r\n    delete this.tableobj.recapVideoDate;\r\n    this.tableobj.export = false;\r\n    this.service\r\n    .getSummaryTableList(this.tableobj)\r\n    ?.pipe(takeUntil(this.destroy$))\r\n    ?.subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code === 200) {\r\n          if(res?.data.summaryData.length ===0){\r\n            this.getSummaryTableData =[]\r\n            this.loading = false;\r\n            this.noData = true;\r\n            this.totalItems = 0; \r\n          } else {\r\n          this.getSummaryTableData = res?.data.summaryData;\r\n          this.totalItems = res.data?.totalCount;\r\n          this.loading = false;``\r\n          this.noData = false;\r\n          }\r\n        } else {\r\n          this.getSummaryTableData =[]\r\n          this.loading = false;\r\n          this.noData = true;\r\n          this.totalItems = 0; \r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.cd.detectChanges();\r\n      },\r\n      complete: () => {},\r\n    });\r\n  }\r\n\r\n  onValueType(type:any){\r\n    this.tableobj.fromDate= this.headerData.date.startDate,\r\n    this.tableobj.toDate= this.headerData.date.endDate,\r\n    delete this.tableobj.recapVideoDate;\r\n    this.tableobj.export = false;\r\n     this.typeValue =type;\r\n    this.tableobj.valueType =type;\r\n    (this.tableobj.conversiontype = this.tableobj.conversiontype);\r\n    this.getTable();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next(true);\r\n    this.destroy$.complete();\r\n    this.zone.runOutsideAngular(() => {\r\n      if (this.lineroot) {\r\n        this.lineroot.dispose();\r\n      }\r\n      if (this.bouncedlineroot) {\r\n        this.bouncedlineroot.dispose();\r\n      }\r\n      if (this.potentialBuyerslineroot) {\r\n        this.potentialBuyerslineroot.dispose();\r\n      }\r\n      if (this.engagerslineroot) {\r\n        this.engagerslineroot.dispose();\r\n      }\r\n      if (this.heatMaproot) {\r\n        this.heatMaproot.dispose();\r\n      } if (this.rootTrends) {\r\n        this.rootTrends.dispose();\r\n      }\r\n      if (this.dwellRoot) {\r\n        this.dwellRoot.dispose();\r\n      }\r\n      if (this.intervalId) {\r\n        clearInterval(this.intervalId);\r\n      }\r\n    });\r\n  }\r\n  // card line Charts Start\r\n\r\n  footfalllineCharts() {\r\n    setTimeout(() => {\r\n      const chartDiv = document.getElementById(\"Footfall\");\r\n      if (!chartDiv) {\r\n        return;\r\n      }\r\n      if (this.lineroot) {\r\n        this.lineroot.dispose();\r\n      }\r\n    let root: any;\r\n    root = am5.Root.new(\"Footfall\");\r\n    root.setThemes([\r\n      am5themes_Animated.new(root),\r\n      am5themes_Responsive.new(root),\r\n    ]);\r\n    let chart = root.container.children.push(\r\n      am5xy.XYChart.new(root, {\r\n        panX: true,\r\n        panY: true,\r\n        wheelX: \"panX\",\r\n        wheelY: \"zoomX\",\r\n        pinchZoomX: true,\r\n      })\r\n    );\r\n\r\n    // Add data\r\n    let data = this.getFootfallCardData?.data?.footfall?.data.map((item: any) => ({\r\n      date: new Date(item.date).getTime(), // Convert date string to timestamp\r\n      value: Number(item.value),\r\n    }));\r\n     // Ensure that data has at least 2 points for line chart\r\n     if (data.length === 1) {\r\n      const duplicatePoint = { ...data[0] }; // Clone the existing point\r\n      duplicatePoint.date += 1; // Add a small offset to the date\r\n      data.push(duplicatePoint); // Add the duplicate point to data\r\n    }\r\n    let cursor = chart.set(\r\n      \"cursor\",\r\n      am5xy.XYCursor.new(root, {\r\n        behavior: \"none\",\r\n      })\r\n    );\r\n    cursor.lineY.set(\"visible\", false);\r\n    // Create axes\r\n    let xAxis = chart.xAxes.push(\r\n      am5xy.DateAxis.new(root, {\r\n        maxDeviation: 0.5,\r\n        baseInterval: { timeUnit: \"day\", count: 1 },\r\n        renderer: am5xy.AxisRendererX.new(root, { }),\r\n      })\r\n    );\r\n    xAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    xAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    let yAxis = chart.yAxes.push(\r\n      am5xy.ValueAxis.new(root, {\r\n        renderer: am5xy.AxisRendererY.new(root, { }),\r\n      })\r\n    );\r\n    yAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    yAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    // Create series\r\n    let series = chart.series.push(\r\n      am5xy.LineSeries.new(root, {\r\n        name: \"Series\",\r\n        xAxis: xAxis,\r\n        yAxis: yAxis,\r\n        valueYField: \"value\",\r\n        valueXField: \"date\",\r\n        stroke: am5.color(0x00a3ff), // Set the line color here (red in this case)\r\n      })\r\n    );\r\n    series.bullets.push(function () {\r\n      let bulletCircle = am5.Circle.new(root, {\r\n        radius: 0,\r\n        fill: series.get(\"fill\")\r\n      });\r\n      return am5.Bullet.new(root, {\r\n        sprite: bulletCircle\r\n      })\r\n    })\r\n    series.data.setAll(data);\r\n    series.set(\r\n      \"tooltip\",\r\n      am5.Tooltip.new(root, {\r\n        labelText: \"{valueY}\",\r\n        getFillFromSprite: false, // Prevents the tooltip from inheriting color from the sprite\r\n        background: am5.Rectangle.new(root, {\r\n          fill: am5.color(0xdaf1ff), // Set the tooltip background color here (blue in this case)\r\n        }),\r\n      })\r\n    );\r\n    this.lineroot = root;\r\n  },0)\r\n  }\r\n  bouncedlineCharts() {\r\n    setTimeout(() => {\r\n      const chartDiv = document.getElementById(\"BouncedRate\");\r\n      if (!chartDiv) {\r\n        return;\r\n      }\r\n      if (this.bouncedlineroot) {\r\n        this.bouncedlineroot.dispose();\r\n      }\r\n    let root: any;\r\n    root = am5.Root.new(\"BouncedRate\");\r\n    root.setThemes([\r\n      am5themes_Animated.new(root),\r\n      am5themes_Responsive.new(root),\r\n    ]);\r\n    let chart = root.container.children.push(\r\n      am5xy.XYChart.new(root, {\r\n        panX: true,\r\n        panY: true,\r\n        wheelX: \"panX\",\r\n        wheelY: \"zoomX\",\r\n        pinchZoomX: true,\r\n      })\r\n    );\r\n\r\n    // Add data\r\n    let data = this.getBouncedCardData?.data?.bounced?.data.map((item: any) => ({\r\n      date: new Date(item.date).getTime(), // Convert date string to timestamp\r\n      value: Number(item.value),\r\n    }));\r\n    let cursor = chart.set(\r\n      \"cursor\",\r\n      am5xy.XYCursor.new(root, {\r\n        behavior: \"none\",\r\n      })\r\n    );\r\n    cursor.lineY.set(\"visible\", false);\r\n    // Create axes\r\n    let xAxis = chart.xAxes.push(\r\n      am5xy.DateAxis.new(root, {\r\n        maxDeviation: 0.2,\r\n        baseInterval: { timeUnit: \"day\", count: 1 },\r\n        renderer: am5xy.AxisRendererX.new(root, { minorGridEnabled: true }),\r\n      })\r\n    );\r\n    xAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    xAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    let yAxis = chart.yAxes.push(\r\n      am5xy.ValueAxis.new(root, {\r\n        renderer: am5xy.AxisRendererY.new(root, { pan: \"zoom\" }),\r\n      })\r\n    );\r\n    yAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    yAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    // Create series\r\n    let series = chart.series.push(\r\n      am5xy.LineSeries.new(root, {\r\n        name: \"Series\",\r\n        xAxis: xAxis,\r\n        yAxis: yAxis,\r\n        valueYField: \"value\",\r\n        valueXField: \"date\",\r\n        stroke: am5.color(0x00a3ff), // Set the line color here (red in this case)\r\n      })\r\n    );\r\n    series.bullets.push(function () {\r\n      let bulletCircle = am5.Circle.new(root, {\r\n        radius: 0,\r\n        fill: series.get(\"fill\")\r\n      });\r\n      return am5.Bullet.new(root, {\r\n        sprite: bulletCircle\r\n      })\r\n    })\r\n    series.data.setAll(data);\r\n    series.set(\r\n      \"tooltip\",\r\n      am5.Tooltip.new(root, {\r\n        labelText: \"{valueY}\",\r\n        getFillFromSprite: false, // Prevents the tooltip from inheriting color from the sprite\r\n        background: am5.Rectangle.new(root, {\r\n          fill: am5.color(0xdaf1ff), // Set the tooltip background color here (blue in this case)\r\n        }),\r\n      })\r\n    );\r\n    this.bouncedlineroot = root;\r\n  },0)\r\n  }\r\n\r\n  potentiallineCharts() {\r\n    setTimeout(() => {\r\n      const chartDiv = document.getElementById(\"PotentialBuyers\");\r\n      if (!chartDiv) {\r\n        return;\r\n      }\r\n      if (this.potentialBuyerslineroot) {\r\n        this.potentialBuyerslineroot.dispose();\r\n      }\r\n    let root: any;\r\n    root = am5.Root.new(\"PotentialBuyers\");\r\n    root.setThemes([\r\n      am5themes_Animated.new(root),\r\n      am5themes_Responsive.new(root),\r\n    ]);\r\n    let chart = root.container.children.push(\r\n      am5xy.XYChart.new(root, {\r\n        panX: true,\r\n        panY: true,\r\n        wheelX: \"panX\",\r\n        wheelY: \"zoomX\",\r\n        pinchZoomX: true,\r\n      })\r\n    );\r\n\r\n    // Add data\r\n    let data = this.getPotentialBuyersCardData?.data?.potentialBuyers?.data.map(\r\n      (item: any) => ({\r\n        date: new Date(item.date).getTime(), // Convert date string to timestamp\r\n        value: Number(item.value),\r\n      })\r\n    );\r\n    let cursor = chart.set(\r\n      \"cursor\",\r\n      am5xy.XYCursor.new(root, {\r\n        behavior: \"none\",\r\n      })\r\n    );\r\n    cursor.lineY.set(\"visible\", false);\r\n    // Create axes\r\n    let xAxis = chart.xAxes.push(\r\n      am5xy.DateAxis.new(root, {\r\n        maxDeviation: 0.2,\r\n        baseInterval: { timeUnit: \"day\", count: 1 },\r\n        renderer: am5xy.AxisRendererX.new(root, { minorGridEnabled: true }),\r\n      })\r\n    );\r\n    xAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    xAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    let yAxis = chart.yAxes.push(\r\n      am5xy.ValueAxis.new(root, {\r\n        renderer: am5xy.AxisRendererY.new(root, { pan: \"zoom\" }),\r\n      })\r\n    );\r\n    yAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    yAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    // Create series\r\n    let series = chart.series.push(\r\n      am5xy.LineSeries.new(root, {\r\n        name: \"Series\",\r\n        xAxis: xAxis,\r\n        yAxis: yAxis,\r\n        valueYField: \"value\",\r\n        valueXField: \"date\",\r\n        stroke: am5.color(0x00a3ff), // Set the line color here (red in this case)\r\n      })\r\n    );\r\n    series.bullets.push(function () {\r\n      let bulletCircle = am5.Circle.new(root, {\r\n        radius: 0,\r\n        fill: series.get(\"fill\")\r\n      });\r\n      return am5.Bullet.new(root, {\r\n        sprite: bulletCircle\r\n      })\r\n    })\r\n    series.data.setAll(data);\r\n    series.set(\r\n      \"tooltip\",\r\n      am5.Tooltip.new(root, {\r\n        labelText: \"{valueY}\",\r\n        getFillFromSprite: false, // Prevents the tooltip from inheriting color from the sprite\r\n        background: am5.Rectangle.new(root, {\r\n          fill: am5.color(0xdaf1ff), // Set the tooltip background color here (blue in this case)\r\n        }),\r\n      })\r\n    );\r\n    this.potentialBuyerslineroot = root;\r\n  },0)\r\n  }\r\n\r\n  engagerslineCharts() {\r\n    setTimeout(() => {\r\n      const chartDiv = document.getElementById(\"engagers\");\r\n      if (!chartDiv) {\r\n        return;\r\n      }\r\n      if (this.engagerslineroot) {\r\n        this.engagerslineroot.dispose();\r\n      }\r\n    let root: any;\r\n    root = am5.Root.new(\"engagers\");\r\n    root.setThemes([\r\n      am5themes_Animated.new(root),\r\n      am5themes_Responsive.new(root),\r\n    ]);\r\n    let chart = root.container.children.push(\r\n      am5xy.XYChart.new(root, {\r\n        panX: true,\r\n        panY: true,\r\n        wheelX: \"panX\",\r\n        wheelY: \"zoomX\",\r\n        pinchZoomX: true,\r\n      })\r\n    );\r\n\r\n    // Add data\r\n    let data = this.getEngagersCardData?.data?.engagers?.data.map((item: any) => ({\r\n      date: new Date(item.date).getTime(), // Convert date string to timestamp\r\n      value: Number(item.value),\r\n    }));\r\n    let cursor = chart.set(\r\n      \"cursor\",\r\n      am5xy.XYCursor.new(root, {\r\n        behavior: \"none\",\r\n      })\r\n    );\r\n    cursor.lineY.set(\"visible\", false);\r\n    // Create axes\r\n    let xAxis = chart.xAxes.push(\r\n      am5xy.DateAxis.new(root, {\r\n        maxDeviation: 0.2,\r\n        baseInterval: { timeUnit: \"day\", count: 1 },\r\n        renderer: am5xy.AxisRendererX.new(root, { minorGridEnabled: true }),\r\n      })\r\n    );\r\n    xAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    xAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    let yAxis = chart.yAxes.push(\r\n      am5xy.ValueAxis.new(root, {\r\n        renderer: am5xy.AxisRendererY.new(root, { pan: \"zoom\" }),\r\n      })\r\n    );\r\n    yAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    yAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n\r\n    // Create series\r\n    let series = chart.series.push(\r\n      am5xy.LineSeries.new(root, {\r\n        name: \"Series\",\r\n        xAxis: xAxis,\r\n        yAxis: yAxis,\r\n        valueYField: \"value\",\r\n        valueXField: \"date\",\r\n        stroke: am5.color(0x00a3ff), // Set the line color here (red in this case)\r\n      })\r\n    );\r\n    series.bullets.push(function () {\r\n      let bulletCircle = am5.Circle.new(root, {\r\n        radius: 0,\r\n        fill: series.get(\"fill\")\r\n      });\r\n      return am5.Bullet.new(root, {\r\n        sprite: bulletCircle\r\n      })\r\n    })\r\n    series.data.setAll(data);\r\n    series.set(\r\n      \"tooltip\",\r\n      am5.Tooltip.new(root, {\r\n        labelText: \"{valueY}\",\r\n        getFillFromSprite: false, // Prevents the tooltip from inheriting color from the sprite\r\n        background: am5.Rectangle.new(root, {\r\n          fill: am5.color(0xdaf1ff), // Set the tooltip background color here (blue in this case)\r\n        }),\r\n      })\r\n    );\r\n    this.engagerslineroot = root;\r\n  },0)\r\n  }\r\n  // card line Charts End\r\n\r\n  heatMap() {\r\n    this.heatloading = false\r\n    this.heatnoData = false\r\n    setTimeout(() => {\r\n      const chartDiv = document.getElementById(\"chartdiv\");\r\n      if (!chartDiv) {\r\n        return;\r\n      }\r\n      if (this.heatMaproot) {\r\n        this.heatMaproot.dispose();\r\n      }\r\n    let root = am5.Root.new(\"chartdiv\");\r\n    root.setThemes([am5themes_Animated.new(root)]);\r\n\r\n    let chart = root.container.children.push(\r\n      am5percent.SlicedChart.new(root, {\r\n        layout: root.verticalLayout,\r\n      })\r\n    );\r\n  \r\n      let data = this.heatMapData;\r\n    if (this.headerData?.client === '452') {\r\n      data = data.filter((item: any) => item.category !== 'Potential Buyers');\r\n      data = data.map((item:any) => {\r\n        const category = item.category.toLowerCase();\r\n      \r\n        const updatedCategory =\r\n          category === 'engagers'\r\n            ? `More than ${this.featureConfig?.bouncedLimit.value} mins`\r\n            : category === 'bounced'\r\n            ? `Less than ${this.featureConfig?.bouncedLimit.value} mins`\r\n            : category === 'conversion'\r\n            ? `More than ${this.featureConfig?.conversion.value} mins`\r\n            : category === 'footfall'\r\n            ? 'Footfall'\r\n            : `${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins`;\r\n      \r\n        return {\r\n          ...item,\r\n          category: updatedCategory,\r\n        };\r\n      });\r\n      }\r\n      \r\n    data.sort((a:any, b:any) => b.value - a.value);\r\n    let series = chart.series.push(\r\n      am5percent.FunnelSeries.new(root, {\r\n        alignLabels: false,\r\n        orientation: \"horizontal\",\r\n        valueField: \"value\",\r\n        categoryField: \"category\",\r\n        bottomRatio: 1,\r\n      })\r\n    );\r\n\r\n      \r\n    series.data.setAll(data);\r\n    series.appear();\r\n    // Update the label template to include the percentage\r\n    series.labels.template.setAll({\r\n      populateText: true,\r\n      text: \"{category} ({count}%)\\n\\n{value}\",\r\n      fontSize:\"13px\",\r\n      fontWeight:\"400\",\r\n      textAlign:\"center\"\r\n    });\r\n      \r\n    this.heatMaproot = root;\r\n    chart.appear(1000, 100);\r\n  },0);\r\n\r\n  }\r\n\r\n  type: any = \"weekly\";\r\n  selectPlan(type: any) {\r\n    this.type = type;\r\n  }\r\n\r\n  // Toggle function for the switch\r\n  toggleAverage(evt:any) {\r\n    // this.tableobj.nob =true;\r\n    this.isAverage = evt.target.checked;\r\n    this.service.toggleAverage(this.isAverage);\r\n    this.service?.togglenob(this.tableobj.nob);\r\n    this.tableobj.fromDate= this.headerData.date.startDate,\r\n    this.tableobj.toDate= this.headerData.date.endDate,\r\n    delete this.tableobj.recapVideoDate;\r\n    delete this.tableobj.limit; delete this.tableobj.export;\r\n    delete this.tableobj.offset;\r\n    if(this.isAverage === true){\r\n    this.valueType = 'average';\r\n     this.footfallName = 'Avg. Footfall'\r\n   this.tableobj.valueType =this.valueType;\r\n   this.objData.valueType =this.valueType;\r\n   this.objDataTraffic.valueType =this.valueType;\r\n  //  this.conversionValue = '';\r\n   this.typeValue='average';\r\n  //  this.valueConversionRate = this.getCardData?.conversion?.rate;\r\n  }  else {\r\n     this.footfallName = 'Actual Footfall'\r\n     this.valueType='actual';\r\n    this.tableobj.valueType ='actual';\r\n    this.objData.valueType ='actual';\r\n    this.objDataTraffic.valueType ='actual';\r\n    this.typeValue='sum';\r\n\r\n    // this.valueConversionRate = this.getCardData?.conversion?.rate;\r\n  }\r\n  if(this.tableobj.nob){\r\n    this.valueConversionRate = this.getConversionCardData?.conversion?.nob.nob;\r\n  this.conversionValue ='NoB Derived'\r\n} else if (this.clientData?.featureConfigs?.missedOpportunityCalculation === 'engagers-conversion') {\r\n  this.valueConversionRate = this.getConversionCardData?.conversion?.engagers?.rate;\r\n  this.conversionValue = 'engagers';\r\n} else {\r\n  this.valueConversionRate = this.getConversionCardData?.conversion?.footfall?.rate;\r\n  this.conversionValue = 'footfall';\r\n}\r\n  this.previousValue = 'footfall'; \r\n  this.tableobj.normalize = this.normalize\r\n\r\n    this.getFunnal();\r\n    this.getFootfallCard();\r\n    this.getConversionCard();\r\n    this.getBouncedCard();\r\n    this.getEngagersCard();\r\n    this.getPotentialBuyersCard();\r\n    this.getMissedOpportunityCard();\r\n    this.getPotentialBuyers();\r\n    this.getTable();\r\n    this.footfallTrend();\r\n    if(this.headerData?.client ==='459'){\r\n      this.selectedTab = \"footfall\"\r\n      this.footfallValue = \"footfall\";\r\n      this.selctedValue ='Footfall Analysis';\r\n    this.selectedTabs('footfall');\r\n    } else {\r\n      this.selectedTab = \"traffic\"\r\n      this.footfallValue = \"traffic\";\r\n      this.selctedValue ='Traffic Analysis';\r\n      this.selectedTabs('traffic');\r\n    }\r\n   \r\n    this.cd.detectChanges();\r\n  }\r\n  toggleConversion(evt:any){\r\n    this.isConversion = evt.target.checked; \r\n    this.tableobj.normalize = this.normalize\r\n    if(this.conversionValue === 'footfall'){\r\n      this.tableobj.conversiontype = 'footfall-count';\r\n     } if (this.conversionValue === 'engagers'){\r\n      this.tableobj.conversiontype = 'engagers-count';\r\n     }if (this.conversionValue === 'Potential Buyers'){\r\n      this.tableobj.conversiontype = 'billable-count';\r\n     } if (this.conversionValue === 'NoB Derived'){\r\n      this.tableobj.conversiontype = 'nob';\r\n     }\r\n    if(this.isConversion ==true){\r\n      this.tableobj.nob = true;\r\n      this.objData.nob = true;\r\n      this.objDataTraffic.nob = true; this.nob =true;\r\n    }  else {\r\n      if(this.tableobj.conversiontype === 'nob'){\r\n        this.tableobj.nob = true;\r\n      this.objData.nob = true;\r\n      this.objDataTraffic.nob = true; this.nob =true; \r\n      } else {\r\n      this.nob =false;\r\n      this.tableobj.nob = false;\r\n      this.objData.nob = false;\r\n      this.objDataTraffic.nob = false;\r\n      }\r\n    }\r\n    this.getFunnal();    \r\n    this.getConversionCard1(); \r\n    this.getTable();\r\n    this.footfallTrend(); \r\n    this.selectedTab = \"traffic\"\r\n    this.footfallValue = \"traffic\";\r\n    this.selctedValue ='Traffic Analysis';\r\n    this.selectedTabs('traffic');\r\n  }\r\n\r\n  cameraView(){\r\n    this.storeIdarray = this.headerData?.stores.filter((store:any) => store.checked).map((store:any) => store.storeId)\r\n    let data: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"\");\r\n    data.store = this.storeIdarray[0];\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(data));\r\n    this.gs.dataRangeValue.next(data);\r\n    this.router.navigate([\"/manage/stores/cameras\"], {\r\n      queryParams: { storeId: this.storeIdarray[0]},\r\n    });\r\n  }\r\n\r\n  exportXLSX() {\r\n    this.tableobj.offset = 0;\r\n    this.tableobj.limit = 10000;\r\n    (this.tableobj.valueType = this.typeValue);\r\n    this.tableobj.fromDate= this.headerData.date.startDate,\r\n    this.tableobj.toDate= this.headerData.date.endDate,\r\n    this.tableobj.search = this.searchValue;\r\n    this.tableobj.export = true;\r\n    this.tableobj.normalize = this.normalize\r\n    delete this.tableobj.recapVideoDate;\r\n    this.service\r\n    .getSummaryTableListExport(this.tableobj)\r\n    ?.pipe(takeUntil(this.destroy$))\r\n    ?.subscribe({\r\n      next: (res: any) => {\r\n        if (res) {\r\n          this.excelService.saveAsExcelFile(res, \"Traffic Summary Table \");\r\n        } else {\r\n        }\r\n      },\r\n      error: () => {},\r\n    });\r\n    this.tableobj.limit = this.limit;\r\n    this.tableobj.export = false;\r\n  }\r\n\r\n  onSort(column: string) {\r\n    if (this.sortedColumn === column) {\r\n      this.sortDirection = this.sortDirection === 1 ? -1 : 1;\r\n    } else {\r\n      this.sortedColumn = column;\r\n      this.sortDirection = 1;\r\n    }\r\n    this.tableobj.fromDate= this.headerData.date.startDate,\r\n    this.tableobj.toDate= this.headerData.date.endDate,\r\n    delete this.tableobj.recapVideoDate;\r\n    this.tableobj.sortBy = this.sortDirection, //[1->asc, -1->DEsc]\r\n    this.tableobj.sort = this.sortedColumn, // Column Name\r\n    this.getTable();\r\n  }\r\n\r\n  getMap() {\r\n    this.mpaloading =true;\r\n    this.mapnoData= false;\r\n    const obj = {\r\n      clientId: this.headerData?.client,\r\n      storeDate: this.headerData?.date?.endDate,\r\n      storeId: this.storeIdarray\r\n    };\r\n\r\n    this.service.geMaps(obj)?.pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if(res && res.code === 200){\r\n          // if (res && res.data && res.data.storeData) {\r\n            this.auLocations = res.data.storeData;\r\n          \r\n            // Update mapOptions center if needed\r\n            if (this.auLocations.length > 0) {\r\n              const firstLocation = this.auLocations[0];\r\n              if (firstLocation && typeof firstLocation.lat === 'number' && typeof firstLocation.lng === 'number') {\r\n                this.mapOptions = {\r\n                  ...this.mapOptions,\r\n                  center: { lat: firstLocation.lat, lng: firstLocation.lng }\r\n                };\r\n                setTimeout(() => {  this.getData(); },100)\r\n                this.cd.detectChanges();\r\n              } else {}\r\n            } else {}\r\n          // }\r\n          this.mpaloading =false;\r\n          this.mapnoData= false;\r\n          } else if(res === null){\r\n            this.mapnoData= true;\r\n            this.mpaloading =false;\r\n          } else {\r\n            this.auLocations =[];\r\n            this.mpaloading =false;\r\n            this.mapnoData= true;\r\n          }\r\n        \r\n        },\r\n        error: (err) => {\r\n          this.auLocations =[];\r\n          this.mpaloading =false;\r\n            this.mapnoData= true;\r\n        }\r\n      });\r\n  }\r\n  map: mapboxgl.Map;\r\n  private checkMapContainerInterval: any;\r\n  getData() {\r\n    this.checkMapContainerInterval = setTimeout(() => {\r\n      const mapContainer = this.el.nativeElement.querySelector('#map');\r\n      if (mapContainer) {\r\n        clearInterval(this.checkMapContainerInterval);\r\n        this.initializeMap(mapContainer);\r\n      } else {\r\n        clearInterval(this.checkMapContainerInterval);\r\n        this.initializeMap(mapContainer);\r\n      }\r\n    }, 100);\r\n\r\n  }\r\n  initializeMap(mapContainer: HTMLElement){\r\n    setTimeout(() => {  \r\n      const mapContainer = document.getElementById('map');\r\n      if (!mapContainer) {\r\n        return;\r\n      }\r\n    // Check that locations exist before proceeding\r\n    if (this.auLocations?.length === 0) {\r\n      return;\r\n    }\r\n  \r\n    const geojson = {\r\n      'type': 'FeatureCollection',\r\n      'features': this.auLocations.map((store, index) => ({\r\n        'type': 'Feature',\r\n        'properties': {\r\n          'storeName': store.storeName,         // Store name\r\n          'imageId': 1011 + index,              // Dynamic image ID\r\n          'iconSize': [60, 60],                 // Adjust icon size as needed\r\n          'footfall': store.avgFootfall,        // Footfall data\r\n          'openTime': store.openTime,           // Open time\r\n          'closeTime': store.closeTime,         // Close time\r\n        },\r\n        'geometry': {\r\n          'type': 'Point',\r\n          'coordinates': [store.lng, store.lat]  // Coordinates from store data\r\n        }\r\n      }))\r\n    };\r\n  \r\n    // Dynamically set map center based on the first location\r\n    const firstLocation = this.auLocations[0];\r\n \r\n    this.map = new mapboxgl.Map({\r\n      container: 'map',\r\n      style: 'mapbox://styles/mapbox/streets-v12',\r\n      center: [firstLocation.lng, firstLocation.lat], // Center map on the first location\r\n      zoom: 10, // Adjust this value (1 = world view, 20 = building view)\r\n      maxZoom: 20, // Optional: Limit max zoom level\r\n      minZoom: 1   // Optional: Limit min zoom level\r\n    });\r\n  \r\n    // Add markers to the map\r\n    geojson.features.forEach((feature, featureIndex) => {\r\n      const { properties, geometry } = feature;\r\n      const store = this.auLocations[featureIndex];\r\n      const el = document.createElement('div');\r\n      const width = properties.iconSize[0];\r\n      const height = properties.iconSize[1];\r\n      el.className = 'marker';\r\n      el.innerHTML = `\r\n      <div class=\"marker-icon\" style=\"background-color: white; width: ${width}px; height: ${height}px; display: flex; justify-content: center; align-items: center;\r\n      color: var(--Gray-700, #344054);\r\ntext-align: center;\r\nfont-family: Inter;\r\nfont-size: 9.007px;\r\nfont-style: normal;\r\nfont-weight: 600;\r\nline-height: 13px;\">\r\n        <div class=\"marker-content\" style=\"display: flex; flex-direction: column; align-items: center;\">\r\n          <svg class=\"mb-1\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n            <path d=\"M1.33654 3.3637L1.29658 3.42611C0.877698 4.16701 1.32493 5.10335 2.12931 5.21076C2.20218 5.21967 2.26999 5.22438 2.33625 5.22438C2.77021 5.22438 3.1539 5.03821 3.42132 4.74793L3.83666 4.2971L4.25059 4.74923C4.51476 5.03778 4.89758 5.22438 5.33448 5.22438C5.76941 5.22438 6.15443 5.03752 6.41837 4.74923L6.83359 4.29568L7.24882 4.74923C7.51275 5.03752 7.89777 5.22438 8.33271 5.22438C8.76764 5.22438 9.15266 5.03752 9.4166 4.74923L9.83182 4.29568L10.247 4.74923C10.511 5.03752 10.896 5.22438 11.3309 5.22438C11.395 5.22438 11.4649 5.21966 11.5372 5.21083C12.3593 5.09875 12.808 4.11225 12.3286 3.36408C12.3286 3.36403 12.3285 3.36399 12.3285 3.36395L11.0088 1.30621L11.0081 1.30511C10.9967 1.28722 10.9686 1.26804 10.9332 1.26804H2.72942C2.69403 1.26804 2.66589 1.28722 2.65448 1.30511L2.65401 1.30584L1.33654 3.3637ZM11.0731 7.06667V9.41753V9.98049H10.5101H3.15248H2.58952V9.41753V7.06702C2.50678 7.07318 2.42308 7.07634 2.33855 7.07634C2.30679 7.07634 2.27525 7.07587 2.24392 7.07495V9.41753V10.8696C2.24392 11.3526 2.64467 11.7587 3.15248 11.7587H10.5101C11.0179 11.7587 11.4187 11.3526 11.4187 10.8696V9.41753V7.07509C11.3888 7.07591 11.3587 7.07634 11.3286 7.07634C11.2428 7.07634 11.1575 7.07308 11.0731 7.06667Z\" stroke=\"#101828\" stroke-width=\"1.12592\"/>\r\n          </svg>\r\n          <div class=\"marker-label\" style=\"font-size: 10px; text-align: center;\">\r\n            ${properties.storeName}\r\n          </div>\r\n        </div>\r\n      </div>\r\n    `;\r\n      // el.style.backgroundImage = `url(https://picsum.photos/id/${properties.imageId}/${width}/${height})`;\r\n      el.style.width = `${width}px`;\r\n      el.style.height = `${height}px`;\r\n      el.style.backgroundSize = '100%';\r\n  \r\n      // Create a popup instance with the feature properties\r\n      const popup = new mapboxgl.Popup({ offset: 25 })  \r\n      // Use the coordinates from the feature\r\n      const coordinates: [number, number] = geometry.coordinates as [number, number];\r\n      el.addEventListener('click', () => {\r\n        this.adjustLayout(store);\r\n      });\r\n      // Add markers to the map\r\n      new mapboxgl.Marker(el)\r\n        .setLngLat(coordinates)\r\n        .setPopup(popup)  // Attach the popup to the marker\r\n        .addTo(this.map);\r\n    });\r\n    \r\n  },100)\r\n  }\r\n  adjustLayout(data: any) {\r\n    const datavalue: any = JSON.parse(\r\n      localStorage.getItem(\"header-filters\") || \"{}\"\r\n    );\r\n    const matchedStores = datavalue.stores.filter((store: any) => store.checked && store.storeId === data.storeId);\r\n    // Update the balance stores (those not in the matched stores) to set their checked property to false\r\n    datavalue.stores.forEach((store: any) => {\r\n      if (!matchedStores.some((matchedStore:any) => matchedStore.storeId === store.storeId)) {\r\n        store.checked = false;\r\n      }\r\n    }); \r\n    datavalue.store = data.storeId;\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(datavalue));\r\n    this.cd.detectChanges()\r\n    this.gs.dataRangeValue.next(datavalue)\r\n    this.gs.manageRefreshTrigger.next(true);\r\n   \r\n  }\r\n  exporeView(){\r\nthis.router.navigate(['/manage/traffic/explore'])\r\n  }\r\n  dateValue(type:any){\r\n    delete this.tableobj.limit; delete this.tableobj.export;\r\n    delete this.tableobj.offset;\r\n    this.tableobj.fromDate= this.headerData.date.startDate,\r\n    this.tableobj.toDate= this.headerData.date.endDate,\r\n    delete this.tableobj.recapVideoDate;\r\n    this.dateType = type;\r\n    this.tableobj.dateType= this.dateType;\r\n    this.tableobj.valueType  = this.valueType\r\n    this.getFootfallCard();\r\n    this.getConversionCard();\r\n    this.getBouncedCard();\r\n    this.getEngagersCard();\r\n    this.getPotentialBuyersCard();\r\n    this.getMissedOpportunityCard();\r\n    this.getPotentialBuyers();\r\n  }\r\n\r\n\r\n  getZone(){\r\n    this.zoneLoading = true;\r\n    this.zoneNoData = false;\r\n    const obj = {\r\n      clientId: this.headerData?.client,\r\n      fromDate: this.headerData?.date?.startDate,\r\n    toDate: this.headerData?.date?.endDate,\r\n      storeId: this.storeIdarray\r\n    };\r\n\r\n    this.service.zoneDwellTime(obj)?.pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if(res && res.code === 200){\r\n            this.zoneDwellTimeSplitData = res.data.zoneDwellTimeSplitData;\r\n            this.zoneLoading = false;\r\n            this.zoneNoData = false;\r\n          } else{\r\n            this.zoneDwellTimeSplitData =[];\r\n            this.zoneLoading = false;\r\n            this.zoneNoData = true;\r\n          }\r\n        },\r\n        error: (err) => {\r\n          this.zoneDwellTimeSplitData=[];\r\n        }\r\n\r\n      })\r\n    \r\n  }\r\n  getZoneValue(){\r\n    const obj = {\r\n      clientId: this.headerData?.client,\r\n      fromDate: this.headerData?.date?.startDate,\r\n    toDate: this.headerData?.date?.endDate,\r\n      storeId: this.storeIdarray\r\n    };\r\n\r\n    this.service.storeOperation(obj)?.pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if(res && res.code === 200){\r\n            this.storeOperationData = res.data.storeOperationData[0];\r\n          } else{\r\n            this.storeOperationData =[];\r\n          }\r\n        },\r\n        error: (err) => {\r\n          this.storeOperationData=[];\r\n        }\r\n\r\n      })\r\n    \r\n  }\r\n  onDateChange(event:any){\r\n    this.detailedCharts = false;\r\n    this.footfallDate = event.target.value;\r\n    this.objDataTraffic.dateRange =Number(this.footfallDate);\r\n this.getDwell();\r\n this.trafficDwell();\r\n  }\r\n  storeView(data:any){\r\n    const datavalue: any = JSON.parse(\r\n      localStorage.getItem(\"header-filters\") || \"{}\"\r\n    );\r\n    const matchedStores = datavalue.stores.filter((store: any) => store.checked && store.storeId === data);\r\n    // Update the balance stores (those not in the matched stores) to set their checked property to false\r\n    datavalue.stores.forEach((store: any) => {\r\n      if (!matchedStores.some((matchedStore:any) => matchedStore.storeId === store.storeId)) {\r\n        store.checked = false;\r\n      }\r\n    }); \r\n    datavalue.store = data;\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(datavalue));\r\n    this.cd.detectChanges()\r\n    this.gs.dataRangeValue.next(datavalue)\r\n    this.gs.manageRefreshTrigger.next(true);\r\n  }\r\n  goToZone(){\r\n    this.router.navigate([\"/manage/zones/v1\"]); \r\n\r\n  }\r\n\r\n  currentIndex: number = 0;\r\n  intervalId: any;\r\n\r\n\r\n  prevSlide() {\r\n    if (this.currentIndex > 0) {\r\n      this.currentIndex--;\r\n    }\r\n  }\r\n\r\n  nextSlide() {\r\n    if (this.currentIndex < this.recapsGrouped.length - 1) {\r\n      this.currentIndex++;\r\n    }\r\n  }\r\n\r\n  goToSlide(index: number) {\r\n    if (index >= 0 && index < this.recapsGrouped.length) {\r\n      this.currentIndex = index;\r\n    }\r\n  }\r\n  \r\n  nobUpload(){\r\n    this.router.navigate([\"/manage/traffic/nob\"]); \r\n  }\r\n  goToLoss(){\r\n    this.router.navigate([\"/manage/settings/brand-detail\"]); \r\n  }\r\n\r\n// footfall trend parts\r\n\r\ngetDateValues: any;\r\nchartTrends: any;\r\nrootTrends: any;\r\nyAxis: any;\r\nxAxis: any; \r\nlegend: any;\r\n@ViewChild('tooltipContainer') tooltipContainer: ElementRef<HTMLDivElement>;\r\ntooltipData: any;\r\ngetFootfallTrendData:any=[];\r\nobjData:any;\r\ndatasets = [\r\n  { value: 'missedopportunities', label: 'Missed Opportunity' },\r\n  { value: 'potentialBuyer', label: 'Potential Buyer' },\r\n  { value: 'conversion', label: 'Conversion' },\r\n  { value: '', label: 'No Filter' }\r\n];\r\n\r\nitemsPerPageTrends = 10;\r\ncurrentPageTrends = 1;\r\ntotalItemsTrends = 1;\r\npaginationSizesTrends: number[] = [];\r\npageSizeTrends = 31;\r\noffsetTrends : number = 0;\r\nlimitTrends : number = 31;\r\nselectValue= new FormControl(\"dataset1\");\r\nloadingTrends =true;\r\nnoDataTrends =false;\r\n  getInitialValue(): string {\r\n    // For example, selecting the second item in the dataset\r\n    return this.datasets[0].value; // Change as needed\r\n  }\r\n  onValueChangetrend(selectedId: any) {\r\n    this.objData.processType = selectedId,\r\n    this.footfallTrend();\r\n  }\r\n  get selectControl(): FormControl {\r\n    return this.form.get('selectValue') as FormControl;\r\n  }\r\n  @HostListener('document:click', ['$event'])\r\n  onClick(event: MouseEvent): void {\r\n    const tooltipElement = this.tooltipContainer?.nativeElement;\r\n\r\n    // Check if the click was outside the tooltip\r\n    if (tooltipElement && !tooltipElement.contains(event.target as Node) && this.tooltipVisible) {\r\n      this.hideTooltip();\r\n    }\r\n    this.show =false;\r\n  }\r\nfootfallTrend(){ \r\n  this.offsetTrends =0;\r\n  this.limitTrends =31;\r\n  this.loadingTrends =true;\r\n  this.noDataTrends =false;\r\n  (this.objData.conversiontype = this.tableobj.conversiontype);\r\n  this.service\r\n  .getfootfallTrend(this.objData)\r\n  .pipe(takeUntil(this.destroy$))\r\n  ?.subscribe({\r\n    next: (res: any) => {\r\n      if (res && res.code === 200) {\r\n        this.getFootfallTrendData = res?.data?.footfallTrendData;\r\n        this.getDateValues = res?.data;\r\n        this.totalItemsTrends = res.data?.totalCount;\r\n        this.setPaginationSizeTrends();\r\n        this.createChart() // Call with a delay to ensure the element is in the DOM\r\n        this.cd.detectChanges(); \r\n        this.loadingTrends =false;\r\n        this.noDataTrends =false;\r\n      } else {\r\n        this.loadingTrends =false;\r\n        this.noDataTrends =true;\r\n        this.getFootfallTrendData =[];\r\n      }\r\n    },\r\n    error: (err: any) => {\r\n      this.cd.detectChanges();\r\n    },\r\n    complete: () => {},\r\n  });\r\n  \r\n}\r\nsetPaginationSizeTrends() {\r\n  if (this.totalItemsTrends > 31 ) {\r\n    if(this.objData.forecast && this.totalItemsTrends > 31){\r\n      this.paginationSizesTrends = [60];\r\n    } else {  \r\n    this.paginationSizesTrends = [31];\r\n    }\r\n  } else {\r\n    this.paginationSizesTrends = [this.totalItemsTrends]; // Just one option if less than 10\r\n  }\r\n  this.pageSizeTrends = this.paginationSizesTrends[0];\r\n}\r\nonPageChangeTrends(pageOffsetTrends: number) {\r\n  this.offsetTrends = Number(pageOffsetTrends);\r\n  this.objData.offset = this.offsetTrends -1;\r\n  this.objData.limit = this.limitTrends;\r\n  this.service\r\n  .getfootfallTrend(this.objData)\r\n  .pipe(takeUntil(this.destroy$))\r\n  ?.subscribe({\r\n    next: (res: any) => {\r\n      if (res && res.code === 200) {\r\n        this.getFootfallTrendData = res?.data.footfallTrendData;\r\n        \r\n        this.getDateValues = res?.data;\r\n        this.totalItemsTrends = res.data?.totalCount;\r\n        this.createChart() // Call with a delay to ensure the element is in the DOM\r\n        this.cd.detectChanges(); \r\n\r\n      } else {\r\n        this.loading =false;\r\n        this.noData =true;\r\n      }\r\n    },\r\n    error: (err: any) => {\r\n      this.cd.detectChanges();\r\n    },\r\n    complete: () => {},\r\n  });\r\n  \r\n}\r\n\r\nonPageSizeChangeTrends(pageSizeTrends: number) {\r\n  this.pageSizeTrends = Number(pageSizeTrends);\r\n  this.limitTrends = Number(pageSizeTrends);\r\n  this.currentPageTrends = 1;\r\n  this.offsetTrends = 0;\r\n  this.objData.offset = this.offsetTrends;\r\n  this.objData.limit = this.limitTrends;\r\n  this.footfallTrend();\r\n}\r\n createChart() {\r\n    this.loadingTrends =false;\r\n    this.noDataTrends =false;\r\n    setTimeout(() => {\r\n      const chartDiv = document.getElementById(\"Footfalltrend\");\r\n      if (!chartDiv) {\r\n        return;\r\n      }\r\n      if (this.rootTrends) {\r\n        this.rootTrends.dispose();\r\n      }\r\n    this.rootTrends  = am5.Root.new('Footfalltrend');\r\n    this.rootTrends.setThemes([am5themes_Animated.new(this.rootTrends)]);\r\n\r\n    this.chartTrends = this.rootTrends.container.children.push(\r\n      am5xy.XYChart.new(this.rootTrends, {\r\n        panX: false,\r\n        panY: false,\r\n        wheelX: 'panX',\r\n        wheelY: 'zoomX',\r\n        layout: this.rootTrends.verticalLayout\r\n      })\r\n    );\r\n\r\n    this.chartTrends.set(\"scrollbarX\", am5.Scrollbar.new(this.rootTrends, {\r\n      orientation: \"horizontal\"\r\n    }));\r\n    let xRenderer = am5xy.AxisRendererX.new(this.rootTrends, {\r\n      minGridDistance: 20,\r\n      minorGridEnabled: true,\r\n    });\r\n    xRenderer.labels.template.setAll({\r\n      rotation: -45,\r\n      centerY: am5.p50,\r\n      centerX: am5.p100,\r\n      paddingRight: 5,\r\n    });\r\n    // xRenderer.grid.template.setAll({\r\n    //   location: 1,\r\n    // });\r\n    const xAxis = this.chartTrends.xAxes.push(\r\n      am5xy.CategoryAxis.new(this.rootTrends, {\r\n        categoryField: 'storeName',\r\n        renderer:xRenderer,\r\n        tooltip: am5.Tooltip.new(this.rootTrends, { labelText: \"{fullStoreName}\"})\r\n      })\r\n    );\r\n    this.getFootfallTrendData.sort((a: any, b: any) => {\r\n      // Parse storeName as a Date and compare\r\n      const dateA = new Date(a.storeName);\r\n      const dateB = new Date(b.storeName);\r\n      \r\n      // Sort in ascending order (oldest to newest)\r\n      return dateA.getTime() - dateB.getTime();\r\n    });\r\n    this.getFootfallTrendData = this.getFootfallTrendData?.map(\r\n      (item: any) => ({\r\n        fullStoreName: item.storeName, // Full store name\r\n        storeName: item.storeName, // item.storeName.length > 20 ? item.storeName.slice(0, 20) + '...' : Shortened for xAxis\r\n        footfall: Number(item.footfall_count),\r\n        conversion: Number(item.conversion_count),\r\n        bounced: Number(item.bounced_count),\r\n        engagers: Number(item.engagers_count),\r\n        missedopportunities: Number(item.missedOpportunity_count),\r\n        potential: Number(item.potentialBuyers_count),\r\n        bounced_count:item.bounced_count,\r\n        avgDwellTime:item.avgDwellTime,\r\n        down_time:item.down_time,\r\n        engagers_count:item.engagers_count,\r\n        footfall_count:item.footfall_count,\r\n        missedOpportunity_count:item.missedOpportunity_count,\r\n        footfall_count_avg:item.footfall_count_avg,\r\n        bounced_footfall_count_avg:item.bounced_footfall_count_avg,\r\n        missedOpportunity_count_avg:item.missedOpportunity_count_avg,\r\n        engagers_count_avg:item.engagers_count_avg,\r\n        conversionRate: item.conversionRate,\r\n        forecast: item.forecast,\r\n      })\r\n    );\r\n   \r\n    xAxis.data?.setAll(this.getFootfallTrendData); \r\n    const yAxis = this.chartTrends.yAxes.push(\r\n      am5xy.ValueAxis.new(this.rootTrends, {\r\n        min:0,\r\n        renderer: am5xy.AxisRendererY.new(this.rootTrends, {})\r\n      })\r\n    );\r\n    // yAxis.get(\"renderer\").grid.template.set(\"forceHidden\", true);\r\n    // yAxis.get(\"renderer\").labels.template.set(\"forceHidden\", true);\r\n    // Set the title of the y-axis\r\n    yAxis.children.unshift(am5.Label.new(this.rootTrends, {\r\n      rotation: -90,\r\n      // text: 'Footfall', //capitalizeFirstLetter(this.objData.processType), // Capitalize the first letter\r\n      y: am5.p50,\r\n      centerX: am5.p50,\r\n      fontFamily: \"Arial\", // Set font family\r\n      fontSize: \"14px\",    // Set font size\r\n      fill: am5.color(0x000000) // Set text color (optional)\r\n    }));\r\nif(this.objData.processType ==='potentialBuyer')\r\n  this.objData.processType ='potential'\r\n// if(this.objData.processType ==='missedopportunities')\r\n//   this.objData.processType ='Missed Opportunity'\r\nconst capitalizeTitle = (text: string): string => {\r\n  return text\r\n    .split(' ')\r\n    .map(word => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())\r\n    .join(' ');\r\n};\r\n\r\n// Example usage\r\nconst processTypeTitle = capitalizeTitle(this.objData.processType);\r\n    // this.createColumnSeries('Footfall', 'footfall', xAxis, yAxis, false, am5.color(0x67b7dc));\r\n    this.createColumnSeries('Bounced', 'bounced', xAxis, yAxis, true, am5.color(0x67b7dc));\r\n    this.createColumnSeries('Engagers', 'engagers', xAxis, yAxis, true, am5.color(0x6794dc));\r\n    // 6771dc\r\n    // this.createColumnSeries('Missed Opportunity', 'missedopportunities', xAxis, yAxis, true, am5.color(0x6794dc));\r\n    // this.createColumnSeries('Potential Buyer', 'potential', xAxis, yAxis, true, am5.color(0xdc69cf));\r\n    // this.createColumnSeries('Conversion', 'conversion', xAxis, yAxis, true, am5.color(0x6771dc));\r\n    if(this.objData.processType !=='' ){\r\n      const myColor = am5.color(0x00FF00);\r\n    this.createLineSeries(processTypeTitle, this.objData.processType, xAxis, yAxis, myColor);\r\n    }\r\n    const legend = this.chartTrends.children.push(\r\n      am5.Legend.new(this.rootTrends, {\r\n        centerX: am5.p50,\r\n        x: am5.p50\r\n      })\r\n    );\r\n\r\n    legend.data.setAll(this.chartTrends.series.values);\r\n\r\n    this.chartTrends.set('cursor', am5xy.XYCursor.new(this.rootTrends, {\r\n      behavior: 'none'\r\n    }));\r\n\r\n    this.chartTrends.series.each((series: any) => {\r\n      if (series.columns) {\r\n        series.columns.template.set(\"interactive\", true);\r\n        series.columns.template.events.on(\"click\", (ev: any) => {\r\n          const data = ev.target.dataItem.dataContext;\r\n          const { clientX, clientY } = ev.originalEvent;\r\n          this.showTooltip(data, clientX, clientY);\r\n        });\r\n      }\r\n    });\r\n    this.chartTrends.appear(1000, 100);\r\n  },100)\r\n  }\r\n\r\n  tooltipVisible = false;\r\n  showTooltip(data: any, x: number, y: number): void {\r\n    this.tooltipVisible = false;\r\n    this.tooltipData = data;\r\n    const tooltipElement = this.tooltipContainer?.nativeElement;\r\n  \r\n    // Set tooltip content and make it visible to calculate dimensions\r\n    tooltipElement.style.display = 'block';\r\n    tooltipElement.style.visibility = 'hidden'; // Make it invisible but still present in the DOM\r\n  \r\n    // Force a reflow to ensure dimensions are up-to-date\r\n    tooltipElement.style.position = 'absolute';\r\n    \r\n    // Wait for the next event loop to get accurate dimensions\r\n    setTimeout(() => {\r\n      const tooltipWidth = tooltipElement.offsetWidth;\r\n      const tooltipHeight = tooltipElement.offsetHeight;\r\n      const screenWidth = window.innerWidth;\r\n      const screenHeight = window.innerHeight;\r\n  \r\n      // Calculate if there is enough space on the right side, otherwise place it on the left\r\n      if (x + tooltipWidth > screenWidth) {\r\n        tooltipElement.style.left = `${x - tooltipWidth}px`;\r\n      } else {\r\n        tooltipElement.style.left = `${x}px`;\r\n      }\r\n  \r\n      // Calculate if there is enough space at the bottom, otherwise place it at the top\r\n      if (y + tooltipHeight > screenHeight) {\r\n        tooltipElement.style.top = `${y - tooltipHeight}px`;\r\n      } else {\r\n        tooltipElement.style.top = `${y}px`;\r\n      }\r\n  \r\n      tooltipElement.style.visibility = 'visible'; // Make it visible again\r\n      this.tooltipVisible = true;\r\n    }, 0);\r\n  }\r\n  selectPlanTrends(type: any) {\r\n    this.type = type;\r\n    this.objData.dateType =type;\r\n    if(type ==='monthly' && this.storeIdarray?.length === 1)\r\n    this.objData.limit= 60;\r\n  else \r\n  this.objData.limit= 31;\r\n    this.objData.offset= 0;\r\n    this.footfallTrend();\r\n    // this.updateChartData();\r\n  }\r\n  hideTooltip(): void {\r\n    this.tooltipVisible = false;\r\n    const tooltipElement = this.tooltipContainer?.nativeElement;\r\n    tooltipElement.style.display = 'none';\r\n  }\r\n\r\n  createColumnSeries(\r\n    name: string,\r\n    fieldName: string,\r\n    xAxis: am5xy.CategoryAxis<am5xy.AxisRenderer>,\r\n    yAxis: am5xy.ValueAxis<am5xy.AxisRenderer>,\r\n    stacked: boolean,\r\n    color: am5.Color\r\n  ): void {\r\n\r\n    if (this.headerData?.client === '452') {\r\n      if (name === 'Bounced') {\r\n        name = `Less than ${this.clientData?.featureConfigs?.bouncedLimit?.value ?? 'X'} mins`;\r\n      }\r\n      if (name === 'Engagers') {\r\n        name = `More than ${this.clientData?.featureConfigs?.bouncedLimit?.value ?? 'X'} mins`;\r\n      }\r\n    }\r\n    const series = this.chartTrends.series.push(\r\n      am5xy.ColumnSeries.new(this.rootTrends, {\r\n        name: name,\r\n        xAxis: xAxis,\r\n        yAxis: yAxis,\r\n        valueYField: fieldName,\r\n        categoryXField: 'storeName',\r\n        stacked: stacked,\r\n      })\r\n    );\r\n    this.getFootfallTrendData = this.getFootfallTrendData.map((item: any) => {\r\n      return {\r\n        ...item,\r\n        dynamicColumn: {\r\n          fillOpacity: item.columnSettings?.fillOpacity ?? 0.8,\r\n          strokeDasharray: Array.isArray(item.columnSettings?.strokeDasharray)\r\n            ? item.columnSettings.strokeDasharray\r\n            : item.columnSettings?.strokeDasharray ? item.columnSettings.strokeDasharray.split(',').map(Number) : [5, 5],\r\n          strokeWidth: item.columnSettings?.strokeWidth ?? 3\r\n        }\r\n      };\r\n    });\r\n  \r\n    // Set data for series\r\n    series.data.setAll(this.getFootfallTrendData);\r\n  \r\n    // Adapters to apply custom column settings\r\n    series.columns.template.adapters.add(\"fillOpacity\", (fillOpacity: any, target: any) => {\r\n      const dataItem = target.dataItem?.dataContext as any;\r\n      if (dataItem?.forecast && dataItem?.dynamicColumn) { \r\n        return dataItem.dynamicColumn.fillOpacity ?? fillOpacity; \r\n      }\r\n      return fillOpacity; // Default opacity\r\n    });\r\n  \r\n    series.columns.template.adapters.add(\"strokeDasharray\", (strokeDasharray: any, target: any) => {\r\n      const dataItem = target.dataItem?.dataContext as any;\r\n      if (dataItem?.forecast && dataItem?.dynamicColumn) { \r\n        return dataItem.dynamicColumn.strokeDasharray ?? strokeDasharray; \r\n      }\r\n      return strokeDasharray; // Default dash array\r\n    });\r\n  \r\n    series.columns.template.adapters.add(\"strokeWidth\", (strokeWidth: any, target: any) => {\r\n      const dataItem = target.dataItem?.dataContext as any;\r\n      if (dataItem?.forecast && dataItem?.dynamicColumn) { \r\n        return dataItem.dynamicColumn.strokeWidth ?? strokeWidth; \r\n      }\r\n      return strokeWidth; // Default stroke width\r\n    });\r\n  \r\n    // Set default color and stroke for the columns\r\n    series.columns.template.setAll({\r\n      fill: color, // Set fill color\r\n      stroke: color // Set stroke color\r\n    });\r\n  \r\n    // Add labels to the columns\r\n    series.bullets.push(() => {\r\n      return am5.Bullet.new(this.rootTrends, {\r\n        sprite: am5.Label.new(this.rootTrends, {\r\n          text: \"{valueY}\",\r\n          fill: this.rootTrends.interfaceColors.get(\"alternativeText\"),\r\n          centerY: am5.p50,\r\n          centerX: am5.p50,\r\n          populateText: true,\r\n          fontSize: 12  // Reduce font size\r\n        })\r\n      });\r\n    });\r\n \r\n    series.appear();\r\n  }\r\n  \r\n  \r\n\r\n\r\n\r\n  createLineSeries(\r\n    name: string,\r\n    fieldName: string,\r\n    xAxis: am5xy.CategoryAxis<am5xy.AxisRenderer>,\r\n    yAxis: am5xy.ValueAxis<am5xy.AxisRenderer>,\r\n    color: am5.Color\r\n  ): void {\r\n    if (this.headerData?.client === '452') {\r\n      if (name === 'Conversion') {\r\n        name = `More than ${this.clientData?.featureConfigs?.conversion?.value ?? 'X'} mins`;\r\n      }\r\n    \r\n      if (name === 'Missedopportunities') {\r\n        name = `${this.clientData?.featureConfigs?.missedOpportunityFrom?.value ?? 'X'} - ${this.clientData?.featureConfigs?.missedOpportunityTo?.value ?? 'Y'} mins`;\r\n      }\r\n    \r\n    } else {\r\n      if (name === 'Missedopportunities') {\r\n        name = 'Missed Opportunity';\r\n      }\r\n    \r\n      if (name === 'Potential' || name === 'potentialBuyer') {\r\n        name = 'Potential Buyer';\r\n      }\r\n    }\r\n    \r\n    const series = this.chartTrends.series.push(\r\n      am5xy.LineSeries.new(this.rootTrends, {\r\n        name: name,\r\n        xAxis: xAxis,\r\n        yAxis: yAxis,\r\n        valueYField: fieldName,\r\n        categoryXField: 'storeName',\r\n        tooltip: am5.Tooltip.new(this.rootTrends, {\r\n          pointerOrientation: \"horizontal\",\r\n          labelText: \"Total Footfall: {footfall}\\n{name}: {valueY} \",\r\n          background: am5.Rectangle.new(this.rootTrends, {\r\n            fill: am5.color(0x00FF00) // Set the desired tooltip background color\r\n          })\r\n        })\r\n      })\r\n    );\r\n  \r\n    // Apply default stroke settings for the line series\r\n    series.strokes.template.setAll({\r\n      strokeWidth: 2,\r\n      stroke: am5.color(0x00FF00), // Default stroke color\r\n      templateField: \"strokeSettings\", // Refer to strokeSettings for dynamic updates\r\n      fontSize: 12 // Reduce font size for labels\r\n    });\r\n  \r\n    // Map dynamic settings for forecast=true items\r\n    this.getFootfallTrendData = this.getFootfallTrendData.map((item: any) => {\r\n      return {\r\n        ...item,\r\n        dynamicLine: {\r\n          stroke: item.strokeSettings?.stroke ?? am5.color(0x00FF00), // Default to green if not specified\r\n          strokeWidth: item.strokeSettings?.strokeWidth ?? 5,\r\n          strokeDasharray: Array.isArray(item.strokeSettings?.strokeDasharray)\r\n            ? item.strokeSettings.strokeDasharray\r\n            : item.strokeSettings?.strokeDasharray\r\n            ? item.strokeSettings.strokeDasharray.split(',').map(Number)\r\n            : [5, 5] // Default dash array\r\n        }\r\n      };\r\n    });\r\n  \r\n    // Set data for series\r\n    series.data.setAll(this.getFootfallTrendData);\r\n  \r\n  // Adapter to apply custom stroke settings based on forecast\r\n  series.strokes.template.adapters.add(\"stroke\", (stroke: any, target: any) => {\r\n    const dataItem = target.dataItem?.dataContext as any;\r\n    if (dataItem?.forecast && dataItem?.dynamicLine) {\r\n      return dataItem.dynamicLine.stroke ?? stroke; // Apply dynamic stroke if forecast is true\r\n    }\r\n    return stroke; // Default stroke\r\n  });\r\n\r\n  series.strokes.template.adapters.add(\"strokeWidth\", (strokeWidth: any, target: any) => {\r\n    const dataItem = target.dataItem?.dataContext as any;\r\n    if (dataItem?.forecast && dataItem?.dynamicLine) {\r\n      return dataItem.dynamicLine.strokeWidth ?? strokeWidth; // Apply dynamic stroke width\r\n    }\r\n    return strokeWidth; // Default stroke width\r\n  });\r\n\r\n  series.strokes.template.adapters.add(\"strokeDasharray\", (strokeDasharray: any, target: any) => {\r\n    const dataItem = target.dataItem?.dataContext as any;\r\n    if (dataItem?.forecast && dataItem?.dynamicLine) {\r\n      // Ensure the dash array is a valid array of numbers for proper rendering\r\n      return Array.isArray(dataItem.dynamicLine.strokeDasharray)\r\n        ? dataItem.dynamicLine.strokeDasharray // Use if already in array format\r\n        : dataItem.dynamicLine.strokeDasharray\r\n        ? dataItem.dynamicLine.strokeDasharray.split(',').map(Number) // Convert string to array\r\n        : [5, 5]; // Default dash array\r\n    }\r\n    return strokeDasharray; // Default stroke dash array if no custom setting\r\n  });\r\n\r\n  \r\n    // Add bullets (markers) to the line series\r\n    series.bullets.push(() => {\r\n      return am5.Bullet.new(this.rootTrends, {\r\n        sprite: am5.Circle.new(this.rootTrends, {\r\n          strokeWidth: 1,\r\n          stroke: am5.color(0x00FF00),\r\n          radius: 3, // Increase radius for visibility\r\n          fill: this.rootTrends.interfaceColors.get(\"background\")\r\n        })\r\n      });\r\n    });\r\n  \r\n    // Trigger the appearance of the series\r\n    series.appear();\r\n  \r\n    // Log the series data for debugging\r\n  }\r\n  \r\n  show: boolean =false;\r\n  producttrailDropdown(event: MouseEvent) {\r\n    event.stopPropagation();\r\n    this.show =true;\r\n  }\r\n  changeStatus(type:any){\r\nthis.trendtypeValue = type;\r\nthis.objData.filterBy =type;\r\nthis.footfallTrend();\r\nthis.show =false;\r\n  }\r\n\r\n\r\n\r\n  // traffic overall card and charts\r\n\r\n  private root!: am5.Root;\r\n  // private chart: am5xy.XYChart;\r\n  private series: am5xy.ColumnSeries;\r\n  private root2: am5.Root;\r\n  private chart2: am5xy.XYChart;\r\n  private series2: am5xy.ColumnSeries;\r\n  detailedRoot: am5.Root;\r\n  detailedChart: am5xy.XYChart;\r\n  detailedSeries: am5xy.ColumnSeries;\r\n  dayjs =dayjs\r\n  heatMapRoot: am5.Root;\r\n  heatMapChart: am5xy.XYChart;\r\n  heatMapSeries: am5xy.ColumnSeries;\r\n  dwellRoot: am5.Root;\r\n  dwellChart: am5xy.XYChart;\r\n  dwellSeries: am5xy.ColumnSeries;\r\n  demoGraphicsData: any;\r\n  demoGraphicsroot: any;\r\n  buyersroot:any;\r\n\r\n  data: any;\r\n  currentData: any;\r\n  currentData2: any;\r\n  detailedCharts: boolean = false;\r\n  date: any;\r\n  value: any;\r\n  footfallValue: string = \"traffic\";\r\n  demoGraphicsChartInstance: any;\r\n  buyersChartInstance:any;\r\n  selectedTab: any = \"traffic\";\r\n  getOverallCardData: any = [];\r\n  // objData: any;\r\n  getOverallHourlyData: any;\r\n  getOverallChartData: any=[];\r\n  getSingleChartData: any;\r\n  buyersData: any;\r\n  getDensityDwellData: any;\r\n  trafficData:any= [];\r\n  footfallDate: any;\r\n  selctedValue:any ='Footfall Analysis';\r\n  chartNoData: boolean =false;\r\n  chartloading: boolean =true;\r\n  totalCount: any;\r\n  demoGraphicsSeries: any;\r\n\r\n  itemsPerPageTrafficCard = 10;\r\n  currentPageTrafficCard = 1;\r\n  totalItemsTrafficCard = 1;\r\n  paginationSizesTrafficCard: number[] = [];\r\n  pageSizeTrafficCard:any=20;\r\n  offsetTrafficCard: number = 0;\r\n  limitTrafficCard: number = 20;\r\n  demoNoData =false;\r\n  demoloading =false;\r\n  buyersNoData =false;\r\n  buyersloading =false;\r\n  datasetsCard:any =[];\r\n  processTypeNew:any;\r\n  selectedTabs(type: any) {\r\n    this.detailedCharts = false;\r\n    this.selectedTab = type;\r\n    this.objDataTraffic.processType = type;\r\n    this.processTypeNew = type;\r\n    this.objDataTraffic.valueType =this.valueType;\r\n   \r\n    this.objDataTraffic.storeId = this.headerData.stores.filter((store:any) => store.checked).map((store:any) => store.storeId);\r\n   if(this.selectedTab === 'traffic'){\r\n   this.getDwell(); this.trafficDwell();\r\n    this.cd.detectChanges();\r\n   } else{\r\n    if(this.selectedTab === \"footfall\"){\r\n      this.footfallValue = \"footfall\";\r\n      this.selctedValue ='Footfall Analysis'\r\n    } else if(this.selectedTab === \"conversion\"){\r\n      this.footfallValue = \"conversion\";\r\n      this.selctedValue = this.headerData?.client === '452' ? `More than ${this.featureConfig?.conversion.value} mins Analysis` : 'Conversion Analysis'\r\n    } else if(this.selectedTab === \"engagers\"){\r\n      this.footfallValue = \"engagers\";\r\n      this.selctedValue = this.headerData?.client === '452' ? `More than ${this.featureConfig?.bouncedLimit.value} mins Analysis` : 'Engagers Analysis'\r\n    } else if(this.selectedTab === \"bounced\"){\r\n      this.footfallValue = \"bounced\";\r\n      this.selctedValue = this.headerData?.client === '452' ? `Less than ${this.featureConfig?.bouncedLimit.value} mins Analysis` :'Bounced Analysis'\r\n    } else if(this.selectedTab === \"potentialBuyers\"){\r\n      this.footfallValue = \"potentialBuyers\";\r\n      this.selctedValue ='Potential Buyer Analysis'\r\n    } else if(this.selectedTab === \"missedOpportunity\"){\r\n      this.footfallValue = \"missedOpportunity\";\r\n      this.selctedValue = this.headerData?.client === '452' ? `${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins Analysis` :'Missed Opportunity Analysis' \r\n    } \r\n    if(this.objDataTraffic.nob === true && this.selectedTab === \"conversion\"){\r\n      this.selectedTab = \"conversion\"\r\n       this.footfallValue = \"conversion\";\r\n      this.selctedValue ='Conversion Analysis'\r\n      this.datasetsCard = [\r\n        { value: this.selectedTab, label: this.selctedValue },\r\n      ];\r\n      this.objDataTraffic.limit =20,\r\n      this.overallCard();\r\n      this.overallChart();\r\n    } else {\r\n      if (this.headerData?.client === '452') {\r\n        this.datasetsCard = [\r\n          { value: this.selectedTab, label: this.selctedValue },\r\n          { value: \"demographic\", label: \"Demographic Analysis\" }\r\n        ]\r\n      } else {\r\n        this.datasetsCard = [\r\n          { value: this.selectedTab, label: this.selctedValue },\r\n          { value: \"demographic\", label: \"Demographic Analysis\" },\r\n          { value: \"buyer\", label: \"Buyer Analysis\" },\r\n      ]\r\n    }\r\n    this.objDataTraffic.limit =20,\r\n    this.overallCard();\r\n    this.overallHourlyChart();\r\n    this.overallChart();\r\n  }\r\n  this.cd.detectChanges();\r\n  }\r\n  }\r\n  getFootfallDensityDwellData:any =[];\r\n  trafficDwell(){\r\n    this.chartNoData = false;\r\n    this.chartloading = true;\r\n    delete this.objDataTraffic.limit;\r\n    delete this.objDataTraffic.offset;\r\n    delete this.objDataTraffic.processType;\r\n    delete this.objDataTraffic.hourFormat;\r\n    delete this.objDataTraffic.normalizedData\r\n    this.objDataTraffic.dateRange =Number(this.footfallDate);\r\n    this.service\r\n      .getTrafficDensityDwell(this.objDataTraffic)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getFootfallDensityDwellData = res?.data;\r\n            this.trafficHeatChart();\r\n            this.chartNoData = false;\r\n            this.chartloading = false;\r\n            this.cd.detectChanges();\r\n          } else if(!res || res.code === 204){\r\n            this.chartNoData = true;\r\n            this.chartloading = false;\r\n            this.getFootfallDensityDwellData =[];\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.chartNoData = true;\r\n          this.chartloading = false;\r\n          this.getFootfallDensityDwellData =[];\r\n          this.cd.detectChanges();\r\n        },\r\n        complete: () => {},\r\n      }); \r\n  }\r\n  chartDwellNoData = false;\r\n      chartDwellloading = true;\r\n   getDwell(){\r\n      this.chartDwellNoData = false;\r\n      this.chartDwellloading = true;\r\n      delete this.objDataTraffic.limit;\r\n      delete this.objDataTraffic.offset;\r\n      delete this.objDataTraffic.processType;\r\n      delete this.objDataTraffic.hourFormat;\r\n      delete this.objDataTraffic.normalizedData;\r\n      this.objDataTraffic.dateRange =Number(this.footfallDate);\r\n      this.service\r\n        .getDensityDwell(this.objDataTraffic)\r\n        .pipe(takeUntil(this.destroy$))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res?.code === 200) {\r\n              this.getDensityDwellData = res?.data;\r\n              if(this.getDensityDwellData?.dwellTimeSplit?.length >0){\r\n                this.getDwellChart();\r\n                this.chartDwellNoData = false;\r\n                this.chartDwellloading = false;\r\n                this.cd.detectChanges();\r\n              } else {\r\n                this.chartDwellNoData = true;\r\n              this.chartDwellloading = false;\r\n              }\r\n            } else if(!res || res.code === 204){\r\n              this.chartDwellNoData = true;\r\n              this.chartDwellloading = false;\r\n              this.getDensityDwellData =[];\r\n            }\r\n          },\r\n          error: (err: any) => {\r\n            this.chartNoData = true;\r\n            this.chartloading = false;\r\n            this.cd.detectChanges();\r\n            this.getDensityDwellData =[];\r\n          },\r\n          complete: () => {},\r\n        });\r\n    }\r\n    initChart(): void {\r\n      this.chartNoData = false;\r\n      this.chartloading = false;\r\n      setTimeout(() => {\r\n        const chartDiv = document.getElementById(\"testGraphics\");\r\n        if (!chartDiv) {\r\n          return;\r\n        }\r\n        if (this.root) {\r\n          this.root.dispose();\r\n        }\r\n        this.root = am5.Root.new(\"testGraphics\");\r\n  \r\n        // Set themes\r\n        // this.root.setThemes([am5themes_Animated.new(this.root)]);\r\n        // const totalCount = this.totalCount;\r\n        // const dynamicWidth = Math.max(800, totalCount * 50); // Minimum 800px or 50px per item\r\n        // console.log(dynamicWidth,this.totalCount)\r\n        // Create chart\r\n        this.chart = this.root.container.children.push(\r\n          am5xy.XYChart.new(this.root, {\r\n            panX: true,\r\n            panY: true,\r\n            wheelX: \"panX\",\r\n            wheelY: \"zoomX\",\r\n            pinchZoomX: true,\r\n            paddingLeft: 0,\r\n            paddingRight: 1,\r\n            width: am5.percent(100), // Let the chart take full width\r\n          })\r\n        );\r\n        // this.chart.plotContainer.setAll({\r\n        //   minWidth: dynamicWidth, // Set dynamic min width for scrolling\r\n        // });\r\n        // Add cursor\r\n        let cursor = this.chart.set(\"cursor\", am5xy.XYCursor.new(this.root, {}));\r\n        cursor.lineY.set(\"visible\", false);\r\n  \r\n        // Create axes\r\n        let xRenderer = am5xy.AxisRendererX.new(this.root, {\r\n          minGridDistance: 30,\r\n          minorGridEnabled: true,\r\n        });\r\n  \r\n        xRenderer.labels.template.setAll({\r\n          rotation: -45,\r\n          centerY: am5.p50,\r\n          centerX: am5.p100,\r\n          paddingRight: 5,\r\n        });\r\n  \r\n        xRenderer.grid.template.setAll({\r\n          location: 1,\r\n        });\r\n        // Add scrollbar\r\n        this.chart.set(\r\n          \"scrollbarX\",\r\n          am5.Scrollbar.new(this.root, {\r\n            orientation: \"horizontal\",\r\n          })\r\n        );\r\n        let xAxis = this.chart.xAxes.push(\r\n          am5xy.CategoryAxis.new(this.root, {\r\n            maxDeviation: 0.3,\r\n            categoryField: \"storeName\",\r\n            renderer: xRenderer,\r\n            // tooltip: am5.Tooltip.new(this.root, {labelText: \"{fullStoreName}\"}),\r\n          })\r\n        );\r\n  \r\n        let yRenderer = am5xy.AxisRendererY.new(this.root, {\r\n          strokeOpacity: 0.1,\r\n        });\r\n  \r\n        let yAxis = this.chart.yAxes.push(\r\n          am5xy.ValueAxis.new(this.root, {\r\n            maxDeviation: 0.3,\r\n            renderer: yRenderer,\r\n          })\r\n        );\r\n        let data = this.getOverallChartData?.storeData?.map(\r\n          (item: any) => ({\r\n            fullStoreName: item.storeName, // Full store name\r\n      storeName:  item.storeName, // item.storeName.length > 20 ? item.storeName.slice(0, 20) + '...' : Shortened for xAxis\r\n      value: Number(item.count),\r\n      storeId: item.storeId\r\n          })\r\n        );\r\n\r\n   if(this.headerData.client ==='452'){\r\n        if(this.objDataTraffic.processType === \"conversion\"){\r\n          this.processTypeNew = this.headerData?.client === '452' ? `More than ${this.featureConfig?.conversion.value} mins ` : 'Conversion'\r\n        } if(this.objDataTraffic.processType === \"engagers\"){\r\n       \r\n          this.processTypeNew = this.headerData?.client === '452' ? `More than ${this.featureConfig?.bouncedLimit.value} mins` : 'Engagers'\r\n        } if(this.objDataTraffic.processType === \"bounced\"){\r\n          this.footfallValue = \"bounced\";\r\n          this.processTypeNew = this.headerData?.client === '452' ? `Less than ${this.featureConfig?.bouncedLimit.value} mins` :'Bounced'\r\n        }\r\n         if(this.objDataTraffic.processType === \"missedOpportunity\"){\r\n          this.processTypeNew = this.headerData?.client === '452' ? `${this.featureConfig?.missedOpportunityFrom.value}-${this.featureConfig?.missedOpportunityTo.value} mins` :'Missed Opportunity' \r\n        } \r\n      } else {\r\n        this.processTypeNew = this.objDataTraffic.processType\r\n      }\r\n    \r\n        // Create series\r\n        this.series = this.chart.series.push(\r\n          am5xy.ColumnSeries.new(this.root, {\r\n            name: \"Series 1\",\r\n            xAxis: xAxis,\r\n            yAxis: yAxis,\r\n            valueYField: \"value\",\r\n            categoryXField: \"storeName\",\r\n            tooltip: am5.Tooltip.new(this.root, {\r\n              labelText: `${(this.processTypeNew)}, {fullStoreName}: {valueY}`,\r\n            }),\r\n          })\r\n        );\r\n        xAxis.data.setAll(data);\r\n        this.series.columns.template.setAll({ strokeOpacity: 0 });\r\n        this.series.columns.template.events.on(\"click\", (ev: any) => {\r\n          const dataItem = ev.target.dataItem.dataContext;\r\n          this.handleBarClick(dataItem);\r\n        });\r\n  \r\n        this.series.columns.template.setAll({ strokeOpacity: 0 });\r\n  \r\n        this.series.data.setAll(data);\r\n    // Set width for chart container to enable scrolling\r\n    // const totalCount = this.totalCount;\r\n    // const itemWidth = 50; // Width of each item, adjust as needed\r\n    // const minWidth = totalCount * itemWidth; // Calculate total width\r\n    // chartDiv.style.width = `${Math.max(minWidth, 1024)}px`; // Minimum width of 800px\r\n        // Make stuff animate on load\r\n        this.series.appear(1000);\r\n        this.chart.appear(1000, 100);\r\n      }, 0);\r\n    }\r\n  \r\n    capitalizeTitle(text: string): string {\r\n      return text\r\n        .toLowerCase() // Ensure the string is in lowercase first\r\n        .split(' ')    // Split the string into words\r\n        .map(word => word.charAt(0).toUpperCase() + word.slice(1)) // Capitalize the first letter of each word\r\n        .join(' ');    // Join the words back together\r\n    }\r\n    getRangeColor(rate: number): am5.Color {\r\n      let color: am5.Color;\r\n      if (rate >= 0 && rate <= 10) {\r\n        color = am5.color(0xEAF8FF);\r\n      } else if (rate > 10 && rate <= 20) {\r\n        color = am5.color(0xCCE9FE);\r\n      } else if (rate > 20 && rate <= 30) {\r\n        color = am5.color(0xB0D6FC);\r\n      } else if (rate > 30 && rate <= 40) {\r\n        color = am5.color(0x94C2FA);\r\n      } else if (rate > 40 && rate <= 55) {\r\n        color = am5.color(0x78A9F8);\r\n      } else if (rate > 55 && rate <= 75) {\r\n        color = am5.color(0x99D2FD);  \r\n      } else if (rate > 75 && rate <= 90) {\r\n        color = am5.color(0x66BCFD);    \r\n      }  else if (rate > 90 && rate <= 100) {\r\n        color = am5.color(0x3460F3);  \r\n      } else {\r\n        color = am5.color(0xFFF);\r\n      }\r\n      return color;\r\n    }\r\n    initHeatChart() {\r\n      this.chartNoData = false;\r\n      this.chartloading = false;\r\n      setTimeout(() => {\r\n        const chartDiv = document.getElementById(\"heatmapchart\");\r\n        if (!chartDiv) {\r\n          return;\r\n        }\r\n        if (this.root2) {\r\n          this.root2.dispose();\r\n        }\r\n        // Create root element\r\n        this.root2 = am5.Root.new(\"heatmapchart\");\r\n  \r\n        this.root2.container.setAll({\r\n          width: am5.percent(100),\r\n        });\r\n  \r\n        // Set themes\r\n        this.root2.setThemes([\r\n          am5themes_Animated.new(this.root2),\r\n          am5themes_Responsive.new(this.root2),\r\n        ]);\r\n  \r\n        // Create chart\r\n        this.chart2 = this.root2.container.children.push(\r\n          am5xy.XYChart.new(this.root2, {\r\n            panX: false,\r\n            panY: false,\r\n            wheelX: \"none\",\r\n            wheelY: \"none\",\r\n            paddingLeft: 0,\r\n            layout: this.root2.verticalLayout,\r\n          })\r\n        );\r\n  \r\n        // Create axes and their renderers\r\n        const yRenderer = am5xy.AxisRendererY.new(this.root2, {\r\n          minGridDistance: 20,\r\n          inversed: true,\r\n          opposite: true,\r\n          minorGridEnabled: true,\r\n        });\r\n  \r\n        yRenderer.grid.template.set(\"visible\", false);\r\n  \r\n        const yAxis = this.chart2.yAxes.push(\r\n          am5xy.CategoryAxis.new(this.root2, {\r\n            renderer: yRenderer,\r\n            categoryField: \"time\",\r\n          })\r\n        );\r\n  \r\n        const xRenderer = am5xy.AxisRendererX.new(this.root2, {\r\n          minGridDistance: 30,\r\n          opposite: true,\r\n          minorGridEnabled: true,\r\n        });\r\n  \r\n        xRenderer.grid.template.set(\"visible\", false);\r\n  \r\n        const xAxis = this.chart2.xAxes.push(\r\n          am5xy.CategoryAxis.new(this.root2, {\r\n            renderer: xRenderer,\r\n            categoryField: \"weekday\",\r\n          })\r\n        );\r\n  \r\n        // Create series\r\n        this.series2 = this.chart2.series.push(\r\n          am5xy.ColumnSeries.new(this.root2, {\r\n            calculateAggregates: true,\r\n            stroke: am5.color(0xffffff),\r\n            clustered: false,\r\n            xAxis: xAxis,\r\n            yAxis: yAxis,\r\n            categoryXField: \"weekday\",\r\n            categoryYField: \"time\",\r\n            valueField: \"rate\",\r\n          })\r\n        );\r\n        this.series2.columns.template.setAll({\r\n          tooltipText: \"{rate}%\",\r\n          strokeOpacity: 1,\r\n          strokeWidth: 2,\r\n          width: am5.percent(100),\r\n          height: am5.percent(100),\r\n          fill: am5.color(0xffffff), // Default color for columns\r\n        });\r\n        \r\n        // Apply range-based color rules for each data item\r\n        this.series2.columns.template.adapters.add(\"fill\", (fill, target) => {\r\n          const dataItem = target.dataItem?.dataContext as ChartDataItem; // Cast dataContext to ChartDataItem\r\n          if (dataItem && dataItem.rate !== undefined) {\r\n            return this.getRangeColor(dataItem.rate); // Get color based on rate\r\n          }\r\n          return fill;\r\n        });\r\n  \r\n        this.series2.bullets.push(() => {\r\n          return am5.Bullet.new(this.root2, {\r\n            sprite: am5.Label.new(this.root2, {\r\n              text: \"{rate.formatNumber('#.#')}%\",\r\n              fill: am5.color(0x000000),\r\n              centerY: am5.p50,\r\n              centerX: am5.p50,\r\n              populateText: true,\r\n              fontSize: 12, // Reduce font size\r\n            }),\r\n          });\r\n        });\r\n  \r\n        // Set data\r\n        const data = this.getOverallHourlyData?.map((item: any) => ({\r\n          ...item,\r\n          weekday: \"Hourly Data\",\r\n        }));\r\n        this.series2.data.setAll(data);\r\n  \r\n        // Auto-populate X and Y axis category data\r\n        const times: string[] = [];\r\n        am5.array.each(data, function (row: any) {\r\n          if (times.indexOf(row.time) === -1) {\r\n            times.push(row.time);\r\n          }\r\n        });\r\n  \r\n        xAxis.data.setAll([{ weekday: \"Hourly Data\" }]); // Set single category for x-axis\r\n        yAxis.data.setAll(\r\n          times.map(function (item) {\r\n            return { time: item };\r\n          })\r\n        );\r\n  \r\n        this.chart2.appear(1000, 100);\r\n      }, 0);\r\n    }\r\n  \r\n    onDatasetChange(event: any): void {\r\n      this.detailedCharts = false;\r\n      // const target = event.target as HTMLSelectElement;\r\n      this.footfallValue = event;\r\n      if (this.footfallValue === \"footfall\" ||  this.footfallValue === \"conversion\"\r\n        ||  this.footfallValue === \"engagers\" ||  this.footfallValue === \"bounced\"\r\n        ||  this.footfallValue === \"potentialBuyer\" ||  this.footfallValue === \"missedOpportunity\") {\r\n        if (this.root) {\r\n          this.root.dispose();\r\n        }\r\n        this.overallHourlyChart();\r\n        this.overallChart();\r\n      } else if (this.footfallValue === \"demographic\") {\r\n        // Dispose of any previous charts to avoid duplicates\r\n        if (this.demoGraphicsroot) {\r\n          this.demoGraphicsroot.dispose();\r\n        }\r\n        this.getDemoGraphics();\r\n      } \r\n      else if (this.footfallValue === \"buyer\") {\r\n        // Dispose of any previous charts to avoid duplicates\r\n        if (this.buyersroot) {\r\n          this.buyersroot.dispose();\r\n        }\r\n        this.getBuyers();\r\n      } \r\n      this.cd.detectChanges();\r\n    }\r\n  \r\n   backToFootfall() {\r\n    this.objDataTraffic.limit =20,\r\n     this.objDataTraffic.storeId = this.headerData.stores.filter((store:any) => store.checked).map((store:any) => store.storeId),\r\n     this.detailedCharts = false;\r\n     this.overallHourlyChart();\r\n     this.overallChart();\r\n   }\r\n \r\n   getDemoGraphics(){\r\n     delete this.objDataTraffic.limit;\r\n     delete this.objDataTraffic.offset;\r\n     this.demoNoData =false;\r\n     this.demoloading = true;\r\n     this.service\r\n     .getDemoGraphicsChart(this.objDataTraffic)\r\n     .pipe(takeUntil(this.destroy$))\r\n     ?.subscribe({\r\n       next: (res: any) => {\r\n         if (res && res.code === 200) {\r\n           this.demoGraphicsData = res?.data.demographicData;\r\n           \r\n           this.demoGraphicsChart();\r\n           this.cd.detectChanges(); \r\n           // Call with a delay to ensure the element is in the DOM\r\n            this.demoNoData =false;\r\n            this.demoloading = false;\r\n         } else {\r\n           this.demoNoData =true;\r\n           this.demoloading = false;\r\n         }\r\n       },\r\n       error: (err: any) => {\r\n         this.cd.detectChanges();\r\n       },\r\n       complete: () => {},\r\n     });\r\n     \r\n   }\r\n   demoGraphicsChart(): void {\r\n     this.chartNoData = false;\r\n     this.chartloading = false;\r\n     this.demoNoData =false;\r\n     this.demoloading = false;\r\n     setTimeout(() => {\r\n       const demoGraphicsDiv = document.getElementById(\"demoGraphics\");\r\n       if (!demoGraphicsDiv) {\r\n         return;\r\n       }\r\n       // Dispose of previous chart if it exists\r\n       if (this.demoGraphicsroot) {\r\n         this.demoGraphicsroot.dispose();\r\n       }\r\n \r\n       // Create a new chart\r\n       this.demoGraphicsroot = am5.Root.new(demoGraphicsDiv);\r\n       this.demoGraphicsroot.setThemes([\r\n         am5themes_Animated.new(this.demoGraphicsroot),\r\n       ]);\r\n \r\n       this.demoGraphicsChartInstance =\r\n         this.demoGraphicsroot.container.children.push(\r\n           am5xy.XYChart.new(this.demoGraphicsroot, {\r\n             panX: false,\r\n             panY: false,\r\n             paddingLeft: 0,\r\n             wheelX: \"panX\",\r\n             wheelY: \"zoomX\",\r\n             layout: this.demoGraphicsroot.verticalLayout,\r\n           })\r\n         );\r\n \r\n       let xRenderer = am5xy.AxisRendererX.new(this.demoGraphicsroot, {\r\n         cellStartLocation: 0.1,\r\n         cellEndLocation: 0.9,\r\n         minorGridEnabled: true,\r\n       });\r\n \r\n       let xAxis = this.demoGraphicsChartInstance.xAxes.push(\r\n         am5xy.CategoryAxis.new(this.demoGraphicsroot, {\r\n           categoryField: \"age\",\r\n           renderer: xRenderer,\r\n           tooltip: am5.Tooltip.new(this.demoGraphicsroot, {}),\r\n         })\r\n       );\r\n       this.demoGraphicsData = this.demoGraphicsData?.map(\r\n         (item: any) => ({\r\n           age: item.age,\r\n           count: Number(item.count),\r\n           maleCount: Number(item.maleCount),\r\n           femaleCount: Number(item.femaleCount),\r\n         })\r\n       );\r\n       xRenderer.grid.template.setAll({ location: 1 });\r\n       xAxis.data.setAll(this.demoGraphicsData);\r\n \r\n       let yAxis = this.demoGraphicsChartInstance.yAxes.push(\r\n         am5xy.ValueAxis.new(this.demoGraphicsroot, {\r\n           renderer: am5xy.AxisRendererY.new(this.demoGraphicsroot, {\r\n             strokeOpacity: 0.1,\r\n           }),\r\n         })\r\n       );\r\n      // Add legend\r\n     let legend = this.demoGraphicsChartInstance.children.push(\r\n       am5.Legend.new(this.demoGraphicsroot, {\r\n         x: am5.p100,    // Align to 100% width (right side)\r\n         y: am5.p0,      // Align to the top\r\n         centerX: am5.p100,  // Align the center of the legend to its right\r\n         centerY: am5.p0,    // Align the top of the legend to the top of the chart\r\n       })\r\n     );\r\n \r\n     // Create the series and add each to the legend\r\n     const maleSeries = this.makeSeries(\"Male\", \"maleCount\", xAxis, yAxis);\r\n     const femaleSeries = this.makeSeries(\"Female\", \"femaleCount\", xAxis, yAxis);\r\n \r\n     legend.data.setAll([maleSeries, femaleSeries]);\r\n       this.demoGraphicsChartInstance.appear(1000, 100);\r\n \r\n     },\r\n            0);\r\n \r\n   }\r\n   makeSeries(\r\n     name: any,\r\n     fieldName: any,\r\n     xAxis: am5xy.CategoryAxis<am5xy.AxisRenderer>,\r\n     yAxis: am5xy.ValueAxis<am5xy.AxisRenderer>\r\n   ) {\r\n     let series = this.demoGraphicsChartInstance.series.push(\r\n       am5xy.ColumnSeries.new(this.demoGraphicsroot, {\r\n         name: name,\r\n         xAxis: xAxis,\r\n         yAxis: yAxis,\r\n         valueYField: fieldName,\r\n         categoryXField: \"age\",\r\n       })\r\n     );\r\n   \r\n     series.columns.template.setAll({\r\n       tooltipText: \"{name}, {categoryX}: {valueY}\",\r\n       width: am5.percent(90),\r\n       tooltipY: 0,\r\n       strokeOpacity: 0,\r\n     });\r\n   \r\n     series.data.setAll(this.demoGraphicsData);\r\n     series.appear();\r\n   \r\n     return series;  // Return the series to add it to the legend\r\n   }\r\n   getBuyers(){\r\n     delete this.objDataTraffic.limit;\r\n     delete this.objDataTraffic.offset;\r\n     this.buyersloading = true;\r\n     this.buyersNoData =false;\r\n     this.service\r\n     .getBuyersChart(this.objDataTraffic)\r\n     .pipe(takeUntil(this.destroy$))\r\n     ?.subscribe({\r\n       next: (res: any) => {\r\n         if (res && res.code === 200) {\r\n           this.buyersData = res?.data.buyerData;\r\n          \r\n          this.getBuyersChart(); // Call with a delay to ensure the element is in the DOM\r\n          this.cd.detectChanges(); \r\n          this.buyersNoData =false;\r\n          this.buyersloading = false;\r\n         } else{\r\n           this.buyersloading = false;\r\n           this.buyersNoData =true;\r\n         }\r\n       },\r\n       error: (err: any) => {\r\n         this.cd.detectChanges();\r\n       },\r\n       complete: () => {},\r\n     });\r\n   }\r\n   getBuyersChart(): void {\r\n     this.chartNoData = false;\r\n     this.chartloading = false;\r\n     this.buyersNoData =false;\r\n     this.buyersloading = false;\r\n     setTimeout(() => {\r\n     const buyersDiv = document.getElementById(\"buyersCharts\");\r\n     if (!buyersDiv) {\r\n       return;\r\n     }\r\n \r\n     // Dispose of previous chart if it exists\r\n     if (this.buyersroot) {\r\n       this.buyersroot.dispose();\r\n     }\r\n \r\n     // Create a new chart\r\n     this.buyersroot = am5.Root.new(buyersDiv);\r\n     this.buyersroot.setThemes([\r\n       am5themes_Animated.new(this.buyersroot),\r\n     ]);\r\n \r\n     this.buyersChartInstance =\r\n       this.buyersroot.container.children.push(\r\n         am5xy.XYChart.new(this.buyersroot, {\r\n           panX: false,\r\n           panY: false,\r\n           paddingLeft: 0,\r\n           wheelX: \"panX\",\r\n           wheelY: \"zoomX\",\r\n           layout: this.buyersroot.verticalLayout,\r\n         })\r\n       );\r\n \r\n     let xRenderer = am5xy.AxisRendererX.new(this.buyersroot, {\r\n       cellStartLocation: 0.1,\r\n       cellEndLocation: 0.9,\r\n       minorGridEnabled: true,\r\n     });\r\n \r\n     let xAxis = this.buyersChartInstance.xAxes.push(\r\n       am5xy.CategoryAxis.new(this.buyersroot, {\r\n         categoryField: \"age\",\r\n         renderer: xRenderer,\r\n         tooltip: am5.Tooltip.new(this.buyersroot, {}),\r\n       })\r\n     );\r\n     this.buyersData = this.buyersData?.map(\r\n       (item: any) => ({\r\n         age: item.age,\r\n         singleCount: Number(item.singleCount),\r\n         groupCount: Number(item.groupCount),\r\n       })\r\n     );\r\n     xRenderer.grid.template.setAll({ location: 1 });\r\n     xAxis.data.setAll(this.buyersData);\r\n \r\n     let yAxis = this.buyersChartInstance.yAxes.push(\r\n       am5xy.ValueAxis.new(this.buyersroot, {\r\n         renderer: am5xy.AxisRendererY.new(this.buyersroot, {\r\n           strokeOpacity: 0.1,\r\n         }),\r\n       })\r\n     );\r\n     let legend = this.buyersChartInstance.children.push(\r\n       am5.Legend.new(this.buyersroot, {\r\n         x: am5.p100,    // Align to 100% width (right side)\r\n     y: am5.p0,      // Align to the top\r\n     centerX: am5.p100,  // Align the center of the legend to its right\r\n     centerY: am5.p0,    // Align the top of the legend to the top of the chart\r\n       })\r\n     );\r\n     \r\n   const singleCount =  this.getBuyerSeries(\"Single\", \"singleCount\", xAxis, yAxis);\r\n   const groupCount =  this.getBuyerSeries(\"Group\", \"groupCount\", xAxis, yAxis);\r\n     legend.data.setAll([singleCount, groupCount]);\r\n     this.buyersChartInstance.appear(1000, 100);\r\n   },0);\r\n }\r\n getBuyerSeries(\r\n   name: string,\r\n   fieldName: string,\r\n   xAxis: am5xy.CategoryAxis<am5xy.AxisRenderer>,\r\n   yAxis: am5xy.ValueAxis<am5xy.AxisRenderer>\r\n ) {\r\n   let series = this.buyersChartInstance.series.push(\r\n     am5xy.ColumnSeries.new(this.buyersroot, {\r\n       name: name,\r\n       xAxis: xAxis,\r\n       yAxis: yAxis,\r\n       valueYField: fieldName,\r\n       categoryXField: \"age\",  // Assuming \"age\" is the category field\r\n     })\r\n   );\r\n \r\n   series.columns.template.setAll({\r\n     tooltipText: \"{name}: {valueY}\",\r\n     width: am5.percent(90),\r\n     tooltipY: 0,\r\n     strokeOpacity: 0,\r\n   });\r\n \r\n   series.data.setAll(this.buyersData);  // Assuming you have buyersData\r\n \r\n   return series;  // Return the series for legend\r\n \r\n }\r\n objDataTraffic:any={};\r\n    overallCard() {\r\n      (this.objDataTraffic.limit = 10), (this.objDataTraffic.offset = 0);\r\n      (this.objDataTraffic.conversiontype = this.tableobj.conversiontype);\r\n      delete this.objDataTraffic.normalizedData;\r\n      delete this.objDataTraffic.revenue;\r\n      delete this.objDataTraffic.hourFormat;\r\n      delete this.objDataTraffic.dateRange;\r\n      this.service\r\n        .getOverallCards(this.objDataTraffic)\r\n        .pipe(takeUntil(this.destroy$))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res.code === 200) {\r\n              this.getOverallCardData = res?.data;\r\n            }\r\n          },\r\n          error: (err: any) => {\r\n            this.cd.detectChanges();\r\n          },\r\n          complete: () => {},\r\n        });\r\n    }\r\n  \r\n    overallHourlyChart() {\r\n      this.chartNoData = false;\r\n      this.chartloading = true;\r\n      (this.objDataTraffic.limit = 10), (this.objDataTraffic.offset = 0);\r\n      delete this.objDataTraffic.normalizedData;\r\n      delete this.objDataTraffic.revenue;\r\n  delete this.objDataTraffic.hourFormat\r\n      delete this.objDataTraffic.dateRange;\r\n      this.service\r\n        .getOverallHourlyChart(this.objDataTraffic)\r\n        .pipe(takeUntil(this.destroy$))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res.code === 200) {\r\n              this.chartNoData = false;\r\n              this.chartloading = false;\r\n              this.getOverallHourlyData = res?.data?.hourlyData;\r\n              this.initHeatChart();\r\n              this.cd.detectChanges();\r\n            } else {\r\n              this.chartNoData = true;\r\n              this.chartloading = false;\r\n            }\r\n          },\r\n          error: (err: any) => {\r\n            this.cd.detectChanges();\r\n          },\r\n          complete: () => {},\r\n        });\r\n    }\r\n    overallChart() {\r\n      this.offsetTrafficCard =0;\r\n      this.limitTrafficCard =20;\r\n      this.chartNoData = false;\r\n      this.chartloading = true;\r\n      (this.objDataTraffic.limit = 20), (this.objDataTraffic.offset = 0);\r\n      delete this.objDataTraffic.normalizedData;\r\n      delete this.objDataTraffic.revenue;\r\n      delete this.objDataTraffic.hourFormat;\r\n      delete this.objDataTraffic.dateRange;\r\n      this.service\r\n        .getOverallChart(this.objDataTraffic)\r\n        .pipe(takeUntil(this.destroy$),debounceTime(300))\r\n        ?.subscribe({\r\n          next: (res: any) => {\r\n            if (res && res.code === 200) {\r\n              this.getOverallChartData = res?.data;\r\n              this.totalItemsTrafficCard = res.data.totalCount\r\n              this.chartNoData = false;\r\n              this.chartloading = false;\r\n              this.initChart();\r\n        this.setPaginationSizesTrafficCard();\r\n              this.cd.detectChanges();\r\n            } else {\r\n              this.chartNoData = true;\r\n              this.chartloading = false;\r\n            }\r\n          },\r\n          error: (err: any) => {\r\n            this.cd.detectChanges();\r\n          },\r\n          complete: () => {},\r\n        });\r\n    }\r\n    setPaginationSizesTrafficCard() {\r\n      if (this.totalItemsTrafficCard > 20) {\r\n        this.paginationSizesTrafficCard = [20];\r\n      } else {\r\n        this.paginationSizesTrafficCard = [this.totalItemsTrafficCard]; // Just one option if less than 10\r\n      }\r\n      this.pageSizeTrafficCard = this.paginationSizesTrafficCard[0];\r\n    }\r\n    onPageChangeTrafficCard(pageOffset: number) {\r\n      this.offsetTrafficCard = Number(pageOffset);\r\n      this.objDataTraffic.offset = this.offsetTrafficCard -1;\r\n      this.objDataTraffic.limit = this.limitTrafficCard;\r\n      delete this.objDataTraffic.normalizedData;\r\n      delete this.objDataTraffic.revenue;\r\n      delete this.objDataTraffic.hourFormat;\r\n      delete this.objDataTraffic.dateRange;\r\n      this.service\r\n      .getOverallChart(this.objDataTraffic)\r\n      .pipe(takeUntil(this.destroy$),debounceTime(300))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getOverallChartData = res?.data;\r\n            this.totalItemsTrafficCard = res.data.totalCount\r\n            this.chartNoData = false;\r\n            this.chartloading = false;\r\n            this.initChart();\r\n            this.cd.detectChanges();\r\n          } else {\r\n            this.chartNoData = true;\r\n            this.chartloading = false;\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          this.cd.detectChanges();\r\n        },\r\n        complete: () => {},\r\n      });\r\n    }\r\n  \r\n    onPageSizeChangeTrafficCard(pageSize: number) {\r\n      this.pageSizeTrafficCard = Number(pageSize);\r\n      this.limitTrafficCard = Number(pageSize);\r\n      this.currentPageTrafficCard = 1;\r\n      this.offsetTrafficCard = 0;\r\n      this.objDataTraffic.offset = this.offsetTrafficCard;\r\n      this.objDataTraffic.limit = this.limitTrafficCard;\r\n      this.overallChart();\r\n    }\r\n\r\n    trafficHeatChart() {\r\n      this.chartNoData = false;\r\n      this.chartloading = false;\r\n    \r\n      setTimeout(() => {\r\n        const chartDiv = document.getElementById(\"trafficHeatmapChart\");\r\n        if (!chartDiv) {\r\n          return;\r\n        }\r\n    \r\n        // Dispose of the previous chart instance if it exists\r\n        if (this.heatMapRoot) {\r\n          this.heatMapRoot.dispose();\r\n        }\r\n    \r\n        // Initialize the chart root\r\n        this.heatMapRoot = am5.Root.new(\"trafficHeatmapChart\");\r\n        this.heatMapRoot.container.setAll({\r\n          width: am5.percent(100),\r\n        });\r\n    \r\n        // Apply themes\r\n        this.heatMapRoot.setThemes([\r\n          am5themes_Animated.new(this.heatMapRoot),\r\n          am5themes_Responsive.new(this.heatMapRoot),\r\n        ]);\r\n    \r\n        // Create the chart\r\n        this.heatMapChart = this.heatMapRoot.container.children.push(\r\n          am5xy.XYChart.new(this.heatMapRoot, {\r\n            panX: false,\r\n            panY: false,\r\n            wheelX: \"none\",\r\n            wheelY: \"none\",\r\n            paddingLeft: 0,\r\n            layout: this.heatMapRoot.verticalLayout,\r\n          })\r\n        );\r\n    \r\n        // Create Y-axis\r\n        const yRenderer = am5xy.AxisRendererY.new(this.heatMapRoot, {\r\n          visible: false,\r\n          minGridDistance: 30,\r\n          inversed: true,\r\n          minorGridEnabled: true,\r\n        });\r\n        yRenderer.grid.template.set(\"visible\", false);\r\n    \r\n        const yAxis = this.heatMapChart.yAxes.push(\r\n          am5xy.CategoryAxis.new(this.heatMapRoot, {\r\n            maxDeviation: 0,\r\n            renderer: yRenderer,\r\n            categoryField: \"hour\",\r\n          })\r\n        );\r\n    \r\n        // Create X-axis\r\n        const xRenderer = am5xy.AxisRendererX.new(this.heatMapRoot, {\r\n          visible: false,\r\n          minGridDistance: 30,\r\n          minorGridEnabled: true,\r\n        });\r\n        xRenderer.grid.template.set(\"visible\", false);\r\n    \r\n        const xAxis = this.heatMapChart.xAxes.push(\r\n          am5xy.CategoryAxis.new(this.heatMapRoot, {\r\n            renderer: xRenderer,\r\n            categoryField: \"weekday\",\r\n          })\r\n        );\r\n    \r\n        // Add Y-axis label\r\n        yAxis.children.unshift(\r\n          am5.Label.new(this.heatMapRoot, {\r\n            rotation: -90,\r\n            text: \"Hours\",\r\n            y: am5.p50,\r\n            centerX: am5.p50,\r\n            fontFamily: \"Arial\",\r\n            fontSize: \"14px\",\r\n            fill: am5.color(0x000000),\r\n          })\r\n        );\r\n    \r\n        // Create series\r\n        this.heatMapSeries = this.heatMapChart.series.push(\r\n          am5xy.ColumnSeries.new(this.heatMapRoot, {\r\n            calculateAggregates: true,\r\n            stroke: am5.color(0xffffff),\r\n            clustered: false,\r\n            xAxis: xAxis,\r\n            yAxis: yAxis,\r\n            categoryXField: \"weekday\",\r\n            categoryYField: \"hour\",\r\n            valueField: \"value\",\r\n          })\r\n        );\r\n        \r\n        // Configure column appearance\r\n        this.heatMapSeries.columns.template.setAll({\r\n          tooltipText: \"{value}\",\r\n          strokeOpacity: 1,\r\n          strokeWidth: 2,\r\n          width: am5.percent(100),\r\n          height: am5.percent(100),\r\n        });\r\n\r\n        this.heatMapSeries.columns.template.adapters.add(\"fill\", (fill, target) => {\r\n          const dataItem = target.dataItem?.dataContext as { value: number };\r\n          return dataItem && dataItem.value !== undefined ? this.getRangeColorDynamic(dataItem.value) : fill;\r\n        });\r\n    \r\n        // Set column color based on value\r\n            // this.heatMapSeries.columns.template.adapters.add(\"fill\", (fill, target) => {\r\n            //   const dataItem = target.dataItem?.dataContext as { value: number };\r\n            //   return dataItem && dataItem.value !== undefined ? this.getRangeColor1(dataItem.value) : fill;\r\n            // });\r\n        \r\n    \r\n        // Add bullet for value labels\r\n        this.heatMapSeries.bullets.push(() => {\r\n          return am5.Bullet.new(this.heatMapRoot, {\r\n            sprite: am5.Label.new(this.heatMapRoot, {\r\n              text: \"{value}\",\r\n              fill: am5.color(0x000000),\r\n              centerY: am5.p50,\r\n              centerX: am5.p50,\r\n              populateText: true,\r\n              fontSize: 12,\r\n            }),\r\n          });\r\n        });\r\n    \r\n        // Prepare and sort data for the chart\r\n        const heatMapData: any[] = [];\r\n        if (this.getFootfallDensityDwellData && this.getFootfallDensityDwellData.trafficDensity) {\r\n          Object.keys(this.getFootfallDensityDwellData.trafficDensity).forEach(hour => {\r\n            this.getFootfallDensityDwellData.trafficDensity[hour].forEach((dayData: any) => {\r\n              heatMapData.push({\r\n                hour: dayData.time,\r\n                weekday: dayData.day,\r\n                value: parseInt(dayData.footfallCount, 10), // Ensure integer parsing\r\n              });\r\n            });\r\n          });\r\n        } else {\r\n          console.error(\"Traffic density data is undefined or null.\");\r\n        }\r\n        \r\n        // Set data to the series\r\n        this.heatMapSeries.data.setAll(heatMapData);\r\n\r\n        const visibleValues = this.heatMapSeries.data.values.map((d:any) => d.value);\r\n\r\n        this.maxFootfall = Math.max(...visibleValues);\r\n        this.minFootfall = Math.min(...visibleValues);\r\n\r\n        // Extract unique weekdays and hours, sorted\r\n        const weekdays: string[] = Array.from(new Set(heatMapData.map(row => row.weekday)));\r\n        const hours: string[] = Array.from(new Set(heatMapData.map(row => row.hour)))\r\n          .sort((a, b) => a.localeCompare(b));\r\n    \r\n        // Set axis data\r\n        xAxis.data.setAll(\r\n          weekdays.map(item => ({ weekday: item }))\r\n        );\r\n    \r\n        yAxis.data.setAll(\r\n          hours.map(item => ({ hour: item }))\r\n        );\r\n    \r\n        // Finalize chart appearance\r\n        this.heatMapChart.appear(1000, 100);\r\n    \r\n        // Ensure the root is assigned correctly\r\n        this.heatMapRoot = this.heatMapRoot;\r\n    \r\n      }, 0);\r\n  }\r\n  \r\n\r\n  getRangeColorDynamic(footfallCount: number): am5.Color {\r\n    let minFootfall = this.minFootfall ?? 0;\r\n    let maxFootfall = this.maxFootfall ?? 1;\r\n  \r\n    if (maxFootfall === minFootfall) return am5.color(0x008edf); // Prevent division by zero\r\n    const normalizedValue = (footfallCount - minFootfall) / (maxFootfall - minFootfall);\r\n    const clampedValue = Math.min(Math.max(normalizedValue, 0), 0.5);\r\n    const adjustedValue = Math.pow(clampedValue, 0.5);  // Increase power to darken faster\r\n    const baseColor = am5.color(0x008edf);  // Starting color (light blue)\r\n    const adjustedColor = am5.Color.lighten(baseColor, 1 - adjustedValue);\r\n    return adjustedColor;\r\n  }\r\n\r\n\r\n    getRangeColor1(footfallCount: number): am5.Color {\r\n      let maxFootfall:any;\r\n      const minFootfall = 0;  // minimum expected footfall\r\n      if(this.objDataTraffic.dateRange =30)\r\n      maxFootfall = 3500;\r\n    else \r\n    maxFootfall = 750;\r\n      const normalizedValue = (footfallCount - minFootfall) / (maxFootfall - minFootfall);\r\n      const clampedValue = Math.min(Math.max(normalizedValue, 0), 0.5);\r\n      const adjustedValue = Math.pow(clampedValue, 0.5);  // Increase power to darken faster\r\n      const baseColor = am5.color(0x008edf);  // Starting color (light blue)\r\n      const adjustedColor = am5.Color.lighten(baseColor, 1 - adjustedValue);\r\n      return adjustedColor;\r\n    }\r\n    \r\n    \r\n      getDwellChart() {\r\n        this.chartDwellNoData = false;\r\n      this.chartDwellloading = true;\r\n        setTimeout(() => {\r\n          const chartDiv = document.getElementById(\"dwellBarChart\");\r\n          if (!chartDiv) {\r\n            return;\r\n          }\r\n          if (this.dwellRoot) {\r\n            this.dwellRoot.dispose();\r\n          }\r\n          // Create root element\r\n          this.dwellRoot = am5.Root.new(\"dwellBarChart\");\r\n    \r\n          // Set themes\r\n          this.dwellRoot.setThemes([am5themes_Animated.new(this.dwellRoot)]);\r\n    \r\n          // Create chart\r\n          this.dwellChart = this.dwellRoot.container.children.push(\r\n            am5xy.XYChart.new(this.dwellRoot, {\r\n              panX: false,\r\n              panY: false,\r\n              wheelX: \"panX\",\r\n              wheelY: \"zoomX\",\r\n              paddingLeft: 0,\r\n              layout: this.dwellRoot.verticalLayout,\r\n            })\r\n          );\r\n    \r\n         let data = this.getDensityDwellData.dwellTimeSplit?.map(\r\n            (item: any) => ({\r\n              year: (item.dwell_time) + \" Mins\",\r\n              maleCount: Number(item.maleCount_value),\r\n              maleCustom: Number(item.maleCount),\r\n              femaleCount: Number(item.femaleCount_value),\r\n              femaleCustom: Number(item.femaleCount)\r\n            })\r\n          );\r\n              \r\n          // Create axes\r\n          let xRenderer = am5xy.AxisRendererX.new(this.dwellRoot, {\r\n            minGridDistance: 30,\r\n            minorGridEnabled: true,\r\n          });\r\n          let xAxis = this.dwellChart.xAxes.push(\r\n            am5xy.CategoryAxis.new(this.dwellRoot, {\r\n              categoryField: \"year\",\r\n              renderer: xRenderer,\r\n              tooltip: am5.Tooltip.new(this.dwellRoot, {}),\r\n            })\r\n          );\r\n    \r\n          xRenderer.grid.template.setAll({\r\n            location: 1,\r\n          });\r\n    \r\n          xAxis.data?.setAll(data);\r\n    \r\n          let yAxis = this.dwellChart.yAxes.push(\r\n            am5xy.ValueAxis.new(this.dwellRoot, {\r\n              min: 0,\r\n              renderer: am5xy.AxisRendererY.new(this.dwellRoot, {\r\n                strokeOpacity: 0.1,\r\n              }),\r\n            })\r\n          );\r\n    \r\n          // Add legend\r\n          let legend = this.dwellChart.children.push(\r\n            am5.Legend.new(this.dwellRoot, {\r\n              centerX: am5.p50,\r\n              x: am5.p50,\r\n            })\r\n          );\r\n    \r\n          // Add series\r\n          // const \r\n         \r\n          this.makeSeries1(\"Male\", \"maleCount\", xAxis, yAxis, data, legend);\r\n          this.makeSeries1(\"Female\", \"femaleCount\", xAxis, yAxis, data, legend);\r\n          // Make stuff animate on load\r\n          this.dwellChart.appear(1000, 100);\r\n        }, 100);\r\n      }\r\n      makeSeries1(name: string, fieldName: string, xAxis: any, yAxis: any, data: any, legend: any) {\r\n        let series = this.dwellChart.series.push(\r\n          am5xy.ColumnSeries.new(this.dwellRoot, {\r\n            name: name,\r\n            stacked: true,\r\n            xAxis: xAxis,\r\n            yAxis: yAxis,\r\n            valueYField: fieldName,\r\n            categoryXField: \"year\",\r\n          })\r\n        );\r\n      \r\n        series.columns.template.setAll({\r\n          tooltipText: `[bold]{name}[/]\\n{categoryX},\\nFootfall %: {customValue}%`,\r\n          tooltipY: am5.percent(10),\r\n        });\r\n      \r\n        if (data?.length) {\r\n          const enhancedData = data.map((d: any) => ({\r\n            ...d,\r\n            customValue: d[fieldName === \"maleCount\" ? \"maleCustom\" : \"femaleCustom\"]\r\n          }));\r\n          series.data.setAll(enhancedData);\r\n        }\r\n      \r\n        series.bullets.push(() => {\r\n          let label = am5.Label.new(this.dwellRoot, {\r\n            text: \"{valueY}\",\r\n            fill: this.dwellRoot.interfaceColors.get(\"alternativeText\"),\r\n            centerY: am5.p50,\r\n            centerX: am5.p50,\r\n            populateText: true,\r\n          });\r\n      \r\n          label.adapters.add(\"visible\", (visible, target) => {\r\n            const value = (target.dataItem?.dataContext as any)?.[fieldName];\r\n            return value !== 0;\r\n          });\r\n      \r\n          return am5.Bullet.new(this.dwellRoot, {\r\n            sprite: label,\r\n          });\r\n        });\r\n      \r\n        if (legend) {\r\n          legend.data.push(series);\r\n        }\r\n      }\r\n      \r\n      \r\n      \r\n      storeName:any;\r\n      storeId:any;\r\n      formatDate(dateString: string): string {\r\n        return this.dayjs(dateString).format('DD MMM');  // Output: '01 Jan'\r\n      }\r\n        handleBarClick(dataItem: any): void {\r\n          this.storeName = dataItem.fullStoreName;\r\n          this.storeId = dataItem.storeId\r\n          this.objDataTraffic.storeId =[dataItem.storeId],\r\n          this.objDataTraffic.limit =31,\r\n          this.service\r\n            .getSingleStoreChart(this.objDataTraffic)\r\n            .pipe(takeUntil(this.destroy$))\r\n            ?.subscribe({\r\n              next: (res: any) => {\r\n                if (res && res.code === 200) {\r\n                  this.getSingleChartData = res?.data.storeData;\r\n                  this.detailedCharts = true;\r\n                  this.cd.detectChanges(); \r\n                  setTimeout(() => this.getSingleStore(), 0); // Call with a delay to ensure the element is in the DOM\r\n                }\r\n              },\r\n              error: (err: any) => {\r\n                this.cd.detectChanges();\r\n              },\r\n              complete: () => {},\r\n            });\r\n            \r\n        }\r\n\r\n        getSingleStore(){\r\n            const chartDiv = document.getElementById(\"detailedChartDiv\");\r\n            if (!chartDiv) {\r\n              return;\r\n            }\r\n        \r\n            if (this.detailedRoot) {\r\n              this.detailedRoot.dispose();\r\n            }\r\n          \r\n            this.detailedRoot = am5.Root.new(\"detailedChartDiv\");\r\n            this.detailedRoot.setThemes([\r\n              am5themes_Animated.new(this.detailedRoot),\r\n            ]);\r\n        \r\n            this.detailedChart = this.detailedRoot.container.children.push(\r\n              am5xy.XYChart.new(this.detailedRoot, {\r\n                panX: false,\r\n                panY: false,\r\n                wheelX: \"panX\",\r\n                wheelY: \"zoomX\",\r\n                paddingLeft: 0,\r\n              })\r\n            );\r\n        \r\n            // Add cursor\r\n            let cursor = this.detailedChart.set(\r\n              \"cursor\",\r\n              am5xy.XYCursor.new(this.detailedRoot, {})\r\n            );\r\n            cursor.lineY.set(\"visible\", false);\r\n        \r\n            // Create axes\r\n            let xRenderer = am5xy.AxisRendererX.new(this.detailedRoot, {\r\n              minGridDistance: 30,\r\n              minorGridEnabled: true,\r\n            });\r\n        \r\n            xRenderer.labels.template.setAll({\r\n              rotation: -90,\r\n              centerY: am5.p50,\r\n              centerX: am5.p100,\r\n              paddingRight: 15,\r\n            });\r\n        \r\n            xRenderer.grid.template.setAll({\r\n              location: 1,\r\n            });\r\n            // Add scrollbar\r\n            this.detailedChart.set(\r\n              \"scrollbarX\",\r\n              am5.Scrollbar.new(this.detailedRoot, {\r\n                orientation: \"horizontal\",\r\n              })\r\n            );\r\n            let xAxis = this.detailedChart.xAxes.push(\r\n              am5xy.CategoryAxis.new(this.detailedRoot, {\r\n                maxDeviation: 0.3,\r\n                categoryField: \"date\",\r\n                renderer: xRenderer,\r\n                tooltip: am5.Tooltip.new(this.detailedRoot, {}),\r\n              })\r\n            );\r\n        \r\n            let yRenderer = am5xy.AxisRendererY.new(this.detailedRoot, {\r\n              strokeOpacity: 0.1,\r\n            });\r\n        \r\n            let yAxis = this.detailedChart.yAxes.push(\r\n              am5xy.ValueAxis.new(this.detailedRoot, {\r\n                maxDeviation: 0.3,\r\n                renderer: yRenderer,\r\n              })\r\n            );\r\n            \r\n            let data = this.getSingleChartData.map((item: any) => ({\r\n              date: this.formatDate(item.date), // Convert date string to timestamp\r\n              value: Number(item.count), // Use `count` as `value`\r\n            }));\r\n            data.sort((a: any, b: any) => {\r\n              // Parse storeName as a Date and compare\r\n              const dateA = new Date(a.date);\r\n              const dateB = new Date(b.date);\r\n              \r\n              // Sort in ascending order (oldest to newest)\r\n              return dateA.getTime() - dateB.getTime();\r\n            });\r\n            // Create series\r\n            this.detailedSeries = this.detailedChart.series.push(\r\n              am5xy.ColumnSeries.new(this.detailedRoot, {\r\n                name: \"Series 2\",\r\n                xAxis: xAxis,\r\n                yAxis: yAxis,\r\n                valueYField: \"value\",\r\n                sequencedInterpolation: true,\r\n                categoryXField: \"date\",\r\n                tooltip: am5.Tooltip.new(this.detailedRoot, {\r\n                  labelText: \"{valueY}\",\r\n                }),\r\n              })\r\n            );\r\n            this.detailedSeries.columns.template.setAll({ strokeOpacity: 0 });\r\n            xAxis.data.setAll(data);\r\n            this.detailedSeries.data.setAll(data);\r\n            this.detailedSeries.appear(1000);\r\n            this.detailedChart.appear(1000, 100);\r\n        }\r\n\r\n        forecastApi(evt:any){\r\n          if(evt.target.checked){\r\n            this.objData.forecast = true\r\n            this.objData.normalize = false\r\n            this.objData.nob = false\r\n            this.objData.filterBy = 'average'\r\n          } else {\r\n            this.objData.forecast = false\r\n            this.objData.normalize = this.clientData?.featureConfigs?.isNormalized\r\n            this.objData.nob = false\r\n            this.objData.filterBy = 'average'\r\n          }\r\n          this.footfallTrend();\r\n        }\r\n        \r\n\r\n        toggleNormalize(evt:any){\r\n          this.normalize =evt.target.checked;\r\n          this.tableobj.normalize = this.normalize\r\n          this.objData.normalize = this.normalize\r\n          this.objDataTraffic.normalize = this.normalize\r\n          // this.tableobj.forecast = false\r\n          this.objData.forecast = false;\r\n          this.forecast =false;\r\n          // this.objDataTraffic.forecast = false\r\n          this.conversionValue = this.nob\r\n              ? \"NoB Derived\"\r\n              : this.clientData?.featureConfigs\r\n                  ?.missedOpportunityCalculation === 'engagers-conversion'\r\n              ? \"engagers\"\r\n              : \"footfall\";\r\n          this.getFunnal();\r\n          this.getFootfallCard();\r\n          this.getConversionCard();\r\n          this.getBouncedCard();\r\n          this.getEngagersCard();\r\n          this.getPotentialBuyersCard();\r\n          this.getMissedOpportunityCard();\r\n          this.getPotentialBuyers();\r\n          this.performance();\r\n          this.getTable();\r\n          this.footfallTrend();\r\n          if(this.headerData?.client ==='459'){\r\n            this.selectedTab = \"footfall\"\r\n            this.footfallValue = \"footfall\";\r\n            this.selctedValue ='Footfall Analysis';\r\n            this.selectedTabs('footfall');\r\n          } else {\r\n            this.selectedTab = \"traffic\"\r\n            this.footfallValue = \"traffic\";\r\n            this.selctedValue ='Traffic Analysis';\r\n            this.selectedTabs('traffic');\r\n          }\r\n          if(this.normalize === true){\r\n          this.zoneDwellTimeSplitData =[];\r\n            this.zoneLoading = false;\r\n            this.zoneNoData = true;\r\n            this.storeOperationData =[];\r\n            this.auLocations =[];\r\n            this.mpaloading =false;\r\n            this.mapnoData= true;\r\n            this.forecast =false;\r\n            this.objData.forecast = false;\r\n            if(this.storeIdarray.length === 1){\r\n            this.getRecapVideoData =[]\r\n            this.recaplaoding =false;\r\n            this.recapnoData =true;\r\n            this.service?.togglenormalize(this.normalize);\r\n            }\r\n          } else {\r\n            this.getZone(); this.getZoneValue();\r\n            this.getMap();\r\n            if(this.storeIdarray.length === 1){\r\n            this.getRecap();\r\n            this.service?.togglenormalize(this.normalize);\r\n            }\r\n          }\r\n          this.cd.detectChanges();\r\n        }\r\n\r\n\r\n        \r\n}\r\n\r\n\r\n\r\n\r\n\r\n\r\ninterface DataContext {\r\n  category: string;\r\n  value: number;\r\n  count: number;\r\n}\r\nfunction getDaysBetweenDates(fromDate: string, toDate: string): number {\r\n  // Parse the date strings into Date objects\r\n  const start = new Date(fromDate);\r\n  const end = new Date(toDate);\r\n\r\n  // Calculate the difference in milliseconds\r\n  const differenceInMs = end.getTime() - start.getTime();\r\n\r\n  // Convert milliseconds to days (1 day = 86400000 milliseconds)\r\n  const millisecondsPerDay = 86400000;\r\n  const differenceInDays = Math.floor(differenceInMs / millisecondsPerDay);\r\n\r\n  return differenceInDays;\r\n}\r\n\r\ninterface ChartDataItem {\r\n  rate: number;\r\n  count: number;\r\n  time: string;\r\n}\r\n\r\n\r\n\r\n\r\n\r\n// getCard() {\r\n//   this.tableobj.valueType= this.valueType,\r\n//   this.tableobj.fromDate = this.headerData?.date.startDate;\r\n//   this.tableobj.toDate = this.headerData?.date.endDate;\r\n//  delete this.tableobj.offset;\r\n//  delete this.tableobj.recapVideoDate;\r\n//  delete this.tableobj.limit; \r\n//  delete this.tableobj.sort;\r\n//  delete this.tableobj.sortBy;\r\n//  delete this.tableobj.export;\r\n//   this.heatloading = true;\r\n//   this.heatnoData = false;\r\n//  delete this.tableobj.dateType\r\n//   this.service\r\n//     .getCardList(this.tableobj)\r\n//     .pipe(takeUntil(this.destroy$))\r\n//     ?.subscribe({\r\n//       next: (res: any) => {\r\n//         if (res && res.code === 200) {\r\n//           this.getCardData = res?.data?.card;\r\n//           // this.heatMapData = res?.data?.funnelChart;\r\n         \r\n//           this.cd.detectChanges();\r\n//         } else {\r\n//           this.getCardData =[];\r\n//           this.heatMapData =[];\r\n//         this.heatloading = false\r\n//         this.heatnoData = true\r\n//         }\r\n//       },\r\n//       error: (err: any) => {\r\n//         this.getCardData =[];\r\n//         this.heatMapData =[];\r\n//         this.cd.detectChanges();\r\n//       },\r\n//       complete: () => {},\r\n//     });\r\n// }\r\n\r\n// getCardGraph() {\r\n//   this.cardloading =true;\r\n//   this.cardNodata =false;\r\n//   delete this.tableobj.normalizedData;\r\n//   delete this.tableobj.processType;\r\n//   this.tableobj.dateType = this.dateType;\r\n//   delete this.tableobj.sort;\r\n//   delete this.tableobj.sortBy;\r\n//   this.service\r\n//     .getCardGraphList(this.tableobj)\r\n//     .pipe(takeUntil(this.destroy$))\r\n//     ?.subscribe({\r\n//       next: (res: any) => {\r\n//         if (res && res.code === 200) {\r\n//           this.getCardGraphData = res?.data;\r\n//           if(this.nob){\r\n//             this.valueConversionRate = this.getCardGraphData?.conversion?.nob.nob;\r\n//           this.conversionValue ='NoB Derived'\r\n//           }else { \r\n//           this.valueConversionRate =  this.getCardGraphData?.conversion?.footfall.rate;\r\n//            this.conversionValue ='footfall'\r\n//           }\r\n//           this.cardloading =false;\r\n//           this.cardNodata =false;           \r\n//           this.cd.detectChanges();\r\n//         } else if(!res || res.code === 204){\r\n//           this.getCardGraphData=[];\r\n//           this.cardloading =false;\r\n//           this.cardNodata =true;\r\n//         }\r\n//       },\r\n//       error: (err: any) => {\r\n//         this.cd.detectChanges();\r\n//       },\r\n//       complete: () => {},\r\n//     });\r\n// }\r\n","<script>\r\n    (g=>{var h,a,k,p=\"The Google Maps JavaScript API\",c=\"google\",l=\"importLibrary\",q=\"__ib__\",m=document,b=window;b=b[c]||(b[c]={});var d=b.maps||(b.maps={}),r=new Set,e=new URLSearchParams,u=()=>h||(h=new Promise(async(f,n)=>{await (a=m.createElement(\"script\"));e.set(\"libraries\",[...r]+\"\");for(k in g)e.set(k.replace(/[A-Z]/g,t=>\"_\"+t[0].toLowerCase()),g[k]);e.set(\"callback\",c+\".maps.\"+q);a.src=`https://maps.${c}apis.com/maps/api/js?`+e;d[q]=f;a.onerror=()=>h=n(Error(p+\" could not load.\"));a.nonce=m.querySelector(\"script[nonce]\")?.nonce||\"\";m.head.append(a)}));d[l]?console.warn(p+\" only loads once. Ignoring:\",g):d[l]=(f,...n)=>r.add(f)&&u().then(()=>d[l](f,...n))})({\r\n      v: \"weekly\",\r\n      key: \"AIzaSyDlOezgwQO0JviD0aizrCuN1FY9tcWfR3o\"\r\n    });\r\n  </script>\r\n  <link href='https://api.mapbox.com/mapbox-gl-js/v2.15.0/mapbox-gl.css' rel='stylesheet' />\r\n  <script src='https://api.mapbox.com/mapbox-gl-js/v2.15.0/mapbox-gl.js'></script>\r\n\r\n<div class=\"row\">\r\n    <div *ngIf=\"(gs.userAccess | async)?.userType === 'tango' || clientData?.featureConfigs?.isNormalized\" class=\"col-md-12 text-end\">\r\n       <div class=\"form-check form-switch my-2\" style=\"float: right !important;\">\r\n            <input class=\"form-check-input cursor-pointer\"  type=\"checkbox\" id=\"flexSwitchCheckDefault\" \r\n            [checked]=\"normalize\" (change)=\"toggleNormalize($event)\"><span class=\"normalize-text\">View Normalized Data</span>\r\n          </div>\r\n    </div>\r\n    <div class=\"col-md-7 h-100\">\r\n        <div class=\"row\">\r\n            <div class=\"col-md-8 \">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"row position-relative\">\r\n                        <div class=\"col-md-6\"  >\r\n                            <div class=\"px-0\">\r\n                                <div class=\"card-header ellipse1 border-0 px-3\" >\r\n                                    <!-- -->\r\n                                    <h3  class=\"card-title align-items-start flex-column\" [ngbTooltip]=\"footfallTooltip\" placement=\"right\">\r\n                                      <!-- Display footfall count or '--' if not available -->\r\n                                      <span class=\"card-label header\">{{ getFootfallCardData?.card?.footfall?.count ? getFootfallCardData?.card?.footfall?.count.toLocaleString('en-IN') : '--' }}</span>\r\n                                      <span class=\"sub-header\">{{footfallName}}</span>\r\n                                    </h3>\r\n                                    \r\n                                    <!-- Switch toggle -->\r\n                                    <div class=\"card-toolbar\">\r\n                                        <div class=\"col-md-12 text-end\">\r\n                                      <div class=\"form-check form-switch text-end\">\r\n                                        <input class=\"form-check-input mt-1 cursor-pointer\" type=\"checkbox\" id=\"flexSwitchCheckDefault\" \r\n                                        [(ngModel)]=\"isAverage\" (change)=\"toggleAverage($event)\" [disabled]=\"isDisabled\">\r\n                                      </div>\r\n                                      <div *ngIf=\"isAverage\" class=\"form-check-label mt-5\">Average</div>\r\n                                      <div *ngIf=\"!isAverage\" class=\"form-check-label mt-5\">Actual</div>\r\n                                      </div>\r\n                                    </div>\r\n                                  </div>\r\n                                  <ng-template #footfallTooltip>\r\n                                    <div class=\"tooltip-content\">\r\n                                      <h5 class=\"tooltip-title text-start\">Footfall</h5>\r\n                                      <p class=\"text-start\">Total unique walk-ins into the selected stores.</p>\r\n                                      <h4 class=\"text-start\">{{getCardData?.footfall?.count}}</h4>\r\n                                    </div>\r\n                                  </ng-template>\r\n                                <div class=\"card-body p-0\">\r\n                              \r\n                                    <section >\r\n                                        <div class=\"row\">\r\n                                            <div class=\"col-md-10 pe-0\">\r\n                                                <div *ngIf=\"footfallloading\" class=\"text-center\">\r\n                                                    <img class=\"loader-img\" src=\"assets/tango/layout/Loader.gif\">\r\n                                                </div>\r\n                                                <div *ngIf=\"footfallNodata\" class=\"row\">\r\n                                                   \r\n                                                        <div class=\"card-body pb-0 px-0 d-flex justify-content-center align-items-center flex-column\">\r\n                                                            <img class=\"footimg-nodata1\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                                            <div class=\"nodata-title1\">No data found</div>\r\n                                                            <!-- <div class=\"nodata-sub\">There is no result for this conversion funnel</div> -->\r\n                                                        </div>\r\n                                                \r\n                                                </div>\r\n                                    <div *ngIf=\"!footfallNodata\" class=\"text-center\" id=\"Footfall\"></div>\r\n                                    </div>\r\n                                    <div class=\"col-md-2 mt-3\">\r\n                                        <div  class=\"mt-1 cursor-pointer fs-5\" [ngClass]=\"dateType ==='daily' ? 'text-primary' :''\" (click)=\"dateValue('daily')\">1D</div>\r\n                                        <div  class=\"mt-1 cursor-pointer fs-5\"  [ngClass]=\"dateType ==='weekly' ? 'text-primary' :''\"  (click)=\"dateValue('weekly')\">1W</div>\r\n                                        <div  class=\"mt-1 cursor-pointer fs-5\"  [ngClass]=\"dateType ==='monthly' ? 'text-primary' :''\"  (click)=\"dateValue('monthly')\">1M</div>\r\n                                    </div>\r\n                                    </div>\r\n                                    </section>\r\n                                </div>\r\n                                <div class=\"card-footer ms-2 p-0\">\r\n                                    <div class=\"col-md-12 mt-3\">\r\n                                        <span class=\"mt-2\">\r\n                                            <svg *ngIf=\"!getFootfallCardData?.data?.footfall?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                            height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                                <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <clipPath id=\"clip0_2328_4654\">\r\n                                                    <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                </clipPath>\r\n                                            </defs>\r\n                                        </svg>\r\n                                        <svg *ngIf=\"getFootfallCardData?.data?.footfall?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                            viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_3216_118)\">\r\n                                                <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <clipPath id=\"clip0_3216_118\">\r\n                                                    <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                </clipPath>\r\n                                            </defs>\r\n                                        </svg>\r\n                                        </span>\r\n                                        <span *ngIf=\"getFootfallCardData?.data?.footfall?.PreviousData ===0\" class=\"percent-value ms-2\">0%</span>\r\n                                        <span  class=\"mt-2 ms-2\"><span class=\"percent-value\" *ngIf=\"getFootfallCardData?.data?.footfall?.PreviousData !==0\">{{getFootfallCardData?.data?.footfall?.PreviousData ? getFootfallCardData?.data?.footfall?.PreviousData:'--'}}%</span><span\r\n                                                class=\"week-font\"> vs Previous <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span> </span>\r\n\r\n                                        </span>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                            <!-- <div>\r\n                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                        <path d=\"M6 12L10 8L6 4\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                        </svg>\r\n                        </div> -->\r\n                        </div>\r\n                        <div class=\"position-absolute left-50\">\r\n                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                <path d=\"M6 12L10 8L6 4\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                </svg>\r\n                                </div>\r\n                        <div class=\"col-md-6\">\r\n\r\n                            <div class=\"px-0\">\r\n                                <div class=\"card-header ellipse1 border-0 ps-2\" >\r\n                                    <div class=\"row\">\r\n                                        <div class=\"col-md-10 text-nowrap pe-0\" >\r\n                                    <h3 class=\" card-title align-items-start flex-column\" [ngbTooltip]=\"conversionTooltip\" placement=\"right\">\r\n                                        <span class=\"card-label header\" *ngIf=\"valueConversionRate === 0\">0%</span>\r\n                                        <span class=\"card-label header\" *ngIf=\"valueConversionRate !== 0\">{{valueConversionRate  ? valueConversionRate : '--'}}%</span>\r\n                                        <span class=\"sub-header\"><span *ngIf=\"headerData?.client === '452'\">More than {{clientData?.featureConfigs?.conversion?.value}} mins Rate</span>\r\n                                        <!-- <span *ngIf=\"headerData?.client !== '452'\">Conversion</span>   -->\r\n                                            <!-- <ng-container *ngIf=\"headerData?.client !== '452'\">\r\n                                            <span *ngIf=\"conversionValue === 'footfall' || conversionValue === 'engagers' || conversionValue === 'Potential Buyers' || conversionValue === 'NoB Derived'\"> \r\n                                                - <span *ngIf=\"conversionValue === 'NoB Derived'; else otherValues\">\r\n                                                    NoB Derived\r\n                                                  </span>\r\n                                                  <ng-template #otherValues>\r\n                                                    {{ conversionValue | titlecase }}\r\n                                                  </ng-template>\r\n                                              </span>\r\n                                              </ng-container> -->\r\n                                              </span>\r\n                                              <ng-container *ngIf=\"headerData?.client !== '452'\">\r\n                                        <span *ngIf=\"!isConversion\" class=\"sub-header\"> Conversion\r\n                                     \r\n                                                <span *ngIf=\"conversionValue === 'footfall' || conversionValue === 'engagers' || conversionValue === 'Potential Buyers' || conversionValue === 'NoB Derived'\"> \r\n                                                     - <span *ngIf=\"conversionValue === 'NoB Derived'; else otherValues\">\r\n                                                        NoB Derived\r\n                                                      </span>\r\n                                                      <ng-template #otherValues>\r\n                                                        {{ conversionValue | titlecase }}\r\n                                                      </ng-template>\r\n                                                     \r\n                                                  </span>\r\n                                      \r\n                                            </span><span *ngIf=\"isConversion\" class=\"sub-header\">\r\n                                     \r\n                                                <span *ngIf=\"conversionValue === 'footfall' || conversionValue === 'engagers' || conversionValue === 'Potential Buyers' || conversionValue === 'NoB Derived'\"> \r\n                                                     <span *ngIf=\"conversionValue === 'NoB Derived'; else otherValues\">\r\n                                                     Conversion - NoB Derived\r\n                                                      </span>\r\n                                                      <ng-template #otherValues>\r\n                                                        {{ conversionValue | titlecase }} - NoB Derived\r\n                                                      </ng-template>\r\n                                                     \r\n                                                  </span>\r\n                                      \r\n                                            </span></ng-container>\r\n                                    </h3>\r\n                                    </div>\r\n                                    <div *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\" class=\"col-md-2 px-0\">\r\n                                        <div class=\"text-end\">\r\n                                      <div class=\"form-check form-switch cursor-pointer\">\r\n                                        <input class=\"form-check-input cursor-pointer\" type=\"checkbox\" id=\"Conversion\" \r\n                                        [(ngModel)]=\"isConversion\" (change)=\"toggleConversion($event)\">\r\n                                        <div  class=\"form-check-label mt-3\"></div>\r\n                                      </div>\r\n                                     \r\n                                      </div>\r\n                                    </div>\r\n                                    </div>\r\n                                </div>\r\n                               <ng-template #conversionTooltip>\r\n                                    <div class=\"tooltip-content\">\r\n                                      <h5 class=\"tooltip-title text-start\" *ngIf=\"headerData?.client !== '452'\">Conversion Rate</h5>\r\n                                      <p class=\"text-start\">Total % of {{conversionValue}} who spent more than {{clientData?.featureConfigs?.conversion?.value}} mins in the store.</p>\r\n                                      <!-- <h4 class=\"text-start\">{{valueConversionRate}}</h4> -->\r\n                                       <!-- <footer class=\"tooltip-footer text-start\"> <span class=\"mt-2\">\r\n                                        <svg *ngIf=\"!getCardGraphData?.conversion?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                        height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                        <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                            <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                                stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </g>\r\n                                        <defs>\r\n                                            <clipPath id=\"clip0_2328_4654\">\r\n                                                <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                            </clipPath>\r\n                                        </defs>\r\n                                    </svg>\r\n                                    <svg *ngIf=\"getCardGraphData?.conversion?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                        viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                        <g clip-path=\"url(#clip0_3216_118)\">\r\n                                            <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                                stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </g>\r\n                                        <defs>\r\n                                            <clipPath id=\"clip0_3216_118\">\r\n                                                <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                            </clipPath>\r\n                                        </defs>\r\n                                    </svg>\r\n                                    </span>\r\n                                    <span class=\"mt-2 ms-2\">\r\n                                        <span *ngIf=\"conversionValue ==='footfall' && getCardGraphData?.conversion?.footfall.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                        <span *ngIf=\"conversionValue ==='footfall' && getCardGraphData?.conversion?.footfall.PreviousData !==0\" class=\"percent-value\">{{getCardGraphData?.conversion?.footfall.PreviousData ? getCardGraphData?.conversion?.footfall.PreviousData:'--'}}%</span>\r\n                                        <span *ngIf=\"conversionValue ==='engagers' && getCardGraphData?.conversion?.engagers.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                      \r\n                                        <span *ngIf=\"conversionValue ==='engagers' && getCardGraphData?.conversion?.engagers.PreviousData !==0\" class=\"percent-value\">{{getCardGraphData?.conversion?.engagers.PreviousData ? getCardGraphData?.conversion?.engagers.PreviousData:'--'}}%</span>\r\n\r\n                                        <span *ngIf=\"conversionValue ==='Potential Buyers' && getCardGraphData?.conversion?.potentialBuyers.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                        <span *ngIf=\"conversionValue ==='Potential Buyers' && getCardGraphData?.conversion?.potentialBuyers.PreviousData !==0\" class=\"percent-value\">{{getCardGraphData?.conversion?.potentialBuyers.PreviousData ? getCardGraphData?.conversion?.potentialBuyers.PreviousData:'--'}}%</span>\r\n                                        <span *ngIf=\"conversionValue ==='NoB Derived'\" class=\"percent-value\">--%</span>\r\n                                        <span *ngIf=\"conversionValue ==='' && getCardGraphData?.conversion?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n\r\n                                            <span *ngIf=\"conversionValue ==='' && getCardGraphData?.conversion?.PreviousData !==0\"  class=\"percent-value\">{{getCardGraphData?.conversion?.PreviousData ? getCardGraphData?.conversion?.PreviousData:'--'}}%</span>\r\n                          \r\n                                        <span\r\n                                            class=\"week-font\"> vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                                    </span>\r\n                            </footer>-->\r\n                                    </div>\r\n                                  </ng-template> \r\n                                <div class=\"card-body p-0\">\r\n                            <div class=\"h-100px pt-10 px-3 row\">\r\n                                <span class=\"h-50px col-md-3\">\r\n                                    <svg class=\"cursor-pointer\" *ngIf=\"conversionValue !=='footfall'\" placement=\"top\" \r\n                                    ngbTooltip=\"Footfall\"\r\n                                    (click)=\"changeValue('footfall')\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path\r\n                                            d=\"M4 18H9.5V19.25C9.5 19.9793 9.21027 20.6788 8.69454 21.1945C8.17882 21.7103 7.47935 22 6.75 22C6.02065 22 5.32118 21.7103 4.80546 21.1945C4.28973 20.6788 4 19.9793 4 19.25V18ZM8 6.11999C10 6.11999 11 8.99999 11 11C11 12 10.5 13 10 14.5L9.5 16H4C4 15 3.5 13.5 3.5 11C3.5 8.49999 5.498 6.11999 8 6.11999ZM20.054 14.098L19.837 15.329C19.7023 16.0396 19.2931 16.6686 18.698 17.0796C18.1029 17.4907 17.3698 17.6508 16.6576 17.5252C15.9453 17.3996 15.3111 16.9984 14.8925 16.4086C14.4739 15.8188 14.3045 15.0878 14.421 14.374L14.637 13.144L20.054 14.098ZM18.178 1.70499C20.642 2.13899 22.196 4.82999 21.762 7.29199C21.328 9.75399 20.575 11.144 20.402 12.129L14.985 11.174L14.753 9.60999C14.521 8.04599 14.203 6.97399 14.376 5.98999C14.723 4.01999 16.208 1.35799 18.178 1.70499Z\"\r\n                                            fill=\"#98A2B3\" />\r\n                                    </svg>\r\n                                    <svg placement=\"top\" ngbTooltip=\"Footfall\" *ngIf=\"conversionValue ==='footfall'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path d=\"M4 18H9.5V19.25C9.5 19.9793 9.21027 20.6788 8.69454 21.1945C8.17882 21.7103 7.47935 22 6.75 22C6.02065 22 5.32118 21.7103 4.80546 21.1945C4.28973 20.6788 4 19.9793 4 19.25V18ZM8 6.11999C10 6.11999 11 8.99999 11 11C11 12 10.5 13 10 14.5L9.5 16H4C4 15 3.5 13.5 3.5 11C3.5 8.49999 5.498 6.11999 8 6.11999ZM20.054 14.098L19.837 15.329C19.7023 16.0396 19.2931 16.6686 18.698 17.0796C18.1029 17.4907 17.3698 17.6508 16.6576 17.5252C15.9453 17.3996 15.3111 16.9984 14.8925 16.4086C14.4739 15.8188 14.3045 15.0878 14.421 14.374L14.637 13.144L20.054 14.098ZM18.178 1.70499C20.642 2.13899 22.196 4.82999 21.762 7.29199C21.328 9.75399 20.575 11.144 20.402 12.129L14.985 11.174L14.753 9.60999C14.521 8.04599 14.203 6.97399 14.376 5.98999C14.723 4.01999 16.208 1.35799 18.178 1.70499Z\" fill=\"#00A3FF\"/>\r\n                                      </svg>\r\n                                </span>\r\n                                <span class=\"h-50px col-md-3\">\r\n                                    <svg placement=\"top\" [ngbTooltip]=\"headerData?.client === '452' ? 'More than '+ featureConfig?.bouncedLimit.value +' mins' : 'Engagers'\" class=\"cursor-pointer\" *ngIf=\"conversionValue !=='engagers'\" (click)=\"changeValue('engagers')\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path \r\n                                            d=\"M17 21V19C17 17.9391 16.5786 16.9217 15.8284 16.1716C15.0783 15.4214 14.0609 15 13 15H5C3.93913 15 2.92172 15.4214 2.17157 16.1716C1.42143 16.9217 1 17.9391 1 19V21M23 21V19C22.9993 18.1137 22.7044 17.2528 22.1614 16.5523C21.6184 15.8519 20.8581 15.3516 20 15.13M16 3.13C16.8604 3.3503 17.623 3.8507 18.1676 4.55231C18.7122 5.25392 19.0078 6.11683 19.0078 7.005C19.0078 7.89317 18.7122 8.75608 18.1676 9.45769C17.623 10.1593 16.8604 10.6597 16 10.88M13 7C13 9.20914 11.2091 11 9 11C6.79086 11 5 9.20914 5 7C5 4.79086 6.79086 3 9 3C11.2091 3 13 4.79086 13 7Z\"\r\n                                            stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                    </svg>\r\n                                    <svg placement=\"top\" [ngbTooltip]=\"headerData?.client === '452' ? 'More than '+ featureConfig?.bouncedLimit.value +' mins' : 'Engagers'\" *ngIf=\"conversionValue ==='engagers'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path d=\"M17 21V19C17 17.9391 16.5786 16.9217 15.8284 16.1716C15.0783 15.4214 14.0609 15 13 15H5C3.93913 15 2.92172 15.4214 2.17157 16.1716C1.42143 16.9217 1 17.9391 1 19V21M23 21V19C22.9993 18.1137 22.7044 17.2528 22.1614 16.5523C21.6184 15.8519 20.8581 15.3516 20 15.13M16 3.13C16.8604 3.3503 17.623 3.8507 18.1676 4.55231C18.7122 5.25392 19.0078 6.11683 19.0078 7.005C19.0078 7.89317 18.7122 8.75608 18.1676 9.45769C17.623 10.1593 16.8604 10.6597 16 10.88M13 7C13 9.20914 11.2091 11 9 11C6.79086 11 5 9.20914 5 7C5 4.79086 6.79086 3 9 3C11.2091 3 13 4.79086 13 7Z\" stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                        </svg>\r\n                                </span>\r\n                                <span *ngIf=\"headerData?.client !== '452'\" class=\"h-50px col-md-3\">\r\n                                    <svg placement=\"top\" ngbTooltip=\"Potential Buyers\" class=\"cursor-pointer\" *ngIf=\"conversionValue !=='Potential Buyers'\" (click)=\"changeValue('potentialBuyers')\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path opacity=\"0.3\"\r\n                                            d=\"M20.0039 18.002H4.00391C3.40391 18.002 3.00391 17.602 3.00391 17.002V7.00195C3.00391 6.40195 3.40391 6.00195 4.00391 6.00195H20.0039C20.6039 6.00195 21.0039 6.40195 21.0039 7.00195V17.002C21.0039 17.602 20.6039 18.002 20.0039 18.002ZM12.0039 8.00195C10.3039 8.00195 9.00391 9.80195 9.00391 12.002C9.00391 14.202 10.3039 16.002 12.0039 16.002C13.7039 16.002 15.0039 14.202 15.0039 12.002C15.0039 9.80195 13.7039 8.00195 12.0039 8.00195Z\"\r\n                                            fill=\"#98A2B3\" />\r\n                                        <path\r\n                                            d=\"M18.0039 6.00195H20.0039C20.6039 6.00195 21.0039 6.40195 21.0039 7.00195V9.00195C19.3039 9.00195 18.0039 7.70195 18.0039 6.00195ZM6.00391 6.00195H4.00391C3.40391 6.00195 3.00391 6.40195 3.00391 7.00195V9.00195C4.70391 9.00195 6.00391 7.70195 6.00391 6.00195ZM21.0039 17.002V15.002C19.3039 15.002 18.0039 16.302 18.0039 18.002H20.0039C20.6039 18.002 21.0039 17.602 21.0039 17.002ZM3.00391 15.002V17.002C3.00391 17.602 3.40391 18.002 4.00391 18.002H6.00391C6.00391 16.302 4.70391 15.002 3.00391 15.002Z\"\r\n                                            fill=\"#98A2B3\" />\r\n                                    </svg>\r\n                                    <svg placement=\"top\" ngbTooltip=\"Potential Buyers\" *ngIf=\"conversionValue ==='Potential Buyers'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path opacity=\"0.3\" d=\"M20.0039 18.002H4.00391C3.40391 18.002 3.00391 17.602 3.00391 17.002V7.00195C3.00391 6.40195 3.40391 6.00195 4.00391 6.00195H20.0039C20.6039 6.00195 21.0039 6.40195 21.0039 7.00195V17.002C21.0039 17.602 20.6039 18.002 20.0039 18.002ZM12.0039 8.00195C10.3039 8.00195 9.00391 9.80195 9.00391 12.002C9.00391 14.202 10.3039 16.002 12.0039 16.002C13.7039 16.002 15.0039 14.202 15.0039 12.002C15.0039 9.80195 13.7039 8.00195 12.0039 8.00195Z\" fill=\"#00A3FF\"/>\r\n                                        <path d=\"M18.0039 6.00195H20.0039C20.6039 6.00195 21.0039 6.40195 21.0039 7.00195V9.00195C19.3039 9.00195 18.0039 7.70195 18.0039 6.00195ZM6.00391 6.00195H4.00391C3.40391 6.00195 3.00391 6.40195 3.00391 7.00195V9.00195C4.70391 9.00195 6.00391 7.70195 6.00391 6.00195ZM21.0039 17.002V15.002C19.3039 15.002 18.0039 16.302 18.0039 18.002H20.0039C20.6039 18.002 21.0039 17.602 21.0039 17.002ZM3.00391 15.002V17.002C3.00391 17.602 3.40391 18.002 4.00391 18.002H6.00391C6.00391 16.302 4.70391 15.002 3.00391 15.002Z\" fill=\"#00A3FF\"/>\r\n                                        </svg>\r\n                                </span>\r\n                                <span class=\"h-50px col-md-3\">\r\n                                    <svg placement=\"top\" ngbTooltip=\"NoB Derived\" class=\"cursor-pointer\" *ngIf=\"conversionValue !=='NoB Derived'\" (click)=\"changeValue('NoB Derived')\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path opacity=\"0.3\"\r\n                                            d=\"M18.0039 21.6005C16.3039 21.6005 15.0039 20.3005 15.0039 18.6005V2.5005C15.0039 2.2005 14.6039 2.00045 14.3039 2.20045L13.0039 3.60048L11.7039 2.30049C11.3039 1.90049 10.7039 1.90049 10.3039 2.30049L9.00391 3.60048L7.70392 2.30049C7.30392 1.90049 6.7039 1.90049 6.3039 2.30049L5.00391 3.60048L3.70392 2.30049C3.50392 2.10049 3.00391 2.2005 3.00391 3.5005V18.6005C3.00391 20.3005 4.30391 21.6005 6.00391 21.6005H18.0039Z\"\r\n                                            fill=\"#98A2B3\" />\r\n                                        <path\r\n                                            d=\"M12.0059 12.5972H11.0059C10.4059 12.5972 10.0059 12.1972 10.0059 11.5972C10.0059 10.9972 10.4059 10.5972 11.0059 10.5972H12.0059C12.6059 10.5972 13.0059 10.9972 13.0059 11.5972C13.0059 12.1972 12.6059 12.5972 12.0059 12.5972ZM9.00586 11.5972C9.00586 10.9972 8.60586 10.5972 8.00586 10.5972H6.00586C5.40586 10.5972 5.00586 10.9972 5.00586 11.5972C5.00586 12.1972 5.40586 12.5972 6.00586 12.5972H8.00586C8.60586 12.5972 9.00586 12.1972 9.00586 11.5972ZM9.00586 7.59717C9.00586 6.99717 8.60586 6.59717 8.00586 6.59717H6.00586C5.40586 6.59717 5.00586 6.99717 5.00586 7.59717C5.00586 8.19717 5.40586 8.59717 6.00586 8.59717H8.00586C8.60586 8.59717 9.00586 8.19717 9.00586 7.59717ZM13.0059 7.59717C13.0059 6.99717 12.6059 6.59717 12.0059 6.59717H11.0059C10.4059 6.59717 10.0059 6.99717 10.0059 7.59717C10.0059 8.19717 10.4059 8.59717 11.0059 8.59717H12.0059C12.6059 8.59717 13.0059 8.19717 13.0059 7.59717ZM13.0059 15.5972C13.0059 14.9972 12.6059 14.5972 12.0059 14.5972H10.0059C9.40586 14.5972 9.00586 14.9972 9.00586 15.5972C9.00586 16.1972 9.40586 16.5972 10.0059 16.5972H12.0059C12.6059 16.5972 13.0059 16.1972 13.0059 15.5972Z\"\r\n                                            fill=\"#98A2B3\" />\r\n                                        <path\r\n                                            d=\"M15.002 18.5971C15.002 20.2971 16.302 21.5971 18.002 21.5971C19.702 21.5971 21.002 20.2971 21.002 18.5971V12.4971C21.002 12.1971 20.602 11.9971 20.302 12.1971L19.002 13.5971L17.702 12.2971C17.302 11.8971 16.702 11.8971 16.302 12.2971L15.002 13.5971V18.5971Z\"\r\n                                            fill=\"#98A2B3\" />\r\n                                    </svg>\r\n                                    <svg placement=\"top\" ngbTooltip=\"NoB Derived\" *ngIf=\"conversionValue ==='NoB Derived'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                        <path opacity=\"0.3\"\r\n                                            d=\"M18.0039 21.6005C16.3039 21.6005 15.0039 20.3005 15.0039 18.6005V2.5005C15.0039 2.2005 14.6039 2.00045 14.3039 2.20045L13.0039 3.60048L11.7039 2.30049C11.3039 1.90049 10.7039 1.90049 10.3039 2.30049L9.00391 3.60048L7.70392 2.30049C7.30392 1.90049 6.7039 1.90049 6.3039 2.30049L5.00391 3.60048L3.70392 2.30049C3.50392 2.10049 3.00391 2.2005 3.00391 3.5005V18.6005C3.00391 20.3005 4.30391 21.6005 6.00391 21.6005H18.0039Z\"\r\n                                            fill=\"#00A3FF\" />\r\n                                        <path\r\n                                            d=\"M12.0059 12.5972H11.0059C10.4059 12.5972 10.0059 12.1972 10.0059 11.5972C10.0059 10.9972 10.4059 10.5972 11.0059 10.5972H12.0059C12.6059 10.5972 13.0059 10.9972 13.0059 11.5972C13.0059 12.1972 12.6059 12.5972 12.0059 12.5972ZM9.00586 11.5972C9.00586 10.9972 8.60586 10.5972 8.00586 10.5972H6.00586C5.40586 10.5972 5.00586 10.9972 5.00586 11.5972C5.00586 12.1972 5.40586 12.5972 6.00586 12.5972H8.00586C8.60586 12.5972 9.00586 12.1972 9.00586 11.5972ZM9.00586 7.59717C9.00586 6.99717 8.60586 6.59717 8.00586 6.59717H6.00586C5.40586 6.59717 5.00586 6.99717 5.00586 7.59717C5.00586 8.19717 5.40586 8.59717 6.00586 8.59717H8.00586C8.60586 8.59717 9.00586 8.19717 9.00586 7.59717ZM13.0059 7.59717C13.0059 6.99717 12.6059 6.59717 12.0059 6.59717H11.0059C10.4059 6.59717 10.0059 6.99717 10.0059 7.59717C10.0059 8.19717 10.4059 8.59717 11.0059 8.59717H12.0059C12.6059 8.59717 13.0059 8.19717 13.0059 7.59717ZM13.0059 15.5972C13.0059 14.9972 12.6059 14.5972 12.0059 14.5972H10.0059C9.40586 14.5972 9.00586 14.9972 9.00586 15.5972C9.00586 16.1972 9.40586 16.5972 10.0059 16.5972H12.0059C12.6059 16.5972 13.0059 16.1972 13.0059 15.5972Z\"\r\n                                            fill=\"#00A3FF\" />\r\n                                        <path\r\n                                            d=\"M15.002 18.5971C15.002 20.2971 16.302 21.5971 18.002 21.5971C19.702 21.5971 21.002 20.2971 21.002 18.5971V12.4971C21.002 12.1971 20.602 11.9971 20.302 12.1971L19.002 13.5971L17.702 12.2971C17.302 11.8971 16.702 11.8971 16.302 12.2971L15.002 13.5971V18.5971Z\"\r\n                                            fill=\"#00A3FF\" />\r\n                                    </svg>\r\n                                    </span>\r\n                            </div>\r\n                                </div>\r\n                                <div class=\"card-footer ms-3 p-0\">\r\n                                    <div class=\"col-md-12\">\r\n                                        <div class=\"row pe-0\">\r\n                                        <span class=\"mt-2 col-md-1\">\r\n                                            <svg *ngIf=\"(conversionValue ==='footfall' && !getConversionCardData?.conversion?.footfall.PreviousVariation) || (conversionValue ==='engagers' && !getConversionCardData?.conversion?.engagers.PreviousVariation) || (conversionValue ==='Potential Buyers' && !getConversionCardData?.conversion?.potentialBuyers.PreviousVariation) || (conversionValue ==='NoB Derived' && !getConversionCardData?.conversion?.nob.PreviousVariation)\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                            height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                                <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <clipPath id=\"clip0_2328_4654\">\r\n                                                    <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                </clipPath>\r\n                                            </defs>\r\n                                        </svg>\r\n                                        <svg *ngIf=\"(conversionValue ==='footfall' && getConversionCardData?.conversion?.footfall.PreviousVariation) || (conversionValue ==='engagers' && getConversionCardData?.conversion?.engagers.PreviousVariation) || (conversionValue ==='Potential Buyers' && getConversionCardData?.conversion?.potentialBuyers.PreviousVariation) || (conversionValue ==='NoB Derived' && getConversionCardData?.conversion?.nob.PreviousVariation)\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                            viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_3216_118)\">\r\n                                                <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <clipPath id=\"clip0_3216_118\">\r\n                                                    <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                </clipPath>\r\n                                            </defs>\r\n                                        </svg>\r\n                                        </span>\r\n                                       \r\n                                        <span class=\"mt-2 col-md-9 pe-0\">\r\n                                            <span *ngIf=\"conversionValue ==='footfall' && getConversionCardData?.conversion?.footfall.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                            <span *ngIf=\"conversionValue ==='footfall' && getConversionCardData?.conversion?.footfall.PreviousData !==0\" class=\"percent-value\">{{getConversionCardData?.conversion?.footfall.PreviousData ? getConversionCardData?.conversion?.footfall.PreviousData:'--'}}%</span>\r\n                                            <span *ngIf=\"conversionValue ==='engagers' && getConversionCardData?.conversion?.engagers.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                          \r\n                                            <span *ngIf=\"conversionValue ==='engagers' && getConversionCardData?.conversion?.engagers.PreviousData !==0\" class=\"percent-value\">{{getConversionCardData?.conversion?.engagers.PreviousData ? getConversionCardData?.conversion?.engagers.PreviousData:'--'}}%</span>\r\n\r\n                                            <span *ngIf=\"conversionValue ==='Potential Buyers' && getConversionCardData?.conversion?.potentialBuyers.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                            <span *ngIf=\"conversionValue ==='Potential Buyers' && getConversionCardData?.conversion?.potentialBuyers.PreviousData !==0\" class=\"percent-value\">{{getConversionCardData?.conversion?.potentialBuyers.PreviousData ? getConversionCardData?.conversion?.potentialBuyers.PreviousData:'--'}}%</span>\r\n                                            <span *ngIf=\"conversionValue ==='NoB Derived' && getConversionCardData?.conversion?.nob.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                            <span *ngIf=\"conversionValue ==='NoB Derived' && getConversionCardData?.conversion?.nob.PreviousData !==0\" class=\"percent-value\">{{getConversionCardData?.conversion?.nob.PreviousData ? getConversionCardData?.conversion?.nob.PreviousData:'--'}}%</span>\r\n                                            <!-- <span *ngIf=\"conversionValue ==='NoB Derived'\" class=\"percent-value\">--%</span> -->\r\n                                            <!-- <span *ngIf=\"conversionValue ==='' && getConversionCardData?.conversion?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n\r\n                                                <span *ngIf=\"conversionValue ==='' && getConversionCardData?.conversion?.PreviousData !==0\"  class=\"percent-value\">{{getCardGraphData?.conversion?.PreviousData ? getCardGraphData?.conversion?.PreviousData:'--'}}%</span> -->\r\n                              \r\n                                            <span\r\n                                                class=\"week-font\"> vs Previous <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                                        </span>\r\n                                        <span *ngIf=\"clientData?.featureConfigs?.isNOB && conversionValue ==='NoB Derived'\" class=\"col-md-2 px-0 cursor-pointer\" (click)=\"nobUpload()\"><svg placement=\"top\" ngbTooltip=\"Upload NoB\" width=\"32\" height=\"32\" viewBox=\"0 0 32 32\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <g filter=\"url(#filter0_d_6160_4394)\">\r\n                                            <rect x=\"2\" y=\"1\" width=\"28\" height=\"28\" rx=\"6.22222\" fill=\"#EAF8FF\"/>\r\n                                            <rect x=\"2.38889\" y=\"1.38889\" width=\"27.2222\" height=\"27.2222\" rx=\"5.83333\" stroke=\"#EAF8FF\" stroke-width=\"0.777778\"/>\r\n                                            <g clip-path=\"url(#clip0_6160_4394)\">\r\n                                            <path d=\"M18.5929 17.5926L16.0003 15M16.0003 15L13.4077 17.5926M16.0003 15V20.8333M21.4382 19.1417C22.0704 18.797 22.5698 18.2517 22.8576 17.5917C23.1454 16.9317 23.2052 16.1947 23.0276 15.4969C22.85 14.7992 22.4451 14.1804 21.8768 13.7384C21.3085 13.2963 20.6092 13.056 19.8892 13.0556H19.0725C18.8763 12.2967 18.5107 11.5923 18.003 10.9951C17.4954 10.3979 16.859 9.92362 16.1416 9.60782C15.4243 9.29201 14.6447 9.14293 13.8615 9.17179C13.0782 9.20065 12.3117 9.40669 11.6196 9.77443C10.9274 10.1422 10.3276 10.662 9.86531 11.2949C9.40299 11.9278 9.09016 12.6573 8.95035 13.4285C8.81054 14.1997 8.84738 14.9926 9.0581 15.7475C9.26881 16.5024 9.64793 17.1997 10.1669 17.7871\" stroke=\"#009BF3\" stroke-width=\"1.29889\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </g>\r\n                                            </g>\r\n                                            <defs>\r\n                                            <filter id=\"filter0_d_6160_4394\" x=\"0.444444\" y=\"0.222222\" width=\"31.1111\" height=\"31.1111\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n                                            <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\r\n                                            <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\r\n                                            <feOffset dy=\"0.777778\"/>\r\n                                            <feGaussianBlur stdDeviation=\"0.777778\"/>\r\n                                            <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\"/>\r\n                                            <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_6160_4394\"/>\r\n                                            <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_6160_4394\" result=\"shape\"/>\r\n                                            </filter>\r\n                                            <clipPath id=\"clip0_6160_4394\">\r\n                                            <rect width=\"15.5556\" height=\"15.5556\" fill=\"white\" transform=\"translate(8.22266 7.22223)\"/>\r\n                                            </clipPath>\r\n                                            </defs>\r\n                                            </svg></span>\r\n                                            </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n\r\n                        </div>\r\n                       \r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-4\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"card-header ellipse1 border-0 px-3\"  [ngbTooltip]=\"bouncedTooltip\" placement=\"right\">\r\n                        <!-- -->\r\n                        <h3 class=\"card-title align-items-start flex-column \">\r\n                            <span class=\"card-label header\">{{getBouncedCardData?.card?.bounced?.rate ? getBouncedCardData?.card?.bounced?.rate :'--'}}%</span>\r\n                            <span class=\"sub-header\"><span *ngIf=\"headerData?.client !== '452'\">Bounced </span> <span *ngIf=\"headerData?.client === '452'\">Less than {{clientData?.featureConfigs?.bouncedLimit?.value}} mins </span> Rate</span>\r\n                        </h3>\r\n                    </div>\r\n                    <ng-template #bouncedTooltip>\r\n                        <div class=\"tooltip-content\">\r\n                          <h5 class=\"tooltip-title text-start\" *ngIf=\"headerData?.client !== '452'\">Bounced Rate</h5>\r\n                          <p class=\"text-start\">Total walk-ins who spent less than {{clientData?.featureConfigs?.bouncedLimit?.value}} mins.</p>\r\n                       \r\n                        </div>\r\n                      </ng-template>\r\n                    <div class=\"card-body p-0\">\r\n                        <div *ngIf=\"bouncedNodata\" class=\"row\">\r\n                            <div class=\"col-lg-12 mb-3\">\r\n                                <div class=\"card-body pb-0 px-0 d-flex justify-content-center align-items-center flex-column\">\r\n                                    <img class=\"img-nodata1\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                    <div class=\"nodata-title1\">No data found</div>\r\n                                    <!-- <div class=\"nodata-sub\">There is no result for this conversion funnel</div> -->\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"!bouncedNodata\" class=\"text-center\" id=\"BouncedRate\"></div>\r\n                    </div>\r\n                    <div class=\"card-footer ms-2 p-0\">\r\n                        <div class=\"col-md-12\">\r\n                            <span class=\"mt-2\">\r\n                                <svg *ngIf=\"!getBouncedCardData?.data?.bounced?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                    <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <clipPath id=\"clip0_2328_4654\">\r\n                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                    </clipPath>\r\n                                </defs>\r\n                            </svg>\r\n                            <svg *ngIf=\"getBouncedCardData?.data?.bounced?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                <g clip-path=\"url(#clip0_3216_118)\">\r\n                                    <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <clipPath id=\"clip0_3216_118\">\r\n                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                    </clipPath>\r\n                                </defs>\r\n                            </svg>\r\n                            </span>\r\n                            <span class=\"mt-2 ms-2\">\r\n                                <span *ngIf=\"getBouncedCardData?.data?.bounced?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                <span *ngIf=\"getBouncedCardData?.data?.bounced?.PreviousData !==0\" class=\"percent-value\">{{getBouncedCardData?.data?.bounced?.PreviousData ? getBouncedCardData?.data?.bounced?.PreviousData:'--'}}%</span>\r\n                                <span class=\"week-font\">\r\n                                    vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                            </span>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-4 mt-3\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"card-header ellipse1 border-0 px-3\"  [ngbTooltip]=\"engagersTooltip\" placement=\"right\">\r\n                        <!--  -->\r\n                        <h3 class=\"card-title align-items-start flex-column \" >\r\n                            <span class=\"card-label header\">{{getEngagersCardData?.card?.engagers?.rate ? getEngagersCardData?.card?.engagers?.rate :'--'}}%</span>\r\n                            <span class=\"sub-header\"><span *ngIf=\"headerData?.client !== '452'\">Engagers</span> <span *ngIf=\"headerData?.client === '452'\">More than {{clientData?.featureConfigs?.bouncedLimit?.value}} mins</span> Rate</span>\r\n                        </h3>\r\n                    </div>\r\n                    <ng-template #engagersTooltip>\r\n                        <div class=\"tooltip-content\">\r\n                          <h5 class=\"tooltip-title text-start\" *ngIf=\"headerData?.client !== '452'\">Engagers Rate</h5>\r\n                          <p class=\"text-start\">Total walk-ins who spent more than {{clientData?.featureConfigs?.bouncedLimit?.value}} mins into the selected stores.</p>                        \r\n                        </div>\r\n                      </ng-template>\r\n                    <div class=\"card-body p-0\">\r\n                        <div *ngIf=\"engagersNodata\" class=\"row\">\r\n                            <div class=\"col-lg-12 mb-3\">\r\n                                <div class=\"card-body pb-0 px-0 d-flex justify-content-center align-items-center flex-column\">\r\n                                    <img class=\"img-nodata1\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                    <div class=\"nodata-title1\">No data found</div>\r\n                                    <!-- <div class=\"nodata-sub\">There is no result for this conversion funnel</div> -->\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"!engagersNodata\" class=\"text-center\" id=\"engagers\"></div>\r\n                    </div>\r\n                    <div class=\"card-footer ms-2 p-0\">\r\n                        <div class=\"col-md-12\">\r\n                            <span class=\"mt-2\">\r\n                                <svg *ngIf=\"!getEngagersCardData?.data?.engagers?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                    height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                    <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                        <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                            stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                    </g>\r\n                                    <defs>\r\n                                        <clipPath id=\"clip0_2328_4654\">\r\n                                            <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                        </clipPath>\r\n                                    </defs>\r\n                                </svg>\r\n                                <svg *ngIf=\"getEngagersCardData?.data?.engagers?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                    viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                    <g clip-path=\"url(#clip0_3216_118)\">\r\n                                        <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                            stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                    </g>\r\n                                    <defs>\r\n                                        <clipPath id=\"clip0_3216_118\">\r\n                                            <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                        </clipPath>\r\n                                    </defs>\r\n                                </svg>\r\n                            </span>\r\n                            <span class=\"mt-2 ms-2\">\r\n                                <span *ngIf=\"getEngagersCardData?.data?.engagers?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                <span *ngIf=\"getEngagersCardData?.data?.engagers?.PreviousData !==0\" class=\"percent-value\">{{getEngagersCardData?.data?.engagers?.PreviousData ? getEngagersCardData?.data?.engagers?.PreviousData:'--'}}%</span>\r\n                                <span class=\"week-font\">\r\n                                    vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                            </span>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-4 mt-3\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div *ngIf=\"headerData?.client === '452'\" class=\"card-header ellipse1 border-0 px-3\" > \r\n                        <h3 class=\"card-title align-items-start flex-column\"  >\r\n                            <span class=\"card-label header\">{{getMissedOpportunityData?.card?.missedopportunities?.rate ? getMissedOpportunityData?.card?.missedopportunities?.rate :'--'}}%</span>\r\n                            <span class=\"sub-header\"><span *ngIf=\"headerData?.client !== '452'\">Missed Opportunities</span><span *ngIf=\"headerData?.client === '452'\">{{clientData?.featureConfigs?.missedOpportunityFrom?.value}} - {{clientData?.featureConfigs?.missedOpportunityTo?.value}} mins</span></span>\r\n                        </h3>\r\n                    </div>\r\n                    <div *ngIf=\"headerData?.client !== '452'\" class=\"card-header ellipse1 border-0 px-3\" [ngbTooltip]=\"missedTooltip\" placement=\"right\"> \r\n                        <h3 class=\"card-title align-items-start flex-column\"  >\r\n                            <span class=\"card-label header\">{{getMissedOpportunityData?.card?.missedopportunities?.rate ? getMissedOpportunityData?.card?.missedopportunities?.rate :'--'}}%</span>\r\n                            <span class=\"sub-header\"><span *ngIf=\"headerData?.client !== '452'\">Missed Opportunities</span><span *ngIf=\"headerData?.client === '452'\">{{clientData?.featureConfigs?.missedOpportunityFrom?.value}} - {{clientData?.featureConfigs?.missedOpportunityTo?.value}} mins</span></span>\r\n                        </h3>\r\n                    </div>\r\n                    <ng-template #missedTooltip>\r\n                        <div class=\"tooltip-content\">\r\n                          <h5 class=\"tooltip-title text-start\" *ngIf=\"headerData?.client !== '452'\">Missed Opportunities</h5>\r\n                        <p *ngIf=\"headerData?.client !== '452'\" class=\"text-start\">The difference between <span *ngIf=\"clientData?.featureConfigs?.missedOpportunityCalculation === 'engagers-conversion' || \r\n                                                    clientData?.featureConfigs?.missedOpportunityCalculation === 'group-conversion'\">\r\n                                {{ clientData?.featureConfigs?.missedOpportunityCalculation === 'engagers-conversion' ? 'engagers and conversions,' : 'potential and conversions,' }}\r\n                            </span>\r\n                            showing potential loss.</p>\r\n                        <p *ngIf=\"headerData?.client === '452'\" class=\"text-start\">The difference between <span *ngIf=\"clientData?.featureConfigs?.missedOpportunityCalculation === 'engagers-conversion' || \r\n                            clientData?.featureConfigs?.missedOpportunityCalculation === 'group-conversion'\">\r\n                            {{\r\n                                clientData?.featureConfigs?.missedOpportunityCalculation === 'engagers-conversion'\r\n                                  ? ('More than ' + featureConfig?.bouncedLimit?.value + ' mins and More than ' + featureConfig?.conversion?.value + ' mins')\r\n                                  : ('potential and More than '+ featureConfig?.conversion?.value+ ' mins')\r\n                              }}\r\n                        </span>\r\n                        showing potential loss.</p>\r\n                         \r\n                        </div>\r\n                      </ng-template>\r\n                    <div class=\"card-body p-0 h-90px mt-3 mx-3\">\r\n                        <div *ngIf=\"headerData?.client !=='452'\" class=\"row\">\r\n                         <div class=\"col-md-9\"><!--{{getCardData?.revenue?.value ?? '--'}} -->\r\n                        <div class=\"my-2\" *ngIf=\"getMissedOpportunityData?.card?.revenue?.currency ==='dollar'\"><span class=\"card-label header\"><span class=\"me-1\">$</span> {{getMissedOpportunityData?.card?.revenue?.value.toLocaleString('en-IN') ?? '--'}}</span></div>\r\n                        <div class=\"my-2\" *ngIf=\"getMissedOpportunityData?.card?.revenue?.currency ==='aed'\"> <span class=\"card-label header\"><span class=\"me-1\">د.إ</span> {{getMissedOpportunityData?.card?.revenue?.value.toLocaleString('en-IN') ?? '--'}}</span></div>  \r\n                        <div class=\"my-2\" *ngIf=\"getMissedOpportunityData?.card?.revenue?.currency ==='inr'\"> <span class=\"card-label header1\"  [ngStyle]=\"{\r\n                                    'font-size': (getMissedOpportunityData?.card?.revenue?.value.toLocaleString('en-IN')?.length > 6 ? '18px' : '20px')}\"><span class=\"me-1\">₹</span>{{getMissedOpportunityData?.card?.revenue?.value.toLocaleString('en-IN') ?? '--'}}</span></div>\r\n                        <div class=\"my-1\"><span class=\"sub-header\" *ngIf=\"headerData?.client !== '452'\">Potential Loss Revenue</span></div>\r\n                        </div>\r\n                        <div class=\"col-md-3 mt-5\" ><svg class=\"cursor-pointer\" (click)=\"goToLoss()\"  xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\r\n                            <g filter=\"url(#filter0_d_3885_2531)\">\r\n                            <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"#EAF8FF\"/>\r\n                            <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#EAF8FF\"/>\r\n                            <g clip-path=\"url(#clip0_3885_2531)\">\r\n                            <path d=\"M27.4585 17.2251C27.8133 18.8556 27.6707 20.5614 27.0505 22.1027L25.8593 21.3838L26.017 26.097L30 23.8834L28.717 23.1086C30.7171 18.4823 29.0726 12.9333 24.7799 10.3407C23.3328 9.46633 21.6918 9.00406 20.0206 9.00003C18.3494 8.99599 16.7064 9.45033 15.2555 10.3177L16.2049 12.0544C17.5933 11.2249 19.1953 10.8712 20.7858 11.043C22.3764 11.2149 23.8754 11.9036 25.0723 13.0125C26.2692 14.1214 27.1037 15.5946 27.4585 17.2251Z\" fill=\"#00A3FF\"/>\r\n                            <path d=\"M12.5402 20.7759C12.1854 19.1452 12.3282 17.4392 12.9485 15.8978L14.1398 16.6167L13.982 11.9035L10 14.1181L11.283 14.8909C9.28199 19.5182 10.9264 25.0662 15.2192 27.6588C16.6661 28.5333 18.3071 28.9958 19.9783 29C21.6495 29.0042 23.2926 28.55 24.7435 27.6828L23.7951 25.9461C22.4067 26.776 20.8045 27.13 19.2138 26.9583C17.623 26.7867 16.1237 26.0979 14.9267 24.989C13.7296 23.88 12.895 22.4066 12.5402 20.7759Z\" fill=\"#00A3FF\"/>\r\n                            <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.0372 13.003C21.0372 12.5514 20.6871 12.1852 20.2552 12.1852C19.8234 12.1852 19.4733 12.5514 19.4733 13.003V14.3659H18.952C18.2607 14.3659 17.5978 14.653 17.109 15.1642C16.6201 15.6754 16.3455 16.3687 16.3455 17.0916C16.3455 17.8146 16.6201 18.5079 17.109 19.0191C17.5978 19.5302 18.2607 19.8174 18.952 19.8174H19.4733V21.998H17.1275C16.6956 21.998 16.3455 22.3641 16.3455 22.8158C16.3455 23.2674 16.6956 23.6335 17.1275 23.6335H19.4733V24.9964C19.4733 25.448 19.8234 25.8141 20.2552 25.8141C20.6871 25.8141 21.0372 25.448 21.0372 24.9964V23.6335H21.5585C22.2498 23.6335 22.9127 23.3463 23.4015 22.8351C23.8903 22.324 24.1649 21.6306 24.1649 20.9077C24.1649 20.1848 23.8903 19.4915 23.4015 18.9803C22.9127 18.4691 22.2498 18.182 21.5585 18.182H21.0372V16.0013H22.8617C23.2936 16.0013 23.6437 15.6352 23.6437 15.1836C23.6437 14.732 23.2936 14.3659 22.8617 14.3659H21.0372V13.003ZM18.952 16.0013H19.4733V18.182H18.952C18.6755 18.182 18.4103 18.0671 18.2148 17.8626C18.0193 17.6581 17.9094 17.3808 17.9094 17.0916C17.9094 16.8025 18.0193 16.5252 18.2148 16.3207C18.4103 16.1162 18.6755 16.0013 18.952 16.0013ZM21.0372 21.998V19.8174H21.5585C21.835 19.8174 22.1002 19.9323 22.2957 20.1368C22.4912 20.3412 22.6011 20.6186 22.6011 20.9077C22.6011 21.1969 22.4912 21.4742 22.2957 21.6787C22.1002 21.8832 21.835 21.998 21.5585 21.998H21.0372Z\" fill=\"#00A3FF\"/>\r\n                            </g>\r\n                            </g>\r\n                            <defs>\r\n                            <filter id=\"filter0_d_3885_2531\" x=\"0\" y=\"0\" width=\"40\" height=\"40\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n                            <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\r\n                            <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\r\n                            <feOffset dy=\"1\"/>\r\n                            <feGaussianBlur stdDeviation=\"1\"/>\r\n                            <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\"/>\r\n                            <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_3885_2531\"/>\r\n                            <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_3885_2531\" result=\"shape\"/>\r\n                            </filter>\r\n                            <clipPath id=\"clip0_3885_2531\">\r\n                            <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(10 9)\"/>\r\n                            </clipPath>\r\n                            </defs>\r\n                            </svg></div>\r\n                            </div>\r\n                    </div>\r\n                    <div class=\"card-footer ms-2 p-0\">\r\n                        <div class=\"col-md-12\">\r\n                            <span class=\"mt-2\">\r\n                                <svg *ngIf=\"!getMissedOpportunityData?.data?.missedopportunities?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                    <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <clipPath id=\"clip0_2328_4654\">\r\n                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                    </clipPath>\r\n                                </defs>\r\n                            </svg>\r\n                            <svg *ngIf=\"getMissedOpportunityData?.data?.missedopportunities?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                <g clip-path=\"url(#clip0_3216_118)\">\r\n                                    <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <clipPath id=\"clip0_3216_118\">\r\n                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                    </clipPath>\r\n                                </defs>\r\n                            </svg>\r\n                            </span>\r\n                            <span class=\"ms-2 mt-2\">\r\n                                <span *ngIf=\"getMissedOpportunityData?.data?.missedopportunities?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                <span *ngIf=\"getMissedOpportunityData?.data?.missedopportunities?.PreviousData !==0\" class=\"percent-value\">{{getMissedOpportunityData?.data?.missedopportunities?.PreviousData ? getMissedOpportunityData?.data?.missedopportunities?.PreviousData:'--'}}%</span>\r\n                            <span class=\"week-font\">\r\n                                    vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                            </span>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-4 mt-3 h-100\">\r\n                <div class=\"card card-border mb-5 py-0\">\r\n                    <div class=\"card-body p-0 h-90px mt-3 mx-3\" [ngbTooltip]=\"dwellTooltip\" placement=\"right\">\r\n                        <div class=\"d-flex align-items-center me-2\">\r\n                            <div class=\"mt-3 flex-shrink-0\">\r\n                                    <svg width=\"40\" height=\"41\" viewBox=\"0 0 40 41\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                                        <rect y=\"0.5\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\"/>\r\n                                        <path d=\"M17.6382 12.8922C17.6382 12.6835 17.7212 12.4833 17.8688 12.3357C18.0164 12.1881 18.2165 12.1052 18.4253 12.1052H21.5734C21.7822 12.1052 21.9823 12.1881 22.1299 12.3357C22.2775 12.4833 22.3605 12.6835 22.3605 12.8922C22.3605 13.1009 22.2775 13.3011 22.1299 13.4487C21.9823 13.5963 21.7822 13.6792 21.5734 13.6792H20.7864V14.7286L20.7853 14.7716C22.1156 14.9174 23.3767 15.4398 24.4204 16.2775L24.4277 16.2712L25.2148 15.4842C25.311 15.3806 25.4333 15.3048 25.569 15.2649C25.7046 15.2251 25.8485 15.2225 25.9855 15.2575C26.1224 15.2925 26.2474 15.3638 26.3472 15.4639C26.4471 15.564 26.5181 15.6892 26.5527 15.8263C26.5877 15.9631 26.5852 16.1068 26.5455 16.2423C26.5058 16.3778 26.4304 16.5002 26.3271 16.5965L25.5401 17.3836L25.5338 17.3909C26.3662 18.4331 26.8875 19.6891 27.0377 21.0144C27.1878 22.3397 26.9607 23.6805 26.3824 24.8825C25.8042 26.0845 24.8983 27.0987 23.7691 27.8086C22.6399 28.5184 21.3332 28.895 19.9993 28.895C18.6655 28.895 17.3588 28.5184 16.2296 27.8086C15.1004 27.0987 14.1945 26.0845 13.6163 24.8825C13.038 23.6805 12.8109 22.3397 12.961 21.0144C13.1112 19.6891 13.6325 18.4331 14.4649 17.3909L14.4586 17.3836L13.6716 16.5965C13.5324 16.4474 13.4566 16.25 13.4601 16.046C13.4636 15.842 13.5462 15.6473 13.6905 15.5031C13.8347 15.3588 14.0294 15.2762 14.2334 15.2727C14.4374 15.2692 14.6348 15.345 14.7839 15.4842L15.571 16.2712L15.5783 16.2775C16.6217 15.44 17.8824 14.9176 19.2123 14.7716V13.6792H18.4253C18.2165 13.6792 18.0164 13.5963 17.8688 13.4487C17.7212 13.3011 17.6382 13.1009 17.6382 12.8922ZM19.9993 27.3212C21.4606 27.3211 22.862 26.7404 23.8952 25.7071C24.9284 24.6737 25.5087 23.2722 25.5086 21.8109C25.5085 20.3496 24.9278 18.9482 23.8945 17.915C22.8611 16.8819 21.4596 16.3015 19.9983 16.3016C18.537 16.3018 17.1356 16.8824 16.1025 17.9158C15.0693 18.9492 14.4889 20.3507 14.489 21.8119C14.4892 23.2732 15.0698 24.6746 16.1032 25.7078C17.1366 26.741 18.5381 27.3213 19.9993 27.3212ZM20.4076 20.2903L21.8032 18.8947C21.8758 18.8195 21.9626 18.7595 22.0586 18.7182C22.1546 18.6769 22.2579 18.6551 22.3624 18.6542C22.4669 18.6532 22.5705 18.6731 22.6673 18.7126C22.764 18.7521 22.8519 18.8105 22.9259 18.8844C22.9998 18.9582 23.0583 19.0461 23.0979 19.1428C23.1375 19.2395 23.1575 19.3431 23.1566 19.4476C23.1557 19.5521 23.1341 19.6554 23.0929 19.7515C23.0517 19.8475 22.9918 19.9344 22.9166 20.007L21.521 21.4037C21.583 21.6371 21.5906 21.8815 21.5432 22.1182C21.4958 22.355 21.3948 22.5777 21.2478 22.7692C21.1008 22.9607 20.9118 23.1159 20.6953 23.2228C20.4789 23.3298 20.2408 23.3856 19.9993 23.386C19.7766 23.3841 19.5567 23.3349 19.3544 23.2416C19.1521 23.1483 18.9718 23.0131 18.8257 22.845C18.6795 22.6768 18.5707 22.4796 18.5066 22.2662C18.4424 22.0528 18.4243 21.8283 18.4534 21.6074C18.4825 21.3865 18.5582 21.1743 18.6755 20.9849C18.7928 20.7955 18.949 20.6332 19.1338 20.5086C19.3185 20.3841 19.5276 20.3003 19.7472 20.2626C19.9668 20.225 20.1919 20.2344 20.4076 20.2903Z\" fill=\"#667085\"/>\r\n                                        </svg>\r\n                            </div>\r\n                            <div class=\"mx-3 mt-1\" >\r\n                                <div class=\"my-1 card-label header\" *ngIf=\"getMissedOpportunityData?.card?.avgDwellTime === 0\">0 mins</div>\r\n                                <div class=\"my-1 card-label header\"  *ngIf=\"getMissedOpportunityData?.card?.avgDwellTime !== 0\">{{getMissedOpportunityData?.card?.avgDwellTime ? getMissedOpportunityData?.card?.avgDwellTime :'--'}} mins</div>\r\n                                <div class=\"sub-header\">Avg Dwell Time</div>\r\n                            </div>\r\n                            \r\n                        </div>\r\n                        \r\n                    </div>\r\n                    <ng-template #dwellTooltip>\r\n                        <div class=\"tooltip-content\">\r\n                          <h5 class=\"tooltip-title text-start\">Avg Dwell Time</h5>\r\n                          <p class=\"text-start\">Average time spent by {{headerData?.client === '452' ? 'More than '+ featureConfig?.bouncedLimit.value +' mins' : 'engagers'}} in the selected stores.</p>\r\n                          </div>\r\n                          </ng-template>\r\n                    </div>\r\n                    <div class=\"card card-border py-0\">\r\n                        <div class=\"card-body p-0 h-90px mt-3 mx-3\"  [ngbTooltip]=\"downTooltip\" placement=\"right\">\r\n                            <div class=\"d-flex align-items-center me-2\">\r\n                                <div class=\"flex-shrink-0 mt-3\">\r\n                                    <svg width=\"40\" height=\"41\" viewBox=\"0 0 40 41\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                                        <rect y=\"0.5\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\"/>\r\n                                        <path d=\"M21.9004 12.1675C22.9958 12.1675 24.0423 12.3918 24.9977 12.7987C25.9889 13.2207 26.8809 13.8402 27.6279 14.6087C28.3734 15.3756 28.9756 16.2931 29.3857 17.3162C29.7813 18.299 29.9993 19.3756 29.9993 20.5008C29.9993 21.6277 29.7813 22.7043 29.3857 23.6871C28.9756 24.7068 28.3734 25.6244 27.6263 26.3929C26.8809 27.1598 25.9889 27.7793 24.9945 28.2012C24.0391 28.6081 22.9925 28.8325 21.8988 28.8325C20.8034 28.8325 19.7568 28.6081 18.8014 28.2012C17.8102 27.7793 16.9183 27.1598 16.1729 26.3929L16.1712 26.3912C15.4242 25.6227 14.8236 24.7052 14.4134 23.6871C14.2865 23.3707 14.1774 23.0459 14.0879 22.7127C14.2572 22.7294 14.4297 22.7378 14.6038 22.7378C14.9342 22.7378 15.2565 22.7076 15.5706 22.649C15.6227 22.8098 15.6797 22.9688 15.7415 23.1246C16.0785 23.9617 16.5732 24.7152 17.1885 25.3481C17.8037 25.981 18.5378 26.49 19.3499 26.8366C20.1328 27.1698 20.9938 27.3557 21.8988 27.3557C22.8037 27.3557 23.6631 27.1715 24.4476 26.8366C25.2614 26.49 25.9938 25.981 26.6091 25.3481C27.2243 24.7152 27.7191 23.9601 28.056 23.1246C28.3799 22.3192 28.5605 21.4334 28.5605 20.5025C28.5605 19.5715 28.3815 18.6875 28.056 17.8804C27.7191 17.0432 27.2243 16.2898 26.6091 15.6569C25.9938 15.024 25.2598 14.5149 24.4476 14.1684C23.6647 13.8352 22.8037 13.6493 21.8988 13.6493C20.9938 13.6493 20.1344 13.8335 19.3499 14.1684C19.2799 14.1985 19.21 14.2303 19.1416 14.2621C18.8747 13.8301 18.5524 13.4383 18.1829 13.0984C18.3848 12.9913 18.5915 12.8925 18.8014 12.8021C19.7601 12.3918 20.805 12.1675 21.9004 12.1675ZM20.971 16.5393C20.971 16.335 21.0524 16.1508 21.181 16.0169C21.3112 15.8829 21.4902 15.8009 21.6888 15.8009C21.8874 15.8009 22.0664 15.8829 22.1966 16.0169C22.3268 16.1508 22.4066 16.335 22.4066 16.5393V20.4271L25.2305 22.1501C25.3997 22.2539 25.5137 22.4196 25.5592 22.6021C25.6048 22.7847 25.5837 22.9856 25.4827 23.1597V23.1614C25.3818 23.3355 25.2207 23.4527 25.0433 23.4996C24.8659 23.5465 24.6706 23.5247 24.5013 23.4209H24.4997L21.3405 21.4937C21.2314 21.4318 21.1419 21.3413 21.0768 21.2342C21.0101 21.122 20.971 20.9897 20.971 20.8491V16.5393Z\" fill=\"#667085\"/>\r\n                                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M14.3913 12.6095C16.8164 12.6095 18.7826 14.6321 18.7826 17.1269C18.7826 19.6218 16.8164 21.6444 14.3913 21.6444C11.9661 21.6444 10 19.6218 10 17.1269C10 14.6321 11.9661 12.6095 14.3913 12.6095ZM14.3913 19.7172L16.748 16.7201H15.2848V15.1261H13.4977V16.7201H12.0345L14.3913 19.7172Z\" fill=\"#F04438\"/>\r\n                                        </svg>\r\n                                </div>\r\n                                <div class=\"mx-3 mt-1\" >\r\n                                    <div class=\"my-1 card-label header\" *ngIf=\"getMissedOpportunityData?.card?.avgDownTime === 0\">0 mins</div>\r\n                                    <div class=\"my-1 card-label header\"  *ngIf=\"getMissedOpportunityData?.card?.avgDownTime !== 0\">{{getMissedOpportunityData?.card?.avgDownTime ? getMissedOpportunityData?.card?.avgDownTime :'--'}} mins</div>\r\n                                    <div class=\"sub-header\">Avg Down Time</div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <ng-template #downTooltip>\r\n                            <div class=\"tooltip-content\">\r\n                              <h5 class=\"tooltip-title text-start\">Avg Down Time</h5>\r\n                              <p class=\"text-start\">Average camera & network downtime for the selected stores.</p>\r\n                              </div>\r\n                              </ng-template>\r\n                    </div>\r\n            </div>\r\n            <div *ngIf=\"headerData?.client !== '452'\" class=\"col-md-4 mt-3 position-relative\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"card-header ellipse1 border-0 px-3\" [ngbTooltip]=\"potentialTooltip\" placement=\"right\">\r\n                        <h3 class=\"card-title align-items-start flex-column \">\r\n                            <span class=\"card-label header\">{{getPotentialBuyersCardData?.card?.potentialBuyers?.rate ? getPotentialBuyersCardData?.card?.potentialBuyers?.rate :'--'}}%</span>\r\n                            <span class=\"sub-header \">Potential Buyers</span>\r\n                        </h3>\r\n                    </div>\r\n                    <ng-template #potentialTooltip>\r\n                        <div class=\"tooltip-content\">\r\n                          <h5 class=\"tooltip-title text-start\">Potential Buyers</h5>\r\n                          <p class=\"text-start\">Number of groups entering the store.</p>\r\n                          </div>\r\n                          </ng-template>\r\n                    <div class=\"card-body p-0\">\r\n                        <div *ngIf=\"potentialNodata\" class=\"row\">\r\n                            <div class=\"col-lg-12 mb-3\">\r\n                                <div class=\"card-body pb-0 px-0 d-flex justify-content-center align-items-center flex-column\">\r\n                                    <img class=\"img-nodata1\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                    <div class=\"nodata-title1\">No data found</div>\r\n                                    <!-- <div class=\"nodata-sub\">There is no result for this conversion funnel</div> -->\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"!potentialNodata\" class=\"text-center\" id=\"PotentialBuyers\"></div>\r\n                    </div>\r\n                    <div class=\"card-footer ms-2 p-0\">\r\n                        <div class=\"col-md-12\">\r\n                            <span class=\"mt-2\">\r\n                                <svg *ngIf=\"!getPotentialBuyersCardData?.data?.potentialBuyers?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                    <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <clipPath id=\"clip0_2328_4654\">\r\n                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                    </clipPath>\r\n                                </defs>\r\n                            </svg>\r\n                            <svg *ngIf=\"getPotentialBuyersCardData?.data?.potentialBuyers?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                <g clip-path=\"url(#clip0_3216_118)\">\r\n                                    <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <clipPath id=\"clip0_3216_118\">\r\n                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                    </clipPath>\r\n                                </defs>\r\n                            </svg>\r\n                            </span>\r\n                            <span class=\"mt-2 ms-2\">\r\n                                <span *ngIf=\"getPotentialBuyersCardData?.data?.potentialBuyers?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                <span *ngIf=\"getPotentialBuyersCardData?.data?.potentialBuyers?.PreviousData !==0\" class=\"percent-value\">{{getPotentialBuyersCardData?.data?.potentialBuyers?.PreviousData ? getPotentialBuyersCardData?.data?.potentialBuyers?.PreviousData:'--'}}%</span>\r\n                                <span class=\"week-font\">\r\n                                    vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                            </span>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"position-absolute end-0\">\r\n                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                        <path d=\"M6 12L10 8L6 4\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                        </svg>\r\n                        </div>\r\n            </div>\r\n            <div *ngIf=\"headerData?.client !== '452'\" class=\"col-md-8 mt-3\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"row\">\r\n                        <div class=\"col-md-12\">\r\n                            <div class=\"px-2\">\r\n                                <div class=\"card-header ellipse1 border-0 px-3\" [ngbTooltip]=\"potentialBuyerTooltip\" placement=\"right\">\r\n                                    <h3 class=\"card-title align-items-start flex-column \">\r\n                                        <span class=\"card-label header\">Potential Buyer Distribution</span>\r\n                                        <span class=\"sub-header\">Category-wise</span>\r\n                                    </h3>   \r\n                                </div>\r\n                                <ng-template #potentialBuyerTooltip>\r\n                                    <div class=\"tooltip-content\">\r\n                                      <h5 class=\"tooltip-title text-start\">Potential Buyer Distribution</h5>\r\n                                      <p class=\"text-start\">Average group size, along with the count of individuals versus groups entering the store.</p>\r\n                                      </div>\r\n                                      </ng-template>\r\n                                <div class=\"row\">\r\n                                    <div class=\"col-md-9\">\r\n                                        <div class=\"row\">\r\n                                <div class=\"col-md-6 px-0\">\r\n                                <div class=\"card-body p-0\">\r\n                                   <div class=\"text-start ms-10  mt-7 mb-3\"><span><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"25\" height=\"24\" viewBox=\"0 0 25 24\" fill=\"none\">\r\n                                    <path d=\"M20.25 21V19C20.25 17.9391 19.8286 16.9217 19.0784 16.1716C18.3283 15.4214 17.3109 15 16.25 15H8.25C7.18913 15 6.17172 15.4214 5.42157 16.1716C4.67143 16.9217 4.25 17.9391 4.25 19V21M16.25 7C16.25 9.20914 14.4591 11 12.25 11C10.0409 11 8.25 9.20914 8.25 7C8.25 4.79086 10.0409 3 12.25 3C14.4591 3 16.25 4.79086 16.25 7Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                  </svg></span><span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.count !== 0\" class=\"left-card-count mt-2 ms-1\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.count ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.count.toLocaleString('en-IN'):'--'}}</span> \r\n                                  <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.count === 0\" class=\"left-card-count mt-2 ms-1\">0</span><span class=\"left-card-count-header ms-1\">Single</span></div>\r\n                                  <div class=\"text-start ms-15 mb-3\"><span class=\"badge badge-light-default week-font\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.ageGroup ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.ageGroup:'--'}} age</span></div>\r\n                                </div>\r\n                                <div class=\"card-footer ms-2 p-0\">\r\n                                    <div class=\"col-md-12\">\r\n                                        <span class=\"mt-2\">\r\n                                            <svg *ngIf=\"!getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                            height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                                <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <clipPath id=\"clip0_2328_4654\">\r\n                                                    <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                </clipPath>\r\n                                            </defs>\r\n                                        </svg>\r\n                                        <svg *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                            viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_3216_118)\">\r\n                                                <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <clipPath id=\"clip0_3216_118\">\r\n                                                    <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                </clipPath>\r\n                                            </defs>\r\n                                        </svg>\r\n                                        </span>\r\n                                        <span class=\"mt-2 ms-2\">\r\n                                            <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                            <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.PreviousData !==0\" class=\"percent-value\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.PreviousData ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersSingle?.PreviousData:'--'}}%</span>\r\n                                            <span\r\n                                                class=\"week-font\"> vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n\r\n                                        </span>\r\n                                    </div>\r\n                                </div>\r\n                                </div>\r\n                                <div class=\"col-md-6 px-0 position-relative\">\r\n                                    <div class=\"card-body p-0\">\r\n                                        <div class=\"text-start ms-10 mt-7 mb-3\"><span> <svg width=\"26\" height=\"24\" viewBox=\"0 0 26 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <rect width=\"26\" height=\"24\" fill=\"#DCDCDC\"/>\r\n                                            <rect x=\"-460.5\" y=\"-340.5\" width=\"783\" height=\"1947\" rx=\"4.5\" stroke=\"#9747FF\" stroke-dasharray=\"10 5\"/>\r\n                                            <mask id=\"path-2-inside-1_707_13106\" fill=\"white\">\r\n                                            <path d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\"/>\r\n                                            </mask>\r\n                                            <path d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\" fill=\"white\"/>\r\n                                            <path d=\"M-190 -89C-190 -96.1797 -184.18 -102 -177 -102H294C301.18 -102 307 -96.1797 307 -89C307 -95.0751 301.627 -100 295 -100H-177C-183.075 -100 -188 -95.0751 -188 -89H-190ZM307 85C307 92.1797 301.18 98 294 98H-177C-184.18 98 -190 92.1797 -190 85H-188C-188 91.0751 -183.075 96 -177 96H295C301.627 96 307 91.0751 307 85ZM-177 98C-184.18 98 -190 92.1797 -190 85V-89C-190 -96.1797 -184.18 -102 -177 -102V-100C-183.075 -100 -188 -95.0751 -188 -89V85C-188 91.0751 -183.075 96 -177 96V98ZM307 -101V97V-101Z\" fill=\"#D0D5DD\" mask=\"url(#path-2-inside-1_707_13106)\"/>\r\n                                            <mask id=\"path-6-inside-2_707_13106\" fill=\"white\">\r\n                                            <path d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\"/>\r\n                                            </mask>\r\n                                            <path d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\" stroke=\"#98A2B3\" stroke-width=\"3\" mask=\"url(#path-6-inside-2_707_13106)\"/>\r\n                                            </svg></span><span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.count !==0\" class=\"left-card-count ms-1 mt-2\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.count ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.count.toLocaleString('en-IN'):'--'}}</span> \r\n                                            <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.count ===0\" class=\"left-card-count ms-1 mt-2\">0</span>\r\n                                            <span class=\"left-card-count-header ms-1\">Group</span></div>\r\n                                       <div class=\"text-start ms-15 mb-3\"><span class=\"badge badge-light-default week-font\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.ageGroup ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.ageGroup:'--'}} age</span></div>\r\n                                      \r\n                                     </div>\r\n                                    <div class=\"card-footer ms-2 p-0\">\r\n                                        <div class=\"col-md-12\">\r\n                                            <span class=\"mt-2\">\r\n                                                <svg *ngIf=\"!getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"18\"\r\n                                                height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2328_4654)\">\r\n                                                    <path d=\"M11.5 9L6.75 4.25L4.25 6.75L0.5 3M11.5 9H8.5M11.5 9V6\" stroke=\"#D92D20\" stroke-width=\"1.5\"\r\n                                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2328_4654\">\r\n                                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                            <svg *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.PreviousVariation\" xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\"\r\n                                                viewBox=\"0 0 12 12\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_3216_118)\">\r\n                                                    <path d=\"M11.5 3L6.75 7.75L4.25 5.25L0.5 9M11.5 3H8.5M11.5 3V6\" stroke=\"#039855\" stroke-width=\"1.5\"\r\n                                                        stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_3216_118\">\r\n                                                        <rect width=\"12\" height=\"12\" fill=\"white\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                            </span>\r\n                                            <span class=\"mt-2 ms-2\">\r\n                                                <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.PreviousData ===0\" class=\"percent-value\">0%</span>\r\n                                                <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.PreviousData !==0\" class=\"percent-value\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.PreviousData ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersGroup?.PreviousData:'--'}}%</span>\r\n                                                <span\r\n                                                    class=\"week-font\"> vs Previous  <span *ngIf=\"dateType ==='daily'\">day</span><span *ngIf=\"dateType ==='weekly'\">week</span> <span *ngIf=\"dateType ==='monthly'\">month</span></span>\r\n    \r\n                                            </span>\r\n                                        </div>\r\n                                    </div>\r\n\r\n                                    <div class=\"position-absolute mt-5 end-0\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path d=\"M6 12L10 8L6 4\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                            </div>\r\n                                    </div>\r\n                                    </div>\r\n                                    </div>\r\n                                    <div class=\"col-md-3 px-0\">\r\n                                        <div class=\"card-body p-0\">\r\n                                            <div class=\"text-center mt-7 mb-3\"><span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersPersons?.count !== 0\" class=\"left-card-count mt-2\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersPersons?.count ? getPotentialBuyersData?.potentialBuyers?.potentialBuyersPersons?.count.toLocaleString('en-IN'):'--'}}</span> \r\n                                                <span *ngIf=\"getPotentialBuyersData?.potentialBuyers?.potentialBuyersPersons?.count === 0\" class=\"left-card-count mt-2\">0</span><span class=\"left-card-count-header ms-1\">Persons</span></div>\r\n\r\n                                           <div class=\"text-center mb-3\"><span class=\"badge badge-light-default week-font\">{{getPotentialBuyersData?.potentialBuyers?.potentialBuyersPersons?.ageGroup ? getPotentialBuyersData.potentialBuyers?.potentialBuyersPersons?.ageGroup:'--'}} age</span>\r\n                                        </div>\r\n                                          \r\n                                         </div>\r\n                                        <div class=\"card-footer text-center p-0\">\r\n                                            <div class=\"col-md-12\">\r\n                                                <span class=\"mt-2 ms-2\"><span class=\"percent-value\"></span><span\r\n                                                        class=\"ms-2 week-font\"> Avg. Group size</span>\r\n        \r\n                                                </span>\r\n                                            </div>\r\n                                        </div>\r\n                                        </div>\r\n                                        </div>\r\n                            </div>\r\n                            <!-- <div>\r\n                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                        <path d=\"M6 12L10 8L6 4\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                        </svg>\r\n                        </div> -->\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n         \r\n        </div>\r\n\r\n    </div>\r\n    <div class=\"col-md-5 h-100\">\r\n        <div class=\"card mb-3\">\r\n            <div class=\"card-header border-0 pt-3 ps-5\">\r\n                <h3 class=\"card-title align-items-start flex-column\">\r\n                    <span class=\"title-text\"><span *ngIf=\"headerData?.client !== '452'\">Conversion</span> Funnel \r\n                       <span *ngIf=\"headerData?.client !== '452'\"> <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" \r\n                        placement=\"top\" \r\n                        ngbTooltip=\"Total opportunity of sales conversion versus total walkins\">\r\n                        <g clip-path=\"url(#clip0_1432_80035)\">\r\n                        <path d=\"M8.00065 10.6666V7.99992M8.00065 5.33325H8.00732M14.6673 7.99992C14.6673 11.6818 11.6826 14.6666 8.00065 14.6666C4.31875 14.6666 1.33398 11.6818 1.33398 7.99992C1.33398 4.31802 4.31875 1.33325 8.00065 1.33325C11.6826 1.33325 14.6673 4.31802 14.6673 7.99992Z\" stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                        </g>\r\n                        <defs>\r\n                        <clipPath id=\"clip0_1432_80035\">\r\n                        <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n                        </clipPath>\r\n                        </defs>\r\n                        </svg></span>\r\n                        <span *ngIf=\"headerData?.client === '452'\">\r\n                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" \r\n                        placement=\"top\" \r\n                        [ngbTooltip]=\"'Total opportunity of sales More than ' + clientData?.featureConfigs?.conversion?.value + ' mins versus total walkins'\">\r\n                        <g clip-path=\"url(#clip0_1432_80035)\">\r\n                        <path d=\"M8.00065 10.6666V7.99992M8.00065 5.33325H8.00732M14.6673 7.99992C14.6673 11.6818 11.6826 14.6666 8.00065 14.6666C4.31875 14.6666 1.33398 11.6818 1.33398 7.99992C1.33398 4.31802 4.31875 1.33325 8.00065 1.33325C11.6826 1.33325 14.6673 4.31802 14.6673 7.99992Z\" stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                        </g>\r\n                        <defs>\r\n                        <clipPath id=\"clip0_1432_80035\">\r\n                        <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n                        </clipPath>\r\n                        </defs>\r\n                        </svg>\r\n                        </span>\r\n                    </span>\r\n                    <span class=\"text-sub mb-2\">{{headerData?.date?.startDate | date:'dd MMM, yyyy'}} – {{headerData?.date?.endDate | date:'dd MMM, yyyy'}}</span>\r\n                </h3>\r\n        \r\n            </div>\r\n\r\n            <div class=\"card-body p-0\" >\r\n                <div *ngIf=\"heatloading\" class=\"row loader d-flex justify-content-center align-items-center h-275px\">\r\n                    <div class=\"shimmer pt-0\">\r\n                        <div class=\"wrapper\">\r\n                            <div class=\"stroke animate title\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n                            <div class=\"stroke animate title\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div *ngIf=\"heatnoData\" class=\"row\">\r\n                    <div class=\"col-lg-12 mb-3\">\r\n                        <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                            <img class=\"img-nodata\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                            <div class=\"nodata-title\">No data found</div>\r\n                            <div class=\"nodata-sub\">There is no result for this <span *ngIf=\"headerData?.client !=='452'\">conversion</span> funnel</div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div *ngIf=\"!heatloading && !heatnoData\" class=\"text-center mb-3\" id=\"chartdiv\"></div>\r\n            </div>\r\n            </div>\r\n           \r\n            <div *ngIf=\"mpaloading && storeIdarray?.length > 1 || mapnoData && storeIdarray?.length > 1 || !storeIdarray?.length\" class=\"card\">\r\n                <div class=\"card-header border-0 pt-3 ps-7 pe-0\">\r\n                    <h3 class=\"card-title align-items-start flex-column\">\r\n                        <span class=\"title-text\" >Explore</span>  \r\n                    </h3>\r\n               \r\n                        </div>\r\n                        <div *ngIf=\"mpaloading\" class=\"row loader d-flex justify-content-center align-items-center h-225px\">\r\n                            <div class=\"shimmer pt-0\">\r\n                                <div class=\"wrapper\">\r\n                                    <div class=\"stroke animate title\"></div>\r\n                                    <div class=\"stroke animate link\"></div>\r\n                                    <div class=\"stroke animate title\"></div>\r\n                                    <div class=\"stroke animate link\"></div>\r\n\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"mapnoData\"  class=\"row px-3\">\r\n                            <div class=\"col-md-12\">\r\n                                <div *ngIf=\"normalize\" class=\"card-body d-flex justify-content-center mb-10 align-items-center flex-column\">\r\n                                    <img class=\"img-map1\" src=\"./assets/tango/Icons/not-applicable.svg\" alt=\"\">\r\n                                    <div class=\"nodata-title mt-3\">Data Not Found</div>\r\n                                    <div class=\"nodata-sub\">Normalized data is not applicable</div>\r\n                                </div>\r\n                                <div *ngIf=\"!normalize\" class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                                    <img class=\"img-map\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                    <div  class=\"nodata-title\">No data found</div>\r\n                                    <div class=\"nodata-sub\">There is no result for this Store map</div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        </div>\r\n            <div *ngIf=\"!mpaloading && !mapnoData && storeIdarray?.length > 1\" class=\"card\">\r\n                <div  class=\"card-header border-0 pt-3 ps-7 pe-0\">\r\n                    <h3 class=\"card-title align-items-start flex-column\">\r\n                        <span class=\"title-text\" >Explore</span>  \r\n                    </h3>\r\n                    <div class=\"card-toolbar mt-0\">\r\n                       \r\n                        <button *ngIf=\"!mpaloading && !mapnoData\" type=\"button\" (click)=\"exporeView()\"\r\n                        class=\"btn me-8 btn-light-primary1 rounded-3 text-nowrap border-val\">\r\n                        <span class=\"ms-2\">Explore</span>\r\n                    </button>\r\n                    </div>\r\n            \r\n                </div>\r\n              \r\n                <div *ngIf=\"!mapnoData\" class=\"card-body col-md-12 pt-0 pb-5 ps-7\">\r\n                  <div id=\"map\" class=\"w-100\" ></div>\r\n                  </div>\r\n            </div>\r\n            <div *ngIf=\"storeIdarray?.length === 1\" class=\"card pb-2\">\r\n                <div class=\"card-header border-0 pt-3 ps-5 pe-0\">\r\n                    <h3 class=\"card-title align-items-start flex-column\">\r\n                        <span class=\"title-text\">Recap Video \r\n                            <svg placement=\"right\"\r\n                            ngbTooltip=\"A quick recap of the store activity along with the avg tech infrastructure downtime status\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                            <g clip-path=\"url(#clip0_1432_80035)\">\r\n                            <path d=\"M8.00065 10.6666V7.99992M8.00065 5.33325H8.00732M14.6673 7.99992C14.6673 11.6818 11.6826 14.6666 8.00065 14.6666C4.31875 14.6666 1.33398 11.6818 1.33398 7.99992C1.33398 4.31802 4.31875 1.33325 8.00065 1.33325C11.6826 1.33325 14.6673 4.31802 14.6673 7.99992Z\" stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                            </g>\r\n                            <defs>\r\n                            <clipPath id=\"clip0_1432_80035\">\r\n                            <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n                            </clipPath>\r\n                            </defs>\r\n                            </svg>\r\n                           \r\n                       \r\n                        </span>\r\n                      \r\n                        <span class=\"text-sub mb-2\">Dated: {{headerData?.date?.endDate | date:' dd MMM,yyyy'}}</span>\r\n                    </h3>\r\n                    <div class=\"card-toolbar mt-0\">\r\n                        <button type=\"button\" \r\n                        class=\"btn btn-default btn-outline btn-outline-default rounded-3 text-nowrap border-val text-start disabled-button\">\r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"14\" viewBox=\"0 0 16 14\" fill=\"none\">\r\n                            <g id=\"Group\">\r\n                            <path id=\"Vector\" d=\"M9.51953 0.333984C10.3958 0.333984 11.2331 0.513477 11.9974 0.838974C12.7904 1.17653 13.5039 1.67214 14.1016 2.28697C14.6979 2.90046 15.1797 3.6345 15.5078 4.45293C15.8242 5.23922 15.9987 6.10051 15.9987 7.00065C15.9987 7.90213 15.8242 8.76343 15.5078 9.54971C15.1797 10.3655 14.6979 11.0995 14.1003 11.7143C13.5039 12.3278 12.7904 12.8234 11.9948 13.161C11.2305 13.4865 10.3932 13.666 9.51823 13.666C8.64193 13.666 7.80469 13.4865 7.04036 13.161C6.2474 12.8234 5.53385 12.3278 4.9375 11.7143L4.9362 11.713C4.33854 11.0982 3.85807 10.3641 3.52995 9.54971C3.42839 9.29655 3.34115 9.03668 3.26953 8.77013C3.40495 8.78352 3.54297 8.79022 3.68229 8.79022C3.94661 8.79022 4.20443 8.76611 4.45573 8.71922C4.4974 8.84782 4.54297 8.97507 4.59245 9.09964C4.86198 9.76939 5.25781 10.3722 5.75 10.8785C6.24219 11.3848 6.82943 11.792 7.47917 12.0693C8.10547 12.3359 8.79427 12.4845 9.51823 12.4845C10.2422 12.4845 10.9297 12.3372 11.5573 12.0693C12.2083 11.792 12.7943 11.3848 13.2865 10.8785C13.7786 10.3722 14.1745 9.76805 14.444 9.09964C14.7031 8.45534 14.8477 7.74675 14.8477 7.00199C14.8477 6.25723 14.7044 5.54998 14.444 4.90434C14.1745 4.23459 13.7786 3.63182 13.2865 3.12549C12.7943 2.61916 12.207 2.21196 11.5573 1.93468C10.931 1.66812 10.2422 1.51944 9.51823 1.51944C8.79427 1.51944 8.10677 1.66678 7.47917 1.93468C7.42318 1.95879 7.36719 1.98424 7.3125 2.00969C7.09896 1.6641 6.84115 1.35066 6.54557 1.07874C6.70703 0.993016 6.8724 0.913986 7.04036 0.841653C7.80729 0.513477 8.64323 0.333984 9.51953 0.333984ZM8.77604 3.83141C8.77604 3.66799 8.84115 3.52064 8.94401 3.41348C9.04818 3.30632 9.19141 3.24069 9.35026 3.24069C9.50911 3.24069 9.65234 3.30632 9.75651 3.41348C9.86068 3.52064 9.92448 3.66799 9.92448 3.83141V6.94171L12.1836 8.32005C12.319 8.4031 12.4102 8.53571 12.4466 8.68172C12.4831 8.82772 12.4661 8.98846 12.3854 9.12777V9.12911C12.3047 9.26842 12.1758 9.36218 12.0339 9.39969C11.8919 9.43719 11.7357 9.41978 11.6003 9.33673H11.599L9.07161 7.79497C8.98438 7.74541 8.91276 7.67308 8.86068 7.58735C8.80729 7.4976 8.77604 7.39178 8.77604 7.27927V3.83141Z\" fill=\"#667085\"/>\r\n                            <path id=\"Vector_2\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M3.51302 0.687622C5.45312 0.687622 7.02604 2.30573 7.02604 4.30158C7.02604 6.29743 5.45312 7.91554 3.51302 7.91554C1.57292 7.91554 0 6.29743 0 4.30158C0 2.30573 1.57292 0.687622 3.51302 0.687622ZM3.51302 6.37378L5.39844 3.97608H4.22786V2.70088H2.79818V3.97608H1.6276L3.51302 6.37378Z\" fill=\"#F04438\"/>\r\n                            </g>\r\n                            </svg>\r\n                        <span class=\"ms-2\">{{getRecapVideoData?.downTime ?? '--'}} Mins</span>\r\n                    </button>\r\n                    <button type=\"button\" \r\n                        class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val disabled-button\">\r\n                        <svg *ngIf=\"getRecapVideoData?.health ==='GOOD'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                            <g id=\"Frame\">\r\n                            <path id=\"Vector\" d=\"M13.4349 2.5C14.8238 2.5 15.9871 3.01389 16.9249 4.04167C17.8627 5.06944 18.3313 6.29167 18.3307 7.70833C18.3307 7.95833 18.3168 8.205 18.2891 8.44833C18.2613 8.69167 18.2127 8.93111 18.1432 9.16667H12.9349L11.5182 7.04167C11.4488 6.93056 11.3516 6.84028 11.2266 6.77083C11.1016 6.70139 10.9696 6.66667 10.8307 6.66667C10.6502 6.66667 10.4868 6.72222 10.3407 6.83333C10.1946 6.94444 10.0941 7.08333 10.0391 7.25L8.91406 10.625L8.1849 9.54167C8.11545 9.43056 8.01823 9.34028 7.89323 9.27083C7.76823 9.20139 7.63628 9.16667 7.4974 9.16667H1.85156C1.78212 8.93056 1.73351 8.69083 1.70573 8.4475C1.67795 8.20417 1.66406 7.96472 1.66406 7.72917C1.66406 6.29861 2.12934 5.06944 3.0599 4.04167C3.99045 3.01389 5.15017 2.5 6.53906 2.5C7.20573 2.5 7.83434 2.63194 8.4249 2.89583C9.01545 3.15972 9.53962 3.52778 9.9974 4C10.4418 3.52778 10.9593 3.15972 11.5499 2.89583C12.1405 2.63194 12.7688 2.5 13.4349 2.5ZM9.9974 17.5C9.7474 17.5 9.50767 17.4547 9.27823 17.3642C9.04878 17.2736 8.84406 17.1383 8.66406 16.9583L3.08073 11.3542C2.9974 11.2708 2.92101 11.1875 2.85156 11.1042C2.78212 11.0208 2.71267 10.9306 2.64323 10.8333H7.03906L8.45573 12.9583C8.52517 13.0694 8.6224 13.1597 8.7474 13.2292C8.8724 13.2986 9.00434 13.3333 9.14323 13.3333C9.32378 13.3333 9.49045 13.2778 9.64323 13.1667C9.79601 13.0556 9.90017 12.9167 9.95573 12.75L11.0807 9.375L11.7891 10.4583C11.8724 10.5694 11.9766 10.6597 12.1016 10.7292C12.2266 10.7986 12.3585 10.8333 12.4974 10.8333H17.3307L17.1224 11.0833L16.9141 11.3333L11.3099 16.9583C11.1293 17.1389 10.928 17.2744 10.7057 17.365C10.4835 17.4556 10.2474 17.5006 9.9974 17.5Z\" fill=\"#12B76A\"/>\r\n                            </g>\r\n                            </svg>\r\n                            <svg *ngIf=\"getRecapVideoData?.health ==='AVERAGE'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                                <g id=\"Frame\">\r\n                                <path id=\"Vector\" d=\"M13.4349 2.5C14.8238 2.5 15.9871 3.01389 16.9249 4.04167C17.8627 5.06944 18.3313 6.29167 18.3307 7.70833C18.3307 7.95833 18.3168 8.205 18.2891 8.44833C18.2613 8.69167 18.2127 8.93111 18.1432 9.16667H12.9349L11.5182 7.04167C11.4488 6.93056 11.3516 6.84028 11.2266 6.77083C11.1016 6.70139 10.9696 6.66667 10.8307 6.66667C10.6502 6.66667 10.4868 6.72222 10.3407 6.83333C10.1946 6.94444 10.0941 7.08333 10.0391 7.25L8.91406 10.625L8.1849 9.54167C8.11545 9.43056 8.01823 9.34028 7.89323 9.27083C7.76823 9.20139 7.63628 9.16667 7.4974 9.16667H1.85156C1.78212 8.93056 1.73351 8.69083 1.70573 8.4475C1.67795 8.20417 1.66406 7.96472 1.66406 7.72917C1.66406 6.29861 2.12934 5.06944 3.0599 4.04167C3.99045 3.01389 5.15017 2.5 6.53906 2.5C7.20573 2.5 7.83434 2.63194 8.4249 2.89583C9.01545 3.15972 9.53962 3.52778 9.9974 4C10.4418 3.52778 10.9593 3.15972 11.5499 2.89583C12.1405 2.63194 12.7688 2.5 13.4349 2.5ZM9.9974 17.5C9.7474 17.5 9.50767 17.4547 9.27823 17.3642C9.04878 17.2736 8.84406 17.1383 8.66406 16.9583L3.08073 11.3542C2.9974 11.2708 2.92101 11.1875 2.85156 11.1042C2.78212 11.0208 2.71267 10.9306 2.64323 10.8333H7.03906L8.45573 12.9583C8.52517 13.0694 8.6224 13.1597 8.7474 13.2292C8.8724 13.2986 9.00434 13.3333 9.14323 13.3333C9.32378 13.3333 9.49045 13.2778 9.64323 13.1667C9.79601 13.0556 9.90017 12.9167 9.95573 12.75L11.0807 9.375L11.7891 10.4583C11.8724 10.5694 11.9766 10.6597 12.1016 10.7292C12.2266 10.7986 12.3585 10.8333 12.4974 10.8333H17.3307L17.1224 11.0833L16.9141 11.3333L11.3099 16.9583C11.1293 17.1389 10.928 17.2744 10.7057 17.365C10.4835 17.4556 10.2474 17.5006 9.9974 17.5Z\" fill=\"#FACC15\"/>\r\n                                </g>\r\n                                </svg>\r\n                                <svg *ngIf=\"getRecapVideoData?.health ==='BAD'\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                                    <g id=\"Frame\">\r\n                                    <path id=\"Vector\" d=\"M13.4349 2.5C14.8238 2.5 15.9871 3.01389 16.9249 4.04167C17.8627 5.06944 18.3313 6.29167 18.3307 7.70833C18.3307 7.95833 18.3168 8.205 18.2891 8.44833C18.2613 8.69167 18.2127 8.93111 18.1432 9.16667H12.9349L11.5182 7.04167C11.4488 6.93056 11.3516 6.84028 11.2266 6.77083C11.1016 6.70139 10.9696 6.66667 10.8307 6.66667C10.6502 6.66667 10.4868 6.72222 10.3407 6.83333C10.1946 6.94444 10.0941 7.08333 10.0391 7.25L8.91406 10.625L8.1849 9.54167C8.11545 9.43056 8.01823 9.34028 7.89323 9.27083C7.76823 9.20139 7.63628 9.16667 7.4974 9.16667H1.85156C1.78212 8.93056 1.73351 8.69083 1.70573 8.4475C1.67795 8.20417 1.66406 7.96472 1.66406 7.72917C1.66406 6.29861 2.12934 5.06944 3.0599 4.04167C3.99045 3.01389 5.15017 2.5 6.53906 2.5C7.20573 2.5 7.83434 2.63194 8.4249 2.89583C9.01545 3.15972 9.53962 3.52778 9.9974 4C10.4418 3.52778 10.9593 3.15972 11.5499 2.89583C12.1405 2.63194 12.7688 2.5 13.4349 2.5ZM9.9974 17.5C9.7474 17.5 9.50767 17.4547 9.27823 17.3642C9.04878 17.2736 8.84406 17.1383 8.66406 16.9583L3.08073 11.3542C2.9974 11.2708 2.92101 11.1875 2.85156 11.1042C2.78212 11.0208 2.71267 10.9306 2.64323 10.8333H7.03906L8.45573 12.9583C8.52517 13.0694 8.6224 13.1597 8.7474 13.2292C8.8724 13.2986 9.00434 13.3333 9.14323 13.3333C9.32378 13.3333 9.49045 13.2778 9.64323 13.1667C9.79601 13.0556 9.90017 12.9167 9.95573 12.75L11.0807 9.375L11.7891 10.4583C11.8724 10.5694 11.9766 10.6597 12.1016 10.7292C12.2266 10.7986 12.3585 10.8333 12.4974 10.8333H17.3307L17.1224 11.0833L16.9141 11.3333L11.3099 16.9583C11.1293 17.1389 10.928 17.2744 10.7057 17.365C10.4835 17.4556 10.2474 17.5006 9.9974 17.5Z\" fill=\"#F04438\"/>\r\n                                    </g>\r\n                                    </svg>\r\n                        <span class=\"ms-2\">{{getRecapVideoData?.health ?? '--'}}</span>\r\n                    </button>\r\n                        <!-- <button type=\"button\" (click)=\"cameraView()\"\r\n                        class=\"btn mx-2 btn-light-primary1 rounded-3 text-nowrap border-val\">\r\n                        <span class=\"ms-2\">Live View</span>\r\n                    </button> -->\r\n                    </div>\r\n            \r\n                </div>\r\n                <div *ngIf=\"recaplaoding\" class=\"row loader d-flex justify-content-center align-items-center h-225px\">\r\n                    <div class=\"shimmer pt-0\">\r\n                        <div class=\"wrapper\">\r\n                            <div class=\"stroke animate title\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n                            <div class=\"stroke animate title\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div *ngIf=\"recapnoData\"  class=\"row px-3\">\r\n                    <div class=\"col-md-12\">\r\n                        <div *ngIf=\"normalize\" class=\"card-body d-flex justify-content-center mb-10 align-items-center flex-column\">\r\n                            <img class=\"img-map1\" src=\"./assets/tango/Icons/not-applicable.svg\" alt=\"\">\r\n                            <div class=\"nodata-title mt-3\">Data Not Found</div>\r\n                            <div class=\"nodata-sub\">Normalized data is not applicable</div>\r\n                        </div>\r\n                        <div *ngIf=\"!normalize\" class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                            <img class=\"img-map-recap\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                            <div class=\"nodata-title\">No data found</div>\r\n                            <div class=\"nodata-sub\">There is no result for this Recap video</div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div *ngIf=\"!recaplaoding && !recapnoData\" class=\"card-body p-0\">\r\n                    <div class=\"row mx-3\">\r\n                \r\n                        <div class=\"carousel\">\r\n                            <div class=\"carousel-inner\">\r\n                              <div\r\n                                class=\"carousel-item\"\r\n                                *ngFor=\"let group of recapsGrouped; let i = index\"\r\n                                [class.active]=\"i === currentIndex\"\r\n                              >\r\n                                <div class=\"row\">\r\n                                  <div *ngFor=\"let pair of group\" [ngClass]=\"colValue\">\r\n                                    <img [src]=\"pair.thumbImage\"\r\n                                         (click)=\"videoClick(pair)\"\r\n                                         class=\"image-thumb mb-8 d-block w-100 cursor-pointer\"\r\n                                         alt=\"Image {{ i + 1 }}\" />\r\n                                  </div>\r\n                                </div>\r\n                              </div>\r\n                            </div>\r\n                          \r\n                            <!-- Conditionally display Previous button -->\r\n                            <button class=\"carousel-control-prev\" *ngIf=\"currentIndex > 0\" (click)=\"prevSlide()\">\r\n                              <span class=\"carousel-control-prev-icon\"></span>\r\n                            </button>\r\n                          \r\n                            <!-- Conditionally display Next button -->\r\n                            <button class=\"carousel-control-next\" *ngIf=\"currentIndex < recapsGrouped.length - 1\" (click)=\"nextSlide()\">\r\n                              <span class=\"carousel-control-next-icon\"></span>\r\n                            </button>\r\n                          \r\n                            <!-- Navigation Dots -->\r\n                            <div *ngIf=\"recapsGrouped.length > 1\" class=\"row\">\r\n                              <ul class=\"carousel-indicators\">\r\n                                <li *ngFor=\"let group of recapsGrouped; let i = index\"\r\n                                    [class.active]=\"i === currentIndex\"\r\n                                    (click)=\"goToSlide(i)\">\r\n                                </li>\r\n                              </ul>\r\n                            </div>\r\n\r\n                          </div>\r\n                          \r\n                          \r\n                        <!-- <video controls autoplay class=\"recap-img p-3\" [src]=\"getRecapData?.videoURL\"> -->\r\n                            <!-- <source  type=\"video/mp4\"> -->\r\n                            <!-- <source [src]=\"getRecapData?.videoURL\" type=\"video/ogg\"> -->\r\n                          <!-- </video> -->\r\n                        <!-- <div #mapContainer style=\"height:230px;\"></div> -->\r\n                        <!-- <div class=\"col-md-6 mb-3\"><img src=\"assets/tango/Images/recap.svg\" alt=\"\" class=\"recap-img\"></div>\r\n                        <div class=\"col-md-6 mb-3\"><img src=\"assets/tango/Images/recap.svg\" alt=\"\" class=\"recap-img\"></div> -->\r\n\r\n                    </div>\r\n                </div>\r\n                </div>\r\n    \r\n    </div>\r\n    <div  class=\"col-md-12 mt-3\">\r\n\r\n        <!-- footfall trend charts -->\r\n        <div *ngIf=\"storeIdarray[0] !=='459-2'\" class=\"card\">\r\n            <div class=\"card-header border-0 pt-3\">\r\n                <h3 class=\"card-title align-items-start flex-column\">\r\n                    <span class=\"card-label1 mb-2\">Footfall Trend</span>\r\n                    <span class=\"text-sub mb-2\">Based on {{getDateValues?.fromDate | date:'dd MMM, yyyy'}} – {{getDateValues?.toDate | date:'dd MMM, yyyy'}}</span>\r\n                </h3>\r\n                <div class=\"card-toolbar text-nowrap\">\r\n                    <div class=\"d-flex\">\r\n                        <div class=\"d-flex align-items-center position-relative my-1\">\r\n                            <!--begin::Nav group-->\r\n                            <div class=\"nav-group nav-group-outline border-1 btn-group p-0\">\r\n                                <button class=\"btn btn-outline px-6 py-3\"\r\n                                    [ngClass]=\"type === 'daily' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n                                    (click)=\"selectPlanTrends('daily')\">\r\n                                    Day\r\n                                </button>\r\n                             <!-- Month Button -->\r\n        \r\n        \r\n        <!-- Week Button -->\r\n        <button  class=\"btn btn-outline px-6 py-3\"\r\n            [ngClass]=\"type === 'weekly' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n            (click)=\"selectPlanTrends('weekly')\">\r\n            Week\r\n        </button>\r\n        \r\n        <!-- Day Button, visible only if dateLength is valid and type is either 'weekly' or 'daily' -->\r\n        <button class=\"btn btn-outline px-6 py-3\"\r\n            [ngClass]=\"type === 'monthly' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n            (click)=\"selectPlanTrends('monthly')\">\r\n            Month\r\n        </button>\r\n        \r\n                            </div>\r\n                            <!--end::Nav group-->\r\n                            <div class=\"d-flex\">\r\n                                <span class=\"mx-2 mt-3 dropselect\">Trend</span>\r\n        \r\n                                <form [formGroup]=\"form\">\r\n                                    <lib-reactive-select\r\n                                      [formControl]=\"selectControl\" \r\n                                      [idField]=\"'value'\"\r\n                                      [nameField]=\"'label'\"\r\n                                      [data]=\"datasets\"\r\n                                      class=\"w-100\"\r\n                                      (valueChange)=\"onValueChangetrend($event)\">\r\n                                    </lib-reactive-select>\r\n                                  </form>\r\n                                <!-- <select class=\"form-select form-select-sm\" (change)=\"onDatasetChange($event)\">\r\n                                    <option *ngFor=\"let dataset of datasets\" [value]=\"dataset.value\">{{ dataset.label }}\r\n                                    </option>\r\n                                </select> -->\r\n                            </div>\r\n                            <div class=\"d-flex mt-1 ms-3\">\r\n                                <section *ngIf=\"storeIdarray?.length === 1\">\r\n                                <span  class=\"d-flex ms-1 dropselect mt-2 cursor-pointer text-nowrap fs-5\">Forecast\r\n                                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                        fill=\"none\">\r\n                                        <g clip-path=\"url(#clip0_2645_27459)\">\r\n                                            <path\r\n                                                d=\"M3.33398 1.33331L3.46065 1.95998C3.55142 2.40998 3.75683 2.82893 4.05699 3.17628C4.35715 3.52362 4.74189 3.78759 5.17398 3.94265L5.33398 3.99998L5.17398 4.05731C4.74189 4.21237 4.35715 4.47634 4.05699 4.82368C3.75683 5.17103 3.55142 5.58998 3.46065 6.03998L3.33398 6.66665L3.20732 6.03998C3.11654 5.58998 2.91114 5.17103 2.61098 4.82368C2.31082 4.47634 1.92607 4.21237 1.49398 4.05731L1.33398 3.99998L1.49398 3.94265C1.92607 3.78759 2.31082 3.52362 2.61098 3.17628C2.91114 2.82893 3.11654 2.40998 3.20732 1.95998L3.33398 1.33331ZM5.33398 10.6666L5.48732 11.5173C5.52713 11.7392 5.62256 11.9474 5.76468 12.1224C5.9068 12.2974 6.09098 12.4335 6.29998 12.518L6.66732 12.6666L6.29998 12.8153C6.09094 12.8997 5.90668 13.0356 5.76445 13.2105C5.62221 13.3854 5.52663 13.5935 5.48665 13.8153L5.33398 14.6666L5.18065 13.816C5.14084 13.5941 5.04541 13.3859 4.90329 13.2109C4.76117 13.0359 4.57699 12.8998 4.36798 12.8153L4.00065 12.6666L4.36798 12.518C4.57703 12.4336 4.76129 12.2977 4.90352 12.1228C5.04576 11.9479 5.14133 11.7398 5.18132 11.518L5.33398 10.6666ZM10.6673 1.99998L11.038 3.76931C11.2269 4.67137 11.6463 5.50908 12.2554 6.20076C12.8645 6.89244 13.6424 7.41448 14.5133 7.71598L15.334 7.99998L14.5133 8.28398C13.6424 8.58548 12.8645 9.10752 12.2554 9.7992C11.6463 10.4909 11.2269 11.3286 11.038 12.2306L10.6673 14L10.2967 12.2306C10.1077 11.3286 9.6883 10.4909 9.07922 9.7992C8.47015 9.10752 7.69223 8.58548 6.82132 8.28398L6.00065 7.99998L6.82132 7.71598C7.69223 7.41448 8.47015 6.89244 9.07922 6.20076C9.6883 5.50908 10.1077 4.67137 10.2967 3.76931L10.6673 1.99998Z\"\r\n                                                stroke=\"#344054\" stroke-width=\"1.5\" stroke-linecap=\"round\"\r\n                                                stroke-linejoin=\"round\" />\r\n                                        </g>\r\n                                        <defs>\r\n                                            <clipPath id=\"clip0_2645_27459\">\r\n                                                <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                                            </clipPath>\r\n                                        </defs>\r\n                                    </svg>\r\n        \r\n                                    <span class=\"form-check form-switch mx-3\">\r\n                                        <input class=\"form-check-input  cursor-pointer\" type=\"checkbox\" [(ngModel)]=\"forecast\" (click)=\"forecastApi($event)\">\r\n                                    </span>\r\n        \r\n                                </span>\r\n        </section>\r\n                                <div *ngIf=\"!objData?.forecast\" class=\"position-relative cursor-pointer\">\r\n                                    <div class=\"ms-1\" (click)=\"producttrailDropdown($event)\">\r\n                                        <svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\"\r\n                                        xmlns=\"http://www.w3.org/2000/svg\">\r\n                                        <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"1.66667\"\r\n                                            stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                    </svg>  \r\n                                       \r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"show\"\r\n                                    class=\"card py-2 w-200px position-absolute productdrop top-20 end-1 mt-10 z-1\">\r\n                                    <ul *ngIf=\"!objData?.forecast\"  class=\"list-unstyled mb-2\">\r\n                                        <!-- <li class=\"producttext px-5 items cursor-pointer py-4\" [ngClass]=\"trendtypeValue ==='normalize' ? 'bg-forcast':''\" type=\"button\"\r\n                                        (click)=\"changeStatus('normalize')\">Normalize\r\n                                            <svg class=\"text-end ms-20\" *ngIf=\"trendtypeValue ==='normalize' ? 'bg-forcast':''\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                                                width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                <path d=\"M13.3327 4L5.99935 11.3333L2.66602 8\" stroke=\"#344054\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </svg>\r\n                                       </li> -->\r\n                                       <li  *ngIf=\"storeIdarray?.length === 1\" class=\"producttext px-5 items cursor-pointer py-4\" [ngClass]=\"trendtypeValue ==='actual' ? 'bg-forcast':''\" type=\"button\"\r\n                                       (click)=\"changeStatus('actual')\">Actual\r\n                                           <svg class=\"text-end ms-20\" *ngIf=\"trendtypeValue ==='actual' ? 'bg-forcast':''\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                                               width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                               <path d=\"M13.3327 4L5.99935 11.3333L2.66602 8\" stroke=\"#344054\" stroke-width=\"1.5\"\r\n                                                   stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                           </svg>\r\n                                      </li>\r\n                                    <li *ngIf=\"storeIdarray?.length > 1\" class=\"producttext px-5 items cursor-pointer py-4\" [ngClass]=\"trendtypeValue ==='average' ? 'bg-forcast':''\" type=\"button\"\r\n                                        (click)=\"changeStatus('average')\">Average\r\n                                           <span> <svg class=\"text-end ms-20\" *ngIf=\"trendtypeValue ==='average' ? 'bg-forcast':''\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                                                width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                <path d=\"M13.3327 4L5.99935 11.3333L2.66602 8\" stroke=\"#344054\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </svg></span>\r\n                                        </li>\r\n                                    <!-- <li class=\"producttext px-5 items cursor-pointer py-4\" [ngClass]=\"trendtypeValue ==='target' ? 'bg-forcast':''\" type=\"button\"\r\n                                    (click)=\"changeStatus('target')\">Target\r\n                                            <svg class=\"text-end ms-20\" *ngIf=\"trendtypeValue ==='target' ? 'bg-forcast':''\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                                            width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path d=\"M13.3327 4L5.99935 11.3333L2.66602 8\" stroke=\"#344054\" stroke-width=\"1.5\" stroke-linecap=\"round\"\r\n                                                stroke-linejoin=\"round\" />\r\n                                        </svg></li> -->\r\n                                   \r\n                                    <li class=\"producttext px-5 items cursor-pointer py-4\" [ngClass]=\"trendtypeValue ==='weekends' ? 'bg-forcast':''\" type=\"button\"\r\n                                    (click)=\"changeStatus('weekends')\">Weekends\r\n                                            <svg class=\"text-end ms-20\" *ngIf=\"trendtypeValue ==='weekends' ? 'bg-forcast':''\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                                            width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path d=\"M13.3327 4L5.99935 11.3333L2.66602 8\" stroke=\"#344054\" stroke-width=\"1.5\" stroke-linecap=\"round\"\r\n                                                stroke-linejoin=\"round\" />\r\n                                        </svg></li>\r\n                                   \r\n                                    <li class=\"producttext px-5 items cursor-pointer py-4\" [ngClass]=\"trendtypeValue ==='weekdays' ? 'bg-forcast':''\" type=\"button\"\r\n                                    (click)=\"changeStatus('weekdays')\">Weekdays\r\n                                            <svg class=\"text-end ms-20\" *ngIf=\"trendtypeValue ==='weekdays' ? 'bg-forcast':''\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                                                width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                                <path d=\"M13.3327 4L5.99935 11.3333L2.66602 8\" stroke=\"#344054\" stroke-width=\"1.5\"\r\n                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                            </svg>\r\n                                        </li>\r\n                                    </ul>\r\n                                </div>\r\n                            </div>\r\n        \r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"loadingTrends\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                <div class=\"shimmer\">\r\n                    <div class=\"wrapper\">\r\n                        <div class=\"stroke animate title\"></div>\r\n                        <div class=\"stroke animate link\"></div>\r\n                        <div class=\"stroke animate description\"></div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"shimmer\">\r\n                    <div class=\"wrapper\">\r\n                        <div class=\"stroke animate title\"></div>\r\n                        <div class=\"stroke animate link\"></div>\r\n                        <div class=\"stroke animate description\"></div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"noDataTrends\" class=\"row\">\r\n                <div class=\"col-lg-12 mb-3\">\r\n                    <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                        <img class=\"img-nodata\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                        <div class=\"nodata-title\">No data found</div>\r\n                        <div class=\"nodata-sub\">There is no result for this footfall trend</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"card-body p-0\" *ngIf=\"!noDataTrends && !loadingTrends\">\r\n                <div class=\"text-center px-3\" id=\"Footfalltrend\"></div>\r\n        \r\n                \r\n                <div #tooltipContainer class=\"tooltip-container\" >\r\n                    <div class=\"tooltip-content\" *ngIf=\"tooltipData\">\r\n                        <div class=\"content p-5\">\r\n                          <!-- <div class=\"container\">\r\n                            <span class=\"title text-start\">{{tooltipData.fullStoreName}}</Span>\r\n                            <span>Sum</span>\r\n                            <span>Avg</span>\r\n                          </div> -->\r\n                          \r\n                          <!-- Table for counts and rates in horizontal format -->\r\n                          <table class=\"table table-horizontal trens\">\r\n                            <thead>\r\n                              <tr>\r\n                              <th class=\"title text-start px-3\">{{tooltipData.fullStoreName}}</th>\r\n                            <th class=\"title text-end\">Sum</th>\r\n                            \r\n                            <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                            <th *ngIf=\"type !== 'daily'\" class=\"title text-end\">Avg</th>\r\n                        </ng-container>\r\n                              </tr>\r\n                            </thead>\r\n                            <tbody>\r\n                              <!-- Counts Section -->\r\n                              <tr >\r\n                                <td class=\"trend-label\"  style=\"line-height: 10px !important\">Total Footfall</td>\r\n                                <td class=\"value\"  style=\"line-height: 10px !important\">{{tooltipData.footfall_count}}</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value\"  style=\"line-height: 10px !important\">{{tooltipData.footfall_count_avg}}</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                              <tr >\r\n                                <td class=\"trend-label\"  style=\"line-height: 10px !important\"><span *ngIf=\"headerData?.client === '452'\">Less than {{clientData?.featureConfigs?.bouncedLimit?.value}} mins</span> <span *ngIf=\"headerData?.client !== '452'\">Bounced Footfall</span></td>\r\n                                <td class=\"value\"  style=\"line-height: 10px !important\">{{tooltipData.bounced_count}}</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value\"  style=\"line-height: 10px !important\">{{tooltipData.bounced_footfall_count_avg}}</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                              <tr>\r\n                                <td class=\"trend-label\" style=\"line-height: 10px !important\"><span *ngIf=\"headerData?.client === '452'\">More than {{clientData?.featureConfigs?.bouncedLimit?.value}} mins</span> <span *ngIf=\"headerData?.client !== '452'\">Engagers</span></td>\r\n                                <td class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.engagers_count}}</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.engagers_count_avg}}</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                              <tr>\r\n                                <td class=\"trend-label\" style=\"line-height: 10px !important\"><span *ngIf=\"headerData?.client === '452'\">{{clientData?.featureConfigs?.missedOpportunityFrom?.value}} - {{clientData?.featureConfigs?.missedOpportunityTo?.value}} mins</span> <span *ngIf=\"headerData?.client !== '452'\">Missed Opportunities</span></td>\r\n                                <td class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.missedOpportunity_count}}</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.missedOpportunity_count_avg}}</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                              <tr style=\"line-height: 10px !important\">\r\n                                <td class=\"trend-label\" style=\"line-height: 10px !important\">Down Time</td>\r\n                                <td class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.down_time ? tooltipData.down_time :'--'}}</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.down_time}}</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                      \r\n                              <!-- Rates Section -->\r\n                              <tr >\r\n                                <td class=\"trend-label\" style=\"line-height: 10px !important\">Dwell Time</td>\r\n                                <td class=\"value text-nowrap\" style=\"line-height: 10px !important\">{{tooltipData.avgDwellTime.toFixed(0)}} Mins</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value text-nowrap\" style=\"line-height: 10px !important\">{{tooltipData.avgDwellTime.toFixed(0)}} Mins</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                              <tr >\r\n                                <td class=\"trend-label\" style=\"line-height: 10px !important\"><span *ngIf=\"headerData?.client === '452'\"> More than {{clientData?.featureConfigs?.conversion?.value}} mins Rate</span><span *ngIf=\"headerData?.client !== '452'\">Conversion</span></td>\r\n                                <td class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.conversionRate.toFixed(0)}}%</td>\r\n                                <ng-container *ngIf=\"storeIdarray?.length !== 1\">\r\n                                <td *ngIf=\"type !== 'daily'\" class=\"value\" style=\"line-height: 10px !important\">{{tooltipData.conversionRate.toFixed(0)}}%</td>\r\n                                </ng-container>\r\n                              </tr>\r\n                            </tbody>\r\n                          </table>\r\n                        </div>\r\n                      </div>\r\n                      \r\n                  </div>\r\n        \r\n        \r\n                  <lib-pagination [itemsPerPage]=\"pageSizeTrends\" [currentPage]=\"offsetTrends\" [totalItems]=\"totalItemsTrends\"\r\n                  [paginationSizes]=\"paginationSizesTrends\" [pageSize]=\"pageSizeTrends\" (pageChange)=\"onPageChangeTrends($event)\"\r\n                  (pageSizeChange)=\"onPageSizeChangeTrends($event)\"></lib-pagination>\r\n               \r\n            </div>\r\n        </div>\r\n\r\n        <!-- <lib-traffic-charts class=\"my-2\"></lib-traffic-charts> -->\r\n        <div *ngIf=\"storeIdarray[0] !=='459-2'\" class=\"card mt-3\">\r\n            <div class=\"card-header my-3 mx-2\">\r\n                <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\r\n                    <li *ngIf=\"this.headerData?.client !=='459'\" class=\"nav-item nav-item1\" (click)=\"selectedTabs('traffic')\"><a\r\n                            [ngClass]=\"selectedTab ==='traffic' ? 'active' :''\"\r\n                            class=\"nav-link nav-link1 cursor-pointer no-border me-6 \">Traffic & Dwell</a>\r\n                    </li>\r\n                    <li class=\"nav-item nav-item1\" (click)=\"selectedTabs('footfall')\">\r\n                        <a [ngClass]=\"selectedTab ==='footfall' ? 'active' :''\"\r\n                            class=\"nav-link nav-link1 cursor-pointer me-6\">Footfall</a>\r\n                    </li>\r\n                    <li class=\"nav-item nav-item1\" (click)=\"selectedTabs('bounced')\"><a\r\n                        [ngClass]=\"selectedTab ==='bounced' ? 'active' :''\"\r\n                        class=\"nav-link nav-link1 cursor-pointer no-border me-6 \">{{headerData?.client ==='452' ? 'Less than '+ featureConfig?.bouncedLimit.value+ ' mins' : 'Bounced'}} Footfall</a>\r\n                </li>\r\n                <li class=\"nav-item nav-item1\" (click)=\"selectedTabs('engagers')\">\r\n                    <a [ngClass]=\"selectedTab ==='engagers' ? 'active' :''\"\r\n                        class=\"nav-link nav-link1 cursor-pointer me-6\">{{headerData?.client ==='452' ? 'More than '+ featureConfig?.bouncedLimit.value +' mins' : 'Engagers'}}</a>\r\n                </li>\r\n              \r\n                   \r\n                    <li class=\"nav-item nav-item1\" (click)=\"selectedTabs('missedOpportunity')\">\r\n                        <a [ngClass]=\"selectedTab ==='missedOpportunity' ? 'active' :''\"\r\n                            class=\"nav-link nav-link1 cursor-pointer me-6\">{{headerData?.client ==='452' ? featureConfig?.missedOpportunityFrom.value+' - '+ featureConfig?.missedOpportunityTo.value+ ' mins':'Missed Opportunity'}}</a>\r\n                    </li>\r\n                    <li *ngIf=\"headerData?.client !== '452'\" class=\"nav-item nav-item1\" (click)=\"selectedTabs('potentialBuyers')\">\r\n                        <a [ngClass]=\"selectedTab ==='potentialBuyers' ? 'active' :''\"\r\n                            class=\"nav-link nav-link1 cursor-pointer me-6\">Potential Buyer</a>\r\n                    </li>\r\n                    <li class=\"nav-item nav-item1\" (click)=\"selectedTabs('conversion')\"><a\r\n                        [ngClass]=\"selectedTab ==='conversion' ? 'active' :''\"\r\n                        class=\"nav-link nav-link1 cursor-pointer no-border me-6 \">{{headerData?.client === '452' ? 'More than '+ featureConfig?.conversion.value + ' mins':'Conversion'}}</a>\r\n                </li>\r\n                </ul>\r\n            </div>\r\n        \r\n            <div class=\"card-body\">\r\n                <div *ngIf=\"chartloading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                    <div class=\"shimmer\">\r\n                        <div class=\"wrapper\">\r\n                            <div class=\"stroke animate title\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n                            <div class=\"stroke animate description\"></div>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"shimmer\">\r\n                        <div class=\"wrapper\">\r\n                            <div class=\"stroke animate title\"></div>\r\n                            <div class=\"stroke animate link\"></div>\r\n                            <div class=\"stroke animate description\"></div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div *ngIf=\"chartNoData\" class=\"row\">\r\n                    <div class=\"col-lg-12 mb-3\">\r\n                        <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                            <img class=\"img-nodata\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                            <div class=\"nodata-title\">No data found</div>\r\n                            <div class=\"nodata-sub\">There is no result for this <span>{{headerData?.client ==='452' ? 'Analysis' : selctedValue}}</span></div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"row\" >\r\n                    <div class=\"col-md-2 h-100\" *ngIf=\"!chartloading && !chartNoData\">\r\n                        <div *ngIf=\"selectedTab ==='traffic'\" class=\"left-bar\">\r\n                            \r\n                            <div class=\"my-7\">\r\n                                <div class=\"d-flex align-items-center my-10 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <span class=\"w-100\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"25\" viewBox=\"0 0 24 25\" fill=\"none\">\r\n                                            <path d=\"M13 2.125L3 14.125H12L11 22.125L21 10.125H12L13 2.125Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg></span>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getDensityDwellData?.densityDwellCard?.busiestDay ?\r\n                                            getDensityDwellData?.densityDwellCard?.busiestDay :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Busiest Day</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-10 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <span class=\"w-100\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"25\" viewBox=\"0 0 24 25\" fill=\"none\">\r\n                                            <path d=\"M13 2.125L3 14.125H12L11 22.125L21 10.125H12L13 2.125Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg></span>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getDensityDwellData?.densityDwellCard?.busiestTime ?\r\n                                            getDensityDwellData?.densityDwellCard?.busiestTime :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Busiest Time</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-10 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <span class=\"w-100\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"25\" viewBox=\"0 0 24 25\" fill=\"none\">\r\n                                            <path d=\"M13 2.125L3 14.125H12L11 22.125L21 10.125H12L13 2.125Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg></span>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getDensityDwellData?.densityDwellCard?.avgDwellTime ?\r\n                                            getDensityDwellData?.densityDwellCard?.avgDwellTime :'--'}} Mins</div>\r\n                                        <div class=\"left-card-count-header\">Avg Dwell Time</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-10 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <span class=\"w-100\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"25\" viewBox=\"0 0 24 25\" fill=\"none\">\r\n                                            <path d=\"M13 2.125L3 14.125H12L11 22.125L21 10.125H12L13 2.125Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg></span>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getDensityDwellData?.densityDwellCard?.maleRate ?\r\n                                            getDensityDwellData?.densityDwellCard?.maleRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">Male</div>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getDensityDwellData?.densityDwellCard?.femaleRate ?\r\n                                            getDensityDwellData?.densityDwellCard?.femaleRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">Female</div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"selectedTab ==='footfall'\" class=\"left-bar\">\r\n                            <div class=\"top-header text-center\">\r\n                                <div class=\"left-bar-count\"  [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.footfallCard?.footfallCount.toLocaleString()?.length > 5 ? '24px' : '36px') \r\n                                  }\" >\r\n                                        {{getOverallCardData?.footfallCard?.footfallCount ?\r\n                                    getOverallCardData?.footfallCard?.footfallCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                <div class=\"left-bar-title\">Footfall Count</div>\r\n        \r\n                            </div>\r\n                            <span class=\"w-100\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"174\" height=\"2\"\r\n                                    viewBox=\"0 0 194 2\" fill=\"none\">\r\n                                    <path opacity=\"0.4\" d=\"M1 1L193 1\" stroke=\"#99DAFF\" stroke-linecap=\"round\" />\r\n                                </svg></span>\r\n                            <div class=\"my-5\">\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M20 21V19C20 17.9391 19.5786 16.9217 18.8284 16.1716C18.0783 15.4214 17.0609 15 16 15H8C6.93913 15 5.92172 15.4214 5.17157 16.1716C4.42143 16.9217 4 17.9391 4 19V21M16 7C16 9.20914 14.2091 11 12 11C9.79086 11 8 9.20914 8 7C8 4.79086 9.79086 3 12 3C14.2091 3 16 4.79086 16 7Z\"\r\n                                                stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                stroke-linejoin=\"round\" />\r\n                                        </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.footfallCard?.singleCount ?\r\n                                            getOverallCardData?.footfallCard?.singleCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Single</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"headerData.client !=='452'\" class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg width=\"26\" height=\"24\" viewBox=\"0 0 26 24\" fill=\"none\"\r\n                                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <rect width=\"26\" height=\"24\" fill=\"#DCDCDC\" />\r\n                                            <rect x=\"-460.5\" y=\"-340.5\" width=\"783\" height=\"1947\" rx=\"4.5\" stroke=\"#9747FF\"\r\n                                                stroke-dasharray=\"10 5\" />\r\n                                            <mask id=\"path-2-inside-1_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\"\r\n                                                fill=\"white\" />\r\n                                            <path\r\n                                                d=\"M-190 -89C-190 -96.1797 -184.18 -102 -177 -102H294C301.18 -102 307 -96.1797 307 -89C307 -95.0751 301.627 -100 295 -100H-177C-183.075 -100 -188 -95.0751 -188 -89H-190ZM307 85C307 92.1797 301.18 98 294 98H-177C-184.18 98 -190 92.1797 -190 85H-188C-188 91.0751 -183.075 96 -177 96H295C301.627 96 307 91.0751 307 85ZM-177 98C-184.18 98 -190 92.1797 -190 85V-89C-190 -96.1797 -184.18 -102 -177 -102V-100C-183.075 -100 -188 -95.0751 -188 -89V85C-188 91.0751 -183.075 96 -177 96V98ZM307 -101V97V-101Z\"\r\n                                                fill=\"#D0D5DD\" mask=\"url(#path-2-inside-1_707_13106)\" />\r\n                                            <mask id=\"path-6-inside-2_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\"\r\n                                                stroke=\"#98A2B3\" stroke-width=\"3\" mask=\"url(#path-6-inside-2_707_13106)\" />\r\n                                        </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.footfallCard?.groupCount ?\r\n                                            getOverallCardData?.footfallCard?.groupCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Group Footfall</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg width=\"26\" height=\"24\" viewBox=\"0 0 26 24\" fill=\"none\"\r\n                                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <rect width=\"26\" height=\"24\" fill=\"#DCDCDC\" />\r\n                                            <rect x=\"-460.5\" y=\"-340.5\" width=\"783\" height=\"1947\" rx=\"4.5\" stroke=\"#9747FF\"\r\n                                                stroke-dasharray=\"10 5\" />\r\n                                            <mask id=\"path-2-inside-1_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\"\r\n                                                fill=\"white\" />\r\n                                            <path\r\n                                                d=\"M-190 -89C-190 -96.1797 -184.18 -102 -177 -102H294C301.18 -102 307 -96.1797 307 -89C307 -95.0751 301.627 -100 295 -100H-177C-183.075 -100 -188 -95.0751 -188 -89H-190ZM307 85C307 92.1797 301.18 98 294 98H-177C-184.18 98 -190 92.1797 -190 85H-188C-188 91.0751 -183.075 96 -177 96H295C301.627 96 307 91.0751 307 85ZM-177 98C-184.18 98 -190 92.1797 -190 85V-89C-190 -96.1797 -184.18 -102 -177 -102V-100C-183.075 -100 -188 -95.0751 -188 -89V85C-188 91.0751 -183.075 96 -177 96V98ZM307 -101V97V-101Z\"\r\n                                                fill=\"#D0D5DD\" mask=\"url(#path-2-inside-1_707_13106)\" />\r\n                                            <mask id=\"path-6-inside-2_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\"\r\n                                                stroke=\"#98A2B3\" stroke-width=\"3\" mask=\"url(#path-6-inside-2_707_13106)\" />\r\n                                        </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.footfallCard?.ageGroup ?\r\n                                            getOverallCardData?.footfallCard?.ageGroup :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Most Common Age</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg width=\"26\" height=\"24\" viewBox=\"0 0 26 24\" fill=\"none\"\r\n                                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <rect width=\"26\" height=\"24\" fill=\"#DCDCDC\" />\r\n                                            <rect x=\"-460.5\" y=\"-340.5\" width=\"783\" height=\"1947\" rx=\"4.5\" stroke=\"#9747FF\"\r\n                                                stroke-dasharray=\"10 5\" />\r\n                                            <mask id=\"path-2-inside-1_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\"\r\n                                                fill=\"white\" />\r\n                                            <path\r\n                                                d=\"M-190 -89C-190 -96.1797 -184.18 -102 -177 -102H294C301.18 -102 307 -96.1797 307 -89C307 -95.0751 301.627 -100 295 -100H-177C-183.075 -100 -188 -95.0751 -188 -89H-190ZM307 85C307 92.1797 301.18 98 294 98H-177C-184.18 98 -190 92.1797 -190 85H-188C-188 91.0751 -183.075 96 -177 96H295C301.627 96 307 91.0751 307 85ZM-177 98C-184.18 98 -190 92.1797 -190 85V-89C-190 -96.1797 -184.18 -102 -177 -102V-100C-183.075 -100 -188 -95.0751 -188 -89V85C-188 91.0751 -183.075 96 -177 96V98ZM307 -101V97V-101Z\"\r\n                                                fill=\"#D0D5DD\" mask=\"url(#path-2-inside-1_707_13106)\" />\r\n                                            <mask id=\"path-6-inside-2_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\"\r\n                                                stroke=\"#98A2B3\" stroke-width=\"3\" mask=\"url(#path-6-inside-2_707_13106)\" />\r\n                                        </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.footfallCard?.maleRate ?\r\n                                            getOverallCardData?.footfallCard?.maleRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">Male</div>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.footfallCard?.femaleRate ?\r\n                                            getOverallCardData?.footfallCard?.femaleRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">Female</div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"selectedTab ==='conversion'\" class=\"left-bar\">\r\n                            <div class=\"top-header text-center\">\r\n                                <div class=\"left-bar-count\" [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.conversionCard?.conversionCount.toLocaleString()?.length > 5 ? '24px' : '36px') \r\n                                  }\">{{getOverallCardData?.conversionCard?.conversionCount ?\r\n                                    getOverallCardData?.conversionCard?.conversionCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                <div class=\"left-bar-title\">{{headerData?.client ==='452' ? 'More than '+ featureConfig?.conversion.value+ ' mins' :'Conversion'}} Count</div>\r\n        \r\n                            </div>\r\n                            <span class=\"w-100\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"174\" height=\"2\"\r\n                                    viewBox=\"0 0 194 2\" fill=\"none\">\r\n                                    <path opacity=\"0.4\" d=\"M1 1L193 1\" stroke=\"#99DAFF\" stroke-linecap=\"round\" />\r\n                                </svg></span>\r\n                            <div class=\"my-5\">\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.conversionCard?.conversionRate ?\r\n                                            getOverallCardData?.conversionCard?.conversionRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">{{headerData?.client ==='452' ? 'More than ' + featureConfig?.conversion.value + ' mins' :'Conversion'}} Rate</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"this.objDataTraffic.nob === false\" class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.conversionCard?.minRate ?\r\n                                            getOverallCardData?.conversionCard?.minRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">5 - 15 Mins</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"this.objDataTraffic.nob === false\" class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.conversionCard?.maxRate ?\r\n                                            getOverallCardData?.conversionCard?.maxRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">15 - 60 Mins</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"this.objDataTraffic.nob === false\" class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.conversionCard?.averageRate ?\r\n                                            getOverallCardData?.conversionCard?.averageRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">1 Hr or more</div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"selectedTab ==='engagers'\" class=\"left-bar\">\r\n                            <div class=\"top-header text-center\">\r\n                                <div class=\"left-bar-count\" [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.engagersCard?.engagersCount.toLocaleString()?.length > 5 ? '24px' : '36px') \r\n                                  }\">{{getOverallCardData?.engagersCard?.engagersCount ?\r\n                                    getOverallCardData?.engagersCard?.engagersCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                <div class=\"left-bar-title\">{{headerData?.client ==='452' ? 'More than ' + featureConfig?.bouncedLimit.value + ' mins' :'Engagers'}} Count</div>\r\n        \r\n                            </div>\r\n                            <div class=\"my-5\">\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.engagersCard?.engagersRate ?\r\n                                            getOverallCardData?.engagersCard?.engagersRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">{{headerData?.client ==='452' ? 'More than ' + featureConfig?.bouncedLimit.value + ' mins' :'Engagers'}} Rate</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.engagersCard?.avgDwellTime ?\r\n                                            getOverallCardData?.engagersCard?.avgDwellTime :'--'}} Mins</div>\r\n                                        <div class=\"left-card-count-header\">Avg dwell Time</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.engagersCard?.highEngagementZone ?\r\n                                            getOverallCardData?.engagersCard?.highEngagementZone :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">High Engagement Zone</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.engagersCard?.lowEngagementZone ?\r\n                                            getOverallCardData?.engagersCard?.lowEngagementZone :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Low Engagement Zone</div>\r\n                                    </div>\r\n                                   \r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"selectedTab ==='bounced'\" class=\"left-bar\">\r\n                            <div class=\"top-header text-center\">\r\n                                <div class=\"left-bar-count\" [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.bouncedCard?.bouncedCount.toLocaleString()?.length > 5 ? '24px' : '36px') \r\n                                  }\">{{getOverallCardData?.bouncedCard?.bouncedCount ?\r\n                                    getOverallCardData?.bouncedCard?.bouncedCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                <div class=\"left-bar-title\">{{headerData?.client ==='452' ? 'Less than ' + featureConfig?.bouncedLimit.value + ' mins':'Bounced'}} Count</div>\r\n        \r\n                            </div>\r\n                            <div class=\"my-5\">\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.bouncedCard?.bouncedRate ?\r\n                                            getOverallCardData?.bouncedCard?.bouncedRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">{{headerData?.client ==='452' ? 'Less than ' + featureConfig?.bouncedLimit.value+' mins':'Bounced'}} Rate</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.bouncedCard?.peakBouncedHour ?\r\n                                            getOverallCardData?.bouncedCard?.peakBouncedHour :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Peak {{headerData?.client ==='452' ? 'Less than '+ featureConfig?.bouncedLimit.value + ' mins':'Bounced'}}</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.bouncedCard?.mostCommonAge ?\r\n                                            getOverallCardData?.bouncedCard?.mostCommonAge :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Most Common Age</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.bouncedCard?.maleRate ?\r\n                                            getOverallCardData?.bouncedCard?.maleRate :'--'}} %</div>\r\n                                        <div class=\"left-card-count-header\">Male</div>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.bouncedCard?.femaleRate ?\r\n                                            getOverallCardData?.bouncedCard?.femaleRate :'--'}} %</div>\r\n                                        <div class=\"left-card-count-header\">Female</div>\r\n                                    </div>\r\n                                   \r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"selectedTab ==='potentialBuyers'\" class=\"left-bar\">\r\n                            <div class=\"top-header text-center\">\r\n                                <div class=\"left-bar-count\" [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.potentialBuyersCard?.potentialBuyersCount.toLocaleString()?.length > 5 ? '24px' : '36px') \r\n                                  }\">{{getOverallCardData?.potentialBuyersCard?.potentialBuyersCount ?\r\n                                    getOverallCardData?.potentialBuyersCard?.potentialBuyersCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                <div class=\"left-bar-title\">Potential Buyers</div>\r\n        \r\n                            </div>\r\n                            <div class=\"my-5\">\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.potentialBuyersCard?.potentialBuyersRate ?\r\n                                            getOverallCardData?.potentialBuyersCard?.potentialBuyersRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">Buyers Rate</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M20 21V19C20 17.9391 19.5786 16.9217 18.8284 16.1716C18.0783 15.4214 17.0609 15 16 15H8C6.93913 15 5.92172 15.4214 5.17157 16.1716C4.42143 16.9217 4 17.9391 4 19V21M16 7C16 9.20914 14.2091 11 12 11C9.79086 11 8 9.20914 8 7C8 4.79086 9.79086 3 12 3C14.2091 3 16 4.79086 16 7Z\"\r\n                                                stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                stroke-linejoin=\"round\" />\r\n                                        </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.potentialBuyersCard?.singleCount ?\r\n                                            getOverallCardData?.potentialBuyersCard?.singleCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Single</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg width=\"26\" height=\"24\" viewBox=\"0 0 26 24\" fill=\"none\"\r\n                                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <rect width=\"26\" height=\"24\" fill=\"#DCDCDC\" />\r\n                                            <rect x=\"-460.5\" y=\"-340.5\" width=\"783\" height=\"1947\" rx=\"4.5\" stroke=\"#9747FF\"\r\n                                                stroke-dasharray=\"10 5\" />\r\n                                            <mask id=\"path-2-inside-1_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M-189 -89C-189 -95.6274 -183.627 -101 -177 -101H295C301.627 -101 307 -95.6274 307 -89V85C307 91.6274 301.627 97 295 97H-177C-183.627 97 -189 91.6274 -189 85V-89Z\"\r\n                                                fill=\"white\" />\r\n                                            <path\r\n                                                d=\"M-190 -89C-190 -96.1797 -184.18 -102 -177 -102H294C301.18 -102 307 -96.1797 307 -89C307 -95.0751 301.627 -100 295 -100H-177C-183.075 -100 -188 -95.0751 -188 -89H-190ZM307 85C307 92.1797 301.18 98 294 98H-177C-184.18 98 -190 92.1797 -190 85H-188C-188 91.0751 -183.075 96 -177 96H295C301.627 96 307 91.0751 307 85ZM-177 98C-184.18 98 -190 92.1797 -190 85V-89C-190 -96.1797 -184.18 -102 -177 -102V-100C-183.075 -100 -188 -95.0751 -188 -89V85C-188 91.0751 -183.075 96 -177 96V98ZM307 -101V97V-101Z\"\r\n                                                fill=\"#D0D5DD\" mask=\"url(#path-2-inside-1_707_13106)\" />\r\n                                            <mask id=\"path-6-inside-2_707_13106\" fill=\"white\">\r\n                                                <path\r\n                                                    d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\" />\r\n                                            </mask>\r\n                                            <path\r\n                                                d=\"M7.71064 7.38462C8.19552 7.38462 8.67565 7.28911 9.12362 7.10356C9.57159 6.918 9.97863 6.64603 10.3215 6.30316C10.6644 5.9603 10.9363 5.55326 11.1219 5.10529C11.3074 4.65732 11.4029 4.17719 11.4029 3.69231C11.4029 3.20743 11.3074 2.72729 11.1219 2.27932C10.9363 1.83135 10.6644 1.42431 10.3215 1.08145C9.97863 0.73859 9.57159 0.466616 9.12362 0.28106C8.67565 0.0955043 8.19552 -7.22529e-09 7.71064 0C6.73138 1.45921e-08 5.79222 0.38901 5.09978 1.08145C4.40734 1.77389 4.01833 2.71305 4.01833 3.69231C4.01833 4.67157 4.40734 5.61072 5.09978 6.30316C5.79222 6.99561 6.73138 7.38462 7.71064 7.38462ZM18.7876 7.38462C19.2724 7.38462 19.7526 7.28911 20.2005 7.10356C20.6485 6.918 21.0556 6.64603 21.3984 6.30316C21.7413 5.9603 22.0133 5.55326 22.1988 5.10529C22.3844 4.65732 22.4799 4.17719 22.4799 3.69231C22.4799 3.20743 22.3844 2.72729 22.1988 2.27932C22.0133 1.83135 21.7413 1.42431 21.3984 1.08145C21.0556 0.73859 20.6485 0.466616 20.2005 0.28106C19.7526 0.0955043 19.2724 -7.22529e-09 18.7876 0C17.8083 1.45921e-08 16.8691 0.38901 16.1767 1.08145C15.4843 1.77389 15.0953 2.71305 15.0953 3.69231C15.0953 4.67157 15.4843 5.61072 16.1767 6.30316C16.8691 6.99561 17.8083 7.38462 18.7876 7.38462ZM0.941406 10.736C0.941406 10.4575 0.996258 10.1818 1.10283 9.92448C1.2094 9.66719 1.3656 9.43342 1.56252 9.2365C1.75944 9.03958 1.99321 8.88338 2.2505 8.77681C2.50778 8.67024 2.78354 8.61539 3.06202 8.61539H8.98448C8.55169 9.36345 8.32452 10.2127 8.32602 11.0769C8.32519 11.7755 8.47341 12.4662 8.76079 13.1029C9.04816 13.7396 9.46807 14.3077 9.99248 14.7692H8.60048C8.01418 14.7687 7.43803 14.9222 6.92969 15.2144C6.42134 15.5065 5.99864 15.927 5.70387 16.4338C3.7211 16.0449 2.51618 15.0782 1.81464 13.992C0.941406 12.64 0.941406 11.2431 0.941406 11.0012V10.736ZM17.8977 14.7692C18.484 14.7687 19.0602 14.9222 19.5685 15.2144C20.0769 15.5065 20.4996 15.927 20.7943 16.4338C22.7771 16.0449 23.982 15.0782 24.6836 13.992C25.5568 12.64 25.5568 11.2431 25.5568 11.0012V10.7366C25.5569 10.4581 25.5021 10.1823 25.3955 9.9249C25.289 9.66755 25.1328 9.4337 24.9359 9.23672C24.739 9.03973 24.5052 8.88348 24.2478 8.77687C23.9905 8.67026 23.7147 8.61539 23.4362 8.61539H17.5137C17.9465 9.36345 18.1737 10.2127 18.1722 11.0769C18.173 11.7755 18.0248 12.4662 17.7374 13.1029C17.45 13.7396 17.0301 14.3077 16.5057 14.7692H17.8977ZM16.9414 11.0769C16.9414 12.0562 16.5524 12.9953 15.86 13.6878C15.1675 14.3802 14.2284 14.7692 13.2491 14.7692C12.2698 14.7692 11.3307 14.3802 10.6382 13.6878C9.9458 12.9953 9.55679 12.0562 9.55679 11.0769C9.55679 10.0977 9.9458 9.15851 10.6382 8.46607C11.3307 7.77363 12.2698 7.38462 13.2491 7.38462C14.2284 7.38462 15.1675 7.77363 15.86 8.46607C16.5524 9.15851 16.9414 10.0977 16.9414 11.0769ZM6.47987 18.1206C6.47987 17.5582 6.70329 17.0188 7.10098 16.6211C7.49867 16.2234 8.03806 16 8.60048 16H17.8977C18.4601 16 18.9995 16.2234 19.3972 16.6211C19.7949 17.0188 20.0183 17.5582 20.0183 18.1206V18.3858C20.0183 18.6283 20.0183 20.0246 19.1451 21.3766C18.2325 22.7895 16.4694 24 13.2491 24C10.0288 24 8.26571 22.7895 7.3531 21.3766C6.47987 20.0246 6.47987 18.6277 6.47987 18.3858V18.1206Z\"\r\n                                                stroke=\"#98A2B3\" stroke-width=\"3\" mask=\"url(#path-6-inside-2_707_13106)\" />\r\n                                        </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.potentialBuyersCard?.groupCount ?\r\n                                            getOverallCardData?.potentialBuyersCard?.groupCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Group</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.potentialBuyersCard?.mostCommonAge ?\r\n                                            getOverallCardData?.potentialBuyersCard?.mostCommonAge :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Most Common Age</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.potentialBuyersCard?.maleRate ?\r\n                                            getOverallCardData?.potentialBuyersCard?.maleRate :'--'}} %</div>\r\n                                        <div class=\"left-card-count-header\">Male</div>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.potentialBuyersCard?.femaleRate ?\r\n                                            getOverallCardData?.potentialBuyersCard?.femaleRate :'--'}} %</div>\r\n                                        <div class=\"left-card-count-header\">Female</div>\r\n                                    </div>\r\n                                   \r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                        <div *ngIf=\"selectedTab ==='missedOpportunity'\" class=\"left-bar\">\r\n                            <div class=\"top-header text-center\">\r\n                                <div class=\"left-bar-count\" [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.missedOpportunityCard?.missedOpportunityCount.toLocaleString()?.length > 5 ? '24px' : '36px') \r\n                                  }\">{{getOverallCardData?.missedOpportunityCard?.missedOpportunityCount ?\r\n                                    getOverallCardData?.missedOpportunityCard?.missedOpportunityCount.toLocaleString('en-IN') :'--'}}</div>\r\n                                <div class=\"left-bar-title\">{{headerData?.client ==='452' ?  featureConfig?.missedOpportunityFrom.value+' - '+ featureConfig?.missedOpportunityTo.value + ' mins' :'Missed opportunity'}} Count</div>\r\n        \r\n                            </div>\r\n                            <div class=\"my-5\">\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.missedOpportunityCard?.missedOpportunityRate ?\r\n                                            getOverallCardData?.missedOpportunityCard?.missedOpportunityRate :'--'}}%</div>\r\n                                        <div class=\"left-card-count-header\">{{headerData?.client ==='452' ?  featureConfig?.missedOpportunityFrom.value+ ' - ' +featureConfig?.missedOpportunityTo.value + ' mins' :'Missed opportunity'}} Rate</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"headerData?.client !=='452'\" class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\" [ngStyle]=\"{\r\n                                    'font-size': (getOverallCardData?.missedOpportunityCard?.potentialRevenueLoss.toLocaleString()?.length > 8 ? '16px' : '18px')}\"><span class=\"me-1\" *ngIf=\"getOverallCardData?.missedOpportunityCard?.currency ==='inr'\">₹</span>\r\n                                            <span class=\"me-1\" *ngIf=\"getOverallCardData?.missedOpportunityCard?.currency ==='dollar'\">$</span>\r\n                                            <span class=\"me-1\" *ngIf=\"getOverallCardData?.missedOpportunityCard?.currency ==='aed'\">د.إ</span>\r\n                                            {{getOverallCardData?.missedOpportunityCard?.potentialRevenueLoss ?\r\n                                            getOverallCardData?.missedOpportunityCard?.potentialRevenueLoss.toLocaleString('en-IN') :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Potential Loss Revenue</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.missedOpportunityCard?.lowConversionZone ?\r\n                                            getOverallCardData?.missedOpportunityCard?.lowConversionZone :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Low Conversion Zone</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.missedOpportunityCard?.mostCommonAge ?\r\n                                            getOverallCardData?.missedOpportunityCard?.mostCommonAge :'--'}}</div>\r\n                                        <div class=\"left-card-count-header\">Most Common Age</div>\r\n                                    </div>\r\n                                </div>\r\n                                <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                    <div class=\"flex-shrink-0 mt-3\">\r\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n                                            <path d=\"M13 2L3 14H12L11 22L21 10H12L13 2Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </svg>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.missedOpportunityCard?.maleRate ?\r\n                                            getOverallCardData?.missedOpportunityCard?.maleRate :'--'}} %</div>\r\n                                        <div class=\"left-card-count-header\">Male</div>\r\n                                    </div>\r\n                                    <div class=\"mx-3 mt-1\">\r\n                                        <div class=\"my-1 card-label left-card-count\">\r\n                                            {{getOverallCardData?.missedOpportunityCard?.femaleRate ?\r\n                                            getOverallCardData?.missedOpportunityCard?.femaleRate :'--'}} %</div>\r\n                                        <div class=\"left-card-count-header\">Female</div>\r\n                                    </div>\r\n                                   \r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                  \r\n                    <div *ngIf=\"selectedTab ==='traffic' && !chartloading && !chartNoData\" class=\"col-md-10 h-100 \">\r\n                        <div class=\"row px-0\">\r\n                            \r\n                            <div class=\"col-md-6 mt-3 px-0\">\r\n                               \r\n                            <div class=\"card-header border-0 pt-3\">\r\n                                <h3 class=\"card-title align-items-start flex-column\">\r\n                                    <span class=\"card-label\">Traffic Density <svg placement=\"right\"\r\n                                        ngbTooltip=\"Traffic analysis distribution across the days\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                        <g clip-path=\"url(#clip0_3352_688)\">\r\n                                        <path d=\"M7.9987 10.6667V8.00004M7.9987 5.33337H8.00536M14.6654 8.00004C14.6654 11.6819 11.6806 14.6667 7.9987 14.6667C4.3168 14.6667 1.33203 11.6819 1.33203 8.00004C1.33203 4.31814 4.3168 1.33337 7.9987 1.33337C11.6806 1.33337 14.6654 4.31814 14.6654 8.00004Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                        </g>\r\n                                        <defs>\r\n                                        <clipPath id=\"clip0_3352_688\">\r\n                                        <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n                                        </clipPath>\r\n                                        </defs>\r\n                                        </svg></span>\r\n                                    <span class=\"text-sub mb-2\">Based on {{getDensityDwellData?.fromDate | date:'dd MMM, yyyy'}} – {{getDensityDwellData?.toDate | date:'dd MMM, yyyy'}} </span>\r\n            \r\n                                </h3>\r\n                                \r\n                            </div>\r\n                                <div id=\"trafficHeatmapChart\"></div>\r\n                            </div>\r\n                            <div class=\"col-md-6 mt-3 px-0\">\r\n                                <div class=\"card-header border-0 pt-3\">\r\n                                    <h3 class=\"card-title align-items-start flex-column\">\r\n                                        <span class=\"card-label\">Dwell Time Split <svg placement=\"right\"\r\n                                            ngbTooltip=\"Time-distributed footfall with demographics\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <g clip-path=\"url(#clip0_3352_688)\">\r\n                                            <path d=\"M7.9987 10.6667V8.00004M7.9987 5.33337H8.00536M14.6654 8.00004C14.6654 11.6819 11.6806 14.6667 7.9987 14.6667C4.3168 14.6667 1.33203 11.6819 1.33203 8.00004C1.33203 4.31814 4.3168 1.33337 7.9987 1.33337C11.6806 1.33337 14.6654 4.31814 14.6654 8.00004Z\" stroke=\"#98A2B3\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                                            </g>\r\n                                            <defs>\r\n                                            <clipPath id=\"clip0_3352_688\">\r\n                                            <rect width=\"16\" height=\"16\" fill=\"white\"/>\r\n                                            </clipPath>\r\n                                            </defs>\r\n                                            </svg></span>\r\n                                        <span class=\"text-sub mb-2\">Based on {{getDensityDwellData?.fromDate | date:'dd MMM, yyyy'}} – {{getDensityDwellData?.toDate | date:'dd MMM, yyyy'}} </span>\r\n                \r\n                                    </h3>\r\n                                    <div class=\"card-toolbar text-nowrap\">\r\n                                        <select class=\"form-select form-select-sm w-auto dropselect\" id=\"dateSelect\"\r\n                                        (change)=\"onDateChange($event)\" [(ngModel)]=\"footfallDate\">\r\n                                        <option *ngFor=\"let dataset of trafficData\" [value]=\"dataset.value\">{{ dataset.label }}</option>\r\n                                    </select>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"!chartDwellNoData && !chartDwellloading\">\r\n                                <div id=\"dwellBarChart\"></div>\r\n                                </div>\r\n                                <div *ngIf=\"chartDwellNoData\" class=\"row\">\r\n                                    <div class=\"col-lg-12 mt-20 mb-6\">\r\n                                        <div class=\" mt-20 card-body d-flex justify-content-center align-items-center flex-column\">\r\n                                            <img class=\"img-nodata-table\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                            <div class=\"nodata-title\">No data found</div>\r\n                                            <div class=\"nodata-sub\">There is no result for this Dwell Time Split</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                    <div *ngIf=\"!chartloading && !chartNoData && (selectedTab ==='footfall' || selectedTab ==='conversion' || selectedTab ==='engagers' || selectedTab ==='bounced' || selectedTab ==='potentialBuyers' || selectedTab ==='missedOpportunity')\" class=\"col-md-10 h-100 right-bar border-1\">\r\n                        \r\n        \r\n                        <div *ngIf=\"(footfallValue ==='footfall' || footfallValue ==='conversion' || footfallValue ==='engagers'\r\n                        || footfallValue ==='missedOpportunity' || footfallValue ==='potentialBuyers' || footfallValue ==='bounced' || footfallValue ==='demographic' || footfallValue ==='buyer') && !detailedCharts\"\r\n                            class=\"row\">\r\n                           <div *ngIf=\"selectedTab !=='potentialBuyers'\">\r\n                            <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap my-2 mx-2\">\r\n                            <li class=\"nav-item nav-item1\" *ngFor=\"let dataset of datasetsCard\" (click)=\"onDatasetChange(dataset.value)\">\r\n                                <a [ngClass]=\"footfallValue ===dataset.value ? 'active' :''\"\r\n                                    class=\"nav-link nav-link1 cursor-pointer me-6\">{{ dataset.label }}</a>\r\n                            </li>\r\n                            </ul>\r\n                            <!-- <ul class=\"nav nav-tabs\">\r\n                                <li class=\"nav-item\" >\r\n                                    <a class=\"nav-link\" [class.active]=\"selectedTab === dataset.label\">{{ dataset.label }}</a>\r\n                                </li>\r\n                            </ul> -->\r\n                            <!-- <select class=\"form-select form-select-sm w-auto m-3 dropselect\" id=\"datasetSelect\" [(ngModel)]=\"footfallValue\"\r\n                            (change)=\"onDatasetChange($event)\">\r\n                            <option *ngFor=\"let dataset of datasets\" [value]=\"dataset.value\">{{ dataset.label }}</option>\r\n                        </select>  -->\r\n                       \r\n                        </div> \r\n                        <div class=\"left-bar-title fw-bold mt-5 mb-2 ms-3\" *ngIf=\"selectedTab ==='potentialBuyers'\">{{selctedValue}}</div>\r\n                            <span class=\"ms-3 text-sub\">Based on {{headerData?.date?.startDate | date:'dd MMM, yyyy'}} – {{headerData?.date?.endDate | date:'dd MMM, yyyy'}} </span>\r\n                            <div *ngIf=\"footfallValue ==='demographic' && !detailedCharts\" class=\"col-md-12\">\r\n                                <div *ngIf=\"!demoNoData && !demoloading\">\r\n                                    <div class=\"text-center\" id=\"demoGraphics\"></div>\r\n                                </div>                     \r\n                                <div *ngIf=\"demoloading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                                    <div class=\"shimmer\">\r\n                                        <div class=\"wrapper\">\r\n                                            <div class=\"stroke animate title\"></div>\r\n                                            <div class=\"stroke animate link\"></div>\r\n                                            <div class=\"stroke animate description\"></div>\r\n                                        </div>\r\n                                    </div>\r\n                                    <div class=\"shimmer\">\r\n                                        <div class=\"wrapper\">\r\n                                            <div class=\"stroke animate title\"></div>\r\n                                            <div class=\"stroke animate link\"></div>\r\n                                            <div class=\"stroke animate description\"></div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"demoNoData\" class=\"row\">\r\n                                    <div class=\"col-lg-12 mb-3\">\r\n                                        <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                                            <img class=\"demo-img-nodata\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                            <div class=\"nodata-title\">No data found</div>\r\n                                            <div class=\"nodata-sub\">There is no result for this Demographic Analysis</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                            <div *ngIf=\"footfallValue ==='buyer' && !detailedCharts\" class=\"col-md-12\">\r\n                                <div *ngIf=\"!buyersNoData && !buyersloading\">\r\n                                    <div class=\"text-center\" id=\"buyersCharts\"></div>\r\n        \r\n                                </div>                     \r\n                                <div *ngIf=\"buyersloading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                                    <div class=\"shimmer\">\r\n                                        <div class=\"wrapper\">\r\n                                            <div class=\"stroke animate title\"></div>\r\n                                            <div class=\"stroke animate link\"></div>\r\n                                            <div class=\"stroke animate description\"></div>\r\n                                        </div>\r\n                                    </div>\r\n                                    <div class=\"shimmer\">\r\n                                        <div class=\"wrapper\">\r\n                                            <div class=\"stroke animate title\"></div>\r\n                                            <div class=\"stroke animate link\"></div>\r\n                                            <div class=\"stroke animate description\"></div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                                <div *ngIf=\"buyersNoData\" class=\"row\">\r\n                                    <div class=\"col-lg-12 mb-3\">\r\n                                        <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                                            <img class=\"demo-img-nodata\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                            <div class=\"nodata-title\">No data found</div>\r\n                                            <div class=\"nodata-sub\">There is no result for this Buyer Analysis</div>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                            <section *ngIf=\"this.objDataTraffic.nob === true && selectedTab ==='conversion'\">\r\n                                <div class=\"text-center mt-3 mx-3\" id=\"testGraphics\"></div>\r\n                                <lib-pagination [itemsPerPage]=\"pageSizeTrafficCard\" [currentPage]=\"offsetTrafficCard\" [totalItems]=\"totalItemsTrafficCard\"\r\n                                [paginationSizes]=\"paginationSizesTrafficCard\" [pageSize]=\"pageSizeTrafficCard\" (pageChange)=\"onPageChangeTrafficCard($event)\"\r\n                                (pageSizeChange)=\"onPageSizeChangeTrafficCard($event)\"></lib-pagination>\r\n                            </section>\r\n        <section *ngIf=\"(this.objDataTraffic.nob === true && selectedTab !=='conversion' || this.objDataTraffic.nob === false) \">\r\n                            <div *ngIf=\"footfallValue ==='footfall' || footfallValue ==='conversion' || footfallValue ==='engagers' \r\n                            || footfallValue ==='missedOpportunity' || footfallValue ==='potentialBuyers' || footfallValue ==='bounced' && !detailedCharts\" \r\n                            class=\"chart-container px-3 mt-3\">\r\n                        <div class=\"text-center\" id=\"testGraphics\"></div>\r\n                        <lib-pagination [itemsPerPage]=\"pageSizeTrafficCard\" [currentPage]=\"offsetTrafficCard\" [totalItems]=\"totalItemsTrafficCard\"\r\n                        [paginationSizes]=\"paginationSizesTrafficCard\" [pageSize]=\"pageSizeTrafficCard\" (pageChange)=\"onPageChangeTrafficCard($event)\"\r\n                        (pageSizeChange)=\"onPageSizeChangeTrafficCard($event)\"></lib-pagination>\r\n                    </div>\r\n                    <div *ngIf=\"footfallValue ==='footfall' || footfallValue ==='conversion' || footfallValue ==='engagers' \r\n                            || footfallValue ==='missedOpportunity' || footfallValue ==='potentialBuyers' || footfallValue ==='bounced' && !detailedCharts\" \r\n                            class=\"heatmap-container element\">\r\n                        <div id=\"heatmapchart\"></div>\r\n                    </div>\r\n                    </section>\r\n                    \r\n                            <!-- <div *ngIf=\"footfallValue ==='footfall' || footfallValue ==='conversion' || footfallValue ==='engagers'\r\n                        || footfallValue ==='missedOpportunity' || footfallValue ==='potentialBuyers' || footfallValue ==='bounced' && !detailedCharts\" class=\"col-md-9 chart-container mt-3\">\r\n                                <div class=\"text-center\" id=\"testGraphics\"></div>\r\n                            </div>\r\n                            <div *ngIf=\"footfallValue ==='footfall' || footfallValue ==='conversion' || footfallValue ==='engagers'\r\n                        || footfallValue ==='missedOpportunity' || footfallValue ==='potentialBuyers' || footfallValue ==='bounced' && !detailedCharts\" class=\"col-md-3 mt-3 me-0 pe-0\">\r\n                                <div id=\"heatmapchart\"></div>\r\n                            </div> -->\r\n        \r\n                        </div>\r\n                        <div *ngIf=\"detailedCharts\" class=\"row\">\r\n                            <div class=\"d-flex align-items-center my-5 me-2\">\r\n                                <div class=\"flex-shrink-0 mt-3\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"backToFootfall()\">\r\n                                        <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\"\r\n                                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <g filter=\"url(#filter0_d_2585_7036)\">\r\n                                                <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\r\n                                                <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\r\n                                                <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\r\n                                                    stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                                    stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                            <defs>\r\n                                                <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\r\n                                                    filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n                                                    <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\r\n                                                    <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\r\n                                                        values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\r\n                                                    <feOffset dy=\"1\" />\r\n                                                    <feGaussianBlur stdDeviation=\"1\" />\r\n                                                    <feColorMatrix type=\"matrix\"\r\n                                                        values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\r\n                                                    <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\r\n                                                        result=\"effect1_dropShadow_2585_7036\" />\r\n                                                    <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\r\n                                                        result=\"shape\" />\r\n                                                </filter>\r\n                                            </defs>\r\n                                        </svg>\r\n                                    </span>\r\n                                </div>\r\n                                <div class=\"mx-3 mt-1\">\r\n                                    <div class=\"my-1 card-label left-card-count\"><span class=\"text-primary cursor-pointer text-decoration-underline\" (click)=\"storeView(storeId)\">{{storeName}}</span><span class=\"ms-2\">Footfall Trend</span></div>\r\n                                    <div class=\"left-card-count-header text-sub\">Based on {{headerData?.date?.startDate | date:'dd MMM, yyyy'}} - {{headerData?.date?.endDate | date:'dd MMM, yyyy'}}</div>\r\n                                </div>\r\n                            </div>\r\n                            <div class=\"col-md-12 mx-5\">\r\n                                <div class=\"text-center\" id=\"detailedChartDiv\"></div>\r\n                            </div>\r\n                        </div>\r\n               \r\n                    </div>\r\n                </div>\r\n        \r\n            </div>\r\n        </div>\r\n        <!-- <lib-traffic-card-charts class=\"my-2\"></lib-traffic-card-charts> -->\r\n         <div *ngIf=\"headerData?.client !=='452'\">\r\n        <lib-image-doc *ngIf=\"storeIdarray?.length === 1 && (clientData?.featureConfigs?.isFootfallDirectory || (gs.userAccess | async)?.userType === 'tango')\" class=\"my-2\"></lib-image-doc>\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"storeIdarray?.length > 1\" class=\"col-md-6 mt-3\">\r\n        <div class=\"card h-100\">\r\n            <div class=\"card-header border-0 pt-3\">\r\n                <h3 class=\"card-title align-items-start flex-column\">\r\n                    <span class=\"title-text mb-2\">Performance Matrix\r\n                         <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\"\r\n                            height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" placement=\"right\"\r\n                            ngbTooltip=\"Store performance based on metrics selected\">\r\n                            <g clip-path=\"url(#clip0_1432_80035)\">\r\n                                <path\r\n                                    d=\"M8.00065 10.6666V7.99992M8.00065 5.33325H8.00732M14.6673 7.99992C14.6673 11.6818 11.6826 14.6666 8.00065 14.6666C4.31875 14.6666 1.33398 11.6818 1.33398 7.99992C1.33398 4.31802 4.31875 1.33325 8.00065 1.33325C11.6826 1.33325 14.6673 4.31802 14.6673 7.99992Z\"\r\n                                    stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                            </g>\r\n                            <defs>\r\n                                <clipPath id=\"clip0_1432_80035\">\r\n                                    <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                                </clipPath>\r\n                            </defs>\r\n                        </svg>\r\n                    </span>\r\n                    <span class=\"text-sub mb-2\">{{headerData?.date?.startDate | date:'dd MMM, yyyy'}} – {{headerData?.date?.endDate | date:'dd MMM, yyyy'}}</span>\r\n                </h3>\r\n                <div class=\"card-toolbar\">\r\n                    \r\n                </div>\r\n            </div>\r\n            <div class=\"row mx-3 align-items-center w-75\">\r\n                <div class=\"d-flex align-items-center ms-3\">\r\n                  <select class=\"form-select-sm form-select me-2 dropselect\" [(ngModel)]=\"footfallValue1\" (change)=\"onValueChange($event)\">\r\n                    <option *ngFor=\"let obj of getFilteredFootfallDatasets()\" [id]=\"obj.label\" [value]=\"obj.value\">{{obj.label}}</option>\r\n                  </select>\r\n                  <span class=\"mx-2\">Vs</span>\r\n                  <select class=\"form-select-sm form-select ms-2 dropselect\" [(ngModel)]=\"bounceValue1\" (change)=\"onBounceChange($event)\">\r\n                    <option *ngFor=\"let obj of getFilteredBounceDatasets()\" [id]=\"obj.label\" [value]=\"obj.value\">{{obj.label}}</option>\r\n\r\n                  </select>\r\n                </div>\r\n              </div>\r\n              <div *ngIf=\"performanceLoading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                <div class=\"shimmer\">\r\n                    <div class=\"wrapper\">\r\n                        <div class=\"stroke animate title\"></div>\r\n                        <div class=\"stroke animate link\"></div>\r\n                        <div class=\"stroke animate description\"></div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"shimmer\">\r\n                    <div class=\"wrapper\">\r\n                        <div class=\"stroke animate title\"></div>\r\n                        <div class=\"stroke animate link\"></div>\r\n                        <div class=\"stroke animate description\"></div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"performancenoData\" class=\"row\">\r\n                <div class=\"col-lg-12 mt-20 mb-6\">\r\n                    <div class=\" mt-20 card-body d-flex justify-content-center align-items-center flex-column\">\r\n                        <img class=\"img-nodata-table\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                        <div class=\"nodata-title\">No data found</div>\r\n                        <div *ngIf=\"headerData?.client !=='452'\" class=\"nodata-sub\">There is no result for this {{footfallLabel | titlecase}} vs {{bounceLabel | titlecase}}</div>\r\n                        <div *ngIf=\"headerData?.client ==='452'\" class=\"nodata-sub\">There is no result for this Performance Matrix</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"!performanceLoading && !performancenoData\" class=\"card-body\">\r\n               \r\n            <div class=\"quadrant-chart z-1\">\r\n                <div class=\"axis-labels\">\r\n                    <!-- X Axis Label -->\r\n                    <div class=\"x-axis-label\">\r\n                      <span>{{bounceLabel | titlecase}} -></span>\r\n                    </div>\r\n                    <!-- Y Axis Label -->\r\n                    <div class=\"y-axis-label\">\r\n                      <span>{{footfallLabel | titlecase}} -></span>\r\n                    </div>\r\n                  </div>\r\n   <!-- Top Left Quadrant -->\r\n   <div class=\"quadrant\" id=\"q1\">\r\n    <span  *ngIf=\"headerData?.client !=='452'\" class=\"label1\">High <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, Low <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel | titlecase}}</span></span> \r\n            <span *ngIf=\"headerData?.client ==='452'\" class=\"label1\"><span *ngIf=\"footfallLabel==='Footfall'\">High </span> <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, <span *ngIf=\"bounceLabel==='Footfall'\">Low </span> <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel | titlecase}}</span></span>\r\n</div>\r\n\r\n<!-- Top Right Quadrant -->\r\n<div class=\"quadrant\" id=\"q2\">\r\n    <span *ngIf=\"headerData?.client !=='452'\" class=\"label1\">High <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, High <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel | titlecase}}</span></span>\r\n            <span *ngIf=\"headerData?.client ==='452'\" class=\"label1\"><span *ngIf=\"footfallLabel==='Footfall'\">High </span> <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, <span *ngIf=\"bounceLabel==='Footfall'\">High </span> <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel | titlecase}}</span></span>        \r\n</div>\r\n\r\n<!-- Bottom Left Quadrant -->\r\n<div class=\"quadrant\" id=\"q3\">\r\n    <span *ngIf=\"headerData?.client !=='452'\"  class=\"label1\">Low <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, Low <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel | titlecase}}</span></span>\r\n            <span *ngIf=\"headerData?.client ==='452'\" class=\"label1\"><span *ngIf=\"footfallLabel==='Footfall'\">Low </span>  <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, <span *ngIf=\"bounceLabel==='Footfall'\">Low </span> <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel | titlecase}}</span></span>\r\n\r\n</div>\r\n\r\n<!-- Bottom Right Quadrant -->\r\n<div class=\"quadrant\" id=\"q4\">\r\n    <span *ngIf=\"headerData?.client !=='452'\"  class=\"label1\">Low <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, High <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel| titlecase}}</span></span>\r\n            <span *ngIf=\"headerData?.client ==='452'\" class=\"label1\"><span *ngIf=\"footfallLabel==='Footfall'\">Low </span> <span *ngIf=\"footfallLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"footfallLabel !=='Bounced Footfall'\">{{footfallLabel | titlecase}}</span>, <span *ngIf=\"bounceLabel==='Footfall'\">High </span> <span\r\n            *ngIf=\"bounceLabel==='Bounced Footfall'\">{{headerData?.client ==='452'?'Less than '+ featureConfig?.bouncedLimit.value+ ' mins':'Bounce'}}</span><span\r\n            *ngIf=\"bounceLabel !=='Bounced Footfall'\">{{bounceLabel| titlecase}}</span></span>\r\n</div>\r\n  \r\n                <div *ngFor=\"let point of points\" class=\"point\" [ngStyle]=\"{'top': point.top + '%', 'left': point.left + '%'}\">\r\n                    <div class=\"text-center\" (click)=\"toggleTooltip(point.name)\">\r\n                    <div class=\"dot\" ></div>\r\n                    <!-- Clickable label that toggles the tooltip -->\r\n                    <div class=\"label z-1 mt-4\"  style=\"font-size: 10px !important;\" >\r\n                      {{ point.name }}\r\n                    </div>\r\n                </div>\r\n                    <!-- Custom Tooltip Popup -->\r\n                    <div class=\"tooltip-popup z-5\" *ngIf=\"activeTooltip === point.name\">\r\n                      <div class=\"tooltip-content\">\r\n                        <h3 class=\"text-white cursor-pointer\" (click)=\"storeView(point.storeId)\">{{ point.name }}</h3>\r\n                        <p>Avg {{footfallLabel | titlecase}}: {{ point.avgFootfall }}</p>\r\n                        <p class=\"my-2\">Open Time: <strong>{{ point.openTime }}</strong></p>\r\n                        <p>Close Time: <strong>{{ point.closeTime }}</strong></p>\r\n                      </div>\r\n                      <div class=\"tooltip-arrow\"></div>\r\n                    </div>\r\n                  </div>\r\n                <!-- Add more points here -->\r\n              </div>\r\n              \r\n              </div>\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"storeIdarray?.length > 1\" class=\"col-md-6 mt-3\">\r\n        <div class=\"card\">\r\n            <div class=\"card-header px-5 border-0 pt-3\">\r\n                <h3 class=\"card-title align-items-start flex-column\">\r\n                    <span class=\"title-text mb-2\">Zone Dwell Time Split \r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\"\r\n                            height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\"\r\n                            placement=\"right\"\r\n                            ngbTooltip=\"Overall zone concentration and average dwell time across selected stores\">\r\n                            <g clip-path=\"url(#clip0_1432_80035)\">\r\n                                <path\r\n                                    d=\"M8.00065 10.6666V7.99992M8.00065 5.33325H8.00732M14.6673 7.99992C14.6673 11.6818 11.6826 14.6666 8.00065 14.6666C4.31875 14.6666 1.33398 11.6818 1.33398 7.99992C1.33398 4.31802 4.31875 1.33325 8.00065 1.33325C11.6826 1.33325 14.6673 4.31802 14.6673 7.99992Z\"\r\n                                    stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                            </g>\r\n                            <defs>\r\n                                <clipPath id=\"clip0_1432_80035\">\r\n                                    <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                                </clipPath>\r\n                            </defs>\r\n                        </svg>\r\n                    </span>\r\n                    <span class=\"text-sub mb-2\">{{headerData?.date?.startDate | date:'dd MMM, yyyy'}} – {{headerData?.date?.endDate | date:'dd MMM, yyyy'}}</span>\r\n                </h3>\r\n                <div class=\"card-toolbar\">\r\n                    <button  type=\"button\" (click)=\"goToZone()\"\r\n                    class=\"btn btn-light-primary1 rounded-3 text-nowrap border-val\">\r\n                    <span class=\"ms-2\">Go to Zones</span>\r\n                </button>\r\n                   \r\n                </div>\r\n            </div>\r\n            <div calss=\"card-body\">\r\n                <div *ngIf=\"!zoneLoading && !zoneNoData\" class=\"image-container position-relative\">\r\n                    <img  src=\"assets/tango/Images/zone-img.svg\" alt=\"Store Layout\" class=\"px-5 img-src my-3 background-image\" />\r\n                    <!-- <img *ngIf=\"zoneDwellTimeSplitData[0]?.zoneName ==='Overall Store'\" src=\"assets/tango/Images/zone-img1.svg\" alt=\"Store Layout\" class=\"px-5 img-src my-3 background-image\" /> -->\r\n                    <!-- <div class=\"centered\">Centered</div> -->\r\n                    <!-- <div class=\"overlay-content\" *ngFor=\"let point of zoneDwellTimeSplitData\"> -->\r\n                      <div *ngIf=\"zoneDwellTimeSplitData[0]?.zoneName !=='Overall Store'\" class=\"top-zone\">\r\n                       <div class=\"text-center text-zone\">{{zoneDwellTimeSplitData[0]?.zoneName ? zoneDwellTimeSplitData[0]?.zoneName :'Front'}}</div>\r\n                       <span class=\"text-zone-val\"> Conc: {{ zoneDwellTimeSplitData[0]?.concentrationRate ? zoneDwellTimeSplitData[0]?.concentrationRate:'--' }}% </span>\r\n                       <span class=\"text-zone-val\">Dwell time: {{ zoneDwellTimeSplitData[0]?.dwellTime ? zoneDwellTimeSplitData[0]?.dwellTime :'--' }} Mins</span>\r\n                      </div>\r\n                      <div *ngIf=\"zoneDwellTimeSplitData[0]?.zoneName ==='Overall Store'\" class=\"centered-zone\">\r\n                        <div class=\"text-center text-zone\">{{zoneDwellTimeSplitData[0]?.zoneName ? zoneDwellTimeSplitData[0]?.zoneName :'Front'}}</div>\r\n                        <span class=\"text-zone-val\"> Conc: {{ zoneDwellTimeSplitData[0]?.concentrationRate ? zoneDwellTimeSplitData[0]?.concentrationRate:'--' }}% </span>\r\n                        <span class=\"text-zone-val\">Dwell time: {{ zoneDwellTimeSplitData[0]?.dwellTime ? zoneDwellTimeSplitData[0]?.dwellTime:'--' }} Mins</span>\r\n                       </div>\r\n                       <div *ngIf=\"zoneDwellTimeSplitData[0]?.zoneName !=='Overall Store'\" class=\"bottom-zone \">\r\n                        <div class=\"text-center text-zone\">{{zoneDwellTimeSplitData[1]?.zoneName ? zoneDwellTimeSplitData[2]?.zoneName  : 'Back'}}</div>\r\n                        <span class=\"text-zone-val\"> Conc: {{ zoneDwellTimeSplitData[1]?.concentrationRate ? zoneDwellTimeSplitData[2]?.concentrationRate:'--' }}% </span>\r\n                        <span class=\"text-zone-val\">Dwell time: {{ zoneDwellTimeSplitData[1]?.dwellTime ? zoneDwellTimeSplitData[2]?.dwellTime:'--'}} Mins</span>\r\n                       </div>\r\n                    <!-- </div> -->\r\n                    </div>\r\n                    <div *ngIf=\"zoneLoading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                        <div class=\"shimmer\">\r\n                            <div class=\"wrapper\">\r\n                                <div class=\"stroke animate title\"></div>\r\n                                <div class=\"stroke animate link\"></div>\r\n                                <div class=\"stroke animate description\"></div>\r\n                            </div>\r\n                        </div>\r\n                        <div class=\"shimmer\">\r\n                            <div class=\"wrapper\">\r\n                                <div class=\"stroke animate title\"></div>\r\n                                <div class=\"stroke animate link\"></div>\r\n                                <div class=\"stroke animate description\"></div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                    <div *ngIf=\"zoneNoData\" class=\"row\">\r\n                        <div class=\"col-lg-12 mb-6 \">\r\n                            <div *ngIf=\"normalize\" class=\"mt-5 card-body right-bar py-20 mx-5 d-flex justify-content-center align-items-center flex-column\">\r\n                                <img class=\"img-nodata-zone\" src=\"./assets/tango/Icons/not-applicable.svg\" alt=\"\">\r\n                                <div class=\"nodata-title mt-3\">Data Not Found</div>\r\n                                <div class=\"nodata-sub\">Normalized data is not applicable</div>\r\n                            </div>\r\n                            <div *ngIf=\"!normalize\" class=\"mt-5 card-body right-bar py-20 mx-5 d-flex justify-content-center align-items-center flex-column\">\r\n                                <img class=\"img-nodata-zone\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                                <div class=\"nodata-title\">No data found</div>\r\n                                <div  class=\"nodata-sub\">There is no result for this Zone Dwell Time Split</div>\r\n\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                <!-- <img class=\"px-5 img-src mb-3\" src=\"assets/tango/Images/zone-img.svg\" alt=\"\"> -->\r\n    </div>\r\n    <div class=\"card-header px-5 border-0 pt-3\">\r\n        <h3 class=\"card-title align-items-start flex-column\">\r\n            <span class=\"title-text mb-2\">Store Operations\r\n                <span > \r\n                <svg ngbTooltip=\"Avg store open & close time across the selected stores\" placement=\"top\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\"\r\n                    height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" >\r\n                    <g clip-path=\"url(#clip0_1432_80035)\">\r\n                        <path\r\n                            d=\"M8.00065 10.6666V7.99992M8.00065 5.33325H8.00732M14.6673 7.99992C14.6673 11.6818 11.6826 14.6666 8.00065 14.6666C4.31875 14.6666 1.33398 11.6818 1.33398 7.99992C1.33398 4.31802 4.31875 1.33325 8.00065 1.33325C11.6826 1.33325 14.6673 4.31802 14.6673 7.99992Z\"\r\n                            stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                    </g>\r\n                    <defs>\r\n                        <clipPath id=\"clip0_1432_80035\">\r\n                            <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                        </clipPath>\r\n                    </defs>\r\n                </svg>\r\n                </span>\r\n            </span>\r\n            <span class=\"text-sub mb-2\">{{headerData?.date?.startDate | date:'dd MMM, yyyy'}} – {{headerData?.date?.endDate | date:'dd MMM, yyyy'}}</span>\r\n        </h3>\r\n        <div class=\"card-toolbar\">\r\n            <!-- <button  type=\"button\"\r\n            class=\"btn btn-light-primary1 rounded-3 text-nowrap border-val\">\r\n            <span class=\"ms-2\">Go to Trax</span>\r\n        </button> -->\r\n        </div>\r\n    </div>\r\n    <div class=\"card-body\">\r\n        <div class=\"row\">\r\n            <div class=\"col-md-3 text-center mb-3\">\r\n                <div class=\"row\">\r\n                    <div class=\"col-md-12\"><!--{{getCardData?.revenue?.value ?? '--'}} -->\r\n                        <div class=\"my-2\"> <span class=\"left-card-count-title\">{{storeOperationData?.overall?.avgOpenTime\r\n                                ?storeOperationData?.overall?.avgOpenTime:'--' }}</span></div>\r\n                        <div class=\"\"><span class=\"sub-header\">Avg. Open Time</span></div>\r\n                    </div>\r\n    \r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-6 mt-5 mb-3\">\r\n                <svg width=\"326\" height=\"2\" viewBox=\"0 0 326 2\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                    <line y1=\"0.75\" x2=\"356\" y2=\"0.75\" stroke=\"#D0D5DD\" />\r\n                </svg>\r\n            </div>\r\n            <div class=\"col-md-3 text-center mb-3\">\r\n                <div class=\"row\">\r\n                    <div class=\"col-md-12\"><!--{{getCardData?.revenue?.value ?? '--'}} -->\r\n                        <div class=\"my-2\"> <span class=\"left-card-count-title\">{{storeOperationData?.overall?.avgCloseTime\r\n                                ?storeOperationData?.overall?.avgCloseTime:'--' }}</span></div>\r\n                        <div class=\"\"><span class=\"sub-header\">Avg. Close Time</span></div>\r\n                    </div>\r\n    \r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-6 mt-3\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"card-header ellipse1 border-0 px-3\">\r\n                        <h3 class=\"card-title align-items-start flex-column \">\r\n                            <span class=\"left-card-count-header1 text-decoration-underline cursor-pointer\"  (click)=\"storeView(storeOperationData?.topLateOpen?.storeId)\">{{storeOperationData?.topLateOpen?.storeName ?\r\n                                storeOperationData?.topLateOpen?.storeName :'--'}}</span>\r\n                            <span class=\"sub-header mt-2\">Top Late Open</span>\r\n                        </h3>\r\n                    </div>\r\n                    <div class=\"card-body p-0 h-75px mt-3 mx-3\">\r\n                        <div class=\"row\">\r\n                            <div class=\"col-md-12\"><!--{{getCardData?.revenue?.value ?? '--'}} -->\r\n                                <div class=\"my-1\"> <span\r\n                                        class=\"left-card-count-header1\">{{storeOperationData?.topLateOpen?.avgStoreOpenTime\r\n                                        ?storeOperationData?.topLateOpen?.avgStoreOpenTime:'--' }}</span></div>\r\n                                <span class=\"sub-header\">Avg. Store Opening Time</span>\r\n                            </div>\r\n    \r\n                        </div>\r\n                    </div>\r\n    \r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-6 mt-3\">\r\n                <div class=\"card card-border h-100\">\r\n                    <div class=\"card-header ellipse1 border-0 px-3\">\r\n                        <h3 class=\"card-title align-items-start flex-column \">\r\n                            <span class=\"left-card-count-header1 text-decoration-underline cursor-pointer\" (click)=\"storeView(storeOperationData?.topEarlyClose?.storeId)\">{{storeOperationData?.topEarlyClose?.storeName ?\r\n                                storeOperationData?.topEarlyClose?.storeName :'--'}}</span>\r\n                            <span class=\"sub-header mt-2\">Top Early Close</span>\r\n                        </h3>\r\n                    </div>\r\n                    <div class=\"card-body p-0 h-75px mt-3 mx-3\">\r\n                        <div class=\"row\">\r\n                            <div class=\"col-md-12\"><!--{{getCardData?.revenue?.value ?? '--'}} -->\r\n                                <div class=\"my-1\"> <span\r\n                                        class=\"left-card-count-header1\">{{storeOperationData?.topEarlyClose?.avgStoreCloseTime\r\n                                        ?storeOperationData?.topEarlyClose?.avgStoreCloseTime:'--' }}</span></div>\r\n                                <span class=\"sub-header\">Avg. Store Closing Time</span>\r\n                            </div>\r\n    \r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"storeIdarray[0] !=='459-2'\" class=\"col-md-12 mt-3\">\r\n        <div class=\"card mb-5\">\r\n            <div class=\"card-header border-0 pt-3\">\r\n                <h3 class=\"card-title align-items-start flex-column\">\r\n                    <span class=\"title-text mb-2\">Summary Table</span>\r\n                    <span class=\"text-sub mb-2\">{{headerData?.date?.startDate | date:'dd MMM, yyyy'}} – {{headerData?.date?.endDate | date:'dd MMM, yyyy'}}</span>\r\n                </h3>\r\n                <div class=\"card-toolbar\">\r\n                    <div class=\"d-flex\">\r\n                        <div class=\"d-flex align-items-center position-relative my-1\">\r\n                            <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n                                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\"\r\n                                    fill=\"none\">\r\n                                    <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\" height=\"2\" rx=\"1\"\r\n                                        transform=\"rotate(45 17.0365 15.1223)\" fill=\"currentColor\"></rect>\r\n                                    <path\r\n                                        d=\"M11 19C6.55556 19 3 15.4444 3 11C3 6.55556 6.55556 3 11 3C15.4444 3 19 6.55556 19 11C19 15.4444 15.4444 19 11 19ZM11 5C7.53333 5 5 7.53333 5 11C5 14.4667 7.53333 17 11 17C14.4667 17 17 14.4667 17 11C17 7.53333 14.4667 5 11 5Z\"\r\n                                        fill=\"currentColor\"></path>\r\n                                </svg>\r\n                            </span>\r\n                            <input (change)=\"searchData()\" [(ngModel)]=\"searchValue\" type=\"text\" class=\"form-control ps-14 me-2\" autocomplete=\"off\" placeholder=\"Search\" />\r\n                            <!-- filter Start -->\r\n                            <!-- <lib-filters [dataObject]=\"dataObject\" (appliedFilters)=\"applyFilters($event)\"></lib-filters> -->\r\n                            <!-- filter End -->\r\n                         <!-- Sum Button -->\r\n                         <section *ngIf=\"(storeIdarray?.length > 1 && headerData?.date?.startDate !== headerData?.date?.endDate) && !noData && !loading\">\r\n                            <button type=\"button\" (click)=\"onValueType('sum')\"\r\n                              class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\"\r\n                              [ngClass]=\"{'btn-light btn-primary text-white': typeValue === 'sum'}\">\r\n                              <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\"\r\n                                [ngStyle]=\"{'stroke': typeValue === 'sum' ? '#FFFFFF' : '#344054'}\">\r\n                                <path d=\"M9.99935 4.16675V15.8334M4.16602 10.0001H15.8327\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                  stroke-linejoin=\"round\" />\r\n                              </svg>\r\n                              <span class=\"ms-2\" [ngClass]=\"{'text-white': typeValue === 'sum'}\">Sum</span>\r\n                            </button>\r\n                          </section>\r\n                          \r\n<!-- Average Button -->\r\n <section *ngIf=\"(storeIdarray?.length > 1 && headerData?.date?.startDate !== headerData?.date?.endDate) \r\n && !noData && !loading\">\r\n<button type=\"button\" (click)=\"onValueType('average')\"\r\nclass=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\"\r\n[ngClass]=\"{'btn-light btn-primary text-white': typeValue === 'average'}\">\r\n<svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n  [ngStyle]=\"{'stroke': typeValue === 'average' ? '#FFFFFF' : '#101828'}\">\r\n  <path d=\"M17.5 17.5H8.33333C5.58333 17.5 4.20833 17.5 3.35417 16.6458C2.5 15.7917 2.5 14.4167 2.5 11.6667V2.5M5 10H5.0075M7.49917 10H7.50583M9.9975 10H10.0042M12.4958 10H12.5033M14.9942 10H15.0017M17.4925 10H17.5\"\r\n    stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n  <path\r\n    d=\"M5 5.83341C5.56083 4.89841 6.3225 4.16675 7.49417 4.16675C12.4467 4.16675 9.6625 14.1667 14.985 14.1667C16.165 14.1667 16.9217 13.4301 17.5 12.5001\"\r\n    stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n</svg>\r\n<span class=\"ms-2\" [ngClass]=\"{'text-white': typeValue === 'average'}\">Average</span>\r\n</button>\r\n</section>\r\n                          \r\n                            <button *ngIf=\"!noData && !loading\" type=\"button\" (click)=\"exportXLSX()\"\r\n                                class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\"><svg\r\n                                    xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\"\r\n                                    fill=\"none\">\r\n                                    <path\r\n                                        d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n                                        stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                        stroke-linejoin=\"round\" />\r\n                                </svg><span class=\"ms-2\">Export</span> </button>\r\n    \r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"loading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                <div class=\"shimmer\">\r\n                    <div class=\"wrapper\">\r\n                        <div class=\"stroke animate title\"></div>\r\n                        <div class=\"stroke animate link\"></div>\r\n                        <div class=\"stroke animate description\"></div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"shimmer\">\r\n                    <div class=\"wrapper\">\r\n                        <div class=\"stroke animate title\"></div>\r\n                        <div class=\"stroke animate link\"></div>\r\n                        <div class=\"stroke animate description\"></div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"noData\" class=\"row\">\r\n                <div class=\"col-lg-12 mb-3\">\r\n                    <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                        <img class=\"img-nodata-table\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                        <div class=\"nodata-title\">No data found</div>\r\n                        <div class=\"nodata-sub\">There is no result for this summary table</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"!noData && !loading\" calss=\"card-body\">\r\n                <div class=\"table-responsive\">\r\n                    <table class=\"w-100 table bottom-border text-nowrap\">\r\n                        <thead>\r\n                            <tr>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('storeName')\">Store Name <svg \r\n                                        [ngClass]=\"sortedColumn === 'storeName' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'storeName' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('storeId')\">Store ID <svg  [ngClass]=\"sortedColumn === 'storeId' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'storeId' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"storeIdarray?.length === 1\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('date')\">Date <svg [ngClass]=\"sortedColumn === 'date' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'date' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('footfallCount')\">Footfall <svg [ngClass]=\"sortedColumn === 'footfallCount' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'footfallCount' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('bouncedCount')\">{{headerData?.client ==='452'?'Less than '+ this.featureConfig?.bouncedLimit.value +' mins':'Bounced'}} Footfall<svg [ngClass]=\"sortedColumn === 'bouncedCount' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                            fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'bouncedCount' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('engagersCount')\">{{headerData?.client ==='452'? 'More than '+ featureConfig?.bouncedLimit.value +' mins':'Engagers'}} <svg [ngClass]=\"sortedColumn === 'engagersCount' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n                                            fill=\"none\"> \r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'engagersCount' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('missedOpportunityCount')\">{{headerData?.client ==='452'? featureConfig?.missedOpportunityFrom.value + ' - ' +featureConfig?.missedOpportunityTo.value +' mins':'Missed Opportunity'}}<svg [ngClass]=\"sortedColumn === 'missedOpportunityCount' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'missedOpportunityCount' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"headerData?.client !=='452'\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('potentialBuyersCount')\">Potential Buyers <svg [ngClass]=\"sortedColumn === 'potentialBuyersCount' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'potentialBuyersCount' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('conversionRate')\">{{headerData?.client ==='452'?'More than '+ featureConfig?.conversion.value + ' mins':'Conversion'}} Rate <svg [ngClass]=\"sortedColumn === 'conversionRate' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'conversionRate' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('NOBCount')\">NOB Count <svg [ngClass]=\"sortedColumn === 'NOBCount' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'NOBCount' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('avgDwellTime')\">Avg.Dwell Time <svg [ngClass]=\"sortedColumn === 'avgDwellTime' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'avgDwellTime' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('avgInfraDowntime')\">Avg.Infra DownTime <svg [ngClass]=\"sortedColumn === 'avgInfraDowntime' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'avgInfraDowntime' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('passerBy_count')\">Passer By<svg [ngClass]=\"sortedColumn === 'passerBy_count' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'passerBy_count' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('below12')\">Below12 <svg [ngClass]=\"sortedColumn === 'below12' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'below12' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('13-19')\">13-19 <svg [ngClass]=\"sortedColumn === '13-19' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '13-19' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('20-30')\">20-30 <svg [ngClass]=\"sortedColumn === '20-30' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '20-30' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"headerData?.client ==='193'\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('31-40')\">31-40 <svg [ngClass]=\"sortedColumn === '31-40' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '31-40' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"headerData?.client ==='193'\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('41-50')\">41-50 <svg [ngClass]=\"sortedColumn === '41-50' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '41-50' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"headerData?.client ==='193'\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('51-60')\">51-60 <svg [ngClass]=\"sortedColumn === '51-60' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '51-60' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"headerData?.client !=='193'\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('31-45')\">31-45 <svg [ngClass]=\"sortedColumn === '31-45' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '31-45' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th *ngIf=\"headerData?.client !=='193'\" class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('46-59')\">46-59 <svg [ngClass]=\"sortedColumn === '46-59' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '46-59' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('60 above')\">60 above <svg [ngClass]=\"sortedColumn === '60 above' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === '60 above' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('male')\">Male <svg [ngClass]=\"sortedColumn === 'male' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'male' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                                <th class=\"cursor-pointer\">\r\n                                    <span class=\"cursor-pointer\" (click)=\"onSort('female')\">Female <svg \r\n                                        [ngClass]=\"sortedColumn === 'female' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\" height=\"16\"\r\n                                            viewBox=\"0 0 16 16\" fill=\"none\">\r\n                                            <path\r\n                                                d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n                                                [attr.stroke]=\"sortedColumn === 'female' ? '#00A3FF' : '#667085'\"\r\n                                                stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                                        </svg></span>\r\n                                </th>\r\n                            </tr>\r\n                        </thead>\r\n                        <tbody>\r\n                            <tr *ngFor=\"let obj of getSummaryTableData;let i=index;\">\r\n                                <!-- (click)=\"storeView(obj)\" -->\r\n                                <td class=\"text-primary text-capitalize text-decoration-underline cursor-pointer\" (click)=\"storeView(obj.storeId)\">{{obj.storeName}}</td>\r\n                                <td>{{obj.storeId}}</td>\r\n                                <td *ngIf=\"obj?.date\">{{obj?.date | date:'MMM dd, yyyy'}}</td>\r\n                                <td>{{obj.footfallCount}}</td>\r\n                                <td>{{obj.bouncedCount}}</td>\r\n                                <td>{{obj.engagersCount}}</td>\r\n                                <td>{{obj.missedOpportunityCount}}</td>\r\n                                <td *ngIf=\"headerData?.client !=='452'\">{{obj.potentialBuyersCount}}</td>\r\n                                <td>{{obj.conversionRate}}%</td>\r\n                                <td>{{obj.NOBCount}}</td>\r\n                                <td>{{obj.avgDwellTime}}</td>\r\n                                <td>{{obj.avgInfraDowntime}}</td>\r\n                                <td>{{obj.passerBy_count}}</td>\r\n                                <td>{{obj.below12}}</td>\r\n                                <td>{{obj['13-19']}}</td>\r\n                                <td>{{obj['20-30']}}</td>\r\n                                <td *ngIf=\"headerData?.client ==='193'\">{{obj['31-40']}}</td>\r\n                                <td *ngIf=\"headerData?.client ==='193'\">{{obj[\"41-50\"]}}</td>\r\n                                <td *ngIf=\"headerData?.client ==='193'\">{{obj[\"51-60\"]}}</td>\r\n                                <td *ngIf=\"headerData?.client !=='193'\">{{obj['31-45']}}</td>\r\n                                <td *ngIf=\"headerData?.client !=='193'\">{{obj[\"46-59\"]}}</td>\r\n                                <td>{{obj[\"60 above\"]}}</td>\r\n                                <td>{{obj.male}}</td>\r\n                                <td>{{obj.female}}</td>\r\n                            </tr>\r\n                        </tbody>\r\n                    </table>\r\n                </div>\r\n                <lib-pagination [itemsPerPage]=\"pageSize\" [currentPage]=\"offset\" [totalItems]=\"totalItems\"\r\n                [paginationSizes]=\"paginationSizes\" [pageSize]=\"pageSize\" (pageChange)=\"onPageChange($event)\"\r\n                (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n            </div>\r\n        </div>\r\n    </div>\r\n\r\n</div>\r\n"]}
|