tango-app-ui-analyse-zone 3.3.1-beta.2 → 3.3.1-beta.20
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 +4 -4
- package/esm2022/lib/components/segmentation/segmentation.component.mjs +68 -0
- package/esm2022/lib/components/services/zone.service.mjs +7 -1
- package/esm2022/lib/components/services/zonev2.service.mjs +28 -11
- package/esm2022/lib/components/tango-analyse-zone/tango-analyse-zone.component.mjs +5 -4
- package/esm2022/lib/components/top-performing-zones/top-performing-zones.component.mjs +7 -6
- package/esm2022/lib/components/zone-concentration/concentrationheatmap/concentrationheatmap.component.mjs +32 -3
- package/esm2022/lib/components/zone-concentration/zone-concentration.component.mjs +89 -30
- package/esm2022/lib/components/zone-summary-table/zone-summary-table.component.mjs +10 -8
- package/esm2022/lib/components/zone-v2/customer-journey/customer-journey.component.mjs +313 -55
- package/esm2022/lib/components/zone-v2/store-heatmap/store-heatmap.component.mjs +284 -281
- package/esm2022/lib/components/zone-v2/store-heatmap/store-zoom-heatmap/store-zoom-heatmap.component.mjs +38 -5
- package/esm2022/lib/components/zone-v2/summary-table/summary-table.component.mjs +43 -13
- package/esm2022/lib/components/zone-v2/top-performing/top-performing.component.mjs +58 -24
- package/esm2022/lib/components/zone-v2/zone-v2.component.mjs +1 -2
- package/esm2022/lib/components/zone-v2/zones-cards/zones-cards.component.mjs +17 -10
- package/esm2022/lib/tango-analyse-zone.module.mjs +6 -3
- package/fesm2022/tango-app-ui-analyse-zone.mjs +994 -461
- package/fesm2022/tango-app-ui-analyse-zone.mjs.map +1 -1
- package/lib/components/segmentation/segmentation.component.d.ts +20 -0
- package/lib/components/services/zone.service.d.ts +2 -0
- package/lib/components/services/zonev2.service.d.ts +7 -0
- package/lib/components/tango-analyse-zone/tango-analyse-zone.component.d.ts +1 -0
- package/lib/components/top-performing-zones/top-performing-zones.component.d.ts +3 -3
- package/lib/components/zone-concentration/concentrationheatmap/concentrationheatmap.component.d.ts +5 -0
- package/lib/components/zone-concentration/zone-concentration.component.d.ts +7 -2
- package/lib/components/zone-summary-table/zone-summary-table.component.d.ts +1 -1
- package/lib/components/zone-v2/customer-journey/customer-journey.component.d.ts +49 -4
- package/lib/components/zone-v2/store-heatmap/store-heatmap.component.d.ts +21 -2
- package/lib/components/zone-v2/store-heatmap/store-zoom-heatmap/store-zoom-heatmap.component.d.ts +8 -1
- package/lib/components/zone-v2/summary-table/summary-table.component.d.ts +5 -3
- package/lib/components/zone-v2/top-performing/top-performing.component.d.ts +9 -0
- package/lib/components/zone-v2/zones-cards/zones-cards.component.d.ts +5 -1
- package/lib/tango-analyse-zone.module.d.ts +7 -6
- package/package.json +1 -1
|
@@ -4,17 +4,23 @@ import { takeUntil } from 'rxjs/operators';
|
|
|
4
4
|
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
|
+
import * as i3 from "@angular/router";
|
|
7
8
|
export class ZonesCardsComponent {
|
|
8
9
|
Zonev2Service;
|
|
9
10
|
changeDetector;
|
|
10
11
|
gs;
|
|
12
|
+
router;
|
|
13
|
+
ActivatedRoute;
|
|
11
14
|
zoneCardsData;
|
|
12
15
|
headerData;
|
|
16
|
+
zoneCardsFootfall;
|
|
13
17
|
destroy$ = new Subject();
|
|
14
|
-
constructor(Zonev2Service, changeDetector, gs) {
|
|
18
|
+
constructor(Zonev2Service, changeDetector, gs, router, ActivatedRoute) {
|
|
15
19
|
this.Zonev2Service = Zonev2Service;
|
|
16
20
|
this.changeDetector = changeDetector;
|
|
17
21
|
this.gs = gs;
|
|
22
|
+
this.router = router;
|
|
23
|
+
this.ActivatedRoute = ActivatedRoute;
|
|
18
24
|
}
|
|
19
25
|
ngOnInit() {
|
|
20
26
|
this.gs.dataRangeValue
|
|
@@ -30,14 +36,15 @@ export class ZonesCardsComponent {
|
|
|
30
36
|
}
|
|
31
37
|
getZoneCards() {
|
|
32
38
|
const requestData = {
|
|
33
|
-
fromDate:
|
|
34
|
-
toDate:
|
|
35
|
-
storeId:
|
|
36
|
-
|
|
39
|
+
fromDate: this.headerData.date.startDate,
|
|
40
|
+
toDate: this.headerData.date.endDate,
|
|
41
|
+
storeId: this.headerData.stores.filter((store) => store.checked).map((store) => store.storeId),
|
|
42
|
+
clientId: this.headerData.client,
|
|
37
43
|
};
|
|
38
44
|
this.Zonev2Service.getZoneCardsData(requestData).pipe(takeUntil(this.destroy$)).subscribe((response) => {
|
|
39
45
|
if (response?.status === 'success') {
|
|
40
46
|
this.zoneCardsData = response.data.card;
|
|
47
|
+
this.Zonev2Service.updateFootfall(response.data.card.footfall.count);
|
|
41
48
|
}
|
|
42
49
|
else {
|
|
43
50
|
this.zoneCardsData = [];
|
|
@@ -47,11 +54,11 @@ export class ZonesCardsComponent {
|
|
|
47
54
|
console.error('Error fetching zone card data', error);
|
|
48
55
|
});
|
|
49
56
|
}
|
|
50
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ZonesCardsComponent, deps: [{ token: i1.Zonev2Service }, { token: i0.ChangeDetectorRef }, { token: i2.GlobalStateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
51
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", 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 : '--'}}</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-
|
|
57
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", 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.0.8", 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?.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", 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"] });
|
|
52
59
|
}
|
|
53
60
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ZonesCardsComponent, decorators: [{
|
|
54
61
|
type: Component,
|
|
55
|
-
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 : '--'}}</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-
|
|
56
|
-
}], ctorParameters: () => [{ type: i1.Zonev2Service }, { type: i0.ChangeDetectorRef }, { type: i2.GlobalStateService }] });
|
|
57
|
-
//# 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;;;;AAQ3C,MAAM,OAAO,mBAAmB;IAIV;IAAqC;IAAyC;IAHlG,aAAa,CAAM;IACnB,UAAU,CAAM;IACR,QAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IACvC,YAAoB,aAA4B,EAAS,cAAiC,EAAQ,EAAsB;QAApG,kBAAa,GAAb,aAAa,CAAe;QAAS,mBAAc,GAAd,cAAc,CAAmB;QAAQ,OAAE,GAAF,EAAE,CAAoB;IAAI,CAAC;IAE7H,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,YAAY;YACtB,MAAM,EAAE,YAAY;YACpB,OAAO,EAAE,CAAC,IAAI,CAAC;YACf,mCAAmC;SACpC,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;aACzC;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;uGAzCU,mBAAmB;2FAAnB,mBAAmB,uDCXhC,q2KA+FA;;2FDpFa,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\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  private destroy$ = new Subject<void>();\r\n  constructor(private Zonev2Service: Zonev2Service,private changeDetector: ChangeDetectorRef,public gs: GlobalStateService,) {}\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: '2024-07-01',\r\n      toDate: '2024-07-22',\r\n      storeId: ['11'],\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        }  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}\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 : '--'}}</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-100px py-3 px-3\">\r\n                        <div class=\"cardcount my-2\"><u>{{zoneCardsData?.footfall?.zoneName ? zoneCardsData?.footfall?.zoneName : '--'}}</u></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 impression</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-100px py-3 px-3\">\r\n                        <div class=\"cardcount my-2\"><u>{{zoneCardsData?.impression?.zoneName ? zoneCardsData?.impression?.zoneName : '--'}}</u></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\">Total Bounced Rate</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-100px py-3 px-3\">\r\n                        <div class=\"cardcount my-2\"><u>{{zoneCardsData?.bounced?.zoneName ? zoneCardsData?.bounced?.zoneName : '--'}}</u></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\">Engagers Rate</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-100px py-3 px-3\">\r\n                        <div class=\"cardcount my-2\"><u>{{zoneCardsData?.engagers?.zoneName ? zoneCardsData?.engagers?.zoneName : '--'}}</u></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 Dwell Time</span>\r\n                    </h3>\r\n                </div>\r\n                <div class=\"card-body p-0\">\r\n                    <div class=\"h-100px py-3 px-3\">\r\n                        <div class=\"cardcount my-2\"><u>{{zoneCardsData?.avgDwellTime?.zoneName ? zoneCardsData?.avgDwellTime?.zoneName : '--'}}</u></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"]}
|
|
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?.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", 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
|
+
}], 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;uGA5CU,mBAAmB;2FAAnB,mBAAmB,uDCZhC,60LA2GA;;2FD/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"]}
|
|
@@ -20,6 +20,7 @@ import { ReactiveSelectComponent } from './components/zone-v2/reactive-select/re
|
|
|
20
20
|
import { TopPerformingComponent } from './components/zone-v2/top-performing/top-performing.component';
|
|
21
21
|
import { SummaryTableComponent } from './components/zone-v2/summary-table/summary-table.component';
|
|
22
22
|
import { StoreZoomHeatmapComponent } from './components/zone-v2/store-heatmap/store-zoom-heatmap/store-zoom-heatmap.component';
|
|
23
|
+
import { SegmentationComponent } from './components/segmentation/segmentation.component';
|
|
23
24
|
import * as i0 from "@angular/core";
|
|
24
25
|
export class TangoAnalyseZoneModule {
|
|
25
26
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: TangoAnalyseZoneModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
@@ -39,7 +40,8 @@ export class TangoAnalyseZoneModule {
|
|
|
39
40
|
ReactiveSelectComponent,
|
|
40
41
|
TopPerformingComponent,
|
|
41
42
|
SummaryTableComponent,
|
|
42
|
-
StoreZoomHeatmapComponent
|
|
43
|
+
StoreZoomHeatmapComponent,
|
|
44
|
+
SegmentationComponent], imports: [
|
|
43
45
|
// CommonModule,
|
|
44
46
|
// TangoAnalyseZoneRoutingModule,
|
|
45
47
|
// NgbProgressbarModule,
|
|
@@ -102,7 +104,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
102
104
|
ReactiveSelectComponent,
|
|
103
105
|
TopPerformingComponent,
|
|
104
106
|
SummaryTableComponent,
|
|
105
|
-
StoreZoomHeatmapComponent
|
|
107
|
+
StoreZoomHeatmapComponent,
|
|
108
|
+
SegmentationComponent,
|
|
106
109
|
],
|
|
107
110
|
imports: [
|
|
108
111
|
// CommonModule,
|
|
@@ -128,4 +131,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
128
131
|
]
|
|
129
132
|
}]
|
|
130
133
|
}] });
|
|
131
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tango-analyse-zone.module.js","sourceRoot":"","sources":["../../../../projects/tango-analyse-zone/src/lib/tango-analyse-zone.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TangoAnalyseZoneRoutingModule } from './tango-analyse-zone-routing.module';\r\nimport { NgbAccordionModule, NgbCarouselModule, NgbModule, NgbProgressbarModule, NgbTooltipModule } from '@ng-bootstrap/ng-bootstrap';\r\nimport { OverallcardsComponent } from './components/overallcards/overallcards.component';\r\nimport { TopPerformingZonesComponent } from './components/top-performing-zones/top-performing-zones.component';\r\nimport { ZoneSummaryTableComponent } from './components/zone-summary-table/zone-summary-table.component';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { ZoneConcentrationComponent } from './components/zone-concentration/zone-concentration.component';\r\nimport { CommonSharedModule } from 'tango-app-ui-shared';\r\nimport { TangoAnalyseZoneComponent } from './components/tango-analyse-zone/tango-analyse-zone.component';\r\nimport { ConcentrationheatmapComponent } from './components/zone-concentration/concentrationheatmap/concentrationheatmap.component';\r\nimport { ZoneV2Component } from './components/zone-v2/zone-v2.component';\r\nimport { ZonesCardsComponent } from './components/zone-v2/zones-cards/zones-cards.component';\r\nimport { StoreHeatmapComponent } from './components/zone-v2/store-heatmap/store-heatmap.component';\r\nimport { ImageDirectoryComponent } from './components/zone-v2/image-directory/image-directory.component';\r\nimport { ImageDirectoryViewComponent } from './components/zone-v2/image-directory-view/image-directory-view.component';\r\nimport { CustomerJourneyComponent } from './components/zone-v2/customer-journey/customer-journey.component';\r\nimport { ReactiveSelectComponent } from './components/zone-v2/reactive-select/reactive-select.component';\r\nimport { TopPerformingComponent } from './components/zone-v2/top-performing/top-performing.component';\r\nimport { SummaryTableComponent } from './components/zone-v2/summary-table/summary-table.component';\r\nimport { StoreZoomHeatmapComponent } from './components/zone-v2/store-heatmap/store-zoom-heatmap/store-zoom-heatmap.component';\nimport { SegmentationComponent } from './components/segmentation/segmentation.component';\r\n\r\n\r\n@NgModule({\r\n  declarations: [\r\n    OverallcardsComponent,\r\n    TangoAnalyseZoneComponent,\r\n    TopPerformingZonesComponent,\r\n    ZoneSummaryTableComponent,\r\n    ZoneConcentrationComponent,\r\n    ConcentrationheatmapComponent,\r\n\r\n    ZoneV2Component,\r\n    ConcentrationheatmapComponent,\r\n    ZonesCardsComponent,\r\n    StoreHeatmapComponent,\r\n    ImageDirectoryComponent,\r\n    ImageDirectoryViewComponent,\r\n    CustomerJourneyComponent,\r\n    ReactiveSelectComponent,\r\n    TopPerformingComponent,\r\n    SummaryTableComponent,\r\n    StoreZoomHeatmapComponent,\r\n    SegmentationComponent,\r\n    \r\n  ],\r\n  imports: [\r\n    // CommonModule,\r\n    // TangoAnalyseZoneRoutingModule,\r\n    // NgbProgressbarModule,\r\n    // FormsModule,\r\n    // ReactiveFormsModule,\r\n    // NgbCarouselModule,\r\n    // CommonSharedModule,\r\n    // NgbTooltipModule,\r\n    // NgbModule\r\n    CommonModule,\r\n    TangoAnalyseZoneRoutingModule,\r\n    NgbProgressbarModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    CommonSharedModule,\r\n    NgbTooltipModule,\r\n    NgbModule,\r\n    NgbAccordionModule,\r\n    CommonSharedModule,\r\n    NgbCarouselModule\r\n  ]\r\n})\r\nexport class TangoAnalyseZoneModule { }\r\n"]}
|