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
|
@@ -3,91 +3,349 @@ import * as am5 from "@amcharts/amcharts5";
|
|
|
3
3
|
import * as am5flow from "@amcharts/amcharts5/flow";
|
|
4
4
|
import am5themes_Animated from "@amcharts/amcharts5/themes/Animated";
|
|
5
5
|
import { FormControl } from '@angular/forms';
|
|
6
|
+
import { Subject, debounceTime, takeUntil } from "rxjs";
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@angular/forms";
|
|
8
|
-
import * as i2 from "
|
|
9
|
+
import * as i2 from "../../services/zonev2.service";
|
|
10
|
+
import * as i3 from "tango-app-ui-global";
|
|
11
|
+
import * as i4 from "@ng-bootstrap/ng-bootstrap";
|
|
12
|
+
import * as i5 from "@angular/router";
|
|
13
|
+
import * as i6 from "tango-app-ui-shared";
|
|
14
|
+
import * as i7 from "@angular/common";
|
|
15
|
+
import * as i8 from "../reactive-select/reactive-select.component";
|
|
9
16
|
export class CustomerJourneyComponent {
|
|
10
17
|
zone;
|
|
11
18
|
elRef;
|
|
12
19
|
fb;
|
|
20
|
+
Zonev2Service;
|
|
21
|
+
changeDetector;
|
|
22
|
+
gs;
|
|
23
|
+
modalService;
|
|
24
|
+
router;
|
|
25
|
+
route;
|
|
26
|
+
toast;
|
|
13
27
|
root;
|
|
28
|
+
destroy$ = new Subject();
|
|
14
29
|
form;
|
|
15
30
|
selectControl;
|
|
16
31
|
datasets = [
|
|
17
|
-
{ value: '
|
|
18
|
-
{ value: '
|
|
32
|
+
{ value: 'top', label: 'Highest Visited Path' },
|
|
33
|
+
{ value: 'bottom', label: 'Lowest Visited Path' }
|
|
19
34
|
];
|
|
20
|
-
|
|
35
|
+
isExport = false;
|
|
36
|
+
itemsPerPage = 10;
|
|
37
|
+
currentPage = 1;
|
|
38
|
+
totalItems = 0;
|
|
39
|
+
paginationSizes = [10, 20, 30];
|
|
40
|
+
pageSize = 10;
|
|
41
|
+
sortColumName = '';
|
|
42
|
+
sortBy = '';
|
|
43
|
+
searchInput = "";
|
|
44
|
+
customerJourneyData = [];
|
|
45
|
+
searchDisabled = false;
|
|
46
|
+
invoiceList = [];
|
|
47
|
+
zonesummaryLoading = true;
|
|
48
|
+
zonesummaryNoData = false;
|
|
49
|
+
customerjourneyLoading = true;
|
|
50
|
+
customerjourneyNoData = false;
|
|
51
|
+
headerData;
|
|
52
|
+
sortDirection = '';
|
|
53
|
+
showAverage = true;
|
|
54
|
+
totalfootfallCount = null;
|
|
55
|
+
;
|
|
56
|
+
constructor(zone, elRef, fb, Zonev2Service, changeDetector, gs, modalService, router, route, toast) {
|
|
21
57
|
this.zone = zone;
|
|
22
58
|
this.elRef = elRef;
|
|
23
59
|
this.fb = fb;
|
|
60
|
+
this.Zonev2Service = Zonev2Service;
|
|
61
|
+
this.changeDetector = changeDetector;
|
|
62
|
+
this.gs = gs;
|
|
63
|
+
this.modalService = modalService;
|
|
64
|
+
this.router = router;
|
|
65
|
+
this.route = route;
|
|
66
|
+
this.toast = toast;
|
|
24
67
|
}
|
|
25
|
-
|
|
68
|
+
ngOnDestroy() {
|
|
69
|
+
this.destroy$.next();
|
|
70
|
+
this.destroy$.complete();
|
|
71
|
+
if (this.root) {
|
|
72
|
+
this.root.dispose();
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
ngAfterViewInit() {
|
|
26
76
|
this.initializeChart();
|
|
27
|
-
|
|
77
|
+
}
|
|
78
|
+
ngOnInit() {
|
|
79
|
+
this.selectControl = new FormControl('top');
|
|
28
80
|
this.form = this.fb.group({
|
|
29
81
|
selectControl: this.selectControl
|
|
30
82
|
});
|
|
83
|
+
this.gs.dataRangeValue
|
|
84
|
+
.pipe(takeUntil(this.destroy$), debounceTime(300))
|
|
85
|
+
.subscribe((data) => {
|
|
86
|
+
this.headerData = data;
|
|
87
|
+
// this.getCustomerJourney()
|
|
88
|
+
this.getCustomerJourneyTable();
|
|
89
|
+
// this.initializeChart();
|
|
90
|
+
});
|
|
91
|
+
this.Zonev2Service.footfall$.subscribe((count) => {
|
|
92
|
+
this.totalfootfallCount = count;
|
|
93
|
+
this.getCustomerJourney();
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
getCustomerJourney() {
|
|
97
|
+
this.customerjourneyLoading = true;
|
|
98
|
+
this.customerjourneyNoData = true;
|
|
99
|
+
const requestData = {
|
|
100
|
+
fromDate: this.headerData.date.startDate,
|
|
101
|
+
toDate: this.headerData.date.endDate,
|
|
102
|
+
storeId: this.headerData.stores.filter((store) => store.checked).map((store) => store.storeId),
|
|
103
|
+
clientId: this.headerData.client,
|
|
104
|
+
search: this.searchInput,
|
|
105
|
+
sortType: this.selectControl.value,
|
|
106
|
+
limit: this.pageSize,
|
|
107
|
+
offset: this.currentPage - 1,
|
|
108
|
+
export: false,
|
|
109
|
+
};
|
|
110
|
+
this.Zonev2Service.getCustomerJourney(requestData).subscribe((response) => {
|
|
111
|
+
// this.customerjourneyLoading = true;
|
|
112
|
+
if (response && response.status === 'success') {
|
|
113
|
+
this.customerjourneyLoading = false;
|
|
114
|
+
this.customerjourneyNoData = false;
|
|
115
|
+
this.initializeChart(); // Initialize chart when data is available
|
|
116
|
+
this.updateChart(response.data.customerJourneyData, this.totalfootfallCount);
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
this.customerjourneyLoading = false;
|
|
120
|
+
this.customerjourneyNoData = true;
|
|
121
|
+
}
|
|
122
|
+
}, error => {
|
|
123
|
+
this.customerjourneyLoading = false;
|
|
124
|
+
this.customerjourneyNoData = true;
|
|
125
|
+
// console.error('Error fetching customer journey data:', error);
|
|
126
|
+
});
|
|
31
127
|
}
|
|
32
|
-
// Function to handle chart creation
|
|
33
128
|
initializeChart() {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
129
|
+
const chartDiv = document.getElementById('customerjourney');
|
|
130
|
+
if (!chartDiv) {
|
|
131
|
+
// console.error('Could not find HTML element with id customerjourney');
|
|
132
|
+
return;
|
|
133
|
+
}
|
|
134
|
+
if (!this.root) { // Check if chart is already initialized
|
|
135
|
+
try {
|
|
136
|
+
this.root = am5.Root.new('customerjourney');
|
|
137
|
+
this.root.setThemes([am5themes_Animated.new(this.root)]);
|
|
138
|
+
const series = this.root.container.children.push(am5flow.Sankey.new(this.root, {
|
|
139
|
+
sourceIdField: "from",
|
|
140
|
+
targetIdField: "to",
|
|
141
|
+
valueField: "value",
|
|
142
|
+
paddingRight: 100
|
|
143
|
+
}));
|
|
144
|
+
}
|
|
145
|
+
catch (error) {
|
|
146
|
+
// console.error('Error initializing chart:', error);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
updateChart(data, footfallCount) {
|
|
151
|
+
let filteredData = this.removeCircularLinks(data);
|
|
152
|
+
let firstZone = filteredData.filter((item) => {
|
|
153
|
+
let findExists = filteredData.find((ele) => ele.to == item.from);
|
|
154
|
+
if (!findExists) {
|
|
155
|
+
return item;
|
|
156
|
+
}
|
|
157
|
+
});
|
|
158
|
+
let lastZone = filteredData.filter((item) => {
|
|
159
|
+
let findExists = filteredData.find((ele) => ele.from == item.to);
|
|
160
|
+
if (!findExists) {
|
|
161
|
+
return item;
|
|
162
|
+
}
|
|
163
|
+
});
|
|
164
|
+
firstZone = firstZone.map((item) => {
|
|
165
|
+
return { from: 'Entry (' + this.totalfootfallCount + ')',
|
|
166
|
+
to: item.from,
|
|
167
|
+
value: item.value, };
|
|
168
|
+
});
|
|
169
|
+
lastZone = lastZone.map((item) => {
|
|
170
|
+
return { from: item.to, to: 'Exit (' + this.totalfootfallCount + ')', value: item.value, };
|
|
171
|
+
});
|
|
172
|
+
filteredData = [...firstZone, ...filteredData, ...lastZone];
|
|
173
|
+
if (this.root) {
|
|
174
|
+
const series = this.root.container.children.getIndex(0);
|
|
175
|
+
if (series) {
|
|
176
|
+
// Check if data is available, otherwise use fallback data
|
|
177
|
+
if (filteredData.length > 0) {
|
|
178
|
+
series.data.setAll(filteredData); // Update with API data
|
|
179
|
+
}
|
|
180
|
+
else {
|
|
181
|
+
// Predefined sample data as fallback
|
|
182
|
+
series.data.setAll([filteredData]);
|
|
183
|
+
}
|
|
184
|
+
this.changeDetector.detectChanges(); // Trigger Angular change detection
|
|
185
|
+
}
|
|
186
|
+
else {
|
|
187
|
+
// console.error('Series not found for chart');
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
removeCircularLinks(data) {
|
|
192
|
+
const graph = new Map();
|
|
193
|
+
const result = [];
|
|
194
|
+
function hasCycle(from, to, visited) {
|
|
195
|
+
if (from === to)
|
|
196
|
+
return true;
|
|
197
|
+
if (visited.has(from))
|
|
198
|
+
return false;
|
|
199
|
+
visited.add(from);
|
|
200
|
+
if (graph.has(from)) {
|
|
201
|
+
for (const neighbor of graph.get(from)) {
|
|
202
|
+
if (hasCycle(neighbor, to, visited)) {
|
|
203
|
+
return true;
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
visited.delete(from);
|
|
208
|
+
return false;
|
|
209
|
+
}
|
|
210
|
+
for (const { from, to, value } of data) {
|
|
211
|
+
if (hasCycle(to, from, new Set())) {
|
|
212
|
+
continue;
|
|
213
|
+
}
|
|
214
|
+
result.push({ from, to, value });
|
|
215
|
+
if (!graph.has(from)) {
|
|
216
|
+
graph.set(from, []);
|
|
217
|
+
}
|
|
218
|
+
graph.get(from).push(to);
|
|
219
|
+
}
|
|
220
|
+
return result;
|
|
221
|
+
}
|
|
222
|
+
setColorStep(series, step) {
|
|
223
|
+
series.nodes.set("colors", am5.ColorSet.new(this.root, {
|
|
224
|
+
step: step
|
|
225
|
+
}));
|
|
226
|
+
}
|
|
227
|
+
onValueChange(event) {
|
|
228
|
+
this.getCustomerJourney();
|
|
229
|
+
}
|
|
230
|
+
getCustomerJourneyTable() {
|
|
231
|
+
this.searchDisabled = true;
|
|
232
|
+
this.zonesummaryLoading = true;
|
|
233
|
+
this.zonesummaryNoData = true;
|
|
234
|
+
const requestData = {
|
|
235
|
+
fromDate: this.headerData.date.startDate,
|
|
236
|
+
toDate: this.headerData.date.endDate,
|
|
237
|
+
// storeId: ["11-253", "11-511","11-1176"],
|
|
238
|
+
storeId: this.headerData.stores.filter((store) => store.checked).map((store) => store.storeId),
|
|
239
|
+
clientId: this.headerData.client,
|
|
240
|
+
// valueType: "sum",
|
|
241
|
+
search: this.searchInput,
|
|
242
|
+
sort: this.sortColumName,
|
|
243
|
+
sortBy: this.sortDirection,
|
|
244
|
+
limit: this.pageSize,
|
|
245
|
+
offset: this.currentPage - 1,
|
|
246
|
+
export: false,
|
|
247
|
+
};
|
|
248
|
+
this.Zonev2Service.getCustomerJourneyTable(requestData)
|
|
249
|
+
.pipe(takeUntil(this.destroy$))
|
|
250
|
+
.subscribe((response) => {
|
|
251
|
+
this.zonesummaryLoading = false;
|
|
252
|
+
if (response?.code === 200 && response?.status === "success") {
|
|
253
|
+
// this.customerJourneyData = response.data;
|
|
254
|
+
this.customerJourneyData = response.data.customerJourneyTableData;
|
|
255
|
+
this.totalItems = response.data.totalCount;
|
|
256
|
+
this.zonesummaryLoading = false;
|
|
257
|
+
this.zonesummaryNoData = false;
|
|
258
|
+
this.searchDisabled = false;
|
|
259
|
+
}
|
|
260
|
+
else {
|
|
261
|
+
this.zonesummaryLoading = false;
|
|
262
|
+
this.zonesummaryNoData = true;
|
|
263
|
+
this.searchDisabled = true;
|
|
264
|
+
if (this.searchInput?.length) {
|
|
265
|
+
this.searchDisabled = true;
|
|
266
|
+
}
|
|
267
|
+
this.customerJourneyData = [];
|
|
268
|
+
this.totalItems = 0;
|
|
269
|
+
this.changeDetector.detectChanges();
|
|
270
|
+
}
|
|
271
|
+
}, error => {
|
|
272
|
+
this.customerJourneyData = [];
|
|
273
|
+
this.changeDetector.detectChanges();
|
|
64
274
|
});
|
|
65
275
|
}
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
const
|
|
69
|
-
|
|
70
|
-
|
|
276
|
+
onExport() {
|
|
277
|
+
this.currentPage = 1;
|
|
278
|
+
const requestData = {
|
|
279
|
+
fromDate: this.headerData.date.startDate,
|
|
280
|
+
toDate: this.headerData.date.endDate,
|
|
281
|
+
storeId: this.headerData.stores.filter((store) => store.checked).map((store) => store.storeId),
|
|
282
|
+
// storeId: ["11-253", "11-511","11-1176"],
|
|
283
|
+
clientId: this.headerData.client,
|
|
284
|
+
// valueType: "sum",
|
|
285
|
+
search: this.searchInput,
|
|
286
|
+
sort: this.sortColumName,
|
|
287
|
+
sortBy: this.sortDirection,
|
|
288
|
+
limit: 10000,
|
|
289
|
+
offset: 0,
|
|
290
|
+
export: true
|
|
291
|
+
};
|
|
292
|
+
this.Zonev2Service.getCustomerJourneyTableExport(requestData)
|
|
293
|
+
.pipe(takeUntil(this.destroy$))
|
|
294
|
+
.subscribe({
|
|
295
|
+
next: (res) => {
|
|
296
|
+
// console.log('API Response:', res);
|
|
297
|
+
this.Zonev2Service.saveAsExcelFile(res, 'CustomerJourney');
|
|
298
|
+
},
|
|
299
|
+
error: (e) => {
|
|
300
|
+
this.toast.getErrorToast('Something went Wrong..');
|
|
301
|
+
}
|
|
302
|
+
});
|
|
303
|
+
}
|
|
304
|
+
searchField() {
|
|
305
|
+
this.getCustomerJourneyTable();
|
|
306
|
+
}
|
|
307
|
+
sortData(column) {
|
|
308
|
+
if (this.sortColumName === column) {
|
|
309
|
+
this.sortDirection = this.sortDirection === 1 ? -1 : 1;
|
|
71
310
|
}
|
|
72
311
|
else {
|
|
73
|
-
|
|
312
|
+
this.sortColumName = column;
|
|
313
|
+
this.sortDirection = 1;
|
|
74
314
|
}
|
|
315
|
+
this.changeDetector.detectChanges();
|
|
316
|
+
this.getCustomerJourneyTable();
|
|
75
317
|
}
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
318
|
+
onPageSizeChange(pageSize) {
|
|
319
|
+
this.currentPage = 1;
|
|
320
|
+
this.pageSize = parseInt(pageSize);
|
|
321
|
+
this.getCustomerJourneyTable();
|
|
79
322
|
}
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
323
|
+
onPageChange(pageOffset) {
|
|
324
|
+
this.currentPage = parseInt(pageOffset);
|
|
325
|
+
this.getCustomerJourneyTable();
|
|
326
|
+
}
|
|
327
|
+
toggleView() {
|
|
328
|
+
this.showAverage = !this.showAverage;
|
|
329
|
+
if (this.showAverage === true) {
|
|
330
|
+
// this.getCustomerJourney()
|
|
331
|
+
// this.initializeChart();
|
|
84
332
|
}
|
|
85
333
|
}
|
|
86
|
-
|
|
87
|
-
|
|
334
|
+
goToZone() {
|
|
335
|
+
const datavalue = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
336
|
+
datavalue.store = datavalue.stores[0].storeId;
|
|
337
|
+
localStorage.setItem("header-filters", JSON.stringify(datavalue));
|
|
338
|
+
this.changeDetector.detectChanges();
|
|
339
|
+
this.gs.dataRangeValue.next(datavalue);
|
|
340
|
+
this.router.navigate(["/manage/stores/zones"], {
|
|
341
|
+
queryParams: { storeId: datavalue.stores[0].storeId },
|
|
342
|
+
});
|
|
343
|
+
}
|
|
344
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: CustomerJourneyComponent, deps: [{ token: i0.NgZone }, { token: i0.ElementRef }, { token: i1.FormBuilder }, { token: i2.Zonev2Service }, { token: i0.ChangeDetectorRef }, { token: i3.GlobalStateService }, { token: i4.NgbModal }, { token: i5.Router }, { token: i5.ActivatedRoute }, { token: i6.ToastService }], target: i0.ɵɵFactoryTarget.Component });
|
|
345
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: CustomerJourneyComponent, selector: "lib-customer-journey", ngImport: i0, template: "<div class=\"card\">\r\n <div [hidden]=\"!showAverage\">\r\n <div class=\"card-header border-0 pt-3\">\r\n <h3 class=\"card-title align-items-start flex-column\"><span class=\"card-label mb-2\">Customer Journey</span></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 justify-content-between\">\r\n <button (click)=\"toggleView()\" type=\"button\" class=\"btn btn-outline align-items-end\">\r\n View All Zones</button>\r\n <form class=\"mx-4\" [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)=\"onValueChange($event)\">\r\n </lib-reactive-select>\r\n </form>\r\n\r\n <button (click)=\"goToZone()\"\r\n class=\"btn bg-light-primary btn-light-primary btn-active-light-primary\"><span\r\n ><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 d=\"M9.99984 4.16602V15.8327M4.1665 9.99935H15.8332\"\r\n stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n </path>\r\n </svg></span> Add New Zone \r\n </button>\r\n \r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"card-body\">\r\n <ng-container *ngIf=\"customerjourneyLoading\">\r\n <div 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 \r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"customerjourneyNoData && !customerjourneyLoading\">\r\n <div class=\"row\">\r\n <div class=\"col-lg-12 my-6\">\r\n <div\r\n class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n <img class=\"img-src\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n <div class=\"nodatamaintext mt-3\">No data found</div>\r\n <div class=\"nodatasubtext\">There is no result for Customer Journey Chart</div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <div [hidden]=\"customerjourneyLoading || customerjourneyNoData\" id=\"customerjourney\"></div>\r\n </div>\r\n</div>\r\n \r\n<div [hidden]=\"showAverage\">\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 mb-2\">Customer Journey</span>\r\n </h3>\r\n <div class=\"card-toolbar\">\r\n <div class=\"d-flex\">\r\n \r\n <div class=\"d-flex align-items-center position-relative my-1 justify-content-between\">\r\n <button (click)=\"toggleView()\" type=\"button\" class=\"btn btn-outline align-items-end mx-4\">\r\n View Average Customer Journey</button>\r\n <span class=\"me-4\">\r\n <span class=\"svg-icon footfallsearch svg-icon-1 position-absolute mt-3 ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\r\n viewBox=\"0 0 24 24\" fill=\"none\">\r\n <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\"\r\n height=\"2\" rx=\"1\" transform=\"rotate(45 17.0365 15.1223)\"\r\n fill=\"currentColor\">\r\n </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 [(ngModel)]=\"searchInput\" type=\"text\"\r\n class=\"form-control ps-14 me-4 footfallsearch\"\r\n placeholder=\"Search...\" autocomplete=\"off\" (keyup.enter)=\"searchField()\"\r\n /></span>\r\n <button type=\"button\" (click)=\"onExport()\" class=\"btn-outline btn align-items-end text-nowrap invheader me-4\" [disabled]=\"!customerJourneyData.length\">\r\n <!-- Export Icon -->\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path 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\" stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"></path>\r\n </svg>\r\n <span class=\"ms-2\"></span> Export\r\n </button>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"table-responsive\">\r\n <table *ngIf=\"!zonesummaryLoading && !zonesummaryNoData\" class=\"table text-nowrap bottom-border\">\r\n <thead>\r\n <tr>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('zoneName')\">\r\n Zone Name\r\n <svg [ngClass]=\"sortColumName === 'zoneName' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'zoneName' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div></th>\r\n <th ><div class=\"cursor-pointer\" (click)=\"sortData('noOfStores')\">\r\n No. of stores\r\n <svg [ngClass]=\"sortColumName === 'noOfStores' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'noOfStores' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div></th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('zoneFF')\">\r\n Zone FF\r\n <svg [ngClass]=\"sortColumName === 'zoneFF' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'zoneFF' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div></th>\r\n <th ><div class=\"cursor-pointer\" (click)=\"sortData('impressions')\">\r\n Impressions\r\n <svg [ngClass]=\"sortColumName === 'impressions' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'impressions' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div>\r\n </th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('AvgDwellTime')\">\r\n Avg Dwell Time\r\n <svg [ngClass]=\"sortColumName === 'AvgDwellTime' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'AvgDwellTime' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div></th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let store of customerJourneyData\">\r\n <td><div class=\"table-title\">{{ store.zoneName || '--' }}</div></td>\r\n <td><div class=\"table-title\">{{ store.noOfStores || '--' }}</div></td>\r\n <td><div class=\"table-title\">{{ store.zoneFF || '--' }}</div></td>\r\n <td><div class=\"table-title\">{{ store.impressions || '--' }}%</div></td>\r\n <td><div class=\"table-title\">{{ store.AvgDwellTime || '--' }} Mins</div></td>\r\n </tr> \r\n </tbody>\r\n </table>\r\n <ng-container *ngIf=\"zonesummaryLoading\">\r\n <div 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 \r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"zonesummaryNoData && !zonesummaryLoading\">\r\n <div class=\"row\">\r\n <div class=\"col-lg-12 my-6\">\r\n <div\r\n class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n <img class=\"img-src\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n <div class=\"nodatamaintext mt-3\">No data found</div>\r\n <div class=\"nodatasubtext\">There is no result for Customer Journey Table</div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n \r\n </div>\r\n <div *ngIf=\"!zonesummaryLoading && !zonesummaryNoData\">\r\n <lib-pagination class=\"text-start\" [itemsPerPage]=\"itemsPerPage\"\r\n [currentPage]=\"currentPage\" [totalItems]=\"totalItems\"\r\n [paginationSizes]=\"paginationSizes\" [pageSize]=\"pageSize\"\r\n (pageChange)=\"onPageChange($event)\"\r\n (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n </div>\r\n \r\n </div>\r\n</div>\r\n</div>", styles: ["#customerjourney{width:100%;height:500px}.bg-light-primary{border-radius:8px;border:1px solid var(--Primary-50, #EAF8FF);background:var(--Primary-50, #EAF8FF);box-shadow:0 1px 2px #1018280d;padding:8px 14px;justify-content:center}.table-title{color:var(--Gray-900, #101828);font-size:14px;font-weight:500;line-height:20px}.subtext{color:var(--Gray-800, #1D2939);font-size:14px;font-weight:500;line-height:20px}.headcount{color:var(--Gray-900, #101828);font-size:20px;font-weight:600;line-height:30px}.headtext{color:var(--Gray-700, #344054);font-size:18px;font-weight:600;line-height:28px}.subratetext{color:var(--Gray-500, #667085);font-size:12px;font-weight:500;line-height:18px}.invoicesearch{color:var(--Gray-700, #344054)!important;font-family:Inter;font-size:14px!important;font-style:normal;font-weight:500!important;line-height:20px}.invoicesearch::placeholder{color:var(--Gray-700, #344054)!important}.loader .title{width:65%}.loader .link{width:85%}.loader .description{width:95%}.loader .shimmer{padding:15px;width:95%;height:120px;margin:10px auto;background:#fff}.loader .shimmer .image-card{height:90px;width:90px;float:right;border-radius:8px}.loader .stroke{height:15px;background:#777;margin-top:20px}.loader .wrapper{width:0px;animation:fullView .5s forwards linear}@keyframes fullView{to{width:100%}}.loader .animate{animation:shimmer 3s;animation-iteration-count:infinite;background:linear-gradient(to right,#e6e6e6 5%,#ccc 25%,#e6e6e6 35%);background-size:1000px 100%}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.activePlanBtn{border-radius:6px;background:var(--Primary-50, #EAF8FF);color:var(--Gray-700, #344054);font-size:14px!important;font-weight:500!important;line-height:20px}.inactivePlanBtn{color:var(--Gray-500, #667085)!important;font-size:14px;font-weight:500!important;line-height:20px}.overalltext{color:var(--Gray-500, #667085);font-size:14px;font-weight:500;line-height:20px}.borderdashed{border-bottom:1px solid var(--Gray-200, #EAECF0)}.conc{width:110%}.overallstore{width:155%}::ng-deep .carousel-indicators [data-bs-target]{flex:0 1 auto;width:8px;height:8px;padding:0;cursor:pointer;background-color:#009bf3!important;border-radius:4px;transition:opacity .6s ease;margin-bottom:10px;border:0px}.category_active{border-bottom:3px solid #009EF7!important;border-radius:3px;margin-bottom:3px!important}.timer_active{color:var(--Primary-700, #009BF3);font-size:14px;font-style:normal;font-weight:500;line-height:20px}table tr{vertical-align:middle}table th,table td{height:44px!important;padding:20px 15px!important;align-items:center;gap:12px;align-self:stretch}.card .card-header{padding:0 1.25rem}.form-control:disabled{background-color:#f9fafb!important}.nodatamaintext{font-family:Inter;font-size:16px;font-weight:600;line-height:24px;text-align:center;color:#101828}.nodatasubtext{font-family:Inter;font-size:14px;font-weight:400;line-height:20px;text-align:center;color:#667085}.rotate{transform:rotate(180deg)}.table-title-primary{color:var(--Primary-700, #009BF3);font-size:14px;font-weight:500;line-height:20px;text-transform:capitalize}\n"], dependencies: [{ kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i6.PaginationComponent, selector: "lib-pagination", inputs: ["collection", "itemsPerPage", "currentPage", "totalItems", "directionLinks", "pageSize", "paginationSizes"], outputs: ["pageChange", "pageSizeChange"] }, { kind: "component", type: i8.ReactiveSelectComponent, selector: "lib-reactive-select", inputs: ["idField", "nameField", "label", "data"], outputs: ["valueChange"] }] });
|
|
88
346
|
}
|
|
89
347
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: CustomerJourneyComponent, decorators: [{
|
|
90
348
|
type: Component,
|
|
91
|
-
args: [{ selector: 'lib-customer-journey', template: "<div class=\"card\">\r\n <div class=\"card-header border-0 pt-3\">\r\n <h3 class=\"card-title align-items-start flex-column\"><span class=\"card-label mb-2\">Customer Journey</span></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 justify-content-between\">\r\n <form class=\"mx-4\" [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)=\"onValueChange($event)\">\r\n </lib-reactive-select>\r\n </form>\r\n\r\n <button \r\n class=\"btn bg-light-primary btn-light-primary btn-active-light-primary\"><span\r\n ><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 d=\"M9.99984 4.16602V15.8327M4.1665 9.99935H15.8332\"\r\n stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n </path>\r\n </svg></span> Add New Zone \r\n </button>\r\n \r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"card-body\">\r\n <div id=\"customerjourney\"></div>\r\n </div>\r\n</div>", styles: ["#customerjourney{width:100%;height:500px}.bg-light-primary{border-radius:8px;border:1px solid var(--Primary-50, #EAF8FF);background:var(--Primary-50, #EAF8FF);box-shadow:0 1px 2px #1018280d;padding:8px 14px;justify-content:center}\n"] }]
|
|
92
|
-
}], ctorParameters: () => [{ type: i0.NgZone }, { type: i0.ElementRef }, { type: i1.FormBuilder }] });
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"customer-journey.component.js","sourceRoot":"","sources":["../../../../../../../projects/tango-analyse-zone/src/lib/components/zone-v2/customer-journey/customer-journey.component.ts","../../../../../../../projects/tango-analyse-zone/src/lib/components/zone-v2/customer-journey/customer-journey.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, ElementRef, NgZone } from '@angular/core';\r\nimport * as am5 from \"@amcharts/amcharts5\";\r\nimport * as am5flow from \"@amcharts/amcharts5/flow\";\r\nimport am5themes_Animated from \"@amcharts/amcharts5/themes/Animated\";\r\nimport { FormBuilder, FormControl, FormGroup } from '@angular/forms';\r\n\r\n\r\n@Component({\r\n  selector: 'lib-customer-journey',\r\n  templateUrl: './customer-journey.component.html',\r\n  styleUrl: './customer-journey.component.scss'\r\n})\r\nexport class CustomerJourneyComponent {\r\n  private root: am5.Root;\r\n  form: FormGroup;\r\n  selectControl: FormControl;\r\n  datasets: Array<{ value: string, label: string }> = [\r\n    { value: 'highest', label: 'Highest Visited Path' },\r\n    { value: 'lowest', label: 'Lowest Visited Path' }\r\n  ];\r\n\r\n  constructor(private zone: NgZone, private elRef: ElementRef, private fb: FormBuilder) {}\r\n\r\n  ngOnInit(): void {\r\n    this.initializeChart();\r\n    this.selectControl = new FormControl('highest');\r\n    this.form = this.fb.group({\r\n      selectControl: this.selectControl\r\n    });\r\n  }\r\n\r\n  // Function to handle chart creation\r\n  initializeChart(): void {\r\n    // Run the chart code inside Angular's NgZone to avoid conflicts\r\n    this.zone.runOutsideAngular(() => {\r\n      let root = am5.Root.new(this.elRef.nativeElement.querySelector('#customerjourney'));\r\n\r\n      // Set themes\r\n      root.setThemes([\r\n        am5themes_Animated.new(root)\r\n      ]);\r\n\r\n      // Create series\r\n      let series = root.container.children.push(am5flow.Sankey.new(root, {\r\n        sourceIdField: \"from\",\r\n        targetIdField: \"to\",\r\n        valueField: \"value\",\r\n        paddingRight: 50\r\n      }));\r\n\r\n      // Set the color step if available\r\n      this.setColorStep(series, 2);\r\n\r\n      // Set data\r\n      series.data.setAll([\r\n          { from: \"Entry (1343)\", to: \"Vincent Chase (1343)\", value: 20 },\r\n          { from: \"Vincent Chase (1343)\", to: \"John Jacobs (1343)\", value: 20 },\r\n          { from: \"Entry (1343)\", to: \"John Jacobs (1343)\", value: 40 },\r\n          { from: \"Entry (1343)\", to: \"Premium Section (1343)\", value: 20 },\r\n          { from: \"John Jacobs (1343)\", to: \"Billing (1343)\", value: 20 },\r\n          { from: \"Billing (1343)\", to: \"Exit\", value: 20 },\r\n          { from: \"Premium Section (1343)\", to: \"Exit\", value: 20 },\r\n          { from: \"Premium Section (1343)\", to: \"Billing (1343)\", value: 20 },\r\n        ]);\r\n\r\n      // Make stuff animate on load\r\n      series.appear(1000, 100);\r\n\r\n      this.root = root;\r\n    });\r\n  }\r\n\r\n  // Function to set color step\r\n  setColorStep(series: any, stepValue: number): void {\r\n    const colors = series.nodes.get(\"colors\");\r\n    if (colors) {\r\n      colors.set(\"step\", stepValue);\r\n    } else {\r\n      console.warn(\"Colors property not available on nodes.\");\r\n    }\r\n  }\r\n  onValueChange(event: any): void {\r\n    console.log('Selected value:', event);\r\n    // Handle value change logic here\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    // Clean up chart instance when the component is destroyed\r\n    if (this.root) {\r\n      this.root.dispose();\r\n    }\r\n  }\r\n}","<div class=\"card\">\r\n    <div class=\"card-header border-0 pt-3\">\r\n        <h3 class=\"card-title align-items-start flex-column\"><span class=\"card-label mb-2\">Customer Journey</span></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 justify-content-between\">\r\n                    <form class=\"mx-4\" [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)=\"onValueChange($event)\">\r\n                        </lib-reactive-select>\r\n                      </form>\r\n\r\n                    <button \r\n                        class=\"btn bg-light-primary btn-light-primary btn-active-light-primary\"><span\r\n                            ><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  d=\"M9.99984 4.16602V15.8327M4.1665 9.99935H15.8332\"\r\n                                    stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n                                </path>\r\n                    </svg></span> Add New Zone \r\n                    </button>\r\n                   \r\n\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"card-body\">\r\n        <div id=\"customerjourney\"></div>\r\n    </div>\r\n</div>"]}
|
|
349
|
+
args: [{ selector: 'lib-customer-journey', template: "<div class=\"card\">\r\n <div [hidden]=\"!showAverage\">\r\n <div class=\"card-header border-0 pt-3\">\r\n <h3 class=\"card-title align-items-start flex-column\"><span class=\"card-label mb-2\">Customer Journey</span></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 justify-content-between\">\r\n <button (click)=\"toggleView()\" type=\"button\" class=\"btn btn-outline align-items-end\">\r\n View All Zones</button>\r\n <form class=\"mx-4\" [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)=\"onValueChange($event)\">\r\n </lib-reactive-select>\r\n </form>\r\n\r\n <button (click)=\"goToZone()\"\r\n class=\"btn bg-light-primary btn-light-primary btn-active-light-primary\"><span\r\n ><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 d=\"M9.99984 4.16602V15.8327M4.1665 9.99935H15.8332\"\r\n stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n </path>\r\n </svg></span> Add New Zone \r\n </button>\r\n \r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"card-body\">\r\n <ng-container *ngIf=\"customerjourneyLoading\">\r\n <div 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 \r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"customerjourneyNoData && !customerjourneyLoading\">\r\n <div class=\"row\">\r\n <div class=\"col-lg-12 my-6\">\r\n <div\r\n class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n <img class=\"img-src\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n <div class=\"nodatamaintext mt-3\">No data found</div>\r\n <div class=\"nodatasubtext\">There is no result for Customer Journey Chart</div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <div [hidden]=\"customerjourneyLoading || customerjourneyNoData\" id=\"customerjourney\"></div>\r\n </div>\r\n</div>\r\n \r\n<div [hidden]=\"showAverage\">\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 mb-2\">Customer Journey</span>\r\n </h3>\r\n <div class=\"card-toolbar\">\r\n <div class=\"d-flex\">\r\n \r\n <div class=\"d-flex align-items-center position-relative my-1 justify-content-between\">\r\n <button (click)=\"toggleView()\" type=\"button\" class=\"btn btn-outline align-items-end mx-4\">\r\n View Average Customer Journey</button>\r\n <span class=\"me-4\">\r\n <span class=\"svg-icon footfallsearch svg-icon-1 position-absolute mt-3 ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\r\n viewBox=\"0 0 24 24\" fill=\"none\">\r\n <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\"\r\n height=\"2\" rx=\"1\" transform=\"rotate(45 17.0365 15.1223)\"\r\n fill=\"currentColor\">\r\n </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 [(ngModel)]=\"searchInput\" type=\"text\"\r\n class=\"form-control ps-14 me-4 footfallsearch\"\r\n placeholder=\"Search...\" autocomplete=\"off\" (keyup.enter)=\"searchField()\"\r\n /></span>\r\n <button type=\"button\" (click)=\"onExport()\" class=\"btn-outline btn align-items-end text-nowrap invheader me-4\" [disabled]=\"!customerJourneyData.length\">\r\n <!-- Export Icon -->\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path 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\" stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"></path>\r\n </svg>\r\n <span class=\"ms-2\"></span> Export\r\n </button>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"card-body p-0\">\r\n <div class=\"table-responsive\">\r\n <table *ngIf=\"!zonesummaryLoading && !zonesummaryNoData\" class=\"table text-nowrap bottom-border\">\r\n <thead>\r\n <tr>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('zoneName')\">\r\n Zone Name\r\n <svg [ngClass]=\"sortColumName === 'zoneName' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'zoneName' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div></th>\r\n <th ><div class=\"cursor-pointer\" (click)=\"sortData('noOfStores')\">\r\n No. of stores\r\n <svg [ngClass]=\"sortColumName === 'noOfStores' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'noOfStores' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div></th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('zoneFF')\">\r\n Zone FF\r\n <svg [ngClass]=\"sortColumName === 'zoneFF' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'zoneFF' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div></th>\r\n <th ><div class=\"cursor-pointer\" (click)=\"sortData('impressions')\">\r\n Impressions\r\n <svg [ngClass]=\"sortColumName === 'impressions' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'impressions' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div>\r\n </th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('AvgDwellTime')\">\r\n Avg Dwell Time\r\n <svg [ngClass]=\"sortColumName === 'AvgDwellTime' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'AvgDwellTime' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div></th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let store of customerJourneyData\">\r\n <td><div class=\"table-title\">{{ store.zoneName || '--' }}</div></td>\r\n <td><div class=\"table-title\">{{ store.noOfStores || '--' }}</div></td>\r\n <td><div class=\"table-title\">{{ store.zoneFF || '--' }}</div></td>\r\n <td><div class=\"table-title\">{{ store.impressions || '--' }}%</div></td>\r\n <td><div class=\"table-title\">{{ store.AvgDwellTime || '--' }} Mins</div></td>\r\n </tr> \r\n </tbody>\r\n </table>\r\n <ng-container *ngIf=\"zonesummaryLoading\">\r\n <div 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 \r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"zonesummaryNoData && !zonesummaryLoading\">\r\n <div class=\"row\">\r\n <div class=\"col-lg-12 my-6\">\r\n <div\r\n class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n <img class=\"img-src\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n <div class=\"nodatamaintext mt-3\">No data found</div>\r\n <div class=\"nodatasubtext\">There is no result for Customer Journey Table</div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n \r\n </div>\r\n <div *ngIf=\"!zonesummaryLoading && !zonesummaryNoData\">\r\n <lib-pagination class=\"text-start\" [itemsPerPage]=\"itemsPerPage\"\r\n [currentPage]=\"currentPage\" [totalItems]=\"totalItems\"\r\n [paginationSizes]=\"paginationSizes\" [pageSize]=\"pageSize\"\r\n (pageChange)=\"onPageChange($event)\"\r\n (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n </div>\r\n \r\n </div>\r\n</div>\r\n</div>", styles: ["#customerjourney{width:100%;height:500px}.bg-light-primary{border-radius:8px;border:1px solid var(--Primary-50, #EAF8FF);background:var(--Primary-50, #EAF8FF);box-shadow:0 1px 2px #1018280d;padding:8px 14px;justify-content:center}.table-title{color:var(--Gray-900, #101828);font-size:14px;font-weight:500;line-height:20px}.subtext{color:var(--Gray-800, #1D2939);font-size:14px;font-weight:500;line-height:20px}.headcount{color:var(--Gray-900, #101828);font-size:20px;font-weight:600;line-height:30px}.headtext{color:var(--Gray-700, #344054);font-size:18px;font-weight:600;line-height:28px}.subratetext{color:var(--Gray-500, #667085);font-size:12px;font-weight:500;line-height:18px}.invoicesearch{color:var(--Gray-700, #344054)!important;font-family:Inter;font-size:14px!important;font-style:normal;font-weight:500!important;line-height:20px}.invoicesearch::placeholder{color:var(--Gray-700, #344054)!important}.loader .title{width:65%}.loader .link{width:85%}.loader .description{width:95%}.loader .shimmer{padding:15px;width:95%;height:120px;margin:10px auto;background:#fff}.loader .shimmer .image-card{height:90px;width:90px;float:right;border-radius:8px}.loader .stroke{height:15px;background:#777;margin-top:20px}.loader .wrapper{width:0px;animation:fullView .5s forwards linear}@keyframes fullView{to{width:100%}}.loader .animate{animation:shimmer 3s;animation-iteration-count:infinite;background:linear-gradient(to right,#e6e6e6 5%,#ccc 25%,#e6e6e6 35%);background-size:1000px 100%}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.activePlanBtn{border-radius:6px;background:var(--Primary-50, #EAF8FF);color:var(--Gray-700, #344054);font-size:14px!important;font-weight:500!important;line-height:20px}.inactivePlanBtn{color:var(--Gray-500, #667085)!important;font-size:14px;font-weight:500!important;line-height:20px}.overalltext{color:var(--Gray-500, #667085);font-size:14px;font-weight:500;line-height:20px}.borderdashed{border-bottom:1px solid var(--Gray-200, #EAECF0)}.conc{width:110%}.overallstore{width:155%}::ng-deep .carousel-indicators [data-bs-target]{flex:0 1 auto;width:8px;height:8px;padding:0;cursor:pointer;background-color:#009bf3!important;border-radius:4px;transition:opacity .6s ease;margin-bottom:10px;border:0px}.category_active{border-bottom:3px solid #009EF7!important;border-radius:3px;margin-bottom:3px!important}.timer_active{color:var(--Primary-700, #009BF3);font-size:14px;font-style:normal;font-weight:500;line-height:20px}table tr{vertical-align:middle}table th,table td{height:44px!important;padding:20px 15px!important;align-items:center;gap:12px;align-self:stretch}.card .card-header{padding:0 1.25rem}.form-control:disabled{background-color:#f9fafb!important}.nodatamaintext{font-family:Inter;font-size:16px;font-weight:600;line-height:24px;text-align:center;color:#101828}.nodatasubtext{font-family:Inter;font-size:14px;font-weight:400;line-height:20px;text-align:center;color:#667085}.rotate{transform:rotate(180deg)}.table-title-primary{color:var(--Primary-700, #009BF3);font-size:14px;font-weight:500;line-height:20px;text-transform:capitalize}\n"] }]
|
|
350
|
+
}], ctorParameters: () => [{ type: i0.NgZone }, { type: i0.ElementRef }, { type: i1.FormBuilder }, { type: i2.Zonev2Service }, { type: i0.ChangeDetectorRef }, { type: i3.GlobalStateService }, { type: i4.NgbModal }, { type: i5.Router }, { type: i5.ActivatedRoute }, { type: i6.ToastService }] });
|
|
351
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"customer-journey.component.js","sourceRoot":"","sources":["../../../../../../../projects/tango-analyse-zone/src/lib/components/zone-v2/customer-journey/customer-journey.component.ts","../../../../../../../projects/tango-analyse-zone/src/lib/components/zone-v2/customer-journey/customer-journey.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, ElementRef, NgZone, ChangeDetectorRef } from '@angular/core';\r\nimport * as am5 from \"@amcharts/amcharts5\";\r\nimport * as am5flow from \"@amcharts/amcharts5/flow\";\r\nimport am5themes_Animated from \"@amcharts/amcharts5/themes/Animated\";\r\nimport { FormBuilder, FormControl, FormGroup } from '@angular/forms';\r\nimport { Zonev2Service } from '../../services/zonev2.service';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\r\nimport { GlobalStateService, PageInfoService } from 'tango-app-ui-global';\r\nimport { ToastService } from 'tango-app-ui-shared';\r\nimport { Subject, debounceTime, distinctUntilChanged, filter, takeUntil } from \"rxjs\";\r\n\r\n@Component({\r\n  selector: 'lib-customer-journey',\r\n  templateUrl: './customer-journey.component.html',\r\n  styleUrl: './customer-journey.component.scss'\r\n})\r\nexport class CustomerJourneyComponent {\r\n  private root: am5.Root;\r\n  private destroy$ = new Subject<void>();\r\n  form: FormGroup;\r\n  selectControl: FormControl;\r\n  datasets: Array<{ value: string, label: string }> = [\r\n    { value: 'top', label: 'Highest Visited Path' },\r\n    { value: 'bottom', label: 'Lowest Visited Path' }\r\n  ];\r\n\r\n  isExport: boolean = false;\r\n  itemsPerPage = 10\r\n  currentPage = 1\r\n  totalItems = 0\r\n  paginationSizes = [10, 20, 30]\r\n  pageSize = 10\r\n  sortColumName: string = '';\r\n  sortBy: any = '';\r\n  searchInput: any =\"\";\r\n  customerJourneyData: any[] = [];\r\n  searchDisabled: boolean = false;\r\n  invoiceList: any[] = [];\r\n  zonesummaryLoading: boolean = true;\r\n  zonesummaryNoData: boolean = false;\r\n  customerjourneyLoading: boolean = true;\r\n  customerjourneyNoData: boolean = false;\r\n  headerData: any;\r\n  sortDirection: any = '';\r\n  showAverage: boolean = true;\r\n  totalfootfallCount: number |  null = null;;\r\n\r\n  constructor(private zone: NgZone, private elRef: ElementRef, private fb: FormBuilder, private Zonev2Service: Zonev2Service,\r\n    private changeDetector: ChangeDetectorRef,\r\n    public gs: GlobalStateService,public modalService: NgbModal,\r\n    private router: Router,private route: ActivatedRoute,\r\n    private toast: ToastService) {}\r\n\r\n    ngOnDestroy(): void {\r\n      this.destroy$.next();\r\n      this.destroy$.complete();\r\n      \r\n      if (this.root) {\r\n        this.root.dispose();\r\n      }\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n      this.initializeChart();\r\n    }\r\n\r\n  ngOnInit(): void {\r\n    this.selectControl = new FormControl('top');\r\n    this.form = this.fb.group({\r\n      selectControl: this.selectControl\r\n    });\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.getCustomerJourney()\r\n        this.getCustomerJourneyTable();\r\n        // this.initializeChart();\r\n})\r\nthis.Zonev2Service.footfall$.subscribe((count) => {\r\n  this.totalfootfallCount = count;\r\n  this.getCustomerJourney();\r\n});\r\n  \r\n  }\r\n  getCustomerJourney(): void {\r\n    this.customerjourneyLoading = true;\r\n    this.customerjourneyNoData = true;\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        search: this.searchInput,\r\n        sortType: this.selectControl.value,\r\n        limit: this.pageSize,\r\n        offset: this.currentPage - 1,\r\n        export: false,\r\n    };\r\n\r\n    this.Zonev2Service.getCustomerJourney(requestData).subscribe((response: any) => {\r\n      // this.customerjourneyLoading = true;\r\n        if (response && response.status === 'success' ) {\r\n          this.customerjourneyLoading = false;\r\n          this.customerjourneyNoData = false;\r\n            this.initializeChart(); // Initialize chart when data is available\r\n            this.updateChart(response.data.customerJourneyData, this.totalfootfallCount);\r\n           \r\n        }  else {\r\n          this.customerjourneyLoading = false;\r\n          this.customerjourneyNoData = true;\r\n        }\r\n    }, error => {\r\n      this.customerjourneyLoading = false;\r\n          this.customerjourneyNoData = true;\r\n        // console.error('Error fetching customer journey data:', error);\r\n    });\r\n}\r\ninitializeChart(): void {\r\n  const chartDiv = document.getElementById('customerjourney');\r\n  if (!chartDiv) {\r\n      // console.error('Could not find HTML element with id customerjourney');\r\n      return;\r\n  }\r\n\r\n  if (!this.root) {  // Check if chart is already initialized\r\n      try {\r\n          this.root = am5.Root.new('customerjourney');\r\n          this.root.setThemes([am5themes_Animated.new(this.root)]);\r\n\r\n          const series = this.root.container.children.push(am5flow.Sankey.new(this.root, {\r\n              sourceIdField: \"from\",\r\n              targetIdField: \"to\",\r\n              valueField: \"value\",\r\n              paddingRight: 100\r\n          }));\r\n      } catch (error) {\r\n          // console.error('Error initializing chart:', error);\r\n      }\r\n  }\r\n}\r\n\r\nupdateChart(data: any[], footfallCount: number | null): void {\r\n  let filteredData = this.removeCircularLinks(data);\r\n  let firstZone = filteredData.filter((item:any) => {\r\n    let findExists = filteredData.find((ele:any) => ele.to == item.from);\r\n    if(!findExists) {\r\n      return item;\r\n    }\r\n  });\r\n  let lastZone = filteredData.filter((item:any) => {\r\n    let findExists = filteredData.find((ele:any) => ele.from == item.to);\r\n    if(!findExists) {\r\n      return item;\r\n    }\r\n  });\r\n  \r\n  firstZone = firstZone.map((item) =>  {\r\n    return {from:'Entry ('+this.totalfootfallCount+')',\r\n      to:item.from,\r\n      value:item.value,}\r\n  })\r\n  lastZone = lastZone.map((item) =>  {\r\n    return {from:item.to,to:'Exit ('+this.totalfootfallCount+')',value:item.value,}\r\n  })\r\n\r\n  filteredData = [...firstZone,...filteredData,...lastZone];\r\n\r\n  if (this.root) {\r\n      const series = this.root.container.children.getIndex(0) as am5flow.Sankey;\r\n      if (series) {\r\n          // Check if data is available, otherwise use fallback data\r\n          if (filteredData.length > 0) {\r\n              series.data.setAll(filteredData); // Update with API data\r\n          } else {\r\n            \r\n              // Predefined sample data as fallback\r\n              series.data.setAll([filteredData]);\r\n          }\r\n\r\n          this.changeDetector.detectChanges(); // Trigger Angular change detection\r\n      } else {\r\n          // console.error('Series not found for chart');\r\n      }\r\n  }\r\n}\r\n\r\nremoveCircularLinks(data: any[]): any[] {\r\n  const graph = new Map();\r\n  const result = [];\r\n\r\n  function hasCycle(from:any, to:any, visited:any) {\r\n    if (from === to) return true;\r\n    if (visited.has(from)) return false;\r\n\r\n    visited.add(from);\r\n\r\n    if (graph.has(from)) {\r\n      for (const neighbor of graph.get(from)) {\r\n        if (hasCycle(neighbor, to, visited)) {\r\n          return true;\r\n        }\r\n      }\r\n    }\r\n\r\n    visited.delete(from);\r\n    return false;\r\n  }\r\n\r\n  for (const { from, to, value } of data) {\r\n    if (hasCycle(to, from, new Set())) {\r\n      continue;\r\n    }\r\n\r\n    result.push({ from, to, value });\r\n\r\n    if (!graph.has(from)) {\r\n      graph.set(from, []);\r\n    }\r\n    graph.get(from).push(to);\r\n  }\r\n\r\n  return result;\r\n}\r\n\r\n  \r\n  setColorStep(series: any, step: number): void {\r\n    series.nodes.set(\"colors\", am5.ColorSet.new(this.root, {\r\n      step: step\r\n    }));\r\n  }\r\n  \r\n  onValueChange(event: any): void {\r\n    this.getCustomerJourney();\r\n  }\r\n\r\n  getCustomerJourneyTable(): void {\r\n    this.searchDisabled = true;\r\n    this.zonesummaryLoading = true;\r\n    this.zonesummaryNoData = true;\r\n    const requestData = {\r\n      fromDate: this.headerData.date.startDate,\r\n      toDate: this.headerData.date.endDate,\r\n      // storeId: [\"11-253\", \"11-511\",\"11-1176\"],\r\n      storeId: this.headerData.stores.filter((store:any) => store.checked).map((store:any) => store.storeId),\r\n      clientId:this.headerData.client,\r\n      // valueType: \"sum\",\r\n      search: this.searchInput,\r\n      sort: this.sortColumName,\r\n      sortBy: this.sortDirection,\r\n      limit: this.pageSize,\r\n      offset: this.currentPage -1,\r\n      export: false,\r\n\r\n    };\r\n\r\n    this.Zonev2Service.getCustomerJourneyTable(requestData)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((response: any) => {\r\n        this.zonesummaryLoading = false;\r\n        if (response?.code === 200 && response?.status === \"success\") {\r\n          // this.customerJourneyData = response.data;\r\n          this.customerJourneyData = response.data.customerJourneyTableData;\r\n          this.totalItems = response.data.totalCount\r\n          this.zonesummaryLoading = false;\r\n          this.zonesummaryNoData = false;\r\n          this.searchDisabled = false;\r\n        } else {\r\n          this.zonesummaryLoading = false;\r\n          this.zonesummaryNoData = true;\r\n          this.searchDisabled = true;\r\n          if (this.searchInput?.length) {\r\n            this.searchDisabled = true\r\n          }\r\n          this.customerJourneyData = []\r\n          this.totalItems = 0\r\n          this.changeDetector.detectChanges()\r\n        }\r\n      }, error => {\r\n        this.customerJourneyData = []\r\n        this.changeDetector.detectChanges()\r\n      });\r\n  }\r\n  onExport(): void {\r\n    this.currentPage = 1;\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      // storeId: [\"11-253\", \"11-511\",\"11-1176\"],\r\n      clientId:this.headerData.client,\r\n      // valueType: \"sum\",\r\n      search: this.searchInput,\r\n      sort: this.sortColumName,\r\n      sortBy: this.sortDirection,\r\n      limit: 10000,\r\n      offset: 0,\r\n      export: true\r\n    };\r\n\r\n    this.Zonev2Service.getCustomerJourneyTableExport(requestData)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res) => {\r\n          // console.log('API Response:', res); \r\n          this.Zonev2Service.saveAsExcelFile(res, 'CustomerJourney');\r\n        },\r\n        error: (e) => {\r\n          this.toast.getErrorToast('Something went Wrong..')\r\n        }\r\n      });\r\n  }\r\n  searchField(): void {\r\n    this.getCustomerJourneyTable();\r\n  }\r\n  sortData(column: string): void {\r\n    if (this.sortColumName === column) {\r\n      this.sortDirection = this.sortDirection === 1 ? -1 : 1;\r\n    } else {\r\n      this.sortColumName = column;\r\n      this.sortDirection = 1;\r\n    }\r\n    this.changeDetector.detectChanges();\r\n    this.getCustomerJourneyTable();\r\n  }\r\n  onPageSizeChange(pageSize: any) {\r\n    this.currentPage = 1;\r\n    this.pageSize = parseInt(pageSize)\r\n    this.getCustomerJourneyTable()\r\n  }\r\n  onPageChange(pageOffset: any) {\r\n    this.currentPage = parseInt(pageOffset)\r\n    this.getCustomerJourneyTable()\r\n  }\r\n  toggleView(): void {\r\n    this.showAverage =!this.showAverage;\r\n if (this.showAverage === true) {\r\n  // this.getCustomerJourney()\r\n  // this.initializeChart();\r\n }\r\n  }\r\n  goToZone(){\r\n    const datavalue: any = JSON.parse(\r\n      localStorage.getItem(\"header-filters\") || \"{}\"\r\n    );\r\n    datavalue.store = datavalue.stores[0].storeId;\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(datavalue));\r\n    this.changeDetector.detectChanges()\r\n    this.gs.dataRangeValue.next(datavalue)\r\n    this.router.navigate([\"/manage/stores/zones\"], {\r\n      queryParams: { storeId: datavalue.stores[0].storeId},\r\n    });\r\n \r\n  }\r\n\r\n\r\n}","<div class=\"card\">\r\n    <div [hidden]=\"!showAverage\">\r\n    <div class=\"card-header border-0 pt-3\">\r\n        <h3 class=\"card-title align-items-start flex-column\"><span class=\"card-label mb-2\">Customer Journey</span></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 justify-content-between\">\r\n                    <button (click)=\"toggleView()\" type=\"button\" class=\"btn btn-outline align-items-end\">\r\n                        View All Zones</button>\r\n                    <form class=\"mx-4\" [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)=\"onValueChange($event)\">\r\n                        </lib-reactive-select>\r\n                      </form>\r\n\r\n                    <button (click)=\"goToZone()\"\r\n                        class=\"btn bg-light-primary btn-light-primary btn-active-light-primary\"><span\r\n                            ><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  d=\"M9.99984 4.16602V15.8327M4.1665 9.99935H15.8332\"\r\n                                    stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n                                </path>\r\n                    </svg></span> Add New Zone \r\n                    </button>\r\n                   \r\n\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"card-body\">\r\n        <ng-container *ngIf=\"customerjourneyLoading\">\r\n            <div 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    \r\n            </div>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"customerjourneyNoData && !customerjourneyLoading\">\r\n            <div class=\"row\">\r\n                <div class=\"col-lg-12 my-6\">\r\n                    <div\r\n                        class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                        <img class=\"img-src\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                        <div class=\"nodatamaintext mt-3\">No data found</div>\r\n                        <div class=\"nodatasubtext\">There is no result for Customer Journey Chart</div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </ng-container>\r\n        <div [hidden]=\"customerjourneyLoading || customerjourneyNoData\"  id=\"customerjourney\"></div>\r\n    </div>\r\n</div>\r\n \r\n<div [hidden]=\"showAverage\">\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 mb-2\">Customer Journey</span>\r\n        </h3>\r\n        <div class=\"card-toolbar\">\r\n            <div class=\"d-flex\">\r\n              \r\n                <div class=\"d-flex align-items-center  position-relative my-1 justify-content-between\">\r\n                    <button (click)=\"toggleView()\" type=\"button\" class=\"btn btn-outline align-items-end mx-4\">\r\n                        View Average Customer Journey</button>\r\n                    <span class=\"me-4\">\r\n                    <span class=\"svg-icon footfallsearch svg-icon-1 position-absolute mt-3 ms-3\">\r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\r\n                            viewBox=\"0 0 24 24\" fill=\"none\">\r\n                            <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\"\r\n                                height=\"2\" rx=\"1\" transform=\"rotate(45 17.0365 15.1223)\"\r\n                                fill=\"currentColor\">\r\n                            </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 [(ngModel)]=\"searchInput\" type=\"text\"\r\n                        class=\"form-control ps-14 me-4 footfallsearch\"\r\n                        placeholder=\"Search...\" autocomplete=\"off\" (keyup.enter)=\"searchField()\"\r\n                         /></span>\r\n                        <button type=\"button\" (click)=\"onExport()\" class=\"btn-outline btn align-items-end text-nowrap invheader me-4\" [disabled]=\"!customerJourneyData.length\">\r\n                            <!-- Export Icon -->\r\n                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                              <path 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\" stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"></path>\r\n                            </svg>\r\n                            <span class=\"ms-2\"></span> Export\r\n                          </button>\r\n\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"card-body p-0\">\r\n        <div class=\"table-responsive\">\r\n            <table *ngIf=\"!zonesummaryLoading && !zonesummaryNoData\" class=\"table text-nowrap bottom-border\">\r\n                <thead>\r\n                    <tr>\r\n                        <th><div class=\"cursor-pointer\" (click)=\"sortData('zoneName')\">\r\n                            Zone Name\r\n                            <svg  [ngClass]=\"sortColumName === 'zoneName' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'zoneName' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                stroke-linejoin=\"round\" />\r\n                        </svg>\r\n                        </div></th>\r\n                        <th ><div class=\"cursor-pointer\" (click)=\"sortData('noOfStores')\">\r\n                            No. of stores\r\n                            <svg  [ngClass]=\"sortColumName === 'noOfStores' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'noOfStores' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                stroke-linejoin=\"round\" />\r\n                        </svg>\r\n                        </div></th>\r\n                        <th><div class=\"cursor-pointer\" (click)=\"sortData('zoneFF')\">\r\n                            Zone FF\r\n                            <svg  [ngClass]=\"sortColumName === 'zoneFF' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'zoneFF' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                stroke-linejoin=\"round\" />\r\n                        </svg>\r\n                        </div></th>\r\n                        <th ><div class=\"cursor-pointer\" (click)=\"sortData('impressions')\">\r\n                            Impressions\r\n                            <svg  [ngClass]=\"sortColumName === 'impressions' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'impressions' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                stroke-linejoin=\"round\" />\r\n                        </svg>\r\n                        </div>\r\n                        </th>\r\n                        <th><div class=\"cursor-pointer\" (click)=\"sortData('AvgDwellTime')\">\r\n                            Avg Dwell Time\r\n                            <svg  [ngClass]=\"sortColumName === 'AvgDwellTime' && sortDirection === 1 ? 'rotate' : ''\" xmlns=\"http://www.w3.org/2000/svg\" 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]=\"sortColumName === 'AvgDwellTime' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n                                stroke-linejoin=\"round\" />\r\n                        </svg>\r\n                        </div></th>\r\n                    </tr>\r\n                </thead>\r\n                <tbody>\r\n                        <tr *ngFor=\"let store of customerJourneyData\">\r\n                            <td><div class=\"table-title\">{{ store.zoneName || '--' }}</div></td>\r\n                            <td><div class=\"table-title\">{{ store.noOfStores || '--' }}</div></td>\r\n                            <td><div class=\"table-title\">{{ store.zoneFF || '--' }}</div></td>\r\n                             <td><div class=\"table-title\">{{ store.impressions || '--' }}%</div></td>\r\n                            <td><div class=\"table-title\">{{ store.AvgDwellTime || '--' }} Mins</div></td>\r\n                          </tr> \r\n                </tbody>\r\n            </table>\r\n            <ng-container *ngIf=\"zonesummaryLoading\">\r\n                <div 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        \r\n                </div>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"zonesummaryNoData && !zonesummaryLoading\">\r\n                <div class=\"row\">\r\n                    <div class=\"col-lg-12 my-6\">\r\n                        <div\r\n                            class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n                            <img class=\"img-src\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n                            <div class=\"nodatamaintext mt-3\">No data found</div>\r\n                            <div class=\"nodatasubtext\">There is no result for Customer Journey Table</div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </ng-container>\r\n        \r\n        </div>\r\n        <div *ngIf=\"!zonesummaryLoading && !zonesummaryNoData\">\r\n            <lib-pagination class=\"text-start\" [itemsPerPage]=\"itemsPerPage\"\r\n            [currentPage]=\"currentPage\" [totalItems]=\"totalItems\"\r\n            [paginationSizes]=\"paginationSizes\" [pageSize]=\"pageSize\"\r\n            (pageChange)=\"onPageChange($event)\"\r\n            (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n        </div>\r\n       \r\n    </div>\r\n</div>\r\n</div>"]}
|