tango-app-ui-analyse-zone 3.7.1-beta.12 → 3.7.1-beta.13
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/overallcards/overallcards.component.mjs +3 -3
- package/esm2022/lib/components/tango-analyse-zone/tango-analyse-zone.component.mjs +2 -2
- package/esm2022/lib/components/zone-v2/customer-journey/customer-journey.component.mjs +41 -32
- package/esm2022/lib/components/zone-v2/store-heatmap/store-heatmap.component.mjs +4 -5
- package/esm2022/lib/components/zone-v2/summary-table/summary-table.component.mjs +3 -3
- package/esm2022/lib/components/zone-v2/zones-cards/zones-cards.component.mjs +4 -3
- package/fesm2022/tango-app-ui-analyse-zone.mjs +699 -690
- package/fesm2022/tango-app-ui-analyse-zone.mjs.map +1 -1
- package/lib/components/zone-v2/customer-journey/customer-journey.component.d.ts +3 -0
- package/package.json +1 -1
|
@@ -5,6 +5,7 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
import * as i1 from "../../services/zonev2.service";
|
|
6
6
|
import * as i2 from "tango-app-ui-global";
|
|
7
7
|
import * as i3 from "@angular/router";
|
|
8
|
+
import * as i4 from "@angular/common";
|
|
8
9
|
export class ZonesCardsComponent {
|
|
9
10
|
Zonev2Service;
|
|
10
11
|
changeDetector;
|
|
@@ -55,10 +56,10 @@ export class ZonesCardsComponent {
|
|
|
55
56
|
});
|
|
56
57
|
}
|
|
57
58
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ZonesCardsComponent, deps: [{ token: i1.Zonev2Service }, { token: i0.ChangeDetectorRef }, { token: i2.GlobalStateService }, { token: i3.Router }, { token: i3.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component });
|
|
58
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ZonesCardsComponent, selector: "lib-zones-cards", ngImport: i0, template: "<div class=\"col-md-12\">\r\n <div class=\"row d-flex justify-content-between align-items-stretch\">\r\n\r\n <!-- Total Store Footfall Card -->\r\n <div class=\"col px-2\">\r\n <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.footfall?.count ? zoneCardsData?.footfall?.count?.toLocaleString('en-US', { minimumFractionDigits: 0 }) : '--'}}</span>\r\n <span class=\"cardtext\">Total Store Footfall</span>\r\n </h3>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"h-auto py-3 px-3\">\r\n <div class=\"cardcount my-2\">{{zoneCardsData?.footfall?.zoneName ? zoneCardsData?.footfall?.zoneName
|
|
59
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ZonesCardsComponent, selector: "lib-zones-cards", ngImport: i0, template: "<div class=\"col-md-12\">\r\n <div class=\"row d-flex justify-content-between align-items-stretch\">\r\n\r\n <!-- Total Store Footfall Card -->\r\n <div class=\"col px-2\">\r\n <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.footfall?.count ? zoneCardsData?.footfall?.count?.toLocaleString('en-US', { minimumFractionDigits: 0 }) : '--'}}</span>\r\n <span class=\"cardtext\">Total Store Footfall</span>\r\n </h3>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"h-auto py-3 px-3\">\r\n <div class=\"cardcount my-2\">{{zoneCardsData?.footfall?.zoneName ? (zoneCardsData?.footfall?.zoneName | titlecase) : '--'}}</div>\r\n <div class=\"cardtext\">Zone with the <br> Highest Footfall <span class=\"subcount\">- {{zoneCardsData?.footfall?.zoneFootfallCount ? zoneCardsData?.footfall?.zoneFootfallCount?.toLocaleString('en-US', { minimumFractionDigits: 0 }) : '--'}}</span></div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Highest Impression Card -->\r\n <div class=\"col px-2\">\r\n <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.impression?.rate ? zoneCardsData?.impression?.rate + '%' : '--'}}</span>\r\n <span class=\"cardtext\">Highest Store impression</span>\r\n </h3>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"h-auto py-3 px-3\">\r\n <div class=\"cardcount my-2\">\r\n \r\n {{zoneCardsData?.impression?.zoneName ?(zoneCardsData?.impression?.zoneName | titlecase) : '--'}}\r\n \r\n </div>\r\n <div class=\"cardtext\">Zone with <span class=\"subcount\">{{zoneCardsData?.impression?.zoneImpressionRate ? zoneCardsData?.impression?.zoneImpressionRate + '%' : '--'}}</span> <br> impression</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Total Bounced Rate Card -->\r\n <div class=\"col px-2\">\r\n <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.bounced?.rate ? zoneCardsData?.bounced?.rate + '%' : '--'}}</span>\r\n <span class=\"cardtext\">Top Zone Bounced Rate</span>\r\n </h3>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"h-auto py-3 px-3\">\r\n <div class=\"cardcount my-2\">\r\n \r\n {{zoneCardsData?.bounced?.zoneName ? zoneCardsData?.bounced?.zoneName : '--'}}\r\n \r\n </div>\r\n <div class=\"cardtext\">Zone with the <br> Highest Bounced rate</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Engagers Rate Card -->\r\n <div class=\"col px-2\">\r\n <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.engagers?.rate ? zoneCardsData?.engagers?.rate + '%' : '--'}}</span>\r\n <span class=\"cardtext\">Top Engagers Zone Rate</span>\r\n </h3>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"h-auto py-3 px-3\">\r\n <div class=\"cardcount my-2\">\r\n \r\n {{zoneCardsData?.engagers?.zoneName ? zoneCardsData?.engagers?.zoneName : '--'}}\r\n \r\n </div>\r\n <div class=\"cardtext\">Zone with the <br> Highest Engager Rate</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Average Dwell Time Card -->\r\n <div class=\"col px-2\">\r\n <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.avgDwellTime?.rate ? zoneCardsData?.avgDwellTime?.rate + ' Mins' : '--'}}</span>\r\n <span class=\"cardtext\">Average Top Zone Dwell Time</span>\r\n </h3>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"h-auto py-3 px-3\">\r\n <div class=\"cardcount my-2\">{{zoneCardsData?.avgDwellTime?.zoneName ? zoneCardsData?.avgDwellTime?.zoneName : '--'}}</div>\r\n <div class=\"cardtext\">Zone with the <br> Highest Dwell Time</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n</div>\r\n", styles: [".ellipse1{border-radius:6px;border-bottom:2px solid var(--Gray-200, #EAECF0);background:radial-gradient(206.89% 107.47% at 16.16% 32.77%,#fff6,#45bbfe33),#f2f4f7;box-shadow:0 4px 10px #0000000d}.cardcount{color:var(--Gray-900, #101828);font-size:20px;font-style:normal;font-weight:700;line-height:30px}.cardtext{color:var(--Gray-700, #344054);font-size:14px;font-style:normal;font-weight:500;line-height:21px}.subcount{color:var(--Gray-700, #344054);font-size:14px;font-style:normal;font-weight:700;line-height:20px}.card-border{padding:8px;border-radius:12px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF)}.zonecard{width:130%;background:var(--White, #FFF)}\n"], dependencies: [{ kind: "pipe", type: i4.TitleCasePipe, name: "titlecase" }] });
|
|
59
60
|
}
|
|
60
61
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ZonesCardsComponent, decorators: [{
|
|
61
62
|
type: Component,
|
|
62
|
-
args: [{ selector: 'lib-zones-cards', template: "<div class=\"col-md-12\">\r\n <div class=\"row d-flex justify-content-between align-items-stretch\">\r\n\r\n <!-- Total Store Footfall Card -->\r\n <div class=\"col px-2\">\r\n <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.footfall?.count ? zoneCardsData?.footfall?.count?.toLocaleString('en-US', { minimumFractionDigits: 0 }) : '--'}}</span>\r\n <span class=\"cardtext\">Total Store Footfall</span>\r\n </h3>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"h-auto py-3 px-3\">\r\n <div class=\"cardcount my-2\">{{zoneCardsData?.footfall?.zoneName ? zoneCardsData?.footfall?.zoneName
|
|
63
|
+
args: [{ selector: 'lib-zones-cards', template: "<div class=\"col-md-12\">\r\n <div class=\"row d-flex justify-content-between align-items-stretch\">\r\n\r\n <!-- Total Store Footfall Card -->\r\n <div class=\"col px-2\">\r\n <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.footfall?.count ? zoneCardsData?.footfall?.count?.toLocaleString('en-US', { minimumFractionDigits: 0 }) : '--'}}</span>\r\n <span class=\"cardtext\">Total Store Footfall</span>\r\n </h3>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"h-auto py-3 px-3\">\r\n <div class=\"cardcount my-2\">{{zoneCardsData?.footfall?.zoneName ? (zoneCardsData?.footfall?.zoneName | titlecase) : '--'}}</div>\r\n <div class=\"cardtext\">Zone with the <br> Highest Footfall <span class=\"subcount\">- {{zoneCardsData?.footfall?.zoneFootfallCount ? zoneCardsData?.footfall?.zoneFootfallCount?.toLocaleString('en-US', { minimumFractionDigits: 0 }) : '--'}}</span></div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Highest Impression Card -->\r\n <div class=\"col px-2\">\r\n <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.impression?.rate ? zoneCardsData?.impression?.rate + '%' : '--'}}</span>\r\n <span class=\"cardtext\">Highest Store impression</span>\r\n </h3>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"h-auto py-3 px-3\">\r\n <div class=\"cardcount my-2\">\r\n \r\n {{zoneCardsData?.impression?.zoneName ?(zoneCardsData?.impression?.zoneName | titlecase) : '--'}}\r\n \r\n </div>\r\n <div class=\"cardtext\">Zone with <span class=\"subcount\">{{zoneCardsData?.impression?.zoneImpressionRate ? zoneCardsData?.impression?.zoneImpressionRate + '%' : '--'}}</span> <br> impression</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Total Bounced Rate Card -->\r\n <div class=\"col px-2\">\r\n <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.bounced?.rate ? zoneCardsData?.bounced?.rate + '%' : '--'}}</span>\r\n <span class=\"cardtext\">Top Zone Bounced Rate</span>\r\n </h3>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"h-auto py-3 px-3\">\r\n <div class=\"cardcount my-2\">\r\n \r\n {{zoneCardsData?.bounced?.zoneName ? zoneCardsData?.bounced?.zoneName : '--'}}\r\n \r\n </div>\r\n <div class=\"cardtext\">Zone with the <br> Highest Bounced rate</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Engagers Rate Card -->\r\n <div class=\"col px-2\">\r\n <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.engagers?.rate ? zoneCardsData?.engagers?.rate + '%' : '--'}}</span>\r\n <span class=\"cardtext\">Top Engagers Zone Rate</span>\r\n </h3>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"h-auto py-3 px-3\">\r\n <div class=\"cardcount my-2\">\r\n \r\n {{zoneCardsData?.engagers?.zoneName ? zoneCardsData?.engagers?.zoneName : '--'}}\r\n \r\n </div>\r\n <div class=\"cardtext\">Zone with the <br> Highest Engager Rate</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Average Dwell Time Card -->\r\n <div class=\"col px-2\">\r\n <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.avgDwellTime?.rate ? zoneCardsData?.avgDwellTime?.rate + ' Mins' : '--'}}</span>\r\n <span class=\"cardtext\">Average Top Zone Dwell Time</span>\r\n </h3>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"h-auto py-3 px-3\">\r\n <div class=\"cardcount my-2\">{{zoneCardsData?.avgDwellTime?.zoneName ? zoneCardsData?.avgDwellTime?.zoneName : '--'}}</div>\r\n <div class=\"cardtext\">Zone with the <br> Highest Dwell Time</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n</div>\r\n", styles: [".ellipse1{border-radius:6px;border-bottom:2px solid var(--Gray-200, #EAECF0);background:radial-gradient(206.89% 107.47% at 16.16% 32.77%,#fff6,#45bbfe33),#f2f4f7;box-shadow:0 4px 10px #0000000d}.cardcount{color:var(--Gray-900, #101828);font-size:20px;font-style:normal;font-weight:700;line-height:30px}.cardtext{color:var(--Gray-700, #344054);font-size:14px;font-style:normal;font-weight:500;line-height:21px}.subcount{color:var(--Gray-700, #344054);font-size:14px;font-style:normal;font-weight:700;line-height:20px}.card-border{padding:8px;border-radius:12px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF)}.zonecard{width:130%;background:var(--White, #FFF)}\n"] }]
|
|
63
64
|
}], ctorParameters: () => [{ type: i1.Zonev2Service }, { type: i0.ChangeDetectorRef }, { type: i2.GlobalStateService }, { type: i3.Router }, { type: i3.ActivatedRoute }] });
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zones-cards.component.js","sourceRoot":"","sources":["../../../../../../../projects/tango-analyse-zone/src/lib/components/zone-v2/zones-cards/zones-cards.component.ts","../../../../../../../projects/tango-analyse-zone/src/lib/components/zone-v2/zones-cards/zones-cards.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAqB,SAAS,EAAE,MAAM,eAAe,CAAC;AAE7D,OAAO,EAAE,OAAO,EAAE,YAAY,EAAC,MAAM,MAAM,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;;;AAS3C,MAAM,OAAO,mBAAmB;IAKV;IAAqC;IAAyC;IAAgC;IAAwB;IAJ1J,aAAa,CAAM;IACnB,UAAU,CAAM;IAChB,iBAAiB,CAAqB;IAC9B,QAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IACvC,YAAoB,aAA4B,EAAS,cAAiC,EAAQ,EAAsB,EAAU,MAAc,EAAU,cAA8B;QAApK,kBAAa,GAAb,aAAa,CAAe;QAAS,mBAAc,GAAd,cAAc,CAAmB;QAAQ,OAAE,GAAF,EAAE,CAAoB;QAAU,WAAM,GAAN,MAAM,CAAQ;QAAU,mBAAc,GAAd,cAAc,CAAgB;IAAI,CAAC;IAE7L,QAAQ;QACN,IAAI,CAAC,EAAE,CAAC,cAAc;aACrB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC;aACjD,SAAS,CAAC,CAAC,IAAS,EAAE,EAAE;YACrB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAA;IACA,CAAC;IACD,WAAW;QAET,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED,YAAY;QACV,MAAM,WAAW,GAAG;YAClB,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS;YACxC,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO;YACpC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,KAAS,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,KAAS,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC;YACtG,QAAQ,EAAC,IAAI,CAAC,UAAU,CAAC,MAAM;SAChC,CAAC;QAEF,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CACvF,CAAC,QAAa,EAAE,EAAE;YAChB,IAAI,QAAQ,EAAE,MAAM,KAAK,SAAS,EAAE;gBAClC,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;gBACxC,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;aAEtE;iBAAO;gBACN,IAAI,CAAC,aAAa,GAAG,EAAE,CAAA;aACxB;QACH,CAAC,EACD,CAAC,KAAK,EAAE,EAAE;YACR,IAAI,CAAC,aAAa,GAAG,EAAE,CAAA;YACvB,OAAO,CAAC,KAAK,CAAC,+BAA+B,EAAE,KAAK,CAAC,CAAC;QACxD,CAAC,CACF,CAAC;IACJ,CAAC;wGA5CU,mBAAmB;4FAAnB,mBAAmB,uDCZhC,60LA2GA;;4FD/Fa,mBAAmB;kBAL/B,SAAS;+BACE,iBAAiB","sourcesContent":["import { ChangeDetectorRef, Component } from '@angular/core';\r\nimport { GlobalStateService } from 'tango-app-ui-global';\r\nimport { Subject, debounceTime} from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { Zonev2Service } from '../../services/zonev2.service';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\n\r\n@Component({\r\n  selector: 'lib-zones-cards',\r\n  templateUrl: './zones-cards.component.html',\r\n  styleUrl: './zones-cards.component.scss'\r\n})\r\nexport class ZonesCardsComponent {\r\n  zoneCardsData: any;\r\n  headerData: any;\r\n  zoneCardsFootfall: number | undefined;\r\n  private destroy$ = new Subject<void>();\r\n  constructor(private Zonev2Service: Zonev2Service,private changeDetector: ChangeDetectorRef,public gs: GlobalStateService, private router: Router, private ActivatedRoute: ActivatedRoute,) {}\r\n\r\n  ngOnInit(): void {\r\n    this.gs.dataRangeValue\r\n    .pipe(takeUntil(this.destroy$), debounceTime(300))\r\n    .subscribe((data: any) => {\r\n        this.headerData = data;\r\n        this.getZoneCards();\r\n})\r\n  }\r\n  ngOnDestroy(): void {\r\n\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  getZoneCards(): void {\r\n    const requestData = {\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    };\r\n\r\n    this.Zonev2Service.getZoneCardsData(requestData).pipe(takeUntil(this.destroy$)).subscribe(\r\n      (response: any) => {\r\n        if (response?.status === 'success') {\r\n          this.zoneCardsData = response.data.card;\r\n          this.Zonev2Service.updateFootfall(response.data.card.footfall.count);\r\n          \r\n        }  else {\r\n          this.zoneCardsData = []\r\n        }\r\n      },\r\n      (error) => {\r\n        this.zoneCardsData = []\r\n        console.error('Error fetching zone card data', error);\r\n      }\r\n    );\r\n  }\r\n\r\n//   redirectToHeatmap(zoneName: string): void {\r\n//     if (zoneName) {\r\n//       this.router.navigate([], {\r\n//         relativeTo: this.ActivatedRoute,\r\n//          queryParams: { zoneName } });\r\n//          const heatmapElement = document.querySelector(`#heatmapscroll`);\r\n//  console.log(\"heatmapElement\", heatmapElement)\r\n//       if (heatmapElement) {\r\n        \r\n//         heatmapElement.scrollIntoView({ block: 'center', behavior: 'smooth' });\r\n//       }\r\n//     }\r\n//   }\r\n\r\n}\r\n","<div class=\"col-md-12\">\r\n    <div class=\"row d-flex justify-content-between align-items-stretch\">\r\n\r\n        <!-- Total Store Footfall Card -->\r\n        <div class=\"col px-2\">\r\n            <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.footfall?.count ? zoneCardsData?.footfall?.count?.toLocaleString('en-US', { minimumFractionDigits: 0 }) : '--'}}</span>\r\n                        <span class=\"cardtext\">Total Store Footfall</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-auto py-3 px-3\">\r\n                        <div  class=\"cardcount my-2\">{{zoneCardsData?.footfall?.zoneName ? zoneCardsData?.footfall?.zoneName?.toLocaleString('en-US', { minimumFractionDigits: 0 }) : '--'}}</div>\r\n                        <div class=\"cardtext\">Zone with the <br> Highest Footfall <span class=\"subcount\">- {{zoneCardsData?.footfall?.zoneFootfallCount ? zoneCardsData?.footfall?.zoneFootfallCount : '--'}}</span></div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Highest Impression Card -->\r\n        <div class=\"col px-2\">\r\n            <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.impression?.rate ? zoneCardsData?.impression?.rate + '%' : '--'}}</span>\r\n                        <span class=\"cardtext\">Highest Store impression</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-auto py-3 px-3\">\r\n                        <div class=\"cardcount my-2\">\r\n                            \r\n                                {{zoneCardsData?.impression?.zoneName ? zoneCardsData?.impression?.zoneName : '--'}}\r\n                            \r\n                          </div>\r\n                        <div class=\"cardtext\">Zone with <span class=\"subcount\">{{zoneCardsData?.impression?.zoneImpressionRate ? zoneCardsData?.impression?.zoneImpressionRate + '%' : '--'}}</span> <br> impression</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Total Bounced Rate Card -->\r\n        <div class=\"col px-2\">\r\n            <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.bounced?.rate ? zoneCardsData?.bounced?.rate + '%' : '--'}}</span>\r\n                        <span class=\"cardtext\">Top Zone Bounced Rate</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-auto py-3 px-3\">\r\n                        <div class=\"cardcount my-2\">\r\n                            \r\n                                {{zoneCardsData?.bounced?.zoneName ? zoneCardsData?.bounced?.zoneName : '--'}}\r\n                            \r\n                          </div>\r\n                        <div class=\"cardtext\">Zone with the <br> Highest Bounced rate</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Engagers Rate Card -->\r\n        <div class=\"col px-2\">\r\n            <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.engagers?.rate ? zoneCardsData?.engagers?.rate + '%' : '--'}}</span>\r\n                        <span class=\"cardtext\">Top Engagers Zone Rate</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-auto py-3 px-3\">\r\n                        <div class=\"cardcount my-2\">\r\n                            \r\n                                {{zoneCardsData?.engagers?.zoneName ? zoneCardsData?.engagers?.zoneName : '--'}}\r\n                            \r\n                          </div>\r\n                        <div class=\"cardtext\">Zone with the <br> Highest Engager Rate</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Average Dwell Time Card -->\r\n        <div class=\"col px-2\">\r\n            <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.avgDwellTime?.rate ? zoneCardsData?.avgDwellTime?.rate + ' Mins' : '--'}}</span>\r\n                        <span class=\"cardtext\">Average Top Zone Dwell Time</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-auto py-3 px-3\">\r\n                        <div class=\"cardcount my-2\">{{zoneCardsData?.avgDwellTime?.zoneName ? zoneCardsData?.avgDwellTime?.zoneName : '--'}}</div>\r\n                        <div class=\"cardtext\">Zone with the <br> Highest Dwell Time</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n    </div>\r\n</div>\r\n"]}
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zones-cards.component.js","sourceRoot":"","sources":["../../../../../../../projects/tango-analyse-zone/src/lib/components/zone-v2/zones-cards/zones-cards.component.ts","../../../../../../../projects/tango-analyse-zone/src/lib/components/zone-v2/zones-cards/zones-cards.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAqB,SAAS,EAAE,MAAM,eAAe,CAAC;AAE7D,OAAO,EAAE,OAAO,EAAE,YAAY,EAAC,MAAM,MAAM,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;;;;AAS3C,MAAM,OAAO,mBAAmB;IAKV;IAAqC;IAAyC;IAAgC;IAAwB;IAJ1J,aAAa,CAAM;IACnB,UAAU,CAAM;IAChB,iBAAiB,CAAqB;IAC9B,QAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IACvC,YAAoB,aAA4B,EAAS,cAAiC,EAAQ,EAAsB,EAAU,MAAc,EAAU,cAA8B;QAApK,kBAAa,GAAb,aAAa,CAAe;QAAS,mBAAc,GAAd,cAAc,CAAmB;QAAQ,OAAE,GAAF,EAAE,CAAoB;QAAU,WAAM,GAAN,MAAM,CAAQ;QAAU,mBAAc,GAAd,cAAc,CAAgB;IAAI,CAAC;IAE7L,QAAQ;QACN,IAAI,CAAC,EAAE,CAAC,cAAc;aACrB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC;aACjD,SAAS,CAAC,CAAC,IAAS,EAAE,EAAE;YACrB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAA;IACA,CAAC;IACD,WAAW;QAET,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED,YAAY;QACV,MAAM,WAAW,GAAG;YAClB,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS;YACxC,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO;YACpC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,KAAS,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,KAAS,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC;YACtG,QAAQ,EAAC,IAAI,CAAC,UAAU,CAAC,MAAM;SAChC,CAAC;QAEF,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CACvF,CAAC,QAAa,EAAE,EAAE;YAChB,IAAI,QAAQ,EAAE,MAAM,KAAK,SAAS,EAAE;gBAClC,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;gBACxC,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;aAEtE;iBAAO;gBACN,IAAI,CAAC,aAAa,GAAG,EAAE,CAAA;aACxB;QACH,CAAC,EACD,CAAC,KAAK,EAAE,EAAE;YACR,IAAI,CAAC,aAAa,GAAG,EAAE,CAAA;YACvB,OAAO,CAAC,KAAK,CAAC,+BAA+B,EAAE,KAAK,CAAC,CAAC;QACxD,CAAC,CACF,CAAC;IACJ,CAAC;wGA5CU,mBAAmB;4FAAnB,mBAAmB,uDCZhC,w2LA2GA;;4FD/Fa,mBAAmB;kBAL/B,SAAS;+BACE,iBAAiB","sourcesContent":["import { ChangeDetectorRef, Component } from '@angular/core';\r\nimport { GlobalStateService } from 'tango-app-ui-global';\r\nimport { Subject, debounceTime} from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { Zonev2Service } from '../../services/zonev2.service';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\n\r\n@Component({\r\n  selector: 'lib-zones-cards',\r\n  templateUrl: './zones-cards.component.html',\r\n  styleUrl: './zones-cards.component.scss'\r\n})\r\nexport class ZonesCardsComponent {\r\n  zoneCardsData: any;\r\n  headerData: any;\r\n  zoneCardsFootfall: number | undefined;\r\n  private destroy$ = new Subject<void>();\r\n  constructor(private Zonev2Service: Zonev2Service,private changeDetector: ChangeDetectorRef,public gs: GlobalStateService, private router: Router, private ActivatedRoute: ActivatedRoute,) {}\r\n\r\n  ngOnInit(): void {\r\n    this.gs.dataRangeValue\r\n    .pipe(takeUntil(this.destroy$), debounceTime(300))\r\n    .subscribe((data: any) => {\r\n        this.headerData = data;\r\n        this.getZoneCards();\r\n})\r\n  }\r\n  ngOnDestroy(): void {\r\n\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  getZoneCards(): void {\r\n    const requestData = {\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    };\r\n\r\n    this.Zonev2Service.getZoneCardsData(requestData).pipe(takeUntil(this.destroy$)).subscribe(\r\n      (response: any) => {\r\n        if (response?.status === 'success') {\r\n          this.zoneCardsData = response.data.card;\r\n          this.Zonev2Service.updateFootfall(response.data.card.footfall.count);\r\n          \r\n        }  else {\r\n          this.zoneCardsData = []\r\n        }\r\n      },\r\n      (error) => {\r\n        this.zoneCardsData = []\r\n        console.error('Error fetching zone card data', error);\r\n      }\r\n    );\r\n  }\r\n\r\n//   redirectToHeatmap(zoneName: string): void {\r\n//     if (zoneName) {\r\n//       this.router.navigate([], {\r\n//         relativeTo: this.ActivatedRoute,\r\n//          queryParams: { zoneName } });\r\n//          const heatmapElement = document.querySelector(`#heatmapscroll`);\r\n//  console.log(\"heatmapElement\", heatmapElement)\r\n//       if (heatmapElement) {\r\n        \r\n//         heatmapElement.scrollIntoView({ block: 'center', behavior: 'smooth' });\r\n//       }\r\n//     }\r\n//   }\r\n\r\n}\r\n","<div class=\"col-md-12\">\r\n    <div class=\"row d-flex justify-content-between align-items-stretch\">\r\n\r\n        <!-- Total Store Footfall Card -->\r\n        <div class=\"col px-2\">\r\n            <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.footfall?.count ? zoneCardsData?.footfall?.count?.toLocaleString('en-US', { minimumFractionDigits: 0 }) : '--'}}</span>\r\n                        <span class=\"cardtext\">Total Store Footfall</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-auto py-3 px-3\">\r\n                        <div  class=\"cardcount my-2\">{{zoneCardsData?.footfall?.zoneName ? (zoneCardsData?.footfall?.zoneName | titlecase) : '--'}}</div>\r\n                        <div class=\"cardtext\">Zone with the <br> Highest Footfall <span class=\"subcount\">- {{zoneCardsData?.footfall?.zoneFootfallCount ? zoneCardsData?.footfall?.zoneFootfallCount?.toLocaleString('en-US', { minimumFractionDigits: 0 }) : '--'}}</span></div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Highest Impression Card -->\r\n        <div class=\"col px-2\">\r\n            <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.impression?.rate ? zoneCardsData?.impression?.rate + '%' : '--'}}</span>\r\n                        <span class=\"cardtext\">Highest Store impression</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-auto py-3 px-3\">\r\n                        <div class=\"cardcount my-2\">\r\n                            \r\n                                {{zoneCardsData?.impression?.zoneName ?(zoneCardsData?.impression?.zoneName | titlecase) : '--'}}\r\n                            \r\n                          </div>\r\n                        <div class=\"cardtext\">Zone with <span class=\"subcount\">{{zoneCardsData?.impression?.zoneImpressionRate ? zoneCardsData?.impression?.zoneImpressionRate + '%' : '--'}}</span> <br> impression</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Total Bounced Rate Card -->\r\n        <div class=\"col px-2\">\r\n            <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.bounced?.rate ? zoneCardsData?.bounced?.rate + '%' : '--'}}</span>\r\n                        <span class=\"cardtext\">Top Zone Bounced Rate</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-auto py-3 px-3\">\r\n                        <div class=\"cardcount my-2\">\r\n                            \r\n                                {{zoneCardsData?.bounced?.zoneName ? zoneCardsData?.bounced?.zoneName : '--'}}\r\n                            \r\n                          </div>\r\n                        <div class=\"cardtext\">Zone with the <br> Highest Bounced rate</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Engagers Rate Card -->\r\n        <div class=\"col px-2\">\r\n            <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.engagers?.rate ? zoneCardsData?.engagers?.rate + '%' : '--'}}</span>\r\n                        <span class=\"cardtext\">Top Engagers Zone Rate</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-auto py-3 px-3\">\r\n                        <div class=\"cardcount my-2\">\r\n                            \r\n                                {{zoneCardsData?.engagers?.zoneName ? zoneCardsData?.engagers?.zoneName : '--'}}\r\n                            \r\n                          </div>\r\n                        <div class=\"cardtext\">Zone with the <br> Highest Engager Rate</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Average Dwell Time Card -->\r\n        <div class=\"col px-2\">\r\n            <div class=\"card card-border pt-2 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=\"cardcount\">{{zoneCardsData?.avgDwellTime?.rate ? zoneCardsData?.avgDwellTime?.rate + ' Mins' : '--'}}</span>\r\n                        <span class=\"cardtext\">Average Top Zone Dwell Time</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-auto py-3 px-3\">\r\n                        <div class=\"cardcount my-2\">{{zoneCardsData?.avgDwellTime?.zoneName ? zoneCardsData?.avgDwellTime?.zoneName : '--'}}</div>\r\n                        <div class=\"cardtext\">Zone with the <br> Highest Dwell Time</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n    </div>\r\n</div>\r\n"]}
|