tango-app-ui-shared 3.5.0-alpha.1 → 3.5.0-alpha.3
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/modules/layout/toolbar/metrics-header/metrics-header.component.mjs +298 -208
- package/esm2022/lib/modules/layout/toolbar/single-storedate/single-storedate.component.mjs +30 -10
- package/esm2022/lib/modules/layout/toolbar/toolbar.component.mjs +1 -2
- package/fesm2022/tango-app-ui-shared.mjs +326 -217
- package/fesm2022/tango-app-ui-shared.mjs.map +1 -1
- package/lib/modules/layout/toolbar/metrics-header/metrics-header.component.d.ts +2 -2
- package/lib/modules/layout/toolbar/single-storedate/single-storedate.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -19,8 +19,10 @@ export class MetricsHeaderComponent {
|
|
|
19
19
|
const isValidDate = m > this.dayjs();
|
|
20
20
|
return isValidDate ? "invalid-date" : false;
|
|
21
21
|
};
|
|
22
|
-
selectedDateRange = {
|
|
23
|
-
|
|
22
|
+
selectedDateRange = {
|
|
23
|
+
startDate: dayjs().subtract(30, "days"),
|
|
24
|
+
endDate: dayjs().subtract(1, "days"),
|
|
25
|
+
};
|
|
24
26
|
selectedFilters = {
|
|
25
27
|
client: null,
|
|
26
28
|
clientName: null,
|
|
@@ -31,7 +33,7 @@ export class MetricsHeaderComponent {
|
|
|
31
33
|
group: [],
|
|
32
34
|
location: [],
|
|
33
35
|
country: [],
|
|
34
|
-
zoneName: []
|
|
36
|
+
zoneName: [],
|
|
35
37
|
};
|
|
36
38
|
Opendropdown = false;
|
|
37
39
|
dropdownOpen = null; // 'location' or 'group'
|
|
@@ -45,8 +47,8 @@ export class MetricsHeaderComponent {
|
|
|
45
47
|
filteredZones = [];
|
|
46
48
|
stores = [];
|
|
47
49
|
zones = [];
|
|
48
|
-
searchStoreText =
|
|
49
|
-
searchZoneText =
|
|
50
|
+
searchStoreText = "";
|
|
51
|
+
searchZoneText = "";
|
|
50
52
|
clientList = [];
|
|
51
53
|
selectedClient;
|
|
52
54
|
locationLabel = [];
|
|
@@ -65,7 +67,7 @@ export class MetricsHeaderComponent {
|
|
|
65
67
|
}
|
|
66
68
|
onClick(event) {
|
|
67
69
|
const target = event.target;
|
|
68
|
-
if (!target.closest(
|
|
70
|
+
if (!target.closest(".dropdown2")) {
|
|
69
71
|
this.Opendropdown = false;
|
|
70
72
|
}
|
|
71
73
|
}
|
|
@@ -80,12 +82,12 @@ export class MetricsHeaderComponent {
|
|
|
80
82
|
// this.setRangesBasedOnRoute();
|
|
81
83
|
// }
|
|
82
84
|
// });
|
|
83
|
-
this.url = this.router.url.split("?")[0].split(
|
|
84
|
-
const user = JSON.parse(localStorage.getItem(
|
|
85
|
+
this.url = this.router.url.split("?")[0].split("/");
|
|
86
|
+
const user = JSON.parse(localStorage.getItem("user-info"));
|
|
85
87
|
this.users = user;
|
|
86
88
|
this.gs?.manageRefreshTrigger?.subscribe((e) => {
|
|
87
89
|
if (e) {
|
|
88
|
-
if (user.userType ===
|
|
90
|
+
if (user.userType === "tango") {
|
|
89
91
|
this.getClient();
|
|
90
92
|
}
|
|
91
93
|
else {
|
|
@@ -94,18 +96,18 @@ export class MetricsHeaderComponent {
|
|
|
94
96
|
const headerFilters = JSON.parse(storedFilters);
|
|
95
97
|
this.filteredStores = headerFilters?.stores.map((store) => ({
|
|
96
98
|
...store,
|
|
97
|
-
checked: store.checked
|
|
99
|
+
checked: store.checked,
|
|
98
100
|
}));
|
|
99
101
|
this.filteredZones = headerFilters?.zoneName.map((store) => ({
|
|
100
102
|
...store,
|
|
101
|
-
checked: store.checked
|
|
103
|
+
checked: store.checked,
|
|
102
104
|
}));
|
|
103
105
|
}
|
|
104
106
|
}
|
|
105
107
|
}
|
|
106
108
|
});
|
|
107
109
|
// Fetch client data if the user is of type 'tango'
|
|
108
|
-
if (user.userType ===
|
|
110
|
+
if (user.userType === "tango") {
|
|
109
111
|
this.getClient();
|
|
110
112
|
}
|
|
111
113
|
else {
|
|
@@ -117,7 +119,7 @@ export class MetricsHeaderComponent {
|
|
|
117
119
|
if (clientFilters) {
|
|
118
120
|
const headerclientFilters = JSON.parse(clientFilters);
|
|
119
121
|
this.selectedClient = {
|
|
120
|
-
trafficDateRange: headerclientFilters.trafficDateRange
|
|
122
|
+
trafficDateRange: headerclientFilters.trafficDateRange,
|
|
121
123
|
};
|
|
122
124
|
}
|
|
123
125
|
}
|
|
@@ -128,7 +130,7 @@ export class MetricsHeaderComponent {
|
|
|
128
130
|
// Initialize selectedFilters with defaults or existing values
|
|
129
131
|
this.selectedFilters = {
|
|
130
132
|
client: headerFilters.client || this.users.client,
|
|
131
|
-
clientName: headerFilters.clientName ||
|
|
133
|
+
clientName: headerFilters.clientName || "",
|
|
132
134
|
clients: headerFilters.clients || [],
|
|
133
135
|
store: headerFilters.store || null,
|
|
134
136
|
date: headerFilters.date || {},
|
|
@@ -171,7 +173,7 @@ export class MetricsHeaderComponent {
|
|
|
171
173
|
return items
|
|
172
174
|
? items.map((item) => ({
|
|
173
175
|
...item,
|
|
174
|
-
checked: item.checked === true
|
|
176
|
+
checked: item.checked === true,
|
|
175
177
|
}))
|
|
176
178
|
: [];
|
|
177
179
|
}
|
|
@@ -186,7 +188,7 @@ export class MetricsHeaderComponent {
|
|
|
186
188
|
resetFilters() {
|
|
187
189
|
this.selectedFilters = {
|
|
188
190
|
client: null,
|
|
189
|
-
clientName:
|
|
191
|
+
clientName: "",
|
|
190
192
|
clients: [],
|
|
191
193
|
store: null,
|
|
192
194
|
date: {},
|
|
@@ -194,7 +196,7 @@ export class MetricsHeaderComponent {
|
|
|
194
196
|
group: [],
|
|
195
197
|
location: [],
|
|
196
198
|
country: [],
|
|
197
|
-
zoneName: []
|
|
199
|
+
zoneName: [],
|
|
198
200
|
};
|
|
199
201
|
this.filteredLocations = [];
|
|
200
202
|
this.filteredGroups = [];
|
|
@@ -293,13 +295,13 @@ export class MetricsHeaderComponent {
|
|
|
293
295
|
}
|
|
294
296
|
getUserInfo(client) {
|
|
295
297
|
let obj = {
|
|
296
|
-
clientId: client ? client :
|
|
298
|
+
clientId: client ? client : "",
|
|
297
299
|
};
|
|
298
300
|
if (client) {
|
|
299
301
|
this.auth.getHeaderUsers(obj).subscribe({
|
|
300
302
|
next: (e) => {
|
|
301
303
|
localStorage.setItem("usersEmail-info", JSON.stringify(e?.data?.userEmailData || []));
|
|
302
|
-
}
|
|
304
|
+
},
|
|
303
305
|
});
|
|
304
306
|
}
|
|
305
307
|
}
|
|
@@ -332,7 +334,7 @@ export class MetricsHeaderComponent {
|
|
|
332
334
|
this.getStore();
|
|
333
335
|
this.getGroups();
|
|
334
336
|
// Update localStorage with the new client selection and empty filter data
|
|
335
|
-
localStorage.setItem(
|
|
337
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
336
338
|
window.location.reload();
|
|
337
339
|
// Emit data to the global service
|
|
338
340
|
// this.gs.dataRangeValue.next(this.selectedFilters);
|
|
@@ -341,16 +343,16 @@ export class MetricsHeaderComponent {
|
|
|
341
343
|
}
|
|
342
344
|
ranges = {
|
|
343
345
|
Today: [dayjs(), dayjs()],
|
|
344
|
-
Yesterday: [dayjs().subtract(1,
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
dayjs().subtract(14,
|
|
348
|
-
dayjs().subtract(8,
|
|
346
|
+
Yesterday: [dayjs().subtract(1, "days"), dayjs().subtract(1, "days")],
|
|
347
|
+
"This Week": [dayjs().subtract(7, "days"), dayjs().subtract(1, "days")],
|
|
348
|
+
"Last Week": [
|
|
349
|
+
dayjs().subtract(14, "days").startOf("day"),
|
|
350
|
+
dayjs().subtract(8, "days").endOf("day"),
|
|
349
351
|
],
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
dayjs().subtract(1,
|
|
353
|
-
dayjs().subtract(1,
|
|
352
|
+
"This Month": [dayjs().subtract(30, "days"), dayjs().subtract(1, "days")],
|
|
353
|
+
"Last Month": [
|
|
354
|
+
dayjs().subtract(1, "month").startOf("month"),
|
|
355
|
+
dayjs().subtract(1, "month").endOf("month"),
|
|
354
356
|
],
|
|
355
357
|
};
|
|
356
358
|
onStartDateChange(event) {
|
|
@@ -363,7 +365,8 @@ export class MetricsHeaderComponent {
|
|
|
363
365
|
}
|
|
364
366
|
else {
|
|
365
367
|
this.isCustomDate = (m) => {
|
|
366
|
-
const isValidDate = m > this.dayjs() ||
|
|
368
|
+
const isValidDate = m > this.dayjs() ||
|
|
369
|
+
m > this.dayjs(event.startDate.add(180, "days"));
|
|
367
370
|
return isValidDate ? "invalid-date" : false;
|
|
368
371
|
};
|
|
369
372
|
}
|
|
@@ -392,18 +395,22 @@ export class MetricsHeaderComponent {
|
|
|
392
395
|
}
|
|
393
396
|
getLocations() {
|
|
394
397
|
const country = this.countries
|
|
395
|
-
.filter(country => country.checked)
|
|
396
|
-
.map(country => country.country);
|
|
398
|
+
.filter((country) => country.checked)
|
|
399
|
+
.map((country) => country.country);
|
|
397
400
|
// const headerFilters: any = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
398
401
|
let obj = {
|
|
399
|
-
clientId: this.selectedFilters.client
|
|
402
|
+
clientId: this.selectedFilters.client
|
|
403
|
+
? this.selectedFilters.client
|
|
404
|
+
: this.users.clientId,
|
|
400
405
|
country,
|
|
401
406
|
city: [],
|
|
402
407
|
group: [],
|
|
403
408
|
};
|
|
404
409
|
this.auth.getLocation(obj).subscribe({
|
|
405
410
|
next: (res) => {
|
|
406
|
-
let cityList = this.selectedFilters?.location
|
|
411
|
+
let cityList = this.selectedFilters?.location
|
|
412
|
+
?.filter((location) => location.checked)
|
|
413
|
+
.map((loc) => loc.city);
|
|
407
414
|
// Map the fetched locations with default unchecked state
|
|
408
415
|
this.locations = res?.data?.locationData.map((city) => ({
|
|
409
416
|
city: city.city,
|
|
@@ -411,19 +418,26 @@ export class MetricsHeaderComponent {
|
|
|
411
418
|
checked: cityList?.includes(city.city) ? true : false,
|
|
412
419
|
}));
|
|
413
420
|
// Sync the fetched locations with any stored checked values in localStorage
|
|
414
|
-
if (this.selectedFilters.location &&
|
|
415
|
-
|
|
421
|
+
if (this.selectedFilters.location &&
|
|
422
|
+
Array.isArray(this.selectedFilters.location)) {
|
|
423
|
+
this.filteredLocations = this.locations.map((location) => {
|
|
416
424
|
const matchedLocation = this.selectedFilters.location.find((loc) => loc.city === location.city);
|
|
417
|
-
return matchedLocation
|
|
425
|
+
return matchedLocation
|
|
426
|
+
? { ...location, checked: matchedLocation.checked }
|
|
427
|
+
: location;
|
|
418
428
|
});
|
|
419
429
|
}
|
|
420
430
|
else {
|
|
421
431
|
this.filteredLocations = this.locations;
|
|
422
432
|
}
|
|
423
433
|
if (this.searchLocationText) {
|
|
424
|
-
this.filteredLocations = this.locations.filter((location) => location.city
|
|
434
|
+
this.filteredLocations = this.locations.filter((location) => location.city
|
|
435
|
+
.toLowerCase()
|
|
436
|
+
.includes(this.searchLocationText.toLowerCase()));
|
|
425
437
|
}
|
|
426
|
-
const selectedLocations = this.locations
|
|
438
|
+
const selectedLocations = this.locations
|
|
439
|
+
.filter((location) => location.checked)
|
|
440
|
+
.map((location) => location.city);
|
|
427
441
|
if (selectedLocations.length > 0) {
|
|
428
442
|
setTimeout(() => {
|
|
429
443
|
this.getGroups();
|
|
@@ -440,36 +454,50 @@ export class MetricsHeaderComponent {
|
|
|
440
454
|
});
|
|
441
455
|
}
|
|
442
456
|
isAllLocationsSelected() {
|
|
443
|
-
return this.filteredLocations.every(location => location.checked);
|
|
457
|
+
return this.filteredLocations.every((location) => location.checked);
|
|
444
458
|
}
|
|
445
459
|
selectedLocationsLabel() {
|
|
446
|
-
const selectedLocations = this.locationLabel = this.searchLocationText
|
|
447
|
-
.
|
|
448
|
-
|
|
460
|
+
const selectedLocations = (this.locationLabel = this.searchLocationText
|
|
461
|
+
.length
|
|
462
|
+
? this.locations
|
|
463
|
+
.filter((location) => location.checked)
|
|
464
|
+
.map((location) => location.city)
|
|
465
|
+
: this.filteredLocations
|
|
466
|
+
.filter((location) => location.checked)
|
|
467
|
+
.map((location) => location.city));
|
|
449
468
|
return selectedLocations.length === 0
|
|
450
|
-
?
|
|
469
|
+
? ""
|
|
451
470
|
: selectedLocations.length === 1
|
|
452
471
|
? selectedLocations[0]
|
|
453
|
-
: `${selectedLocations.length}
|
|
472
|
+
: `${selectedLocations.length} Region`;
|
|
454
473
|
}
|
|
455
474
|
removeLocation() {
|
|
456
475
|
this.Reset();
|
|
457
476
|
}
|
|
458
477
|
getGroups() {
|
|
459
478
|
const country = this.countries
|
|
460
|
-
.filter(country => country.checked)
|
|
461
|
-
.map(country => country.country);
|
|
479
|
+
.filter((country) => country.checked)
|
|
480
|
+
.map((country) => country.country);
|
|
462
481
|
let city;
|
|
463
482
|
city = this.locations
|
|
464
|
-
.filter(location => location.checked)
|
|
465
|
-
.map(location => location.city);
|
|
483
|
+
.filter((location) => location.checked)
|
|
484
|
+
.map((location) => location.city);
|
|
466
485
|
if (!city.length && country.length) {
|
|
467
486
|
city = this.locations.map((loc) => loc.city);
|
|
468
487
|
}
|
|
469
|
-
const obj = {
|
|
488
|
+
const obj = {
|
|
489
|
+
country,
|
|
490
|
+
city,
|
|
491
|
+
clientId: this.selectedFilters.client
|
|
492
|
+
? this.selectedFilters.client
|
|
493
|
+
: this.users.clientId,
|
|
494
|
+
group: [],
|
|
495
|
+
};
|
|
470
496
|
this.auth.getGroups(obj).subscribe({
|
|
471
497
|
next: (res) => {
|
|
472
|
-
let checkedGroup = this.selectedFilters?.group
|
|
498
|
+
let checkedGroup = this.selectedFilters?.group
|
|
499
|
+
?.filter((group) => group.checked)
|
|
500
|
+
.map((group) => group.groupName);
|
|
473
501
|
const combinedGroups = res?.data?.groupData?.map((groupName) => ({
|
|
474
502
|
groupName: groupName.groupName,
|
|
475
503
|
checked: checkedGroup?.includes(groupName.groupName) ? true : false,
|
|
@@ -483,7 +511,9 @@ export class MetricsHeaderComponent {
|
|
|
483
511
|
this.filteredGroups = combinedGroups;
|
|
484
512
|
}
|
|
485
513
|
// Auto-fetch stores when groups are selected
|
|
486
|
-
const selectedGroups = this.groupsData
|
|
514
|
+
const selectedGroups = this.groupsData
|
|
515
|
+
.filter((group) => group.checked)
|
|
516
|
+
.map((group) => group.groupName);
|
|
487
517
|
if (selectedGroups.length > 0) {
|
|
488
518
|
setTimeout(() => {
|
|
489
519
|
this.getStore(); // Fetch stores based on selected groups
|
|
@@ -503,51 +533,57 @@ export class MetricsHeaderComponent {
|
|
|
503
533
|
else {
|
|
504
534
|
// Open the specific dropdown and handle data fetching only if necessary
|
|
505
535
|
this.dropdownOpen = type;
|
|
506
|
-
if (type ===
|
|
536
|
+
if (type === "country") {
|
|
507
537
|
// Fetch countries only if not already fetched and no search text exists
|
|
508
|
-
if ((!this.filteredCountries || this.filteredCountries.length === 0) &&
|
|
538
|
+
if ((!this.filteredCountries || this.filteredCountries.length === 0) &&
|
|
539
|
+
!this.searchCountryText.trim()) {
|
|
509
540
|
this.getCountry();
|
|
510
541
|
}
|
|
511
542
|
}
|
|
512
|
-
if (type ===
|
|
543
|
+
if (type === "group") {
|
|
513
544
|
// Fetch groups only if there are selected cities and no active search text
|
|
514
545
|
const selectedCities = this.locations
|
|
515
546
|
.filter((location) => location.checked)
|
|
516
547
|
.map((location) => location.city);
|
|
517
548
|
// Fetch groups only if locations are selected, no search text exists, and dropdown is opened
|
|
518
|
-
if (this.filteredLocations.length > 0 ||
|
|
549
|
+
if (this.filteredLocations.length > 0 ||
|
|
550
|
+
(selectedCities.length > 0 && !this.searchGroupText.trim())) {
|
|
519
551
|
this.getGroups();
|
|
520
552
|
}
|
|
521
553
|
else {
|
|
522
554
|
this.filteredGroups = []; // Clear groups if no locations are selected
|
|
523
555
|
}
|
|
524
556
|
}
|
|
525
|
-
if (type ===
|
|
557
|
+
if (type === "store") {
|
|
526
558
|
// Fetch stores only if not already fetched and no search text is active
|
|
527
|
-
if ((!this.filteredStores || this.filteredStores.length === 0) &&
|
|
559
|
+
if ((!this.filteredStores || this.filteredStores.length === 0) &&
|
|
560
|
+
!this.searchStoreText.trim()) {
|
|
528
561
|
this.getStore();
|
|
529
562
|
}
|
|
530
563
|
}
|
|
531
|
-
if (type ===
|
|
564
|
+
if (type === "zone") {
|
|
532
565
|
// Fetch stores only if not already fetched and no search text is active
|
|
533
|
-
if ((!this.filteredZones || this.filteredZones.length === 0) &&
|
|
566
|
+
if ((!this.filteredZones || this.filteredZones.length === 0) &&
|
|
567
|
+
!this.searchZoneText.trim()) {
|
|
534
568
|
this.getZone();
|
|
535
569
|
}
|
|
536
570
|
}
|
|
537
571
|
}
|
|
538
572
|
}
|
|
539
573
|
handleGroupDropdownClick() {
|
|
540
|
-
if (this.dropdownOpen ===
|
|
574
|
+
if (this.dropdownOpen === "group") {
|
|
541
575
|
this.resetSelectedGroups();
|
|
542
576
|
}
|
|
543
|
-
this.toggleDropdown(
|
|
577
|
+
this.toggleDropdown("group");
|
|
544
578
|
}
|
|
545
579
|
resetSelectedGroups() {
|
|
546
580
|
this.filteredGroups.forEach((group) => (group.checked = false));
|
|
547
581
|
this.searchGroupText = "";
|
|
548
582
|
}
|
|
549
583
|
selectedGroupsLabel() {
|
|
550
|
-
const selectedGroups = this.groupLabel = this.searchGroupText.length
|
|
584
|
+
const selectedGroups = (this.groupLabel = this.searchGroupText.length
|
|
585
|
+
? this.groupsData.filter((group) => group.checked)
|
|
586
|
+
: this.filteredGroups.filter((group) => group.checked));
|
|
551
587
|
return selectedGroups.length === 0
|
|
552
588
|
? ""
|
|
553
589
|
: selectedGroups.length === 1
|
|
@@ -558,23 +594,25 @@ export class MetricsHeaderComponent {
|
|
|
558
594
|
this.Reset();
|
|
559
595
|
}
|
|
560
596
|
isAllGroupsSelected() {
|
|
561
|
-
return this.filteredGroups.length
|
|
597
|
+
return this.filteredGroups.length
|
|
598
|
+
? this.filteredGroups.every((group) => group.checked)
|
|
599
|
+
: false;
|
|
562
600
|
}
|
|
563
601
|
getStore() {
|
|
564
602
|
const country = this.countries
|
|
565
|
-
.filter(country => country.checked)
|
|
566
|
-
.map(country => country.country);
|
|
603
|
+
.filter((country) => country.checked)
|
|
604
|
+
.map((country) => country.country);
|
|
567
605
|
const city = this.locations
|
|
568
|
-
.filter(location => location.checked)
|
|
569
|
-
.map(location => location.city);
|
|
606
|
+
.filter((location) => location.checked)
|
|
607
|
+
.map((location) => location.city);
|
|
570
608
|
const group = this.groupsData
|
|
571
|
-
.filter(group => group.checked)
|
|
572
|
-
.map(group => group.groupName);
|
|
609
|
+
.filter((group) => group.checked)
|
|
610
|
+
.map((group) => group.groupName);
|
|
573
611
|
const data = {
|
|
574
612
|
country,
|
|
575
613
|
city,
|
|
576
614
|
clusters: group,
|
|
577
|
-
clientId: this.users.clientId || this.selectedFilters.client
|
|
615
|
+
clientId: this.users.clientId || this.selectedFilters.client,
|
|
578
616
|
};
|
|
579
617
|
this.auth.getHeaderStores(data).subscribe({
|
|
580
618
|
next: (res) => {
|
|
@@ -583,30 +621,34 @@ export class MetricsHeaderComponent {
|
|
|
583
621
|
this.stores = res.data.storesData;
|
|
584
622
|
// Check if there are previously selected stores
|
|
585
623
|
const checkedStoreIds = this.selectedFilters?.stores
|
|
586
|
-
? this.selectedFilters.stores
|
|
624
|
+
? this.selectedFilters.stores
|
|
625
|
+
.filter((store) => store.checked)
|
|
626
|
+
.map((store) => store.storeId)
|
|
587
627
|
: [];
|
|
588
628
|
// Sync the `checked` state
|
|
589
|
-
this.stores.forEach(store => {
|
|
629
|
+
this.stores.forEach((store) => {
|
|
590
630
|
store.checked = checkedStoreIds.length
|
|
591
631
|
? checkedStoreIds.includes(store.storeId) // Use previous selection
|
|
592
632
|
: true; // Default to true if no previous selection
|
|
593
633
|
});
|
|
594
634
|
// Apply search filter if search text is present
|
|
595
635
|
if (this.searchStoreText.length) {
|
|
596
|
-
this.filteredStores = this.stores.filter(store => store.storeName
|
|
636
|
+
this.filteredStores = this.stores.filter((store) => store.storeName
|
|
637
|
+
.toLowerCase()
|
|
638
|
+
.includes(this.searchStoreText.toLowerCase()));
|
|
597
639
|
}
|
|
598
640
|
else {
|
|
599
641
|
this.filteredStores = [...this.stores];
|
|
600
642
|
}
|
|
601
643
|
// Update `selectedFilters.stores` to reflect the current state
|
|
602
|
-
this.selectedFilters.stores = this.filteredStores.map(store => ({
|
|
644
|
+
this.selectedFilters.stores = this.filteredStores.map((store) => ({
|
|
603
645
|
storeId: store.storeId,
|
|
604
646
|
storeName: store.storeName,
|
|
605
|
-
checked: store.checked
|
|
647
|
+
checked: store.checked,
|
|
606
648
|
}));
|
|
607
649
|
// this.selectedFilters.country = country;
|
|
608
650
|
// Save updated filters to localStorage
|
|
609
|
-
localStorage.setItem(
|
|
651
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
610
652
|
this.getZone();
|
|
611
653
|
// Trigger UI change detection
|
|
612
654
|
this.cd.detectChanges();
|
|
@@ -619,93 +661,108 @@ export class MetricsHeaderComponent {
|
|
|
619
661
|
error: (err) => {
|
|
620
662
|
console.error("Failed to fetch stores", err);
|
|
621
663
|
this.clearStoresState();
|
|
622
|
-
}
|
|
664
|
+
},
|
|
623
665
|
});
|
|
624
666
|
}
|
|
625
667
|
getZone() {
|
|
626
668
|
const country = this.countries
|
|
627
|
-
.filter(country => country.checked)
|
|
628
|
-
.map(country => country.country);
|
|
669
|
+
.filter((country) => country.checked)
|
|
670
|
+
.map((country) => country.country);
|
|
629
671
|
const city = this.locations
|
|
630
|
-
.filter(location => location.checked)
|
|
631
|
-
.map(location => location.city);
|
|
672
|
+
.filter((location) => location.checked)
|
|
673
|
+
.map((location) => location.city);
|
|
632
674
|
const group = this.groupsData
|
|
633
|
-
.filter(group => group.checked)
|
|
634
|
-
.map(group => group.groupName);
|
|
675
|
+
.filter((group) => group.checked)
|
|
676
|
+
.map((group) => group.groupName);
|
|
635
677
|
const storeId = this.filteredStores
|
|
636
|
-
.filter(group => group.checked)
|
|
637
|
-
.map(group => group.storeId);
|
|
678
|
+
.filter((group) => group.checked)
|
|
679
|
+
.map((group) => group.storeId);
|
|
638
680
|
const data = {
|
|
639
681
|
country,
|
|
640
682
|
city,
|
|
641
683
|
clusters: group,
|
|
642
684
|
clientId: this.users.clientId || this.selectedFilters.client,
|
|
643
|
-
storeId: storeId
|
|
685
|
+
storeId: storeId,
|
|
644
686
|
};
|
|
645
687
|
this.auth.getHeaderZone(data).subscribe({
|
|
646
688
|
next: (res) => {
|
|
647
689
|
if (res && res.code === 200) {
|
|
648
|
-
// Initialize
|
|
649
|
-
this.zones =
|
|
650
|
-
|
|
690
|
+
// Initialize zones with Overall Store first, unchecked by default
|
|
691
|
+
this.zones = [
|
|
692
|
+
{ _id: "overall", tagName: "Overall Store", checked: false },
|
|
693
|
+
...(res?.data?.zoneData?.map((zone) => ({
|
|
694
|
+
_id: zone._id,
|
|
695
|
+
tagName: zone.tagName,
|
|
696
|
+
checked: false, // initialize unchecked; will update below
|
|
697
|
+
})) || []),
|
|
698
|
+
];
|
|
699
|
+
// Get previously selected zone IDs (checked ones)
|
|
651
700
|
const checkedStoreIds = this.selectedFilters?.zoneName
|
|
652
|
-
? this.selectedFilters
|
|
701
|
+
? this.selectedFilters.zoneName
|
|
702
|
+
.filter((zone) => zone.checked)
|
|
703
|
+
.map((zone) => zone._id)
|
|
653
704
|
: [];
|
|
654
|
-
// Sync
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
705
|
+
// Sync checked state with previous selections or default:
|
|
706
|
+
// If no previous selection, Overall Store unchecked, others checked
|
|
707
|
+
this.zones.forEach((zone) => {
|
|
708
|
+
if (checkedStoreIds.length) {
|
|
709
|
+
zone.checked = checkedStoreIds.includes(zone._id);
|
|
710
|
+
}
|
|
711
|
+
else {
|
|
712
|
+
zone.checked = zone._id !== "overall";
|
|
713
|
+
}
|
|
659
714
|
});
|
|
660
|
-
// Apply search filter if
|
|
715
|
+
// Apply search filter if any
|
|
661
716
|
if (this.searchZoneText.length) {
|
|
662
|
-
this.filteredZones = this.zones.filter(zone => zone.tagName
|
|
717
|
+
this.filteredZones = this.zones.filter((zone) => zone.tagName
|
|
718
|
+
.toLowerCase()
|
|
719
|
+
.includes(this.searchZoneText.toLowerCase()));
|
|
663
720
|
}
|
|
664
721
|
else {
|
|
665
722
|
this.filteredZones = [...this.zones];
|
|
666
723
|
}
|
|
667
|
-
// Update
|
|
668
|
-
this.selectedFilters.zoneName = this.filteredZones.map(zone => ({
|
|
724
|
+
// Update selectedFilters.zoneName with current checked states
|
|
725
|
+
this.selectedFilters.zoneName = this.filteredZones.map((zone) => ({
|
|
669
726
|
_id: zone._id,
|
|
670
727
|
tagName: zone.tagName,
|
|
671
|
-
checked: zone.checked
|
|
728
|
+
checked: zone.checked,
|
|
672
729
|
}));
|
|
673
|
-
// this.selectedFilters.country = couthis.filteredZonesntry;
|
|
674
730
|
// Save updated filters to localStorage
|
|
675
|
-
localStorage.setItem(
|
|
676
|
-
// Trigger
|
|
731
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
732
|
+
// Trigger change detection if needed
|
|
677
733
|
this.cd.detectChanges();
|
|
678
734
|
}
|
|
679
735
|
else {
|
|
680
|
-
// Handle empty or error response
|
|
681
736
|
this.clearZoneState();
|
|
682
737
|
}
|
|
683
738
|
},
|
|
684
739
|
error: (err) => {
|
|
685
|
-
console.error("Failed to fetch
|
|
740
|
+
console.error("Failed to fetch zones", err);
|
|
686
741
|
this.clearZoneState();
|
|
687
|
-
}
|
|
742
|
+
},
|
|
688
743
|
});
|
|
689
744
|
}
|
|
690
745
|
clearZoneState() {
|
|
691
746
|
this.zones = [];
|
|
692
747
|
this.filteredZones = [];
|
|
693
748
|
this.selectedFilters.zonename = [];
|
|
694
|
-
localStorage.setItem(
|
|
749
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
695
750
|
}
|
|
696
751
|
// Clear stores state and reset filters
|
|
697
752
|
clearStoresState() {
|
|
698
753
|
this.stores = [];
|
|
699
754
|
this.filteredStores = [];
|
|
700
755
|
this.selectedFilters.stores = [];
|
|
701
|
-
localStorage.setItem(
|
|
756
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
702
757
|
}
|
|
703
758
|
resetSelectedStores() {
|
|
704
759
|
this.filteredStores.forEach((store) => (store.checked = false));
|
|
705
760
|
this.searchStoreText = "";
|
|
706
761
|
}
|
|
707
762
|
selectedStoresLabel() {
|
|
708
|
-
const selectedStores = this.searchStoreText.length
|
|
763
|
+
const selectedStores = this.searchStoreText.length
|
|
764
|
+
? this.stores.filter((store) => store.checked)
|
|
765
|
+
: this.filteredStores.filter((store) => store.checked);
|
|
709
766
|
return selectedStores.length === 0
|
|
710
767
|
? "0 Stores"
|
|
711
768
|
: selectedStores.length === 1
|
|
@@ -713,7 +770,9 @@ export class MetricsHeaderComponent {
|
|
|
713
770
|
: `${selectedStores.length} Stores`;
|
|
714
771
|
}
|
|
715
772
|
selectedZonesLabel() {
|
|
716
|
-
const selectedStores = this.searchZoneText.length
|
|
773
|
+
const selectedStores = this.searchZoneText.length
|
|
774
|
+
? this.zones.filter((zone) => zone.checked)
|
|
775
|
+
: this.filteredZones.filter((zone) => zone.checked);
|
|
717
776
|
return selectedStores.length === 0
|
|
718
777
|
? "0 Zones"
|
|
719
778
|
: selectedStores.length === 1
|
|
@@ -721,23 +780,26 @@ export class MetricsHeaderComponent {
|
|
|
721
780
|
: `${selectedStores.length} Zones`;
|
|
722
781
|
}
|
|
723
782
|
isAllStoresSelected() {
|
|
724
|
-
return this.filteredStores.length > 0 &&
|
|
783
|
+
return (this.filteredStores.length > 0 &&
|
|
784
|
+
this.filteredStores.every((store) => store.checked));
|
|
725
785
|
}
|
|
726
786
|
isAllZonesSelected() {
|
|
727
|
-
return this.filteredZones
|
|
787
|
+
return this.filteredZones
|
|
788
|
+
.filter((zone) => zone._id !== "overall")
|
|
789
|
+
.every((zone) => zone.checked);
|
|
728
790
|
}
|
|
729
791
|
// Method to handle dropdown item selection
|
|
730
792
|
updateSelectedStores() {
|
|
731
|
-
this.filteredStores.forEach(store => {
|
|
732
|
-
const filteredStore = this.stores.findIndex(fStore => fStore.storeId === store.storeId);
|
|
793
|
+
this.filteredStores.forEach((store) => {
|
|
794
|
+
const filteredStore = this.stores.findIndex((fStore) => fStore.storeId === store.storeId);
|
|
733
795
|
if (filteredStore != -1) {
|
|
734
796
|
this.stores[filteredStore].checked = store.checked; // Sync the checked state with full store list
|
|
735
797
|
}
|
|
736
798
|
});
|
|
737
799
|
// Update selectedFilters based on the current store selection
|
|
738
|
-
this.selectedFilters.stores = this.stores.filter(store => store.checked);
|
|
800
|
+
this.selectedFilters.stores = this.stores.filter((store) => store.checked);
|
|
739
801
|
// Update localStorage with the latest selection
|
|
740
|
-
localStorage.setItem(
|
|
802
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
741
803
|
// Emit updated filters via service
|
|
742
804
|
// this.gs.dataRangeValue.next(this.selectedFilters);
|
|
743
805
|
// Trigger change detection if necessary
|
|
@@ -749,20 +811,30 @@ export class MetricsHeaderComponent {
|
|
|
749
811
|
this.selectedFilters.zoneName = [];
|
|
750
812
|
this.cd.detectChanges();
|
|
751
813
|
}
|
|
752
|
-
updateSelectedZones() {
|
|
753
|
-
this.filteredZones.forEach(zone => {
|
|
754
|
-
const
|
|
755
|
-
if (
|
|
756
|
-
this.zones[
|
|
814
|
+
updateSelectedZones(clickedZoneId) {
|
|
815
|
+
this.filteredZones.forEach((zone) => {
|
|
816
|
+
const index = this.zones.findIndex((z) => z._id === zone._id);
|
|
817
|
+
if (index !== -1) {
|
|
818
|
+
this.zones[index].checked = zone.checked;
|
|
757
819
|
}
|
|
758
820
|
});
|
|
759
|
-
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
|
|
821
|
+
const overallZone = this.zones.find((z) => z._id === "overall");
|
|
822
|
+
const overallChecked = overallZone?.checked ?? false;
|
|
823
|
+
const othersSelected = this.zones.some((z) => z._id !== "overall" && z.checked);
|
|
824
|
+
if (clickedZoneId === "overall" && overallChecked) {
|
|
825
|
+
this.zones = this.zones.map((z) => ({
|
|
826
|
+
...z,
|
|
827
|
+
checked: z._id === "overall",
|
|
828
|
+
}));
|
|
829
|
+
}
|
|
830
|
+
if (clickedZoneId !== "overall" && overallChecked) {
|
|
831
|
+
if (overallZone) {
|
|
832
|
+
overallZone.checked = false;
|
|
833
|
+
}
|
|
834
|
+
}
|
|
835
|
+
this.filteredZones = [...this.zones];
|
|
836
|
+
this.selectedFilters.zoneName = this.zones.filter((z) => z.checked);
|
|
837
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
766
838
|
this.cd.detectChanges();
|
|
767
839
|
}
|
|
768
840
|
toggleSelectAllLocations(event) {
|
|
@@ -773,9 +845,9 @@ export class MetricsHeaderComponent {
|
|
|
773
845
|
toggleSelectAllStores(event) {
|
|
774
846
|
const checked = event.target.checked;
|
|
775
847
|
// Apply the selection to both filtered and full list of stores
|
|
776
|
-
this.filteredStores.forEach(store => store.checked = checked);
|
|
777
|
-
this.stores.forEach(store => {
|
|
778
|
-
const filteredStore = this.filteredStores.find(fStore => fStore.storeId === store.storeId);
|
|
848
|
+
this.filteredStores.forEach((store) => (store.checked = checked));
|
|
849
|
+
this.stores.forEach((store) => {
|
|
850
|
+
const filteredStore = this.filteredStores.find((fStore) => fStore.storeId === store.storeId);
|
|
779
851
|
if (filteredStore) {
|
|
780
852
|
store.checked = checked; // Sync the checked state with full store list
|
|
781
853
|
}
|
|
@@ -785,16 +857,24 @@ export class MetricsHeaderComponent {
|
|
|
785
857
|
}
|
|
786
858
|
toggleSelectAllZones(event) {
|
|
787
859
|
const checked = event.target.checked;
|
|
788
|
-
|
|
789
|
-
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
|
|
793
|
-
zone.checked =
|
|
860
|
+
this.filteredZones.forEach((zone) => {
|
|
861
|
+
if (zone._id !== "overall") {
|
|
862
|
+
zone.checked = checked;
|
|
863
|
+
}
|
|
864
|
+
else {
|
|
865
|
+
zone.checked = false;
|
|
794
866
|
}
|
|
795
867
|
});
|
|
796
|
-
|
|
797
|
-
|
|
868
|
+
this.zones.forEach((zone) => {
|
|
869
|
+
const match = this.filteredZones.find((fz) => fz._id === zone._id);
|
|
870
|
+
if (match) {
|
|
871
|
+
zone.checked = match.checked;
|
|
872
|
+
}
|
|
873
|
+
});
|
|
874
|
+
// Since this is bulk, pass a dummy value — any non-overall zone is fine
|
|
875
|
+
const anySelectedZone = this.filteredZones.find((z) => z._id !== "overall");
|
|
876
|
+
const clickedId = anySelectedZone ? anySelectedZone._id : "";
|
|
877
|
+
this.updateSelectedZones(clickedId);
|
|
798
878
|
}
|
|
799
879
|
updateSelectedLocations() {
|
|
800
880
|
// When locations are selected, fetch the related groups
|
|
@@ -821,8 +901,8 @@ export class MetricsHeaderComponent {
|
|
|
821
901
|
}
|
|
822
902
|
this.selectedFilters.group = [];
|
|
823
903
|
this.filteredStores = []; // Reset stores as well
|
|
824
|
-
this.searchGroupText =
|
|
825
|
-
this.searchStoreText =
|
|
904
|
+
this.searchGroupText = "";
|
|
905
|
+
this.searchStoreText = "";
|
|
826
906
|
// this.Opendropdown = false;
|
|
827
907
|
}
|
|
828
908
|
toggleSelectAllGroups(event) {
|
|
@@ -852,26 +932,25 @@ export class MetricsHeaderComponent {
|
|
|
852
932
|
this.filteredStores = [];
|
|
853
933
|
// Also, update localStorage to reflect the cleared store selection
|
|
854
934
|
this.selectedFilters.stores = [];
|
|
855
|
-
localStorage.setItem(
|
|
935
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
856
936
|
// Emit data via service
|
|
857
937
|
// this.gs.dataRangeValue.next(this.selectedFilters);
|
|
858
938
|
}
|
|
859
939
|
// Clear the search store text when groups are updated
|
|
860
|
-
this.searchStoreText =
|
|
940
|
+
this.searchStoreText = "";
|
|
861
941
|
}
|
|
862
942
|
Reset() {
|
|
863
943
|
setTimeout(() => {
|
|
864
|
-
// Clear selected groups, stores, and locations
|
|
865
944
|
this.filteredCountries = [];
|
|
866
945
|
this.filteredGroups = [];
|
|
867
946
|
this.filteredStores = [];
|
|
868
|
-
this.filteredLocations = [];
|
|
947
|
+
this.filteredLocations = [];
|
|
869
948
|
this.locations = [];
|
|
870
949
|
this.groupsData = [];
|
|
871
950
|
this.stores = [];
|
|
872
951
|
this.filteredZones = [];
|
|
873
952
|
this.zones = [];
|
|
874
|
-
|
|
953
|
+
this.countries = [];
|
|
875
954
|
this.searchLocationText = "";
|
|
876
955
|
this.searchGroupText = "";
|
|
877
956
|
this.searchStoreText = "";
|
|
@@ -880,32 +959,14 @@ export class MetricsHeaderComponent {
|
|
|
880
959
|
this.selectedFilters.location = [];
|
|
881
960
|
this.selectedFilters.country = [];
|
|
882
961
|
this.selectedFilters.zoneName = [];
|
|
883
|
-
// Fetch locations, groups, and stores again
|
|
884
962
|
this.getCountry();
|
|
885
963
|
this.getLocations();
|
|
886
964
|
this.getStore();
|
|
887
965
|
this.getGroups();
|
|
888
|
-
|
|
889
|
-
// // Once stores are fetched, mark all as checked
|
|
890
|
-
// setTimeout(() => {
|
|
891
|
-
// this.filteredStores = this.stores.map(store => ({
|
|
892
|
-
// ...store,
|
|
893
|
-
// checked: true // Mark all stores as checked
|
|
894
|
-
// }));
|
|
895
|
-
// // Sync selectedFilters with the updated store state
|
|
896
|
-
// this.selectedFilters.stores = this.filteredStores.map(store => ({
|
|
897
|
-
// ...store,
|
|
898
|
-
// checked: true
|
|
899
|
-
// }));
|
|
900
|
-
// Update localStorage with the latest selectedFilters
|
|
901
|
-
localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
|
|
966
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
902
967
|
window.location.reload();
|
|
903
|
-
// Emit the reset filters to update other components if needed
|
|
904
968
|
// this.gs.dataRangeValue.next(this.selectedFilters);
|
|
905
|
-
// Trigger change detection
|
|
906
969
|
this.cd.detectChanges();
|
|
907
|
-
// Adding a slight delay to ensure stores are fetched first
|
|
908
|
-
// Close dropdown after reset if necessary
|
|
909
970
|
this.Opendropdown = false;
|
|
910
971
|
}, 100);
|
|
911
972
|
}
|
|
@@ -914,17 +975,18 @@ export class MetricsHeaderComponent {
|
|
|
914
975
|
if (searchText) {
|
|
915
976
|
// Preserve the checked state during filtering
|
|
916
977
|
this.filteredLocations = this.locations
|
|
917
|
-
.map(location => ({
|
|
978
|
+
.map((location) => ({
|
|
918
979
|
...location,
|
|
919
|
-
checked: this.filteredLocations.find(l => l.city === location.city)
|
|
980
|
+
checked: this.filteredLocations.find((l) => l.city === location.city)
|
|
981
|
+
?.checked || false,
|
|
920
982
|
}))
|
|
921
|
-
.filter(location => location?.city?.toLowerCase().includes(searchText));
|
|
983
|
+
.filter((location) => location?.city?.toLowerCase().includes(searchText));
|
|
922
984
|
}
|
|
923
985
|
else {
|
|
924
986
|
// Restore the original checked state when search text is cleared
|
|
925
|
-
this.filteredLocations = this.locations.map(location => ({
|
|
987
|
+
this.filteredLocations = this.locations.map((location) => ({
|
|
926
988
|
...location,
|
|
927
|
-
checked: this.selectedFilters.location.find((l) => l.city === location.city)?.checked || false
|
|
989
|
+
checked: this.selectedFilters.location.find((l) => l.city === location.city)?.checked || false,
|
|
928
990
|
}));
|
|
929
991
|
}
|
|
930
992
|
}
|
|
@@ -933,17 +995,18 @@ export class MetricsHeaderComponent {
|
|
|
933
995
|
if (searchText) {
|
|
934
996
|
// Preserve the checked state during filtering
|
|
935
997
|
this.filteredGroups = this.groupsData
|
|
936
|
-
.map(group => ({
|
|
998
|
+
.map((group) => ({
|
|
937
999
|
...group,
|
|
938
|
-
checked: this.filteredGroups.find(g => g.groupName === group.groupName)
|
|
1000
|
+
checked: this.filteredGroups.find((g) => g.groupName === group.groupName)
|
|
1001
|
+
?.checked || false,
|
|
939
1002
|
}))
|
|
940
|
-
.filter(group => group?.groupName?.toLowerCase().includes(searchText));
|
|
1003
|
+
.filter((group) => group?.groupName?.toLowerCase().includes(searchText));
|
|
941
1004
|
}
|
|
942
1005
|
else {
|
|
943
1006
|
// Restore the original checked state when search text is cleared
|
|
944
|
-
this.filteredGroups = this.groupsData.map(group => ({
|
|
1007
|
+
this.filteredGroups = this.groupsData.map((group) => ({
|
|
945
1008
|
...group,
|
|
946
|
-
checked: this.selectedFilters.group.find((g) => g.groupName === group.groupName)?.checked || false
|
|
1009
|
+
checked: this.selectedFilters.group.find((g) => g.groupName === group.groupName)?.checked || false,
|
|
947
1010
|
}));
|
|
948
1011
|
}
|
|
949
1012
|
}
|
|
@@ -953,19 +1016,23 @@ export class MetricsHeaderComponent {
|
|
|
953
1016
|
if (searchText) {
|
|
954
1017
|
// Filter based on search text while preserving checked state
|
|
955
1018
|
this.filteredStores = this.stores
|
|
956
|
-
.map(store => ({
|
|
1019
|
+
.map((store) => ({
|
|
957
1020
|
...store,
|
|
958
1021
|
// Check if the store is already checked in filteredStores, fallback to original stores' checked state
|
|
959
|
-
checked: this.selectedFilters.stores.find((s) => s.storeId === store.storeId)?.checked ||
|
|
1022
|
+
checked: this.selectedFilters.stores.find((s) => s.storeId === store.storeId)?.checked ||
|
|
1023
|
+
store.checked ||
|
|
1024
|
+
false,
|
|
960
1025
|
}))
|
|
961
|
-
.filter(store => store.storeName.toLowerCase().includes(searchText));
|
|
1026
|
+
.filter((store) => store.storeName.toLowerCase().includes(searchText));
|
|
962
1027
|
}
|
|
963
1028
|
else {
|
|
964
1029
|
// When the search text is cleared, restore the original list with preserved checked states
|
|
965
|
-
this.filteredStores = this.stores.map(store => ({
|
|
1030
|
+
this.filteredStores = this.stores.map((store) => ({
|
|
966
1031
|
...store,
|
|
967
1032
|
// Preserve the checked state based on the selected filters
|
|
968
|
-
checked: this.selectedFilters.stores.find((s) => s.storeId === store.storeId)?.checked ||
|
|
1033
|
+
checked: this.selectedFilters.stores.find((s) => s.storeId === store.storeId)?.checked ||
|
|
1034
|
+
store.checked ||
|
|
1035
|
+
false,
|
|
969
1036
|
}));
|
|
970
1037
|
}
|
|
971
1038
|
}
|
|
@@ -975,19 +1042,25 @@ export class MetricsHeaderComponent {
|
|
|
975
1042
|
if (searchText) {
|
|
976
1043
|
// Filter based on search text while preserving checked state
|
|
977
1044
|
this.filteredZones = this.zones
|
|
978
|
-
.map(zone => ({
|
|
1045
|
+
.map((zone) => ({
|
|
979
1046
|
...zone,
|
|
980
1047
|
// Check if the store is already checked in filteredStores, fallback to original stores' checked state
|
|
981
|
-
checked: this.selectedFilters.zoneName.find((s) => s._id === zone._id)
|
|
1048
|
+
checked: this.selectedFilters.zoneName.find((s) => s._id === zone._id)
|
|
1049
|
+
?.checked ||
|
|
1050
|
+
zone.checked ||
|
|
1051
|
+
false,
|
|
982
1052
|
}))
|
|
983
|
-
.filter(zone => zone.tagName.toLowerCase().includes(searchText));
|
|
1053
|
+
.filter((zone) => zone.tagName.toLowerCase().includes(searchText));
|
|
984
1054
|
}
|
|
985
1055
|
else {
|
|
986
1056
|
// When the search text is cleared, restore the original list with preserved checked states
|
|
987
|
-
this.filteredZones = this.zones.map(zone => ({
|
|
1057
|
+
this.filteredZones = this.zones.map((zone) => ({
|
|
988
1058
|
...zone,
|
|
989
1059
|
// Preserve the checked state based on the selected filters
|
|
990
|
-
checked: this.selectedFilters.zoneName.find((s) => s._id === zone._id)
|
|
1060
|
+
checked: this.selectedFilters.zoneName.find((s) => s._id === zone._id)
|
|
1061
|
+
?.checked ||
|
|
1062
|
+
zone.checked ||
|
|
1063
|
+
false,
|
|
991
1064
|
}));
|
|
992
1065
|
}
|
|
993
1066
|
}
|
|
@@ -1054,7 +1127,7 @@ export class MetricsHeaderComponent {
|
|
|
1054
1127
|
// isAllCountriesSelected(): boolean {
|
|
1055
1128
|
// return this.filteredCountries.every(country => country.checked);
|
|
1056
1129
|
// }
|
|
1057
|
-
// filterCountries(): void {
|
|
1130
|
+
// filterCountries(): void {
|
|
1058
1131
|
// const searchText = this.searchCountryText.toLowerCase();
|
|
1059
1132
|
// if (searchText) {
|
|
1060
1133
|
// // Preserve the checked state during filtering
|
|
@@ -1076,12 +1149,16 @@ export class MetricsHeaderComponent {
|
|
|
1076
1149
|
// }
|
|
1077
1150
|
getCountry() {
|
|
1078
1151
|
let obj = {
|
|
1079
|
-
clientId: this.selectedFilters.client
|
|
1152
|
+
clientId: this.selectedFilters.client
|
|
1153
|
+
? this.selectedFilters.client
|
|
1154
|
+
: this.users.clientId,
|
|
1080
1155
|
};
|
|
1081
1156
|
this.auth.getCountry(obj).subscribe({
|
|
1082
1157
|
next: (res) => {
|
|
1083
1158
|
// Extract selected countries from existing filters (if any)
|
|
1084
|
-
let countryList = this.selectedFilters?.country
|
|
1159
|
+
let countryList = this.selectedFilters?.country
|
|
1160
|
+
?.filter((country) => country.checked)
|
|
1161
|
+
.map((loc) => loc.country);
|
|
1085
1162
|
// Map API response to frontend model
|
|
1086
1163
|
this.countries = res?.data?.countryData.map((item) => ({
|
|
1087
1164
|
country: item.country,
|
|
@@ -1089,10 +1166,13 @@ export class MetricsHeaderComponent {
|
|
|
1089
1166
|
// checked: cityList?.length ? cityList.includes(city.city) : true,
|
|
1090
1167
|
checked: countryList?.includes(item.country) ? true : false,
|
|
1091
1168
|
}));
|
|
1092
|
-
if (this.selectedFilters.country &&
|
|
1093
|
-
|
|
1169
|
+
if (this.selectedFilters.country &&
|
|
1170
|
+
Array.isArray(this.selectedFilters.country)) {
|
|
1171
|
+
this.filteredCountries = this.countries.map((location) => {
|
|
1094
1172
|
const matchedLocation = this.selectedFilters.country.find((loc) => loc.country === location.country);
|
|
1095
|
-
return matchedLocation
|
|
1173
|
+
return matchedLocation
|
|
1174
|
+
? { ...location, checked: matchedLocation.checked }
|
|
1175
|
+
: location;
|
|
1096
1176
|
});
|
|
1097
1177
|
}
|
|
1098
1178
|
else {
|
|
@@ -1120,10 +1200,14 @@ export class MetricsHeaderComponent {
|
|
|
1120
1200
|
}
|
|
1121
1201
|
selectedCountriesLabel() {
|
|
1122
1202
|
const selectedCountries = this.searchCountryText.length
|
|
1123
|
-
? this.filteredCountries
|
|
1124
|
-
|
|
1203
|
+
? this.filteredCountries
|
|
1204
|
+
.filter((country) => country.checked)
|
|
1205
|
+
.map((country) => country.country)
|
|
1206
|
+
: this.countries
|
|
1207
|
+
.filter((country) => country.checked)
|
|
1208
|
+
.map((country) => country.country);
|
|
1125
1209
|
return selectedCountries.length === 0
|
|
1126
|
-
?
|
|
1210
|
+
? ""
|
|
1127
1211
|
: selectedCountries.length === 1
|
|
1128
1212
|
? selectedCountries[0]
|
|
1129
1213
|
: `${selectedCountries.length} countries`;
|
|
@@ -1133,22 +1217,24 @@ export class MetricsHeaderComponent {
|
|
|
1133
1217
|
if (searchText) {
|
|
1134
1218
|
// Filter and preserve checked state
|
|
1135
1219
|
this.filteredCountries = this.countries
|
|
1136
|
-
.map(country => ({
|
|
1220
|
+
.map((country) => ({
|
|
1137
1221
|
...country,
|
|
1138
|
-
checked: this.filteredCountries.find(c => c.country === country.country)
|
|
1222
|
+
checked: this.filteredCountries.find((c) => c.country === country.country)
|
|
1223
|
+
?.checked || false,
|
|
1139
1224
|
}))
|
|
1140
|
-
.filter(country => country.country.toLowerCase().includes(searchText));
|
|
1225
|
+
.filter((country) => country.country.toLowerCase().includes(searchText));
|
|
1141
1226
|
}
|
|
1142
1227
|
else {
|
|
1143
1228
|
// Reset to full list
|
|
1144
1229
|
this.filteredCountries = this.countries.map((country) => ({
|
|
1145
1230
|
...country,
|
|
1146
|
-
checked: this.selectedFilters.country?.find((c) => c.country === country.country)?.checked || false
|
|
1231
|
+
checked: this.selectedFilters.country?.find((c) => c.country === country.country)?.checked || false,
|
|
1147
1232
|
}));
|
|
1148
1233
|
}
|
|
1149
1234
|
}
|
|
1150
1235
|
isAllCountriesSelected() {
|
|
1151
|
-
return this.filteredCountries.length > 0 &&
|
|
1236
|
+
return (this.filteredCountries.length > 0 &&
|
|
1237
|
+
this.filteredCountries.every((country) => country.checked));
|
|
1152
1238
|
}
|
|
1153
1239
|
toggleSelectAllCountries(event) {
|
|
1154
1240
|
const isChecked = event.target.checked;
|
|
@@ -1185,8 +1271,8 @@ export class MetricsHeaderComponent {
|
|
|
1185
1271
|
this.selectedFilters.group = [];
|
|
1186
1272
|
this.filteredStores = []; // Reset stores as well
|
|
1187
1273
|
this.filteredZones = [];
|
|
1188
|
-
this.searchGroupText =
|
|
1189
|
-
this.searchStoreText =
|
|
1274
|
+
this.searchGroupText = "";
|
|
1275
|
+
this.searchStoreText = "";
|
|
1190
1276
|
// this.Opendropdown = false;
|
|
1191
1277
|
}
|
|
1192
1278
|
removeCountry() {
|
|
@@ -1202,8 +1288,12 @@ export class MetricsHeaderComponent {
|
|
|
1202
1288
|
this.selectedFilters.country = this.filteredCountries;
|
|
1203
1289
|
this.selectedFilters.location = this.locations;
|
|
1204
1290
|
this.selectedFilters.group = this.groupsData;
|
|
1205
|
-
this.selectedFilters.stores = headerFilters.stores
|
|
1206
|
-
|
|
1291
|
+
this.selectedFilters.stores = headerFilters.stores
|
|
1292
|
+
? headerFilters.stores
|
|
1293
|
+
: this.stores;
|
|
1294
|
+
this.selectedFilters.zoneName = headerFilters.zoneName
|
|
1295
|
+
? headerFilters.zoneName
|
|
1296
|
+
: this.zones;
|
|
1207
1297
|
// this.selectedFilters.zoneName = this.filteredZones;
|
|
1208
1298
|
// Store updated filters back in localStorage
|
|
1209
1299
|
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
@@ -1216,16 +1306,16 @@ export class MetricsHeaderComponent {
|
|
|
1216
1306
|
this.cd.detectChanges();
|
|
1217
1307
|
}
|
|
1218
1308
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetricsHeaderComponent, deps: [{ token: i1.AuthService }, { token: i2.Router }, { token: i3.GlobalStateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
1219
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MetricsHeaderComponent, selector: "lib-metrics-header", host: { listeners: { "document:click": "clickOutside($event)" } }, ngImport: i0, template: "<div class=\"me-3\">\r\n <label *ngIf=\"selectedCountriesLabel()\" class=\"badge badge-light-default mx-2\">{{selectedCountriesLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeCountry()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label *ngIf=\"selectedLocationsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedLocationsLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeLocation()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label *ngIf=\"selectedGroupsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedGroupsLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label class=\"badge badge-light-default\">{{selectedStoresLabel()}}</label>\r\n <label class=\"badge badge-light-default mx-2\">{{selectedZonesLabel()}} \r\n <!-- <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span> -->\r\n </label>\r\n</div>\r\n\r\n\r\n<div class=\"wrapper me-3\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\">\r\n<lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n(selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n</div>\r\n<div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <input class=\"fx-date-range form-control ps-14\" style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [autoApply]=\"true\"\r\n [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\"\r\n [(ngModel)]=\"selectedDateRange\" (startDateChanged)=\"onStartDateChange($event)\" [isCustomDate]=\"isCustomDate\"\r\n [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n (datesUpdated)=\"datechange($event)\" name=\"daterange\" [readonly]=\"true\" />\r\n</div>\r\n<div class=\"position-relative\">\r\n <button type=\"button\" (click)=\"opendropdown($event)\" class=\"btn btn-default mx-2 rounded-3 text-nowrap border-val\">\r\n <!-- <span class=\"me-2\">Filter</span> -->\r\n <svg class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </button>\r\n\r\n <div *ngIf=\"Opendropdown\" class=\"card p-5 dropdown2 position-absolute z-1 end-0\" style=\"z-index: 1 !important;\" (clickOutside)=\"closeDropdown1()\">\r\n <div class=\"dropdown-title d-flex justify-content-between mb-2\">Filter Options\r\n <button class=\"btn btn-outline w-25 ms-3 btn-resize\" (click)=\"Reset()\"> Reset </button>\r\n <button class=\"btn btn-primary w-25 btn-resize\" (click)=\"Apply()\">Apply</button>\r\n </div>\r\n\r\n <!-- Country Dropdown -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('country')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedCountriesLabel()\"\r\n readonly\r\n placeholder=\"Select country\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'country'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search country\" \r\n [(ngModel)]=\"searchCountryText\" \r\n (ngModelChange)=\"filterCountries()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllCountries\" \r\n [checked]=\"isAllCountriesSelected()\" \r\n (change)=\"toggleSelectAllCountries($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllCountries\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let country of filteredCountries\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"country.country\" \r\n [(ngModel)]=\"country.checked\"\r\n (change)=\"updateSelectedCountries()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"country.country\">\r\n {{ country.country }}\r\n </label>\r\n \r\n </div>\r\n </div>\r\n</div>\r\n\r\n <!-- Location Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('location')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedLocationsLabel()\"\r\n readonly\r\n placeholder=\"Select Region\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'location'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search Region\" \r\n [(ngModel)]=\"searchLocationText\" \r\n (ngModelChange)=\"filterLocations()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllLocations\" \r\n [checked]=\"isAllLocationsSelected()\" \r\n (change)=\"toggleSelectAllLocations($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllLocations\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let location of filteredLocations\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"location.city\" \r\n [(ngModel)]=\"location.checked\"\r\n (change)=\"updateSelectedLocations()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"location.city\">\r\n {{ location.city }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('group')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedGroupsLabel()\" readonly\r\n placeholder=\"Select clusters\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'group'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search clusters\" \r\n [(ngModel)]=\"searchGroupText\" \r\n (ngModelChange)=\"filterGroups()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllGroups\" \r\n [checked]=\"isAllGroupsSelected()\" \r\n (change)=\"toggleSelectAllGroups($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllGroups\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let group of filteredGroups\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"group.groupName\"\r\n [(ngModel)]=\"group.checked\"\r\n (change)=\"updateSelectedGroups()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"group.groupName\">\r\n {{ group.groupName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n<!-- Store Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('store')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\"\r\n [value]=\"selectedStoresLabel()\"\r\n readonly\r\n placeholder=\"Select stores\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'store'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search \" \r\n placeholder=\"Search stores\" \r\n [(ngModel)]=\"searchStoreText\" \r\n (ngModelChange)=\"filterStores()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllStores\" \r\n [checked]=\"isAllStoresSelected()\" \r\n (change)=\"toggleSelectAllStores($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllStores\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let store of filteredStores\"\r\n >\r\n <input \r\n class=\"form-check-input\" \r\n type=\"checkbox\" \r\n [id]=\"store.storeId\"\r\n [(ngModel)]=\"store.checked\"\r\n (change)=\"updateSelectedStores()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"store.storeId\">\r\n {{ store.storeName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Zone Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('zone')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\"\r\n [value]=\"selectedZonesLabel()\"\r\n readonly\r\n placeholder=\"Select zones\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'zone'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search \" \r\n placeholder=\"Search zones\" \r\n [(ngModel)]=\"searchZoneText\" \r\n (ngModelChange)=\"filterZones()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllZones\" \r\n [checked]=\"isAllZonesSelected()\" \r\n (change)=\"toggleSelectAllZones($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllZones\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let zone of filteredZones\"\r\n >\r\n <input \r\n class=\"form-check-input\" \r\n type=\"checkbox\" \r\n [id]=\"zone._id\"\r\n [(ngModel)]=\"zone.checked\"\r\n (change)=\"updateSelectedZones()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"zone._id\">\r\n {{ zone.tagName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n </div>\r\n</div>", styles: [".daterangepicker{display:block!important;top:153.85px!important;left:900px!important;right:0}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize}::ng-deep .applyBtn{display:none!important}:host::ng-deep .md-drppicker .btn{line-height:10px!important}:host::ng-deep .daterangepicker-input+.ngx-daterangepicker-material .applyBtn{display:none}:host::ng-deep .md-drppicker.drops-down-right.ltr.double.show-ranges.shown{top:65px!important;left:-470px!important;height:365px!important}:host::ng-deep .md-drppicker .btn{border-radius:8px!important;border:1px solid var(--Primary-600, #00A3FF)!important;background:var(--Primary-600, #00A3FF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--White, #FFF)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize}:host::ng-deep .md-drppicker .ranges ul li button{padding:12px 16px;width:160px;color:var(--Gray-700, #344054);font-size:14px;font-weight:400;line-height:20px;background:none;border:none;text-align:left;cursor:pointer}:host::ng-deep .md-drppicker td.active,:host::ng-deep .md-drppicker td.active:hover{background-color:#029cf4!important;border-radius:20px!important;color:var(--White, #FFF)!important;text-align:center!important;font-size:14px!important;font-weight:500!important;line-height:20px}:host::ng-deep .md-drppicker.ltr .ranges{float:left;margin-top:10px!important}:host::ng-deep .md-drppicker td.in-range{background:var(--Primary-50, #EAF8FF)}:host::ng-deep .md-drppicker .ranges ul li button.active{background:var(--Primary-50, #EAF8FF)!important;border-radius:8px!important;color:var(--Primary-700, #009BF3);font-size:14px!important;font-weight:500!important;line-height:20px!important}:host::ng-deep table th,:host::ng-deep table td{width:40px!important;height:40px!important;padding:10px 8px!important}:host::ng-deep .md-drppicker td.available.prev,:host::ng-deep .md-drppicker th.available.prev{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep .md-drppicker td.available.next,:host::ng-deep .md-drppicker th.available.next{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep table th{border-bottom:0px solid var(--Gray-200, #EAECF0)!important;background:transparent!important;color:var(--Gray-700, #344054)!important;text-align:center;font-size:16px!important;font-weight:500!important;line-height:24px}:host::ng-deep .md-drppicker .btn.btn-default{border-radius:8px!important;border:1px solid var(--Gray-300, #D0D5DD)!important;background:var(--White, #FFF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize;margin-right:10px!important}:host::ng-deep .md-drppicker td.available.invalid-date{text-decoration:line-through;pointer-events:none;color:#a9a9a9}:host::ng-deep .md-drppicker td.available.today:not(.invalid-date){text-decoration:unset;pointer-events:unset;color:unset}.wrapper{min-width:200px}.btn-primary{line-height:18px!important}.filter-label{color:var(--Gray-500, #667085)!important;font-size:14px;font-style:normal;font-weight:600;line-height:20px;text-transform:capitalize}.position-relative{position:relative}.filter-icon{cursor:pointer}.dropdown-container{position:relative;display:inline-block;width:100%}.dropdown-header{cursor:pointer;width:100%}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize;width:100%;box-sizing:border-box}.dropdown-menu{position:absolute;top:100%;left:0;right:0;border:1px solid #ccc;background-color:#fff;z-index:1000;max-height:230px;overflow-y:auto;display:block;box-sizing:border-box;padding:10px 5px}.dropdown-item{padding:6px 0}.dropdown-item:hover{background-color:#f1f1f1}.dropdown-item input[type=checkbox]{margin-right:10px}.custom-dropdown-menu{border-radius:4px;box-shadow:0 1px 2px #1018280d}.custom-dropdown-item{display:flex;align-items:center}.custom-dropdown-item input{margin-left:10px}.btn-resize{font-size:13px!important;height:29px!important;line-height:11px!important;padding:3px!important}.dropdown2{position:absolute;top:70px;min-width:270px!important}.dropdown2 .dropdown-title{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:24px}.dropdown2 .dropdown{position:relative;display:inline-block}.dropdown2 .dropdown span{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:20px}.form-check-label{color:var(--Gray-700, #344054)!important;font-size:14px;font-style:normal;font-weight:500;line-height:20px}input[type=checkbox]{width:16px!important;height:16px!important;margin:0 5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-300, #D0D5DD);box-shadow:none;font-size:.8em;text-align:center;line-height:1em;background:#fff}input[type=checkbox]:checked{outline:1px solid var(--primary-600, #00A3FF);background-color:var(--primary-50, #EAF8FF)}input[type=checkbox]:checked:after{content:\"\";transform:rotate(45deg);border-bottom:2px solid #00A3FF;border-right:2px solid #00A3FF;display:inline-block;width:.2em;padding-left:0;padding-top:9px;padding-right:4px}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.CustomSelectComponent, selector: "lib-select", inputs: ["items", "searchField", "multi", "idField", "selectedValues", "disabled", "label"], outputs: ["selected"] }, { kind: "directive", type: i6.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: i6.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i7.DaterangepickerDirective, selector: "input[ngxDaterangepickerMd]", inputs: ["minDate", "maxDate", "autoApply", "alwaysShowCalendars", "showCustomRangeLabel", "linkedCalendars", "dateLimit", "singleDatePicker", "showWeekNumbers", "showISOWeekNumbers", "showDropdowns", "isInvalidDate", "isCustomDate", "isTooltipDate", "showClearButton", "customRangeDirection", "ranges", "opens", "drops", "firstMonthDayClass", "lastMonthDayClass", "emptyWeekRowClass", "emptyWeekColumnClass", "firstDayOfNextMonthClass", "lastDayOfPreviousMonthClass", "keepCalendarOpeningWithRange", "showRangeLabelOnInput", "showCancel", "lockStartDate", "timePicker", "timePicker24Hour", "timePickerIncrement", "timePickerSeconds", "closeOnAutoApply", "endKeyHolder", "startKey", "locale", "endKey"], outputs: ["change", "rangeClicked", "datesUpdated", "startDateChanged", "endDateChanged", "clearClicked"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] });
|
|
1309
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: MetricsHeaderComponent, selector: "lib-metrics-header", host: { listeners: { "document:click": "clickOutside($event)" } }, ngImport: i0, template: "<div class=\"me-3\">\r\n <label *ngIf=\"selectedCountriesLabel()\" class=\"badge badge-light-default mx-2\">{{selectedCountriesLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeCountry()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label *ngIf=\"selectedLocationsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedLocationsLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeLocation()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label *ngIf=\"selectedGroupsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedGroupsLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label class=\"badge badge-light-default\">{{selectedStoresLabel()}}</label>\r\n <label class=\"badge badge-light-default mx-2\">{{selectedZonesLabel()}} \r\n <!-- <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span> -->\r\n </label>\r\n</div>\r\n\r\n\r\n<div class=\"wrapper me-3\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\">\r\n<lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n(selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n</div>\r\n<div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <input class=\"fx-date-range form-control ps-14\" style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [autoApply]=\"true\"\r\n [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\"\r\n [(ngModel)]=\"selectedDateRange\" (startDateChanged)=\"onStartDateChange($event)\" [isCustomDate]=\"isCustomDate\"\r\n [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n (datesUpdated)=\"datechange($event)\" name=\"daterange\" [readonly]=\"true\" />\r\n</div>\r\n<div class=\"position-relative\">\r\n <button type=\"button\" (click)=\"opendropdown($event)\" class=\"btn btn-default mx-2 rounded-3 text-nowrap border-val\">\r\n <!-- <span class=\"me-2\">Filter</span> -->\r\n <svg class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </button>\r\n\r\n <div *ngIf=\"Opendropdown\" class=\"card p-5 dropdown2 position-absolute z-1 end-0\" style=\"z-index: 1 !important;\" (clickOutside)=\"closeDropdown1()\">\r\n <div class=\"dropdown-title d-flex justify-content-between mb-2\">Filter Options\r\n <button class=\"btn btn-outline w-25 ms-3 btn-resize\" (click)=\"Reset()\"> Reset </button>\r\n <button class=\"btn btn-primary w-25 btn-resize\" (click)=\"Apply()\">Apply</button>\r\n </div>\r\n\r\n <!-- Country Dropdown -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('country')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedCountriesLabel()\"\r\n readonly\r\n placeholder=\"Select country\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'country'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search country\" \r\n [(ngModel)]=\"searchCountryText\" \r\n (ngModelChange)=\"filterCountries()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllCountries\" \r\n [checked]=\"isAllCountriesSelected()\" \r\n (change)=\"toggleSelectAllCountries($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllCountries\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let country of filteredCountries\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"country.country\" \r\n [(ngModel)]=\"country.checked\"\r\n (change)=\"updateSelectedCountries()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"country.country\">\r\n {{ country.country }}\r\n </label>\r\n \r\n </div>\r\n </div>\r\n</div>\r\n\r\n <!-- Location Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('location')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedLocationsLabel()\"\r\n readonly\r\n placeholder=\"Select Region\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'location'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search Region\" \r\n [(ngModel)]=\"searchLocationText\" \r\n (ngModelChange)=\"filterLocations()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllLocations\" \r\n [checked]=\"isAllLocationsSelected()\" \r\n (change)=\"toggleSelectAllLocations($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllLocations\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let location of filteredLocations\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"location.city\" \r\n [(ngModel)]=\"location.checked\"\r\n (change)=\"updateSelectedLocations()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"location.city\">\r\n {{ location.city }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('group')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedGroupsLabel()\" readonly\r\n placeholder=\"Select clusters\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'group'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search clusters\" \r\n [(ngModel)]=\"searchGroupText\" \r\n (ngModelChange)=\"filterGroups()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllGroups\" \r\n [checked]=\"isAllGroupsSelected()\" \r\n (change)=\"toggleSelectAllGroups($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllGroups\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let group of filteredGroups\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"group.groupName\"\r\n [(ngModel)]=\"group.checked\"\r\n (change)=\"updateSelectedGroups()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"group.groupName\">\r\n {{ group.groupName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n<!-- Store Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('store')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\"\r\n [value]=\"selectedStoresLabel()\"\r\n readonly\r\n placeholder=\"Select stores\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'store'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search \" \r\n placeholder=\"Search stores\" \r\n [(ngModel)]=\"searchStoreText\" \r\n (ngModelChange)=\"filterStores()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllStores\" \r\n [checked]=\"isAllStoresSelected()\" \r\n (change)=\"toggleSelectAllStores($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllStores\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let store of filteredStores\"\r\n >\r\n <input \r\n class=\"form-check-input\" \r\n type=\"checkbox\" \r\n [id]=\"store.storeId\"\r\n [(ngModel)]=\"store.checked\"\r\n (change)=\"updateSelectedStores()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"store.storeId\">\r\n {{ store.storeName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Zone Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('zone')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\"\r\n [value]=\"selectedZonesLabel()\"\r\n readonly\r\n placeholder=\"Select zones\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'zone'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search \" \r\n placeholder=\"Search zones\" \r\n [(ngModel)]=\"searchZoneText\" \r\n (ngModelChange)=\"filterZones()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllZones\" \r\n [checked]=\"isAllZonesSelected()\" \r\n (change)=\"toggleSelectAllZones($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllZones\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let zone of filteredZones\"\r\n >\r\n <input \r\n class=\"form-check-input\" \r\n type=\"checkbox\" \r\n [id]=\"zone._id\"\r\n [(ngModel)]=\"zone.checked\"\r\n (change)=\"updateSelectedZones(zone._id)\"\r\n />\r\n <label class=\"form-check-label\" [for]=\"zone._id\">\r\n {{ zone.tagName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n </div>\r\n</div>", styles: [".daterangepicker{display:block!important;top:153.85px!important;left:900px!important;right:0}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize}::ng-deep .applyBtn{display:none!important}:host::ng-deep .md-drppicker .btn{line-height:10px!important}:host::ng-deep .daterangepicker-input+.ngx-daterangepicker-material .applyBtn{display:none}:host::ng-deep .md-drppicker.drops-down-right.ltr.double.show-ranges.shown{top:65px!important;left:-470px!important;height:365px!important}:host::ng-deep .md-drppicker .btn{border-radius:8px!important;border:1px solid var(--Primary-600, #00A3FF)!important;background:var(--Primary-600, #00A3FF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--White, #FFF)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize}:host::ng-deep .md-drppicker .ranges ul li button{padding:12px 16px;width:160px;color:var(--Gray-700, #344054);font-size:14px;font-weight:400;line-height:20px;background:none;border:none;text-align:left;cursor:pointer}:host::ng-deep .md-drppicker td.active,:host::ng-deep .md-drppicker td.active:hover{background-color:#029cf4!important;border-radius:20px!important;color:var(--White, #FFF)!important;text-align:center!important;font-size:14px!important;font-weight:500!important;line-height:20px}:host::ng-deep .md-drppicker.ltr .ranges{float:left;margin-top:10px!important}:host::ng-deep .md-drppicker td.in-range{background:var(--Primary-50, #EAF8FF)}:host::ng-deep .md-drppicker .ranges ul li button.active{background:var(--Primary-50, #EAF8FF)!important;border-radius:8px!important;color:var(--Primary-700, #009BF3);font-size:14px!important;font-weight:500!important;line-height:20px!important}:host::ng-deep table th,:host::ng-deep table td{width:40px!important;height:40px!important;padding:10px 8px!important}:host::ng-deep .md-drppicker td.available.prev,:host::ng-deep .md-drppicker th.available.prev{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep .md-drppicker td.available.next,:host::ng-deep .md-drppicker th.available.next{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep table th{border-bottom:0px solid var(--Gray-200, #EAECF0)!important;background:transparent!important;color:var(--Gray-700, #344054)!important;text-align:center;font-size:16px!important;font-weight:500!important;line-height:24px}:host::ng-deep .md-drppicker .btn.btn-default{border-radius:8px!important;border:1px solid var(--Gray-300, #D0D5DD)!important;background:var(--White, #FFF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize;margin-right:10px!important}:host::ng-deep .md-drppicker td.available.invalid-date{text-decoration:line-through;pointer-events:none;color:#a9a9a9}:host::ng-deep .md-drppicker td.available.today:not(.invalid-date){text-decoration:unset;pointer-events:unset;color:unset}.wrapper{min-width:200px}.btn-primary{line-height:18px!important}.filter-label{color:var(--Gray-500, #667085)!important;font-size:14px;font-style:normal;font-weight:600;line-height:20px;text-transform:capitalize}.position-relative{position:relative}.filter-icon{cursor:pointer}.dropdown-container{position:relative;display:inline-block;width:100%}.dropdown-header{cursor:pointer;width:100%}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize;width:100%;box-sizing:border-box}.dropdown-menu{position:absolute;top:100%;left:0;right:0;border:1px solid #ccc;background-color:#fff;z-index:1000;max-height:230px;overflow-y:auto;display:block;box-sizing:border-box;padding:10px 5px}.dropdown-item{padding:6px 0}.dropdown-item:hover{background-color:#f1f1f1}.dropdown-item input[type=checkbox]{margin-right:10px}.custom-dropdown-menu{border-radius:4px;box-shadow:0 1px 2px #1018280d}.custom-dropdown-item{display:flex;align-items:center}.custom-dropdown-item input{margin-left:10px}.btn-resize{font-size:13px!important;height:29px!important;line-height:11px!important;padding:3px!important}.dropdown2{position:absolute;top:70px;min-width:270px!important}.dropdown2 .dropdown-title{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:24px}.dropdown2 .dropdown{position:relative;display:inline-block}.dropdown2 .dropdown span{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:20px}.form-check-label{color:var(--Gray-700, #344054)!important;font-size:14px;font-style:normal;font-weight:500;line-height:20px}input[type=checkbox]{width:16px!important;height:16px!important;margin:0 5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-300, #D0D5DD);box-shadow:none;font-size:.8em;text-align:center;line-height:1em;background:#fff}input[type=checkbox]:checked{outline:1px solid var(--primary-600, #00A3FF);background-color:var(--primary-50, #EAF8FF)}input[type=checkbox]:checked:after{content:\"\";transform:rotate(45deg);border-bottom:2px solid #00A3FF;border-right:2px solid #00A3FF;display:inline-block;width:.2em;padding-left:0;padding-top:9px;padding-right:4px}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.CustomSelectComponent, selector: "lib-select", inputs: ["items", "searchField", "multi", "idField", "selectedValues", "disabled", "label"], outputs: ["selected"] }, { kind: "directive", type: i6.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: i6.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i7.DaterangepickerDirective, selector: "input[ngxDaterangepickerMd]", inputs: ["minDate", "maxDate", "autoApply", "alwaysShowCalendars", "showCustomRangeLabel", "linkedCalendars", "dateLimit", "singleDatePicker", "showWeekNumbers", "showISOWeekNumbers", "showDropdowns", "isInvalidDate", "isCustomDate", "isTooltipDate", "showClearButton", "customRangeDirection", "ranges", "opens", "drops", "firstMonthDayClass", "lastMonthDayClass", "emptyWeekRowClass", "emptyWeekColumnClass", "firstDayOfNextMonthClass", "lastDayOfPreviousMonthClass", "keepCalendarOpeningWithRange", "showRangeLabelOnInput", "showCancel", "lockStartDate", "timePicker", "timePicker24Hour", "timePickerIncrement", "timePickerSeconds", "closeOnAutoApply", "endKeyHolder", "startKey", "locale", "endKey"], outputs: ["change", "rangeClicked", "datesUpdated", "startDateChanged", "endDateChanged", "clearClicked"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] });
|
|
1220
1310
|
}
|
|
1221
1311
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetricsHeaderComponent, decorators: [{
|
|
1222
1312
|
type: Component,
|
|
1223
|
-
args: [{ selector: 'lib-metrics-header', template: "<div class=\"me-3\">\r\n <label *ngIf=\"selectedCountriesLabel()\" class=\"badge badge-light-default mx-2\">{{selectedCountriesLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeCountry()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label *ngIf=\"selectedLocationsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedLocationsLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeLocation()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label *ngIf=\"selectedGroupsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedGroupsLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label class=\"badge badge-light-default\">{{selectedStoresLabel()}}</label>\r\n <label class=\"badge badge-light-default mx-2\">{{selectedZonesLabel()}} \r\n <!-- <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span> -->\r\n </label>\r\n</div>\r\n\r\n\r\n<div class=\"wrapper me-3\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\">\r\n<lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n(selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n</div>\r\n<div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <input class=\"fx-date-range form-control ps-14\" style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [autoApply]=\"true\"\r\n [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\"\r\n [(ngModel)]=\"selectedDateRange\" (startDateChanged)=\"onStartDateChange($event)\" [isCustomDate]=\"isCustomDate\"\r\n [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n (datesUpdated)=\"datechange($event)\" name=\"daterange\" [readonly]=\"true\" />\r\n</div>\r\n<div class=\"position-relative\">\r\n <button type=\"button\" (click)=\"opendropdown($event)\" class=\"btn btn-default mx-2 rounded-3 text-nowrap border-val\">\r\n <!-- <span class=\"me-2\">Filter</span> -->\r\n <svg class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </button>\r\n\r\n <div *ngIf=\"Opendropdown\" class=\"card p-5 dropdown2 position-absolute z-1 end-0\" style=\"z-index: 1 !important;\" (clickOutside)=\"closeDropdown1()\">\r\n <div class=\"dropdown-title d-flex justify-content-between mb-2\">Filter Options\r\n <button class=\"btn btn-outline w-25 ms-3 btn-resize\" (click)=\"Reset()\"> Reset </button>\r\n <button class=\"btn btn-primary w-25 btn-resize\" (click)=\"Apply()\">Apply</button>\r\n </div>\r\n\r\n <!-- Country Dropdown -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('country')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedCountriesLabel()\"\r\n readonly\r\n placeholder=\"Select country\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'country'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search country\" \r\n [(ngModel)]=\"searchCountryText\" \r\n (ngModelChange)=\"filterCountries()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllCountries\" \r\n [checked]=\"isAllCountriesSelected()\" \r\n (change)=\"toggleSelectAllCountries($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllCountries\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let country of filteredCountries\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"country.country\" \r\n [(ngModel)]=\"country.checked\"\r\n (change)=\"updateSelectedCountries()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"country.country\">\r\n {{ country.country }}\r\n </label>\r\n \r\n </div>\r\n </div>\r\n</div>\r\n\r\n <!-- Location Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('location')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedLocationsLabel()\"\r\n readonly\r\n placeholder=\"Select Region\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'location'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search Region\" \r\n [(ngModel)]=\"searchLocationText\" \r\n (ngModelChange)=\"filterLocations()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllLocations\" \r\n [checked]=\"isAllLocationsSelected()\" \r\n (change)=\"toggleSelectAllLocations($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllLocations\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let location of filteredLocations\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"location.city\" \r\n [(ngModel)]=\"location.checked\"\r\n (change)=\"updateSelectedLocations()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"location.city\">\r\n {{ location.city }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('group')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedGroupsLabel()\" readonly\r\n placeholder=\"Select clusters\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'group'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search clusters\" \r\n [(ngModel)]=\"searchGroupText\" \r\n (ngModelChange)=\"filterGroups()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllGroups\" \r\n [checked]=\"isAllGroupsSelected()\" \r\n (change)=\"toggleSelectAllGroups($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllGroups\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let group of filteredGroups\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"group.groupName\"\r\n [(ngModel)]=\"group.checked\"\r\n (change)=\"updateSelectedGroups()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"group.groupName\">\r\n {{ group.groupName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n<!-- Store Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('store')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\"\r\n [value]=\"selectedStoresLabel()\"\r\n readonly\r\n placeholder=\"Select stores\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'store'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search \" \r\n placeholder=\"Search stores\" \r\n [(ngModel)]=\"searchStoreText\" \r\n (ngModelChange)=\"filterStores()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllStores\" \r\n [checked]=\"isAllStoresSelected()\" \r\n (change)=\"toggleSelectAllStores($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllStores\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let store of filteredStores\"\r\n >\r\n <input \r\n class=\"form-check-input\" \r\n type=\"checkbox\" \r\n [id]=\"store.storeId\"\r\n [(ngModel)]=\"store.checked\"\r\n (change)=\"updateSelectedStores()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"store.storeId\">\r\n {{ store.storeName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Zone Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('zone')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\"\r\n [value]=\"selectedZonesLabel()\"\r\n readonly\r\n placeholder=\"Select zones\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'zone'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search \" \r\n placeholder=\"Search zones\" \r\n [(ngModel)]=\"searchZoneText\" \r\n (ngModelChange)=\"filterZones()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllZones\" \r\n [checked]=\"isAllZonesSelected()\" \r\n (change)=\"toggleSelectAllZones($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllZones\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let zone of filteredZones\"\r\n >\r\n <input \r\n class=\"form-check-input\" \r\n type=\"checkbox\" \r\n [id]=\"zone._id\"\r\n [(ngModel)]=\"zone.checked\"\r\n (change)=\"updateSelectedZones()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"zone._id\">\r\n {{ zone.tagName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n </div>\r\n</div>", styles: [".daterangepicker{display:block!important;top:153.85px!important;left:900px!important;right:0}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize}::ng-deep .applyBtn{display:none!important}:host::ng-deep .md-drppicker .btn{line-height:10px!important}:host::ng-deep .daterangepicker-input+.ngx-daterangepicker-material .applyBtn{display:none}:host::ng-deep .md-drppicker.drops-down-right.ltr.double.show-ranges.shown{top:65px!important;left:-470px!important;height:365px!important}:host::ng-deep .md-drppicker .btn{border-radius:8px!important;border:1px solid var(--Primary-600, #00A3FF)!important;background:var(--Primary-600, #00A3FF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--White, #FFF)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize}:host::ng-deep .md-drppicker .ranges ul li button{padding:12px 16px;width:160px;color:var(--Gray-700, #344054);font-size:14px;font-weight:400;line-height:20px;background:none;border:none;text-align:left;cursor:pointer}:host::ng-deep .md-drppicker td.active,:host::ng-deep .md-drppicker td.active:hover{background-color:#029cf4!important;border-radius:20px!important;color:var(--White, #FFF)!important;text-align:center!important;font-size:14px!important;font-weight:500!important;line-height:20px}:host::ng-deep .md-drppicker.ltr .ranges{float:left;margin-top:10px!important}:host::ng-deep .md-drppicker td.in-range{background:var(--Primary-50, #EAF8FF)}:host::ng-deep .md-drppicker .ranges ul li button.active{background:var(--Primary-50, #EAF8FF)!important;border-radius:8px!important;color:var(--Primary-700, #009BF3);font-size:14px!important;font-weight:500!important;line-height:20px!important}:host::ng-deep table th,:host::ng-deep table td{width:40px!important;height:40px!important;padding:10px 8px!important}:host::ng-deep .md-drppicker td.available.prev,:host::ng-deep .md-drppicker th.available.prev{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep .md-drppicker td.available.next,:host::ng-deep .md-drppicker th.available.next{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep table th{border-bottom:0px solid var(--Gray-200, #EAECF0)!important;background:transparent!important;color:var(--Gray-700, #344054)!important;text-align:center;font-size:16px!important;font-weight:500!important;line-height:24px}:host::ng-deep .md-drppicker .btn.btn-default{border-radius:8px!important;border:1px solid var(--Gray-300, #D0D5DD)!important;background:var(--White, #FFF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize;margin-right:10px!important}:host::ng-deep .md-drppicker td.available.invalid-date{text-decoration:line-through;pointer-events:none;color:#a9a9a9}:host::ng-deep .md-drppicker td.available.today:not(.invalid-date){text-decoration:unset;pointer-events:unset;color:unset}.wrapper{min-width:200px}.btn-primary{line-height:18px!important}.filter-label{color:var(--Gray-500, #667085)!important;font-size:14px;font-style:normal;font-weight:600;line-height:20px;text-transform:capitalize}.position-relative{position:relative}.filter-icon{cursor:pointer}.dropdown-container{position:relative;display:inline-block;width:100%}.dropdown-header{cursor:pointer;width:100%}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize;width:100%;box-sizing:border-box}.dropdown-menu{position:absolute;top:100%;left:0;right:0;border:1px solid #ccc;background-color:#fff;z-index:1000;max-height:230px;overflow-y:auto;display:block;box-sizing:border-box;padding:10px 5px}.dropdown-item{padding:6px 0}.dropdown-item:hover{background-color:#f1f1f1}.dropdown-item input[type=checkbox]{margin-right:10px}.custom-dropdown-menu{border-radius:4px;box-shadow:0 1px 2px #1018280d}.custom-dropdown-item{display:flex;align-items:center}.custom-dropdown-item input{margin-left:10px}.btn-resize{font-size:13px!important;height:29px!important;line-height:11px!important;padding:3px!important}.dropdown2{position:absolute;top:70px;min-width:270px!important}.dropdown2 .dropdown-title{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:24px}.dropdown2 .dropdown{position:relative;display:inline-block}.dropdown2 .dropdown span{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:20px}.form-check-label{color:var(--Gray-700, #344054)!important;font-size:14px;font-style:normal;font-weight:500;line-height:20px}input[type=checkbox]{width:16px!important;height:16px!important;margin:0 5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-300, #D0D5DD);box-shadow:none;font-size:.8em;text-align:center;line-height:1em;background:#fff}input[type=checkbox]:checked{outline:1px solid var(--primary-600, #00A3FF);background-color:var(--primary-50, #EAF8FF)}input[type=checkbox]:checked:after{content:\"\";transform:rotate(45deg);border-bottom:2px solid #00A3FF;border-right:2px solid #00A3FF;display:inline-block;width:.2em;padding-left:0;padding-top:9px;padding-right:4px}\n"] }]
|
|
1313
|
+
args: [{ selector: "lib-metrics-header", template: "<div class=\"me-3\">\r\n <label *ngIf=\"selectedCountriesLabel()\" class=\"badge badge-light-default mx-2\">{{selectedCountriesLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeCountry()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label *ngIf=\"selectedLocationsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedLocationsLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeLocation()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label *ngIf=\"selectedGroupsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedGroupsLabel()}} \r\n <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </label>\r\n <label class=\"badge badge-light-default\">{{selectedStoresLabel()}}</label>\r\n <label class=\"badge badge-light-default mx-2\">{{selectedZonesLabel()}} \r\n <!-- <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span> -->\r\n </label>\r\n</div>\r\n\r\n\r\n<div class=\"wrapper me-3\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\">\r\n<lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n(selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n</div>\r\n<div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <input class=\"fx-date-range form-control ps-14\" style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [autoApply]=\"true\"\r\n [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\"\r\n [(ngModel)]=\"selectedDateRange\" (startDateChanged)=\"onStartDateChange($event)\" [isCustomDate]=\"isCustomDate\"\r\n [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n (datesUpdated)=\"datechange($event)\" name=\"daterange\" [readonly]=\"true\" />\r\n</div>\r\n<div class=\"position-relative\">\r\n <button type=\"button\" (click)=\"opendropdown($event)\" class=\"btn btn-default mx-2 rounded-3 text-nowrap border-val\">\r\n <!-- <span class=\"me-2\">Filter</span> -->\r\n <svg class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </button>\r\n\r\n <div *ngIf=\"Opendropdown\" class=\"card p-5 dropdown2 position-absolute z-1 end-0\" style=\"z-index: 1 !important;\" (clickOutside)=\"closeDropdown1()\">\r\n <div class=\"dropdown-title d-flex justify-content-between mb-2\">Filter Options\r\n <button class=\"btn btn-outline w-25 ms-3 btn-resize\" (click)=\"Reset()\"> Reset </button>\r\n <button class=\"btn btn-primary w-25 btn-resize\" (click)=\"Apply()\">Apply</button>\r\n </div>\r\n\r\n <!-- Country Dropdown -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('country')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedCountriesLabel()\"\r\n readonly\r\n placeholder=\"Select country\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'country'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search country\" \r\n [(ngModel)]=\"searchCountryText\" \r\n (ngModelChange)=\"filterCountries()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllCountries\" \r\n [checked]=\"isAllCountriesSelected()\" \r\n (change)=\"toggleSelectAllCountries($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllCountries\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let country of filteredCountries\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"country.country\" \r\n [(ngModel)]=\"country.checked\"\r\n (change)=\"updateSelectedCountries()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"country.country\">\r\n {{ country.country }}\r\n </label>\r\n \r\n </div>\r\n </div>\r\n</div>\r\n\r\n <!-- Location Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('location')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedLocationsLabel()\"\r\n readonly\r\n placeholder=\"Select Region\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'location'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search Region\" \r\n [(ngModel)]=\"searchLocationText\" \r\n (ngModelChange)=\"filterLocations()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllLocations\" \r\n [checked]=\"isAllLocationsSelected()\" \r\n (change)=\"toggleSelectAllLocations($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllLocations\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let location of filteredLocations\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"location.city\" \r\n [(ngModel)]=\"location.checked\"\r\n (change)=\"updateSelectedLocations()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"location.city\">\r\n {{ location.city }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('group')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedGroupsLabel()\" readonly\r\n placeholder=\"Select clusters\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'group'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search clusters\" \r\n [(ngModel)]=\"searchGroupText\" \r\n (ngModelChange)=\"filterGroups()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllGroups\" \r\n [checked]=\"isAllGroupsSelected()\" \r\n (change)=\"toggleSelectAllGroups($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllGroups\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let group of filteredGroups\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"group.groupName\"\r\n [(ngModel)]=\"group.checked\"\r\n (change)=\"updateSelectedGroups()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"group.groupName\">\r\n {{ group.groupName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n<!-- Store Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('store')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\"\r\n [value]=\"selectedStoresLabel()\"\r\n readonly\r\n placeholder=\"Select stores\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'store'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search \" \r\n placeholder=\"Search stores\" \r\n [(ngModel)]=\"searchStoreText\" \r\n (ngModelChange)=\"filterStores()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllStores\" \r\n [checked]=\"isAllStoresSelected()\" \r\n (change)=\"toggleSelectAllStores($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllStores\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let store of filteredStores\"\r\n >\r\n <input \r\n class=\"form-check-input\" \r\n type=\"checkbox\" \r\n [id]=\"store.storeId\"\r\n [(ngModel)]=\"store.checked\"\r\n (change)=\"updateSelectedStores()\" \r\n />\r\n <label class=\"form-check-label\" [for]=\"store.storeId\">\r\n {{ store.storeName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Zone Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('zone')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\"\r\n [value]=\"selectedZonesLabel()\"\r\n readonly\r\n placeholder=\"Select zones\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'zone'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search \" \r\n placeholder=\"Search zones\" \r\n [(ngModel)]=\"searchZoneText\" \r\n (ngModelChange)=\"filterZones()\" \r\n />\r\n <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n id=\"selectAllZones\" \r\n [checked]=\"isAllZonesSelected()\" \r\n (change)=\"toggleSelectAllZones($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllZones\">\r\n Select All\r\n </label>\r\n </div>\r\n <div \r\n class=\"dropdown-item form-check custom-dropdown-item\" \r\n *ngFor=\"let zone of filteredZones\"\r\n >\r\n <input \r\n class=\"form-check-input\" \r\n type=\"checkbox\" \r\n [id]=\"zone._id\"\r\n [(ngModel)]=\"zone.checked\"\r\n (change)=\"updateSelectedZones(zone._id)\"\r\n />\r\n <label class=\"form-check-label\" [for]=\"zone._id\">\r\n {{ zone.tagName }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n </div>\r\n</div>", styles: [".daterangepicker{display:block!important;top:153.85px!important;left:900px!important;right:0}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize}::ng-deep .applyBtn{display:none!important}:host::ng-deep .md-drppicker .btn{line-height:10px!important}:host::ng-deep .daterangepicker-input+.ngx-daterangepicker-material .applyBtn{display:none}:host::ng-deep .md-drppicker.drops-down-right.ltr.double.show-ranges.shown{top:65px!important;left:-470px!important;height:365px!important}:host::ng-deep .md-drppicker .btn{border-radius:8px!important;border:1px solid var(--Primary-600, #00A3FF)!important;background:var(--Primary-600, #00A3FF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--White, #FFF)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize}:host::ng-deep .md-drppicker .ranges ul li button{padding:12px 16px;width:160px;color:var(--Gray-700, #344054);font-size:14px;font-weight:400;line-height:20px;background:none;border:none;text-align:left;cursor:pointer}:host::ng-deep .md-drppicker td.active,:host::ng-deep .md-drppicker td.active:hover{background-color:#029cf4!important;border-radius:20px!important;color:var(--White, #FFF)!important;text-align:center!important;font-size:14px!important;font-weight:500!important;line-height:20px}:host::ng-deep .md-drppicker.ltr .ranges{float:left;margin-top:10px!important}:host::ng-deep .md-drppicker td.in-range{background:var(--Primary-50, #EAF8FF)}:host::ng-deep .md-drppicker .ranges ul li button.active{background:var(--Primary-50, #EAF8FF)!important;border-radius:8px!important;color:var(--Primary-700, #009BF3);font-size:14px!important;font-weight:500!important;line-height:20px!important}:host::ng-deep table th,:host::ng-deep table td{width:40px!important;height:40px!important;padding:10px 8px!important}:host::ng-deep .md-drppicker td.available.prev,:host::ng-deep .md-drppicker th.available.prev{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep .md-drppicker td.available.next,:host::ng-deep .md-drppicker th.available.next{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep table th{border-bottom:0px solid var(--Gray-200, #EAECF0)!important;background:transparent!important;color:var(--Gray-700, #344054)!important;text-align:center;font-size:16px!important;font-weight:500!important;line-height:24px}:host::ng-deep .md-drppicker .btn.btn-default{border-radius:8px!important;border:1px solid var(--Gray-300, #D0D5DD)!important;background:var(--White, #FFF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize;margin-right:10px!important}:host::ng-deep .md-drppicker td.available.invalid-date{text-decoration:line-through;pointer-events:none;color:#a9a9a9}:host::ng-deep .md-drppicker td.available.today:not(.invalid-date){text-decoration:unset;pointer-events:unset;color:unset}.wrapper{min-width:200px}.btn-primary{line-height:18px!important}.filter-label{color:var(--Gray-500, #667085)!important;font-size:14px;font-style:normal;font-weight:600;line-height:20px;text-transform:capitalize}.position-relative{position:relative}.filter-icon{cursor:pointer}.dropdown-container{position:relative;display:inline-block;width:100%}.dropdown-header{cursor:pointer;width:100%}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize;width:100%;box-sizing:border-box}.dropdown-menu{position:absolute;top:100%;left:0;right:0;border:1px solid #ccc;background-color:#fff;z-index:1000;max-height:230px;overflow-y:auto;display:block;box-sizing:border-box;padding:10px 5px}.dropdown-item{padding:6px 0}.dropdown-item:hover{background-color:#f1f1f1}.dropdown-item input[type=checkbox]{margin-right:10px}.custom-dropdown-menu{border-radius:4px;box-shadow:0 1px 2px #1018280d}.custom-dropdown-item{display:flex;align-items:center}.custom-dropdown-item input{margin-left:10px}.btn-resize{font-size:13px!important;height:29px!important;line-height:11px!important;padding:3px!important}.dropdown2{position:absolute;top:70px;min-width:270px!important}.dropdown2 .dropdown-title{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:24px}.dropdown2 .dropdown{position:relative;display:inline-block}.dropdown2 .dropdown span{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:20px}.form-check-label{color:var(--Gray-700, #344054)!important;font-size:14px;font-style:normal;font-weight:500;line-height:20px}input[type=checkbox]{width:16px!important;height:16px!important;margin:0 5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-300, #D0D5DD);box-shadow:none;font-size:.8em;text-align:center;line-height:1em;background:#fff}input[type=checkbox]:checked{outline:1px solid var(--primary-600, #00A3FF);background-color:var(--primary-50, #EAF8FF)}input[type=checkbox]:checked:after{content:\"\";transform:rotate(45deg);border-bottom:2px solid #00A3FF;border-right:2px solid #00A3FF;display:inline-block;width:.2em;padding-left:0;padding-top:9px;padding-right:4px}\n"] }]
|
|
1224
1314
|
}], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.Router }, { type: i3.GlobalStateService }, { type: i0.ChangeDetectorRef }], propDecorators: { onClick: [{
|
|
1225
1315
|
type: HostListener,
|
|
1226
|
-
args: [
|
|
1316
|
+
args: ["document:click", ["$event"]]
|
|
1227
1317
|
}], clickOutside: [{
|
|
1228
1318
|
type: HostListener,
|
|
1229
1319
|
args: ["document:click", ["$event"]]
|
|
1230
1320
|
}] } });
|
|
1231
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metrics-header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/metrics-header/metrics-header.component.ts","../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/metrics-header/metrics-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  HostListener,\r\n  OnInit,\r\n} from \"@angular/core\";\r\nimport dayjs from \"dayjs\";\r\nimport \"dayjs/locale/en\";\r\nimport { AuthService } from \"../../../../services/auth.service\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\nimport { NavigationEnd, Router } from \"@angular/router\";\r\n@Component({\r\n  selector: 'lib-metrics-header',\r\n  templateUrl: './metrics-header.component.html',\r\n  styleUrl: './metrics-header.component.scss'\r\n})\r\nexport class MetricsHeaderComponent implements OnInit {\r\n dayjs = dayjs;\r\n  isCustomDate = (m: dayjs.Dayjs) => {\r\n    const isValidDate = m > this.dayjs();\r\n    return isValidDate ? \"invalid-date\" : false;\r\n  };\r\n\r\n  selectedDateRange: any = { startDate: dayjs().subtract(30, 'days'),\r\n    endDate: dayjs().subtract(1, \"days\"),};\r\n  selectedFilters: any = {\r\n    client: null,\r\n    clientName: null,\r\n    clients: [],\r\n    store: null,\r\n    stores: [],\r\n    date: null,\r\n    group: [],\r\n    location: [],\r\n    country: [],\r\n    zoneName: [] \r\n  };\r\n  Opendropdown: boolean = false;\r\n  dropdownOpen: string | null = null; // 'location' or 'group'\r\n  searchLocationText: string = \"\";\r\n  searchGroupText: string = \"\";\r\n  locations: any[] = [];\r\n  filteredLocations: any[] = [];\r\n  groupsData: any[] = [];\r\n  filteredGroups: any[] = [];\r\n  filteredStores: any[] = [];\r\n  filteredZones: any[] = [];\r\n  stores: any[] = []\r\n  zones:any[] = []\r\n  searchStoreText: string = '';\r\n  searchZoneText: string = '';\r\n  clientList:any = []\r\n  selectedClient:any\r\n  locationLabel: any[]=[];\r\n  groupLabel: any[]=[];\r\n  users: any;\r\n  url: any;\r\n  filteredCountries: any[] = [];\r\n  countryLabel: any[]=[];\r\n  searchCountryText: string = \"\";\r\n  countries: any[] = [];\r\n  constructor(\r\n    private auth: AuthService,    private router: Router,\r\n    public gs: GlobalStateService,\r\n    private cd: ChangeDetectorRef,\r\n  ) {}\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onClick (event: MouseEvent) {\r\n    const target = event.target as HTMLElement;\r\n    if(!target.closest('.dropdown2')) {\r\n      this.Opendropdown = false;\r\n    }\r\n  }\r\n  closeDropdown1(){\r\n    this.Opendropdown = false;\r\n  }\r\n  ngOnInit(): void {\r\n    // this.setRangesBasedOnRoute();\r\n\r\n    // Listen for route changes to update ranges\r\n    // this.router?.events?.subscribe((event) => {\r\n    //   if (event instanceof NavigationEnd) {\r\n    //     this.setRangesBasedOnRoute();\r\n    //   }\r\n    // });\r\n    this.url = this.router.url.split(\"?\")[0].split('/');\r\n    const user = JSON.parse(localStorage.getItem('user-info') as string);\r\n    this.users = user;\r\n    this.gs?.manageRefreshTrigger?.subscribe((e) => {      \r\n      if (e) {\r\n        if (user.userType === 'tango') {\r\n        this.getClient();\r\n        } else{\r\n          const storedFilters = localStorage.getItem(\"header-filters\");\r\n          if (storedFilters) {\r\n          const headerFilters = JSON.parse(storedFilters);\r\n          this.filteredStores = headerFilters?.stores.map((store:any) => ({\r\n            ...store,\r\n            checked: store.checked\r\n          }));\r\n          this.filteredZones = headerFilters?.zoneName.map((store:any) => ({\r\n            ...store,\r\n            checked: store.checked\r\n          }));\r\n        \r\n        }\r\n        \r\n        }\r\n      }\r\n    });\r\n \r\n    // Fetch client data if the user is of type 'tango'\r\n    if (user.userType === 'tango') {\r\n      this.getClient();\r\n    } else {\r\n      this.getCountry();\r\n      this.getLocations();\r\n      this.getGroups();\r\n      this.getStore();\r\n      const clientFilters = localStorage.getItem(\"client-details\");\r\n      if (clientFilters) {\r\n        const headerclientFilters = JSON.parse(clientFilters);\r\n      this.selectedClient = {\r\n      trafficDateRange : headerclientFilters.trafficDateRange\r\n      }\r\n      }\r\n    }\r\n   \r\n    // Load filters from localStorage if they exist\r\n    const storedFilters = localStorage.getItem(\"header-filters\");\r\n    if (storedFilters) {\r\n      const headerFilters = JSON.parse(storedFilters);\r\n  \r\n      // Initialize selectedFilters with defaults or existing values\r\n      this.selectedFilters = {\r\n        client: headerFilters.client || this.users.client,\r\n        clientName: headerFilters.clientName || '',\r\n        clients: headerFilters.clients || [],\r\n        store: headerFilters.store || null,\r\n        date: headerFilters.date || {},\r\n        stores: headerFilters.stores || [],\r\n        group: headerFilters.group || [],\r\n        location: headerFilters.location || [],\r\n        country: headerFilters.country || [],\r\n         zoneName: headerFilters.zoneName || [],\r\n      };\r\n  \r\n      // Sync filtered data with stored selections\r\n      this.filteredCountries = this.syncWithLocalStorage(headerFilters.country);\r\n      this.filteredLocations = this.syncWithLocalStorage(headerFilters.location);\r\n      this.filteredGroups = this.syncWithLocalStorage(headerFilters.group);\r\n      this.filteredStores = this.syncWithLocalStorage(headerFilters.stores);\r\n  this.filteredZones = this.syncWithLocalStorage(headerFilters.zoneName);\r\n      // Format date range if it exists\r\n      if (headerFilters.date) {\r\n    \r\n        this.selectedDateRange = {\r\n          startDate: this.dayjs(headerFilters.date.startDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n          endDate: this.dayjs(headerFilters.date.endDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n        };\r\n      } else {\r\n        this.selectedDateRange = {\r\n          startDate: this.dayjs(this.selectedDateRange.startDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n          endDate: this.dayjs(this.selectedDateRange.endDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n        };\r\n      }\r\n      // console.log(\"3\")\r\n      // Emit data via service and update localStorage\r\nthis.emitAndStoreFilters();\r\n    } else {\r\n      // Initialize empty states if no header filters are present in localStorage\r\n      this.resetFilters();\r\n      // console.log(\"2\")\r\n    }\r\n  }\r\n  private syncWithLocalStorage(items: any[]): any[] {\r\n    return items\r\n      ? items.map((item: any) => ({\r\n          ...item,\r\n          checked: item.checked === true\r\n        }))\r\n      : [];\r\n  }\r\n  \r\n  private emitAndStoreFilters(): void {\r\n    this.gs.dataRangeValue.next(this.selectedFilters);\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(this.selectedFilters));\r\n    // console.log(\"1\")\r\n  }\r\n  \r\n  /**\r\n   * Reset selectedFilters and all related arrays to empty states\r\n   */\r\n  private resetFilters(): void {\r\n    this.selectedFilters = {\r\n      client: null,\r\n      clientName: '',\r\n      clients: [],\r\n      store: null,\r\n      date: {},\r\n      stores: [],\r\n      group: [],\r\n      location: [],\r\n      country: [],\r\n      zoneName: []\r\n    };\r\n    this.filteredLocations = [];\r\n    this.filteredGroups = [];\r\n    this.filteredStores = [];\r\n    this.filteredCountries = [];\r\n    this.filteredZones = [];\r\n  }\r\ngetClient(){\r\n  this.auth.getClients().subscribe({\r\n    next: (e) => {\r\n      if (e) {\r\n        this.clientList = e.data.result;\r\n        const headerFilters: any = JSON.parse(\r\n          localStorage.getItem(\"header-filters\") || \"{}\"\r\n        );\r\n        if (headerFilters.client) {\r\n          this.clientList.find((obj: any) => {\r\n            if (obj.clientId === headerFilters.client) {\r\n              this.selectedClient = obj;\r\n            }\r\n          });\r\n          // const startDate = this.dayjs(headerFilters.date.startDate);\r\n          // const endDate = this.dayjs(headerFilters.date.endDate);\r\n          // const differenceInDays = endDate.diff(startDate, 'days');\r\n          // if (differenceInDays >= 90 && this.selectedClient?.trafficDateRange === 90) {\r\n          //   this.selectedDateRange = {\r\n          //     startDate: this.dayjs(headerFilters.date.startDate, \"YYYY-MM-DD\").subtract(-90, 'days').format(\"DD-MM-YYYY\"),\r\n          //     endDate: this.dayjs(headerFilters.date.endDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n          //   };\r\n          // } else {\r\n          //   this.selectedDateRange = {\r\n          //     startDate: this.dayjs(this.selectedDateRange.startDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n          //     endDate: this.dayjs(this.selectedDateRange.endDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n          //   };\r\n          // }\r\n\r\n          this.selectedFilters.client = headerFilters.client;\r\n          this.selectedFilters.clientName = headerFilters.clientName;\r\n          this.selectedFilters.clients = [headerFilters.client];\r\n          this.selectedFilters.store = headerFilters.store;\r\n          this.selectedFilters.date = headerFilters.date;\r\n          this.selectedFilters.stores = headerFilters.stores;\r\n          this.selectedFilters.group = headerFilters.group;\r\n          this.selectedFilters.location = headerFilters.location;\r\n          this.selectedFilters.country = headerFilters.country;\r\n          this.selectedFilters.zoneName = headerFilters.zoneName;\r\n          this.gs.dataRangeValue.next(this.selectedFilters);\r\n          // console.log(\"2\")\r\n                 // Ensure locations and groups are loaded before fetching stores\r\n          this.getCountry();  \r\n          this.getLocations();\r\n          this.getGroups();\r\n          // Fetch stores only after locations and groups are set\r\n          this.getStore();\r\n      } else {\r\n        this.selectedClient = this.clientList[0];\r\n        this.selectedFilters.client =  this.selectedClient.clientId;\r\n        this.selectedFilters.clientName = this.selectedClient.clientName\r\n      this.selectedFilters.clients = [this.selectedClient.clientId];\r\n      this.selectedFilters.store = headerFilters.store;\r\n      this.selectedFilters.date = headerFilters.date;\r\n      this.selectedFilters.stores = headerFilters.stores;\r\n      this.selectedFilters.group = headerFilters.group;\r\n      this.selectedFilters.location = headerFilters.location;\r\n          this.selectedFilters.country = headerFilters.country;\r\n           this.selectedFilters.zoneName = headerFilters.zoneName;\r\n        localStorage.setItem(\r\n          \"header-filters\",\r\n          JSON.stringify(this.selectedFilters) \r\n        );\r\n        this.gs.dataRangeValue.next(this.selectedFilters);\r\n        // console.log(\"3\")\r\n        this.cd.detectChanges();\r\n               // Ensure locations and groups are loaded before fetching stores\r\n this.getCountry();\r\n this.getLocations();\r\n this.getGroups();\r\n  // Fetch stores only after locations and groups are set\r\n          this.getStore();\r\n      }\r\n\r\n\r\n    } else {\r\n      this.selectedClient = this.clientList[0];\r\n      this.selectedFilters.client =  this.selectedClient.clientId;\r\n      this.selectedFilters.clientName = this.selectedClient.clientName\r\n       // Ensure locations and groups are loaded before fetching stores\r\n this.getCountry();\r\n this.getLocations();\r\n this.getGroups();\r\n // Fetch stores only after locations and groups are set\r\n        this.getStore();\r\n        this.getZone();\r\n      localStorage.setItem(\r\n        \"header-filters\",\r\n        JSON.stringify(this.selectedFilters) \r\n      );\r\n      this.gs.dataRangeValue.next(this.selectedFilters);\r\n      // console.log(\"4\")\r\n      this.cd.detectChanges();\r\n    }\r\n  this.getUserInfo(this.selectedFilters.client);\r\n\r\n    },\r\n  });\r\n}\r\ngetUserInfo(client:any){\r\n  let obj ={\r\n      clientId: client ? client :''\r\n  }\r\n  if(client){\r\n    this.auth.getHeaderUsers(obj).subscribe({\r\n      next: (e) => {\r\n        localStorage.setItem(\r\n          \"usersEmail-info\",\r\n          JSON.stringify(e?.data?.userEmailData || [])\r\n        );\r\n      } \r\n    })\r\n  }\r\n}\r\nonClientSelect(event: any): void {\r\n  // Update the selected client\r\n  this.selectedClient = event;\r\n  // Clear previous filtered data and selections\r\n  this.filteredGroups = [];\r\n  this.filteredStores = [];\r\n  this.filteredLocations = [];\r\n  this.selectedFilters.stores = [];\r\n  this.selectedFilters.group = [];\r\n  this.selectedFilters.location = [];\r\n  this.selectedFilters.country = [];\r\n  this.selectedFilters.zoneName = [];\r\n\r\n  // Fetch header filters from localStorage\r\n  const headerFilters: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"{}\");\r\n  \r\n  // Update the selected filters with the new client\r\n  this.selectedFilters.client = this.selectedClient.clientId;\r\n  this.selectedFilters.clientName = this.selectedClient.clientName;\r\n  \r\n  // Remove old store, group, and location data from the header filters\r\n  delete headerFilters.stores;\r\n  delete headerFilters.groups;\r\n  delete headerFilters.location;\r\n  delete headerFilters.country;\r\ndelete headerFilters.zoneName;\r\n  \r\n  // Fetch new data based on the new client\r\n  this.getCountry();\r\n  this.getLocations();\r\n  this.getStore();\r\n  this.getGroups();\r\n\r\n  // Update localStorage with the new client selection and empty filter data\r\n  localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n  window.location.reload()\r\n  // Emit data to the global service\r\n  // this.gs.dataRangeValue.next(this.selectedFilters);\r\n  // Trigger change detection to reflect UI changes\r\n  this.cd.detectChanges();\r\n}\r\n\r\n\r\n\r\nranges:any = {\r\n  Today: [dayjs(), dayjs()],\r\n  Yesterday: [dayjs().subtract(1, 'days'), dayjs().subtract(1, 'days')],\r\n  'This Week': [dayjs().subtract(7, 'days'), dayjs().subtract(1, 'days')],\r\n  'Last Week': [\r\n    dayjs().subtract(14, 'days').startOf('day'),\r\n    dayjs().subtract(8, 'days').endOf('day'),\r\n  ],\r\n  'This Month': [dayjs().subtract(30, 'days'), dayjs().subtract(1, 'days')],\r\n  'Last Month': [\r\n    dayjs().subtract(1, 'month').startOf('month'),\r\n    dayjs().subtract(1, 'month').endOf('month'),\r\n  ],\r\n};\r\n\r\n  onStartDateChange(event: any) {\r\n    if (this.dayjs(event.startDate).isValid()) {\r\n         if(this.selectedClient?.traxDateRange === 90){\r\n             this.isCustomDate = (m: dayjs.Dayjs) => {\r\n               const isValidDate =\r\n                 m > this.dayjs() || m > this.dayjs(event.startDate.add(90, \"days\"));\r\n               return isValidDate ? \"invalid-date\" : false;\r\n             };\r\n           } else {\r\n            this.isCustomDate = (m: dayjs.Dayjs) => {\r\n        const isValidDate =\r\n          m > this.dayjs() || m > this.dayjs(event.startDate.add(180, \"days\"));\r\n        return isValidDate ? \"invalid-date\" : false;\r\n      };\r\n         }\r\n    \r\n    }\r\n  }\r\n\r\n  datechange(event: any) {\r\n    if (event && event.startDate && event.endDate) {\r\n      if (\r\n        this.dayjs(event.startDate).isValid() &&\r\n        this.dayjs(event.endDate).isValid()\r\n      ) {\r\n        this.selectedDateRange.startDate = event.startDate;\r\n        this.selectedDateRange.endDate = event.endDate;\r\n        var datetime = {\r\n          startDate: this.dayjs(event.startDate, \"DD-MM-YYYY\").format(\r\n            \"YYYY-MM-DD\"\r\n          ),\r\n          endDate: this.dayjs(event.endDate, \"DD-MM-YYYY\").format(\"YYYY-MM-DD\"),\r\n        };\r\n        this.selectedFilters.date = datetime;\r\n        localStorage.setItem(\r\n          \"header-filters\",\r\n          JSON.stringify(this.selectedFilters)\r\n        );\r\n        window.location.reload()\r\n      // this.gs.dataRangeValue.next(this.selectedFilters);\r\n      }\r\n    } \r\n  }\r\n  opendropdown(e:MouseEvent) {\r\n    e.stopPropagation();\r\n    this.Opendropdown = !this.Opendropdown;\r\n  }\r\n  getLocations(): void {\r\n    const country = this.countries\r\n    .filter(country => country.checked)\r\n    .map(country => country.country);  \r\n    // const headerFilters: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"{}\");\r\n    let obj ={\r\n     clientId: this.selectedFilters.client ? this.selectedFilters.client :this.users.clientId,\r\n     country,\r\n     city: [],\r\n     group: [],\r\n    }\r\n    this.auth.getLocation(obj).subscribe({\r\n      next: (res: any) => {\r\n        let cityList = this.selectedFilters?.location?.filter((location:any) => location.checked).map((loc:any) => loc.city);\r\n        // Map the fetched locations with default unchecked state\r\n        this.locations = res?.data?.locationData.map((city: any) => ({\r\n          city: city.city,\r\n          // checked: cityList?.length ? cityList.includes(city.city) : true,\r\n          checked: cityList?.includes(city.city) ? true : false,\r\n        }));\r\n  \r\n        // Sync the fetched locations with any stored checked values in localStorage\r\n        if (this.selectedFilters.location && Array.isArray(this.selectedFilters.location)) {\r\n          this.filteredLocations = this.locations.map(location => {\r\n            const matchedLocation = this.selectedFilters.location.find((loc: any) => loc.city === location.city);\r\n            return matchedLocation ? { ...location, checked: matchedLocation.checked } : location;\r\n          });\r\n        } else {\r\n          this.filteredLocations = this.locations;\r\n        }\r\n\r\n        if(this.searchLocationText) {\r\n          this.filteredLocations = this.locations.filter((location:any) => location.city.toLowerCase().includes(this.searchLocationText.toLowerCase()))\r\n        }\r\n        const selectedLocations = this.locations.filter((location) => location.checked).map((location) => location.city);\r\n        if (selectedLocations.length > 0) {\r\n          setTimeout(()=>{\r\n            this.getGroups();\r\n            this.getStore(); // Fetch stores based on selected groups\r\n          },1000)\r\n        }\r\n\r\n        if(!selectedLocations.length && country.length) {\r\n          this.getGroups();\r\n        }\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch locations\", err);\r\n      },\r\n    });\r\n  }\r\n  \r\n  isAllLocationsSelected(): boolean {\r\n    return this.filteredLocations.every(location => location.checked);\r\n\r\n  }\r\n  \r\n  selectedLocationsLabel(): string {\r\n    const selectedLocations = this.locationLabel = this.searchLocationText.length ? this.locations\r\n      .filter(location => location.checked).map(location => location.city) :  this.filteredLocations\r\n      .filter(location => location.checked).map(location => location.city);\r\n    return selectedLocations.length === 0\r\n      ? ''\r\n      : selectedLocations.length === 1\r\n      ? selectedLocations[0]\r\n      : `${selectedLocations.length} locations`;\r\n  }\r\n\r\n  removeLocation(): void {\r\n    this.Reset();\r\n  }\r\n  \r\n  getGroups(): void {  \r\n    const country = this.countries\r\n      .filter(country => country.checked)\r\n      .map(country => country.country);  \r\n    let city;\r\n    city = this.locations\r\n      .filter(location => location.checked)\r\n      .map(location => location.city);\r\n\r\n      if(!city.length && country.length) {\r\n        city = this.locations.map((loc) => loc.city);\r\n      }\r\n    const obj = { country,city,clientId:this.selectedFilters.client ? this.selectedFilters.client :this.users.clientId,group:[] };\r\n    this.auth.getGroups(obj).subscribe({\r\n      next: (res: any) => {\r\n        let checkedGroup = this.selectedFilters?.group?.filter((group:any) => group.checked).map((group:any) => group.groupName);\r\n        const combinedGroups = res?.data?.groupData?.map((groupName: any) => ({\r\n          groupName: groupName.groupName,\r\n          checked: checkedGroup?.includes(groupName.groupName) ? true : false,\r\n          // checked: checkedGroup?.length ? checkedGroup.includes(groupName.groupName) : true,\r\n        }));\r\n        this.groupsData = combinedGroups;\r\n        if(this.searchGroupText.length) {\r\n          this.filteredGroups = combinedGroups.filter((item:any) => item.groupName.toLowerCase().includes(this.searchGroupText));\r\n        }\r\n        else {\r\n          this.filteredGroups = combinedGroups;\r\n        }\r\n  \r\n        // Auto-fetch stores when groups are selected\r\n        const selectedGroups = this.groupsData.filter((group) => group.checked).map((group) => group.groupName);\r\n        if (selectedGroups.length > 0) {\r\n          setTimeout(()=>{\r\n            this.getStore(); // Fetch stores based on selected groups\r\n          },1000)\r\n        }\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch groups\", err);\r\n      },\r\n    });\r\n  }\r\n\r\n  toggleDropdown(type: 'country' | 'location' | 'group' | 'store' | 'zone'): void {\r\n    if (this.dropdownOpen === type) {\r\n      // If the dropdown is open, close it and avoid resetting the selected values unnecessarily\r\n      this.dropdownOpen = null;\r\n    } else {\r\n      // Open the specific dropdown and handle data fetching only if necessary\r\n      this.dropdownOpen = type;\r\n\r\n      if (type === 'country') {\r\n        // Fetch countries only if not already fetched and no search text exists\r\n        if ((!this.filteredCountries || this.filteredCountries.length === 0) && !this.searchCountryText.trim()) {\r\n          this.getCountry();\r\n        }\r\n      }\r\n  \r\n      if (type === 'group') {\r\n        // Fetch groups only if there are selected cities and no active search text\r\n        const selectedCities = this.locations\r\n          .filter((location) => location.checked)\r\n          .map((location) => location.city);\r\n  \r\n        // Fetch groups only if locations are selected, no search text exists, and dropdown is opened\r\n      if (this.filteredLocations.length > 0 || (selectedCities.length > 0 && !this.searchGroupText.trim())) {\r\n        this.getGroups();\r\n      } else {\r\n        this.filteredGroups = []; // Clear groups if no locations are selected\r\n      }\r\n    }\r\n\r\n    if (type === 'store') {\r\n      // Fetch stores only if not already fetched and no search text is active\r\n      if ((!this.filteredStores || this.filteredStores.length === 0) && !this.searchStoreText.trim()) {\r\n        this.getStore();\r\n      } \r\n      }\r\n      \r\n      if (type === 'zone') {\r\n      // Fetch stores only if not already fetched and no search text is active\r\n      if ((!this.filteredZones || this.filteredZones.length === 0) && !this.searchZoneText.trim()) {\r\n        this.getZone();\r\n      } \r\n    }\r\n    }\r\n  }\r\n  \r\n  \r\n  handleGroupDropdownClick(): void {\r\n    if (this.dropdownOpen === 'group') {\r\n      this.resetSelectedGroups();\r\n    }\r\n    this.toggleDropdown('group');\r\n  }\r\n\r\n  resetSelectedGroups(): void {\r\n    this.filteredGroups.forEach((group) => (group.checked = false));\r\n    this.searchGroupText = \"\";\r\n  }\r\n  selectedGroupsLabel(): string {\r\n    const selectedGroups = this.groupLabel = this.searchGroupText.length ? this.groupsData.filter((group) => group.checked) : this.filteredGroups.filter((group) => group.checked);\r\n    return selectedGroups.length === 0\r\n      ? \"\"\r\n      : selectedGroups.length === 1\r\n      ? selectedGroups[0].groupName\r\n      : `${selectedGroups.length} Clusters`;\r\n  }\r\n  removeGroup(): void {\r\n    this.Reset();\r\n   \r\n  }\r\n  \r\n\r\n  isAllGroupsSelected(): boolean {\r\n    \r\n    return this.filteredGroups.length ? this.filteredGroups.every((group) => group.checked) : false;\r\n  }\r\n        \r\n  getStore(): void {\r\n    const country = this.countries\r\n    .filter(country => country.checked)\r\n    .map(country => country.country);\r\n    const city = this.locations\r\n      .filter(location => location.checked)\r\n      .map(location => location.city);\r\n    const group = this.groupsData\r\n      .filter(group => group.checked)\r\n      .map(group => group.groupName);\r\n  \r\n    const data = {\r\n      country,\r\n      city,\r\n      clusters: group,\r\n      clientId: this.users.clientId || this.selectedFilters.client\r\n    };\r\n  \r\n    this.auth.getHeaderStores(data).subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code === 200) {\r\n          // Initialize stores from API response\r\n          this.stores = res.data.storesData;\r\n          // Check if there are previously selected stores\r\n          const checkedStoreIds = this.selectedFilters?.stores\r\n            ? this.selectedFilters.stores.filter((store:any) => store.checked).map((store:any) => store.storeId)\r\n            : [];\r\n          // Sync the `checked` state\r\n          this.stores.forEach(store => {\r\n            store.checked = checkedStoreIds.length\r\n              ? checkedStoreIds.includes(store.storeId) // Use previous selection\r\n              : true; // Default to true if no previous selection\r\n          });\r\n          \r\n          // Apply search filter if search text is present\r\n          if (this.searchStoreText.length) {\r\n            this.filteredStores = this.stores.filter(store =>\r\n              store.storeName.toLowerCase().includes(this.searchStoreText.toLowerCase())\r\n            );\r\n          } else {\r\n            this.filteredStores = [...this.stores];\r\n          }\r\n  \r\n          // Update `selectedFilters.stores` to reflect the current state\r\n          this.selectedFilters.stores = this.filteredStores.map(store => ({\r\n            storeId: store.storeId,\r\n            storeName: store.storeName,\r\n            checked: store.checked\r\n          }));\r\n          // this.selectedFilters.country = country;\r\n  \r\n          // Save updated filters to localStorage\r\n          localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n          this.getZone();\r\n          // Trigger UI change detection\r\n          this.cd.detectChanges();\r\n        } else {\r\n          // Handle empty or error response\r\n          this.clearStoresState();\r\n        }\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch stores\", err);\r\n        this.clearStoresState();\r\n      }\r\n    });\r\n  }\r\n\r\n  getZone() {\r\n    const country = this.countries\r\n    .filter(country => country.checked)\r\n    .map(country => country.country);\r\n    const city = this.locations\r\n      .filter(location => location.checked)\r\n      .map(location => location.city);\r\n    const group = this.groupsData\r\n      .filter(group => group.checked)\r\n      .map(group => group.groupName);\r\n    const storeId = this.filteredStores\r\n      .filter(group => group.checked)\r\n      .map(group => group.storeId)\r\n    \r\n    const data = {\r\n      country,\r\n      city,\r\n      clusters: group,\r\n      clientId: this.users.clientId || this.selectedFilters.client,\r\n      storeId: storeId\r\n    };\r\n\r\n    this.auth.getHeaderZone(data).subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code === 200) {\r\n          // Initialize stores from API response\r\n          this.zones = res?.data?.zoneData;\r\n          // Check if there are previously selected stores\r\n          const checkedStoreIds = this.selectedFilters?.zoneName\r\n            ? this.selectedFilters?.zoneName.filter((Zone:any) => Zone.checked).map((zone:any) => zone._id)\r\n            : [];\r\n          // Sync the `checked` state,\r\n          this.zones.forEach(zone => {\r\n            zone.checked = checkedStoreIds.length\r\n              ? checkedStoreIds.includes(zone._id) // Use previous selection\r\n              : true; // Default to true if no previous selection\r\n          });\r\n  \r\n          // Apply search filter if search text is present\r\n          if (this.searchZoneText.length) {\r\n            this.filteredZones = this.zones.filter(zone =>\r\n              zone.tagName.toLowerCase().includes(this.searchZoneText.toLowerCase())\r\n            );\r\n          } else {\r\n          this.filteredZones = [...this.zones];\r\n          }\r\n  \r\n          // Update `selectedFilters.stores` to reflect the current state\r\n          this.selectedFilters.zoneName = this.filteredZones.map(zone => ({\r\n            _id: zone._id,\r\n            tagName: zone.tagName,\r\n            checked: zone.checked\r\n          }));\r\n          // this.selectedFilters.country = couthis.filteredZonesntry;\r\n           \r\n\r\n          // Save updated filters to localStorage\r\n          localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n  \r\n          // Trigger UI change detection\r\n          this.cd.detectChanges();\r\n        } else {\r\n          // Handle empty or error response\r\n          this.clearZoneState();\r\n        }\r\n      },\r\n      error: (err:any) => {\r\n        console.error(\"Failed to fetch stores\", err);\r\n        this.clearZoneState();\r\n      }\r\n    });\r\n\r\n  }\r\n    private clearZoneState(): void {\r\n    this.zones = [];\r\n    this.filteredZones = [];\r\n    this.selectedFilters.zonename = [];\r\n    localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n  }\r\n  // Clear stores state and reset filters\r\n  private clearStoresState(): void {\r\n    this.stores = [];\r\n    this.filteredStores = [];\r\n    this.selectedFilters.stores = [];\r\n    localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n  }\r\n  \r\n  resetSelectedStores(): void {\r\n    this.filteredStores.forEach((store) => (store.checked = false));\r\n    this.searchStoreText = \"\";\r\n  }\r\n\r\n  selectedStoresLabel(): string {\r\n    const selectedStores = this.searchStoreText.length ? this.stores.filter((store) => store.checked) : this.filteredStores.filter((store) => store.checked);\r\n    return selectedStores.length === 0\r\n      ? \"0 Stores\"\r\n      : selectedStores.length === 1\r\n      ? selectedStores[0].storeName\r\n      : `${selectedStores.length} Stores`;\r\n  }\r\n\r\n  selectedZonesLabel(): string {\r\n    const selectedStores = this.searchZoneText.length ? this.zones.filter((zone) => zone.checked) : this.filteredZones.filter((zone) => zone.checked);\r\n    return selectedStores.length === 0\r\n      ? \"0 Zones\"\r\n      : selectedStores.length === 1\r\n      ? selectedStores[0].tagName\r\n      : `${selectedStores.length} Zones`;\r\n  }\r\n\r\n  isAllStoresSelected(): boolean {\r\n    return this.filteredStores.length > 0 && this.filteredStores.every(store => store.checked);\r\n  }\r\n\r\n  isAllZonesSelected(): boolean {\r\n    return this.filteredZones.length > 0 && this.filteredZones.every(zone => zone.checked);\r\n  }\r\n// Method to handle dropdown item selection\r\n  updateSelectedStores(): void {\r\n  this.filteredStores.forEach(store => {\r\n    const filteredStore = this.stores.findIndex(fStore => fStore.storeId === store.storeId);\r\n    if (filteredStore != -1) {\r\n      this.stores[filteredStore].checked = store.checked; // Sync the checked state with full store list\r\n    }\r\n  });  \r\n  // Update selectedFilters based on the current store selection\r\n  this.selectedFilters.stores = this.stores.filter(store => store.checked);\r\n\r\n  // Update localStorage with the latest selection\r\n  localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n\r\n  // Emit updated filters via service\r\n  // this.gs.dataRangeValue.next(this.selectedFilters);\r\n\r\n  // Trigger change detection if necessary\r\n  if (this.selectedFilters.stores.length > 0)\r\n    this.getZone(); else this.zones = [];\r\n    this.filteredZones = [];\r\n    this.selectedFilters.zoneName = [];\r\n  this.cd.detectChanges();\r\n  }\r\n  \r\n  updateSelectedZones(): void {\r\n  this.filteredZones.forEach(zone => {\r\n    const filteredZone = this.zones.findIndex(fStore => fStore._id === zone._id);\r\n    if (filteredZone != -1) {\r\n      this.zones[filteredZone].checked = zone.checked; // Sync the checked state with full store list\r\n    }\r\n  });  \r\n  // Update selectedFilters based on the current store selection\r\n  this.selectedFilters.zoneName = this.zones.filter(zone => zone.checked);\r\n\r\n  // Update localStorage with the latest selection\r\n  localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n\r\n  // Emit updated filters via service\r\n  // this.gs.dataRangeValue.next(this.selectedFilters);\r\n\r\n  // Trigger change detection if necessary\r\n  this.cd.detectChanges();\r\n  }\r\n  \r\n  toggleSelectAllLocations(event: any): void {\r\n    const isChecked = event.target.checked;\r\n    this.filteredLocations.forEach((location) => (location.checked = isChecked));\r\n    this.updateSelectedLocations();\r\n  }\r\n\r\n  toggleSelectAllStores(event: Event): void {\r\n    const checked = (event.target as HTMLInputElement).checked;\r\n  \r\n    // Apply the selection to both filtered and full list of stores\r\n    this.filteredStores.forEach(store => store.checked = checked);\r\n    this.stores.forEach(store => {\r\n      const filteredStore = this.filteredStores.find(fStore => fStore.storeId === store.storeId);\r\n      if (filteredStore) {\r\n        store.checked = checked; // Sync the checked state with full store list\r\n      }\r\n    });\r\n  \r\n    // Update the selected stores and persist the selection\r\n    this.updateSelectedStores();\r\n  }\r\n\r\n  toggleSelectAllZones(event: Event): void {\r\n    const checked = (event.target as HTMLInputElement).checked;\r\n  \r\n    // Apply the selection to both filtered and full list of stores\r\n    this.filteredZones.forEach(zone => zone.checked = checked);\r\n    this.zones.forEach(zone => {\r\n      const filteredStore = this.filteredZones.find(fStore => fStore._id === zone._id);\r\n      if (filteredStore) {\r\n        zone.checked = checked; // Sync the checked state with full store list\r\n      }\r\n    });\r\n  \r\n    // Update the selected stores and persist the selection\r\n    this.updateSelectedZones();\r\n  }\r\n\r\n  updateSelectedLocations(): void {\r\n    // When locations are selected, fetch the related groups\r\n    const selectedCities = this.filteredLocations\r\n      .filter((location) => location.checked)\r\n      .map((location) => location.city);\r\n    this.filteredLocations.forEach((location:any) => {\r\n      let findLocationIndex = this.locations.findIndex((loc:any) => loc.city == location.city);\r\n      if(findLocationIndex != -1) {\r\n        this.locations[findLocationIndex].checked = location.checked;\r\n      }\r\n    })\r\n    if (selectedCities.length > 0 || !selectedCities.length) {\r\n      this.selectedFilters.stores =[];\r\n      this.groupsData =[]\r\n      this.getGroups(); // Fetch groups based on selected cities\r\n      // If there are selected groups, fetch the stores based on selected groups\r\n      this.getStore();\r\n      this.selectedFilters.location = this.locations;\r\n     \r\n    } else {\r\n      this.filteredGroups = []; // Clear groups if no locations are selected\r\n      this.selectedFilters.location = [];\r\n    }\r\n    \r\n    this.selectedFilters.group = [];\r\n    this.filteredStores = []; // Reset stores as well\r\n    this.searchGroupText = '';\r\n    this.searchStoreText = '';\r\n    // this.Opendropdown = false;\r\n  }\r\n\r\n  toggleSelectAllGroups(event: any): void {\r\n    const isChecked = event.target.checked;\r\n    this.filteredGroups.forEach((group) => (group.checked = isChecked));\r\n    this.updateSelectedGroups();\r\n  }\r\n\r\n  updateSelectedGroups(): void {\r\n    // Fetch the relevant stores after groups are selected\r\n    const selectedGroups = this.filteredGroups\r\n      .filter((group) => group.checked)\r\n      .map((group) => group.groupName);\r\n\r\n    this.filteredGroups.forEach((group:any) => {\r\n      let findGroupIndex = this.groupsData.findIndex((item:any) => item.groupName == group.groupName);\r\n      if(findGroupIndex != -1) {\r\n        this.groupsData[findGroupIndex].checked = group.checked;\r\n      }\r\n    }) \r\n    if (selectedGroups.length > 0 || !selectedGroups.length) {\r\n      this.selectedFilters.stores =[];\r\n      // If there are selected groups, fetch the stores based on selected groups\r\n      this.getStore();\r\n      this.selectedFilters.group = this.groupsData;\r\n    } else {\r\n      // If no groups are selected, clear the stores list\r\n      this.filteredStores = [];\r\n      \r\n      // Also, update localStorage to reflect the cleared store selection\r\n      this.selectedFilters.stores = [];\r\n      localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n  \r\n      // Emit data via service\r\n      // this.gs.dataRangeValue.next(this.selectedFilters);\r\n    }\r\n  \r\n    // Clear the search store text when groups are updated\r\n    this.searchStoreText = '';\r\n  }\r\n  \r\n\r\n  Reset(): void {\r\n    setTimeout(()=>{\r\n     // Clear selected groups, stores, and locations\r\n  this.filteredCountries = []\r\n  this.filteredGroups = [];\r\n  this.filteredStores = [];\r\n  this.filteredLocations = []; // Reset locations as well\r\nthis.locations =[];this.groupsData =[]; this.stores =[]; this.filteredZones =[]; this.zones =[];\r\n  // Clear search input fields\r\n  this.searchLocationText = \"\";\r\n  this.searchGroupText = \"\";\r\n  this.searchStoreText = \"\";\r\nthis.selectedFilters.stores =[];\r\nthis.selectedFilters.group =[];\r\nthis.selectedFilters.location =[];\r\nthis.selectedFilters.country =[];\r\n      this.selectedFilters.zoneName = [];\r\n \r\n  // Fetch locations, groups, and stores again\r\n  this.getCountry();\r\n  this.getLocations();\r\n  this.getStore();\r\n      this.getGroups();\r\n  // Reset the filters in selectedFilters\r\n\r\n\r\n  // // Once stores are fetched, mark all as checked\r\n  // setTimeout(() => {\r\n  //   this.filteredStores = this.stores.map(store => ({\r\n  //     ...store,\r\n  //     checked: true  // Mark all stores as checked\r\n  //   }));\r\n\r\n  //   // Sync selectedFilters with the updated store state\r\n  //   this.selectedFilters.stores = this.filteredStores.map(store => ({\r\n  //     ...store,\r\n  //     checked: true\r\n  //   }));\r\n\r\n    // Update localStorage with the latest selectedFilters\r\n    localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n window.location.reload()\r\n    // Emit the reset filters to update other components if needed\r\n    // this.gs.dataRangeValue.next(this.selectedFilters);\r\n    // Trigger change detection\r\n    this.cd.detectChanges();\r\n   // Adding a slight delay to ensure stores are fetched first\r\n \r\n  \r\n    // Close dropdown after reset if necessary\r\n    this.Opendropdown = false;\r\n  },100)\r\n  }\r\n  \r\n  \r\n  \r\n\r\n  filterLocations(): void {    \r\n    const searchText = this.searchLocationText.toLowerCase();\r\n    \r\n    if (searchText) {\r\n      // Preserve the checked state during filtering\r\n      this.filteredLocations = this.locations\r\n        .map(location => ({\r\n          ...location,\r\n          checked: this.filteredLocations.find(l => l.city === location.city)?.checked || false\r\n        }))\r\n        .filter(location =>\r\n          location?.city?.toLowerCase().includes(searchText)\r\n        );\r\n    } else {\r\n      // Restore the original checked state when search text is cleared\r\n      this.filteredLocations = this.locations.map(location => ({\r\n        ...location,\r\n        checked: this.selectedFilters.location.find((l:any) => l.city === location.city)?.checked || false\r\n      }));\r\n    }\r\n  }\r\n  \r\n\r\n  filterGroups(): void {  \r\n    const searchText = this.searchGroupText.toLowerCase();\r\n    \r\n    if (searchText) {\r\n      // Preserve the checked state during filtering\r\n      this.filteredGroups = this.groupsData\r\n        .map(group => ({\r\n          ...group,\r\n          checked: this.filteredGroups.find(g => g.groupName === group.groupName)?.checked || false\r\n        }))\r\n        .filter(group =>\r\n          group?.groupName?.toLowerCase().includes(searchText)\r\n        );\r\n    } else {\r\n      // Restore the original checked state when search text is cleared\r\n      this.filteredGroups = this.groupsData.map(group => ({\r\n        ...group,\r\n        checked: this.selectedFilters.group.find((g:any) => g.groupName === group.groupName)?.checked || false\r\n      }));\r\n    }\r\n  }\r\n  \r\n  \r\n  filterStores(): void {\r\n    const searchText = this.searchStoreText.toLowerCase();\r\n    // Preserve checked states during filtering\r\n    if (searchText) {\r\n      // Filter based on search text while preserving checked state\r\n      this.filteredStores = this.stores\r\n        .map(store => ({\r\n          ...store,\r\n          // Check if the store is already checked in filteredStores, fallback to original stores' checked state\r\n          checked: this.selectedFilters.stores.find((s: any) => s.storeId === store.storeId)?.checked || store.checked || false\r\n        }))\r\n        .filter(store => store.storeName.toLowerCase().includes(searchText));\r\n    } else {\r\n      // When the search text is cleared, restore the original list with preserved checked states\r\n      this.filteredStores = this.stores.map(store => ({\r\n        ...store,\r\n        // Preserve the checked state based on the selected filters\r\n        checked: this.selectedFilters.stores.find((s: any) => s.storeId === store.storeId)?.checked || store.checked || false\r\n      }));\r\n    }\r\n  }\r\n\r\n  filterZones(): void {\r\n    const searchText = this.searchZoneText.toLowerCase();\r\n    // Preserve checked states during filtering\r\n    if (searchText) {\r\n      // Filter based on search text while preserving checked state\r\n      this.filteredZones = this.zones\r\n        .map(zone => ({\r\n          ...zone,\r\n          // Check if the store is already checked in filteredStores, fallback to original stores' checked state\r\n          checked: this.selectedFilters.zoneName.find((s: any) => s._id === zone._id)?.checked || zone.checked || false\r\n        }))\r\n        .filter(zone => zone.tagName.toLowerCase().includes(searchText));\r\n    } else {\r\n      // When the search text is cleared, restore the original list with preserved checked states\r\n      this.filteredZones = this.zones.map(zone => ({\r\n        ...zone,\r\n        // Preserve the checked state based on the selected filters\r\n        checked: this.selectedFilters.zoneName.find((s: any) => s._id === zone._id)?.checked || zone.checked || false\r\n      }));\r\n    }\r\n  }\r\n\r\n  closeDropdown(): void {\r\n    this.dropdownOpen = null;\r\n  }\r\n\r\n  @HostListener(\"document:click\", [\"$event\"])\r\n  clickOutside(event: MouseEvent): void {\r\n    const clickedInside = (event.target as HTMLElement).closest(\r\n      \".dropdown-container\"\r\n    );\r\n    const clickedoutSide = (event.target as HTMLElement).closest(\r\n      \".dropdown2\"\r\n    );\r\n    if (!clickedInside) {\r\n      this.closeDropdown();\r\n    }\r\n    if(!clickedoutSide) {\r\n      this.closeDropdown1();\r\n    }\r\n\r\n  }\r\n\r\n  // getCountry(): void {\r\n  //   // const headerFilters: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"{}\");\r\n  //   let obj ={\r\n  //    clientId: this.selectedFilters.client ? this.selectedFilters.client :this.users.clientId,\r\n  //   }\r\n  //   this.auth.getCountry(obj).subscribe({\r\n  //     next: (res: any) => {\r\n  //       let countryList = this.selectedFilters?.country?.filter((country:any) => country.checked).map((loc:any) => loc.allCountry);\r\n  //       // Map the fetched countries with default unchecked state\r\n  //       this.countires = res?.data?.countryData.map((allCountry: any) => ({\r\n  //         allCountry: allCountry.allCountry,\r\n  //         checked: countryList?.includes(allCountry.allCountry) ? true : false,\r\n  //       }));\r\n  \r\n  //       // Sync the fetched countries with any stored checked values in localStorage\r\n  //       if (this.selectedFilters.country && Array.isArray(this.selectedFilters.country)) {\r\n  //         this.filteredCountries = this.countries.map(country => {\r\n  //           const matchedLocation = this.selectedFilters.country.find((loc: any) => loc.allCountry === country.allCountry);\r\n  //           return matchedLocation ? { ...country, checked: matchedLocation.checked } : country;\r\n  //         });\r\n  //       } else {\r\n  //         this.filteredCountries = this.countries;\r\n  //       }\r\n\r\n  //       if(this.searchLocationText) {\r\n  //         this.filteredCountries = this.countries.filter((country:any) => country.city.toLowerCase().includes(this.searchLocationText.toLowerCase()))\r\n  //       }\r\n  //       const selectedCountries = this.countries.filter((country) => country.checked).map((country) => country.allCountry);\r\n  //       if (selectedCountries.length > 0) {\r\n  //         setTimeout(()=>{\r\n  //           this.getStore(); // Fetch stores based on selected groups\r\n  //         },1000)\r\n  //       }\r\n  //     },\r\n  //     error: (err) => {\r\n  //       console.error(\"Failed to fetch countries\", err);\r\n  //     },\r\n  //   });\r\n  // }\r\n\r\n  // selectedCountriesLabel(): string {\r\n  //   const selectedCountries = this.countryLabel = this.searchLocationText.length ? this.countries\r\n  //     .filter(country => country.checked).map(country => country.allCountry) :  this.filteredCountries\r\n  //     .filter(country => country.checked).map(country => country.allCountry);\r\n  //   return selectedCountries.length === 0\r\n  //     ? ''\r\n  //     : selectedCountries.length === 1\r\n  //     ? selectedCountries[0]\r\n  //     : `${selectedCountries.length} countries`;\r\n  // }\r\n\r\n  // isAllCountriesSelected(): boolean {\r\n  //   return this.filteredCountries.every(country => country.checked);\r\n\r\n  // }\r\n  // filterCountries(): void {    \r\n  //   const searchText = this.searchCountryText.toLowerCase();\r\n    \r\n  //   if (searchText) {\r\n  //     // Preserve the checked state during filtering\r\n  //     this.filteredCountries = this.countires\r\n  //       .map(country => ({\r\n  //         ...country,\r\n  //         checked: this.filteredCountries.find(l => l.allCountry === country.allCountry)?.checked || false\r\n  //       }))\r\n  //       .filter(location =>\r\n  //         location?.allCountry?.toLowerCase().includes(searchText)\r\n  //       );\r\n  //   } else {\r\n  //     // Restore the original checked state when search text is cleared\r\n  //     this.filteredCountries = this.countires.map(country => ({\r\n  //       ...country,\r\n  //       checked: this.selectedFilters.country.find((l:any) => l.allCountry === country.allCountry)?.checked || false\r\n  //     }));\r\n  //   }\r\n  // }\r\n  \r\n\r\n    getCountry(): void {\r\n    let obj = {\r\n      clientId: this.selectedFilters.client ? this.selectedFilters.client : this.users.clientId,\r\n    };\r\n    \r\n    this.auth.getCountry(obj).subscribe({\r\n      next: (res: any) => {\r\n        // Extract selected countries from existing filters (if any)\r\n        let countryList = this.selectedFilters?.country?.filter((country: any) => country.checked).map((loc: any) => loc.country);\r\n  \r\n        // Map API response to frontend model\r\n        this.countries = res?.data?.countryData.map((item: any) => ({\r\n          country: item.country,\r\n          // checked: countryList?.length ? countryList.includes(item.country) : true,\r\n          // checked: cityList?.length ? cityList.includes(city.city) : true,\r\n          checked: countryList?.includes(item.country) ? true : false,\r\n          \r\n        }));\r\n        if (this.selectedFilters.country && Array.isArray(this.selectedFilters.country)) {\r\n          this.filteredCountries = this.countries.map(location => {\r\n            const matchedLocation = this.selectedFilters.country.find((loc: any) => loc.country === location.country);\r\n            return matchedLocation ? { ...location, checked: matchedLocation.checked } : location;\r\n          });\r\n        } else {\r\n          this.filteredCountries = this.countries;\r\n        }\r\n\r\n\r\n        // Initially, all countries are visible\r\n        this.filteredCountries = [...this.countries];\r\n        \r\n\r\n        // If a search text already exists, filter immediately\r\n        if (this.searchCountryText) {\r\n          this.filterCountries();\r\n        }\r\n  \r\n        // Fetch stores if at least one country is selected\r\n        let selectedCountries = this.countries.filter((country) => country.checked);\r\n        if (selectedCountries.length > 0) {\r\n          setTimeout(() => {\r\n            this.getLocations();\r\n            this.getStore(); // fetch stores\r\n          }, 1000);\r\n        }\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch countries\", err);\r\n      },\r\n    });\r\n  }\r\n\r\n  selectedCountriesLabel(): string {\r\n    const selectedCountries = this.searchCountryText.length\r\n      ? this.filteredCountries.filter(country => country.checked).map(country => country.country)\r\n      : this.countries.filter(country => country.checked).map(country => country.country);\r\n  \r\n    return selectedCountries.length === 0\r\n      ? ''\r\n      : selectedCountries.length === 1\r\n      ? selectedCountries[0]\r\n      : `${selectedCountries.length} countries`;\r\n  }\r\n\r\n  filterCountries(): void {\r\n    const searchText = this.searchCountryText.toLowerCase();\r\n    \r\n    if (searchText) {\r\n      // Filter and preserve checked state\r\n      this.filteredCountries = this.countries\r\n        .map(country => ({\r\n          ...country,\r\n          checked: this.filteredCountries.find(c => c.country === country.country)?.checked || false\r\n        }))\r\n        .filter(country => country.country.toLowerCase().includes(searchText));\r\n    } else {\r\n      // Reset to full list\r\n      this.filteredCountries = this.countries.map((country: Country) => ({\r\n        ...country,\r\n        checked: this.selectedFilters.country?.find((c: any) => c.country === country.country)?.checked || false\r\n      }));\r\n    }\r\n  }\r\n\r\n  isAllCountriesSelected(): boolean {\r\n    return this.filteredCountries.length > 0 && this.filteredCountries.every(country => country.checked);\r\n  }\r\n  toggleSelectAllCountries(event: any): void {\r\n    const isChecked = event.target.checked;\r\n    this.filteredCountries.forEach((country) => (country.checked = isChecked));\r\n    this.updateSelectedCountries();\r\n    \r\n  }\r\n  \r\n  updateSelectedCountries(): void {\r\n    // When locations are selected, fetch the related groups\r\n    const selectedCountries = this.filteredCountries\r\n      .filter((country) => country.checked)\r\n      .map((country) => country.country);\r\n    this.filteredCountries.forEach((country:any) => {\r\n      let findCountryIndex = this.countries.findIndex((loc:any) => loc.country == country.country);\r\n      if(findCountryIndex != -1) {\r\n        this.countries[findCountryIndex].checked = country.checked;\r\n      }\r\n    })\r\n    if (selectedCountries.length > 0 || !selectedCountries.length) {\r\n      this.selectedFilters.stores =[];\r\n      this.groupsData =[]\r\n      this.locations =[];\r\n      this.selectedFilters.zoneName =[];\r\n      this.getLocations();\r\n      this.getGroups(); // Fetch groups based on selected cities\r\n      // If there are selected groups, fetch the stores based on selected groups\r\n      this.getStore();\r\n      this.getZone();\r\n      this.selectedFilters.country = this.filteredCountries;\r\n     \r\n    } else {\r\n      this.filteredGroups = []; // Clear groups if no locations are selected\r\n      this.selectedFilters.country = [];\r\n    }\r\n    \r\n    this.selectedFilters.group = [];\r\n    this.filteredStores = []; // Reset stores as well\r\n     this.filteredZones = [];\r\n    this.searchGroupText = '';\r\n    this.searchStoreText = '';\r\n    // this.Opendropdown = false;\r\n  }\r\n\r\n  removeCountry(): void {\r\n    this.Reset();\r\n  }\r\n\r\n  Apply(): void {\r\n    // Close the dropdown\r\n    this.Opendropdown = false;\r\n  \r\n    // Fetch existing filters from localStorage\r\n    const headerFilters: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"{}\");\r\n    this.selectedFilters.store =  null\r\n  \r\n    // Ensure current selections are reflected\r\n    this.selectedFilters.country = this.filteredCountries;\r\n    this.selectedFilters.location = this.locations;\r\n    this.selectedFilters.group = this.groupsData;\r\n    this.selectedFilters.stores = headerFilters.stores ? headerFilters.stores : this.stores;\r\n    this.selectedFilters.zoneName = headerFilters.zoneName ? headerFilters.zoneName :this.zones\r\n    // this.selectedFilters.zoneName = this.filteredZones;\r\n    // Store updated filters back in localStorage\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(this.selectedFilters));\r\n    // this.gs.dataRangeValue.next(this.selectedFilters);\r\n    window.location.reload()\r\n    // Emit the updated filters via the service\r\n    // this.gs.dataRangeValue.next(this.selectedFilters);\r\n    // Trigger refresh if necessary\r\n    // this.gs.manageRefreshTrigger.next(true);\r\n    this.cd.detectChanges();\r\n  }\r\n  \r\n\r\n\r\n}\r\ninterface City {\r\n  city: string;\r\n}\r\n\r\ninterface Location {\r\n  city: City;\r\n  checked: boolean;\r\n}\r\ninterface Country {\r\n  country: string;\r\n  checked: boolean;\r\n}\r\n\r\n","<div class=\"me-3\">\r\n    <label *ngIf=\"selectedCountriesLabel()\" class=\"badge badge-light-default mx-2\">{{selectedCountriesLabel()}} \r\n        <span class=\"cursor-pointer\" (click)=\"removeCountry()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n        <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n        </svg></span>\r\n    </label>\r\n    <label *ngIf=\"selectedLocationsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedLocationsLabel()}} \r\n        <span class=\"cursor-pointer\" (click)=\"removeLocation()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n        <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n        </svg></span>\r\n    </label>\r\n    <label *ngIf=\"selectedGroupsLabel()\"  class=\"badge badge-light-default mx-2\">{{selectedGroupsLabel()}} \r\n        <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n        <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n        </svg></span>\r\n    </label>\r\n    <label  class=\"badge badge-light-default\">{{selectedStoresLabel()}}</label>\r\n      <label class=\"badge badge-light-default mx-2\">{{selectedZonesLabel()}} \r\n        <!-- <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n        <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n        </svg></span> -->\r\n    </label>\r\n</div>\r\n\r\n\r\n<div class=\"wrapper me-3\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\">\r\n<lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n(selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n</div>\r\n<div class=\"d-flex align-items-center position-relative my-1\">\r\n    <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n            <path\r\n                d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n                stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n        </svg>\r\n    </span>\r\n    <input class=\"fx-date-range form-control ps-14\" style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n        ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [autoApply]=\"true\"\r\n        [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\"\r\n        [(ngModel)]=\"selectedDateRange\" (startDateChanged)=\"onStartDateChange($event)\" [isCustomDate]=\"isCustomDate\"\r\n        [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n        (datesUpdated)=\"datechange($event)\" name=\"daterange\" [readonly]=\"true\" />\r\n</div>\r\n<div class=\"position-relative\">\r\n    <button type=\"button\" (click)=\"opendropdown($event)\"  class=\"btn btn-default mx-2 rounded-3 text-nowrap border-val\">\r\n        <!-- <span class=\"me-2\">Filter</span> -->\r\n        <svg class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                stroke-linejoin=\"round\" />\r\n        </svg>\r\n    </button>\r\n\r\n    <div *ngIf=\"Opendropdown\" class=\"card p-5 dropdown2 position-absolute z-1 end-0\" style=\"z-index: 1 !important;\" (clickOutside)=\"closeDropdown1()\">\r\n        <div class=\"dropdown-title d-flex justify-content-between mb-2\">Filter Options\r\n            <button class=\"btn btn-outline w-25 ms-3 btn-resize\" (click)=\"Reset()\"> Reset </button>\r\n            <button class=\"btn btn-primary w-25  btn-resize\" (click)=\"Apply()\">Apply</button>\r\n        </div>\r\n\r\n             <!-- Country Dropdown -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('country')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\" \r\n            [value]=\"selectedCountriesLabel()\"\r\n            readonly\r\n            placeholder=\"Select country\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'country'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search\" \r\n            placeholder=\"Search country\" \r\n            [(ngModel)]=\"searchCountryText\" \r\n            (ngModelChange)=\"filterCountries()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllCountries\" \r\n                [checked]=\"isAllCountriesSelected()\" \r\n                (change)=\"toggleSelectAllCountries($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllCountries\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let country of filteredCountries\"\r\n        >\r\n        <input \r\n        class=\"form-check-input cursor-pointer\" \r\n        type=\"checkbox\" \r\n        [id]=\"country.country\" \r\n        [(ngModel)]=\"country.checked\"\r\n        (change)=\"updateSelectedCountries()\" \r\n      />\r\n      <label class=\"form-check-label\" [for]=\"country.country\">\r\n        {{ country.country }}\r\n      </label>\r\n      \r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n     <!-- Location Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('location')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\" \r\n            [value]=\"selectedLocationsLabel()\"\r\n            readonly\r\n            placeholder=\"Select Region\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'location'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search\" \r\n            placeholder=\"Search Region\" \r\n            [(ngModel)]=\"searchLocationText\" \r\n            (ngModelChange)=\"filterLocations()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllLocations\" \r\n                [checked]=\"isAllLocationsSelected()\" \r\n                (change)=\"toggleSelectAllLocations($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllLocations\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let location of filteredLocations\"\r\n        >\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                [id]=\"location.city\" \r\n                [(ngModel)]=\"location.checked\"\r\n                (change)=\"updateSelectedLocations()\" \r\n            />\r\n            <label class=\"form-check-label\" [for]=\"location.city\">\r\n                {{ location.city }}\r\n            </label>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<!-- Group Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('group')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\" \r\n            [value]=\"selectedGroupsLabel()\" readonly\r\n            placeholder=\"Select clusters\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'group'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search\" \r\n            placeholder=\"Search clusters\" \r\n            [(ngModel)]=\"searchGroupText\" \r\n            (ngModelChange)=\"filterGroups()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllGroups\" \r\n                [checked]=\"isAllGroupsSelected()\" \r\n                (change)=\"toggleSelectAllGroups($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllGroups\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let group of filteredGroups\"\r\n        >\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                [id]=\"group.groupName\"\r\n                [(ngModel)]=\"group.checked\"\r\n                (change)=\"updateSelectedGroups()\" \r\n            />\r\n            <label class=\"form-check-label\" [for]=\"group.groupName\">\r\n                {{ group.groupName }}\r\n            </label>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n\r\n<!-- Store Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('store')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\"\r\n            [value]=\"selectedStoresLabel()\"\r\n            readonly\r\n            placeholder=\"Select stores\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'store'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search \" \r\n            placeholder=\"Search stores\" \r\n            [(ngModel)]=\"searchStoreText\" \r\n            (ngModelChange)=\"filterStores()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllStores\" \r\n                [checked]=\"isAllStoresSelected()\" \r\n                (change)=\"toggleSelectAllStores($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllStores\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let store of filteredStores\"\r\n        >\r\n            <input \r\n                class=\"form-check-input\" \r\n                type=\"checkbox\" \r\n                [id]=\"store.storeId\"\r\n                [(ngModel)]=\"store.checked\"\r\n                (change)=\"updateSelectedStores()\" \r\n            />\r\n            <label class=\"form-check-label\" [for]=\"store.storeId\">\r\n                {{ store.storeName }}\r\n            </label>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<!-- Zone Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('zone')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\"\r\n            [value]=\"selectedZonesLabel()\"\r\n            readonly\r\n            placeholder=\"Select zones\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'zone'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search \" \r\n            placeholder=\"Search zones\" \r\n            [(ngModel)]=\"searchZoneText\" \r\n            (ngModelChange)=\"filterZones()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllZones\" \r\n                [checked]=\"isAllZonesSelected()\" \r\n                (change)=\"toggleSelectAllZones($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllZones\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let zone of filteredZones\"\r\n        >\r\n            <input \r\n                class=\"form-check-input\" \r\n                type=\"checkbox\" \r\n                [id]=\"zone._id\"\r\n                [(ngModel)]=\"zone.checked\"\r\n                (change)=\"updateSelectedZones()\" \r\n            />\r\n            <label class=\"form-check-label\" [for]=\"zone._id\">\r\n                {{ zone.tagName }}\r\n            </label>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n    </div>\r\n</div>"]}
|
|
1321
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metrics-header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/metrics-header/metrics-header.component.ts","../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/metrics-header/metrics-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  HostListener,\r\n  OnInit,\r\n} from \"@angular/core\";\r\nimport dayjs from \"dayjs\";\r\nimport \"dayjs/locale/en\";\r\nimport { AuthService } from \"../../../../services/auth.service\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\nimport { NavigationEnd, Router } from \"@angular/router\";\r\n@Component({\r\n  selector: \"lib-metrics-header\",\r\n  templateUrl: \"./metrics-header.component.html\",\r\n  styleUrl: \"./metrics-header.component.scss\",\r\n})\r\nexport class MetricsHeaderComponent implements OnInit {\r\n  dayjs = dayjs;\r\n  isCustomDate = (m: dayjs.Dayjs) => {\r\n    const isValidDate = m > this.dayjs();\r\n    return isValidDate ? \"invalid-date\" : false;\r\n  };\r\n\r\n  selectedDateRange: any = {\r\n    startDate: dayjs().subtract(30, \"days\"),\r\n    endDate: dayjs().subtract(1, \"days\"),\r\n  };\r\n  selectedFilters: any = {\r\n    client: null,\r\n    clientName: null,\r\n    clients: [],\r\n    store: null,\r\n    stores: [],\r\n    date: null,\r\n    group: [],\r\n    location: [],\r\n    country: [],\r\n    zoneName: [],\r\n  };\r\n  Opendropdown: boolean = false;\r\n  dropdownOpen: string | null = null; // 'location' or 'group'\r\n  searchLocationText: string = \"\";\r\n  searchGroupText: string = \"\";\r\n  locations: any[] = [];\r\n  filteredLocations: any[] = [];\r\n  groupsData: any[] = [];\r\n  filteredGroups: any[] = [];\r\n  filteredStores: any[] = [];\r\n  filteredZones: any[] = [];\r\n  stores: any[] = [];\r\n  zones: any[] = [];\r\n  searchStoreText: string = \"\";\r\n  searchZoneText: string = \"\";\r\n  clientList: any = [];\r\n  selectedClient: any;\r\n  locationLabel: any[] = [];\r\n  groupLabel: any[] = [];\r\n  users: any;\r\n  url: any;\r\n  filteredCountries: any[] = [];\r\n  countryLabel: any[] = [];\r\n  searchCountryText: string = \"\";\r\n  countries: any[] = [];\r\n  constructor(\r\n    private auth: AuthService,\r\n    private router: Router,\r\n    public gs: GlobalStateService,\r\n    private cd: ChangeDetectorRef\r\n  ) {}\r\n\r\n  @HostListener(\"document:click\", [\"$event\"])\r\n  onClick(event: MouseEvent) {\r\n    const target = event.target as HTMLElement;\r\n    if (!target.closest(\".dropdown2\")) {\r\n      this.Opendropdown = false;\r\n    }\r\n  }\r\n  closeDropdown1() {\r\n    this.Opendropdown = false;\r\n  }\r\n  ngOnInit(): void {\r\n    // this.setRangesBasedOnRoute();\r\n\r\n    // Listen for route changes to update ranges\r\n    // this.router?.events?.subscribe((event) => {\r\n    //   if (event instanceof NavigationEnd) {\r\n    //     this.setRangesBasedOnRoute();\r\n    //   }\r\n    // });\r\n    this.url = this.router.url.split(\"?\")[0].split(\"/\");\r\n    const user = JSON.parse(localStorage.getItem(\"user-info\") as string);\r\n    this.users = user;\r\n    this.gs?.manageRefreshTrigger?.subscribe((e) => {\r\n      if (e) {\r\n        if (user.userType === \"tango\") {\r\n          this.getClient();\r\n        } else {\r\n          const storedFilters = localStorage.getItem(\"header-filters\");\r\n          if (storedFilters) {\r\n            const headerFilters = JSON.parse(storedFilters);\r\n            this.filteredStores = headerFilters?.stores.map((store: any) => ({\r\n              ...store,\r\n              checked: store.checked,\r\n            }));\r\n            this.filteredZones = headerFilters?.zoneName.map((store: any) => ({\r\n              ...store,\r\n              checked: store.checked,\r\n            }));\r\n          }\r\n        }\r\n      }\r\n    });\r\n\r\n    // Fetch client data if the user is of type 'tango'\r\n    if (user.userType === \"tango\") {\r\n      this.getClient();\r\n    } else {\r\n      this.getCountry();\r\n      this.getLocations();\r\n      this.getGroups();\r\n      this.getStore();\r\n      const clientFilters = localStorage.getItem(\"client-details\");\r\n      if (clientFilters) {\r\n        const headerclientFilters = JSON.parse(clientFilters);\r\n        this.selectedClient = {\r\n          trafficDateRange: headerclientFilters.trafficDateRange,\r\n        };\r\n      }\r\n    }\r\n\r\n    // Load filters from localStorage if they exist\r\n    const storedFilters = localStorage.getItem(\"header-filters\");\r\n    if (storedFilters) {\r\n      const headerFilters = JSON.parse(storedFilters);\r\n\r\n      // Initialize selectedFilters with defaults or existing values\r\n      this.selectedFilters = {\r\n        client: headerFilters.client || this.users.client,\r\n        clientName: headerFilters.clientName || \"\",\r\n        clients: headerFilters.clients || [],\r\n        store: headerFilters.store || null,\r\n        date: headerFilters.date || {},\r\n        stores: headerFilters.stores || [],\r\n        group: headerFilters.group || [],\r\n        location: headerFilters.location || [],\r\n        country: headerFilters.country || [],\r\n        zoneName: headerFilters.zoneName || [],\r\n      };\r\n\r\n      // Sync filtered data with stored selections\r\n      this.filteredCountries = this.syncWithLocalStorage(headerFilters.country);\r\n      this.filteredLocations = this.syncWithLocalStorage(\r\n        headerFilters.location\r\n      );\r\n      this.filteredGroups = this.syncWithLocalStorage(headerFilters.group);\r\n      this.filteredStores = this.syncWithLocalStorage(headerFilters.stores);\r\n      this.filteredZones = this.syncWithLocalStorage(headerFilters.zoneName);\r\n      // Format date range if it exists\r\n      if (headerFilters.date) {\r\n        this.selectedDateRange = {\r\n          startDate: this.dayjs(\r\n            headerFilters.date.startDate,\r\n            \"YYYY-MM-DD\"\r\n          ).format(\"DD-MM-YYYY\"),\r\n          endDate: this.dayjs(headerFilters.date.endDate, \"YYYY-MM-DD\").format(\r\n            \"DD-MM-YYYY\"\r\n          ),\r\n        };\r\n      } else {\r\n        this.selectedDateRange = {\r\n          startDate: this.dayjs(\r\n            this.selectedDateRange.startDate,\r\n            \"YYYY-MM-DD\"\r\n          ).format(\"DD-MM-YYYY\"),\r\n          endDate: this.dayjs(\r\n            this.selectedDateRange.endDate,\r\n            \"YYYY-MM-DD\"\r\n          ).format(\"DD-MM-YYYY\"),\r\n        };\r\n      }\r\n      // console.log(\"3\")\r\n      // Emit data via service and update localStorage\r\n      this.emitAndStoreFilters();\r\n    } else {\r\n      // Initialize empty states if no header filters are present in localStorage\r\n      this.resetFilters();\r\n      // console.log(\"2\")\r\n    }\r\n  }\r\n  private syncWithLocalStorage(items: any[]): any[] {\r\n    return items\r\n      ? items.map((item: any) => ({\r\n          ...item,\r\n          checked: item.checked === true,\r\n        }))\r\n      : [];\r\n  }\r\n\r\n  private emitAndStoreFilters(): void {\r\n    this.gs.dataRangeValue.next(this.selectedFilters);\r\n    localStorage.setItem(\r\n      \"header-filters\",\r\n      JSON.stringify(this.selectedFilters)\r\n    );\r\n    // console.log(\"1\")\r\n  }\r\n\r\n  /**\r\n   * Reset selectedFilters and all related arrays to empty states\r\n   */\r\n  private resetFilters(): void {\r\n    this.selectedFilters = {\r\n      client: null,\r\n      clientName: \"\",\r\n      clients: [],\r\n      store: null,\r\n      date: {},\r\n      stores: [],\r\n      group: [],\r\n      location: [],\r\n      country: [],\r\n      zoneName: [],\r\n    };\r\n    this.filteredLocations = [];\r\n    this.filteredGroups = [];\r\n    this.filteredStores = [];\r\n    this.filteredCountries = [];\r\n    this.filteredZones = [];\r\n  }\r\n  getClient() {\r\n    this.auth.getClients().subscribe({\r\n      next: (e) => {\r\n        if (e) {\r\n          this.clientList = e.data.result;\r\n          const headerFilters: any = JSON.parse(\r\n            localStorage.getItem(\"header-filters\") || \"{}\"\r\n          );\r\n          if (headerFilters.client) {\r\n            this.clientList.find((obj: any) => {\r\n              if (obj.clientId === headerFilters.client) {\r\n                this.selectedClient = obj;\r\n              }\r\n            });\r\n            // const startDate = this.dayjs(headerFilters.date.startDate);\r\n            // const endDate = this.dayjs(headerFilters.date.endDate);\r\n            // const differenceInDays = endDate.diff(startDate, 'days');\r\n            // if (differenceInDays >= 90 && this.selectedClient?.trafficDateRange === 90) {\r\n            //   this.selectedDateRange = {\r\n            //     startDate: this.dayjs(headerFilters.date.startDate, \"YYYY-MM-DD\").subtract(-90, 'days').format(\"DD-MM-YYYY\"),\r\n            //     endDate: this.dayjs(headerFilters.date.endDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n            //   };\r\n            // } else {\r\n            //   this.selectedDateRange = {\r\n            //     startDate: this.dayjs(this.selectedDateRange.startDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n            //     endDate: this.dayjs(this.selectedDateRange.endDate, \"YYYY-MM-DD\").format(\"DD-MM-YYYY\"),\r\n            //   };\r\n            // }\r\n\r\n            this.selectedFilters.client = headerFilters.client;\r\n            this.selectedFilters.clientName = headerFilters.clientName;\r\n            this.selectedFilters.clients = [headerFilters.client];\r\n            this.selectedFilters.store = headerFilters.store;\r\n            this.selectedFilters.date = headerFilters.date;\r\n            this.selectedFilters.stores = headerFilters.stores;\r\n            this.selectedFilters.group = headerFilters.group;\r\n            this.selectedFilters.location = headerFilters.location;\r\n            this.selectedFilters.country = headerFilters.country;\r\n            this.selectedFilters.zoneName = headerFilters.zoneName;\r\n            this.gs.dataRangeValue.next(this.selectedFilters);\r\n            // console.log(\"2\")\r\n            // Ensure locations and groups are loaded before fetching stores\r\n            this.getCountry();\r\n            this.getLocations();\r\n            this.getGroups();\r\n            // Fetch stores only after locations and groups are set\r\n            this.getStore();\r\n          } else {\r\n            this.selectedClient = this.clientList[0];\r\n            this.selectedFilters.client = this.selectedClient.clientId;\r\n            this.selectedFilters.clientName = this.selectedClient.clientName;\r\n            this.selectedFilters.clients = [this.selectedClient.clientId];\r\n            this.selectedFilters.store = headerFilters.store;\r\n            this.selectedFilters.date = headerFilters.date;\r\n            this.selectedFilters.stores = headerFilters.stores;\r\n            this.selectedFilters.group = headerFilters.group;\r\n            this.selectedFilters.location = headerFilters.location;\r\n            this.selectedFilters.country = headerFilters.country;\r\n            this.selectedFilters.zoneName = headerFilters.zoneName;\r\n            localStorage.setItem(\r\n              \"header-filters\",\r\n              JSON.stringify(this.selectedFilters)\r\n            );\r\n            this.gs.dataRangeValue.next(this.selectedFilters);\r\n            // console.log(\"3\")\r\n            this.cd.detectChanges();\r\n            // Ensure locations and groups are loaded before fetching stores\r\n            this.getCountry();\r\n            this.getLocations();\r\n            this.getGroups();\r\n            // Fetch stores only after locations and groups are set\r\n            this.getStore();\r\n          }\r\n        } else {\r\n          this.selectedClient = this.clientList[0];\r\n          this.selectedFilters.client = this.selectedClient.clientId;\r\n          this.selectedFilters.clientName = this.selectedClient.clientName;\r\n          // Ensure locations and groups are loaded before fetching stores\r\n          this.getCountry();\r\n          this.getLocations();\r\n          this.getGroups();\r\n          // Fetch stores only after locations and groups are set\r\n          this.getStore();\r\n          this.getZone();\r\n          localStorage.setItem(\r\n            \"header-filters\",\r\n            JSON.stringify(this.selectedFilters)\r\n          );\r\n          this.gs.dataRangeValue.next(this.selectedFilters);\r\n          // console.log(\"4\")\r\n          this.cd.detectChanges();\r\n        }\r\n        this.getUserInfo(this.selectedFilters.client);\r\n      },\r\n    });\r\n  }\r\n  getUserInfo(client: any) {\r\n    let obj = {\r\n      clientId: client ? client : \"\",\r\n    };\r\n    if (client) {\r\n      this.auth.getHeaderUsers(obj).subscribe({\r\n        next: (e) => {\r\n          localStorage.setItem(\r\n            \"usersEmail-info\",\r\n            JSON.stringify(e?.data?.userEmailData || [])\r\n          );\r\n        },\r\n      });\r\n    }\r\n  }\r\n  onClientSelect(event: any): void {\r\n    // Update the selected client\r\n    this.selectedClient = event;\r\n    // Clear previous filtered data and selections\r\n    this.filteredGroups = [];\r\n    this.filteredStores = [];\r\n    this.filteredLocations = [];\r\n    this.selectedFilters.stores = [];\r\n    this.selectedFilters.group = [];\r\n    this.selectedFilters.location = [];\r\n    this.selectedFilters.country = [];\r\n    this.selectedFilters.zoneName = [];\r\n\r\n    // Fetch header filters from localStorage\r\n    const headerFilters: any = JSON.parse(\r\n      localStorage.getItem(\"header-filters\") || \"{}\"\r\n    );\r\n\r\n    // Update the selected filters with the new client\r\n    this.selectedFilters.client = this.selectedClient.clientId;\r\n    this.selectedFilters.clientName = this.selectedClient.clientName;\r\n\r\n    // Remove old store, group, and location data from the header filters\r\n    delete headerFilters.stores;\r\n    delete headerFilters.groups;\r\n    delete headerFilters.location;\r\n    delete headerFilters.country;\r\n    delete headerFilters.zoneName;\r\n\r\n    // Fetch new data based on the new client\r\n    this.getCountry();\r\n    this.getLocations();\r\n    this.getStore();\r\n    this.getGroups();\r\n\r\n    // Update localStorage with the new client selection and empty filter data\r\n    localStorage.setItem(\r\n      \"header-filters\",\r\n      JSON.stringify(this.selectedFilters)\r\n    );\r\n    window.location.reload();\r\n    // Emit data to the global service\r\n    // this.gs.dataRangeValue.next(this.selectedFilters);\r\n    // Trigger change detection to reflect UI changes\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  ranges: any = {\r\n    Today: [dayjs(), dayjs()],\r\n    Yesterday: [dayjs().subtract(1, \"days\"), dayjs().subtract(1, \"days\")],\r\n    \"This Week\": [dayjs().subtract(7, \"days\"), dayjs().subtract(1, \"days\")],\r\n    \"Last Week\": [\r\n      dayjs().subtract(14, \"days\").startOf(\"day\"),\r\n      dayjs().subtract(8, \"days\").endOf(\"day\"),\r\n    ],\r\n    \"This Month\": [dayjs().subtract(30, \"days\"), dayjs().subtract(1, \"days\")],\r\n    \"Last Month\": [\r\n      dayjs().subtract(1, \"month\").startOf(\"month\"),\r\n      dayjs().subtract(1, \"month\").endOf(\"month\"),\r\n    ],\r\n  };\r\n\r\n  onStartDateChange(event: any) {\r\n    if (this.dayjs(event.startDate).isValid()) {\r\n      if (this.selectedClient?.traxDateRange === 90) {\r\n        this.isCustomDate = (m: dayjs.Dayjs) => {\r\n          const isValidDate =\r\n            m > this.dayjs() || m > this.dayjs(event.startDate.add(90, \"days\"));\r\n          return isValidDate ? \"invalid-date\" : false;\r\n        };\r\n      } else {\r\n        this.isCustomDate = (m: dayjs.Dayjs) => {\r\n          const isValidDate =\r\n            m > this.dayjs() ||\r\n            m > this.dayjs(event.startDate.add(180, \"days\"));\r\n          return isValidDate ? \"invalid-date\" : false;\r\n        };\r\n      }\r\n    }\r\n  }\r\n\r\n  datechange(event: any) {\r\n    if (event && event.startDate && event.endDate) {\r\n      if (\r\n        this.dayjs(event.startDate).isValid() &&\r\n        this.dayjs(event.endDate).isValid()\r\n      ) {\r\n        this.selectedDateRange.startDate = event.startDate;\r\n        this.selectedDateRange.endDate = event.endDate;\r\n        var datetime = {\r\n          startDate: this.dayjs(event.startDate, \"DD-MM-YYYY\").format(\r\n            \"YYYY-MM-DD\"\r\n          ),\r\n          endDate: this.dayjs(event.endDate, \"DD-MM-YYYY\").format(\"YYYY-MM-DD\"),\r\n        };\r\n        this.selectedFilters.date = datetime;\r\n        localStorage.setItem(\r\n          \"header-filters\",\r\n          JSON.stringify(this.selectedFilters)\r\n        );\r\n        window.location.reload();\r\n        // this.gs.dataRangeValue.next(this.selectedFilters);\r\n      }\r\n    }\r\n  }\r\n  opendropdown(e: MouseEvent) {\r\n    e.stopPropagation();\r\n    this.Opendropdown = !this.Opendropdown;\r\n  }\r\n  getLocations(): void {\r\n    const country = this.countries\r\n      .filter((country) => country.checked)\r\n      .map((country) => country.country);\r\n    // const headerFilters: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"{}\");\r\n    let obj = {\r\n      clientId: this.selectedFilters.client\r\n        ? this.selectedFilters.client\r\n        : this.users.clientId,\r\n      country,\r\n      city: [],\r\n      group: [],\r\n    };\r\n    this.auth.getLocation(obj).subscribe({\r\n      next: (res: any) => {\r\n        let cityList = this.selectedFilters?.location\r\n          ?.filter((location: any) => location.checked)\r\n          .map((loc: any) => loc.city);\r\n        // Map the fetched locations with default unchecked state\r\n        this.locations = res?.data?.locationData.map((city: any) => ({\r\n          city: city.city,\r\n          // checked: cityList?.length ? cityList.includes(city.city) : true,\r\n          checked: cityList?.includes(city.city) ? true : false,\r\n        }));\r\n\r\n        // Sync the fetched locations with any stored checked values in localStorage\r\n        if (\r\n          this.selectedFilters.location &&\r\n          Array.isArray(this.selectedFilters.location)\r\n        ) {\r\n          this.filteredLocations = this.locations.map((location) => {\r\n            const matchedLocation = this.selectedFilters.location.find(\r\n              (loc: any) => loc.city === location.city\r\n            );\r\n            return matchedLocation\r\n              ? { ...location, checked: matchedLocation.checked }\r\n              : location;\r\n          });\r\n        } else {\r\n          this.filteredLocations = this.locations;\r\n        }\r\n\r\n        if (this.searchLocationText) {\r\n          this.filteredLocations = this.locations.filter((location: any) =>\r\n            location.city\r\n              .toLowerCase()\r\n              .includes(this.searchLocationText.toLowerCase())\r\n          );\r\n        }\r\n        const selectedLocations = this.locations\r\n          .filter((location) => location.checked)\r\n          .map((location) => location.city);\r\n        if (selectedLocations.length > 0) {\r\n          setTimeout(() => {\r\n            this.getGroups();\r\n            this.getStore(); // Fetch stores based on selected groups\r\n          }, 1000);\r\n        }\r\n\r\n        if (!selectedLocations.length && country.length) {\r\n          this.getGroups();\r\n        }\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch locations\", err);\r\n      },\r\n    });\r\n  }\r\n\r\n  isAllLocationsSelected(): boolean {\r\n    return this.filteredLocations.every((location) => location.checked);\r\n  }\r\n\r\n  selectedLocationsLabel(): string {\r\n    const selectedLocations = (this.locationLabel = this.searchLocationText\r\n      .length\r\n      ? this.locations\r\n          .filter((location) => location.checked)\r\n          .map((location) => location.city)\r\n      : this.filteredLocations\r\n          .filter((location) => location.checked)\r\n          .map((location) => location.city));\r\n    return selectedLocations.length === 0\r\n      ? \"\"\r\n      : selectedLocations.length === 1\r\n      ? selectedLocations[0]\r\n      : `${selectedLocations.length} Region`;\r\n  }\r\n\r\n  removeLocation(): void {\r\n    this.Reset();\r\n  }\r\n\r\n  getGroups(): void {\r\n    const country = this.countries\r\n      .filter((country) => country.checked)\r\n      .map((country) => country.country);\r\n    let city;\r\n    city = this.locations\r\n      .filter((location) => location.checked)\r\n      .map((location) => location.city);\r\n\r\n    if (!city.length && country.length) {\r\n      city = this.locations.map((loc) => loc.city);\r\n    }\r\n    const obj = {\r\n      country,\r\n      city,\r\n      clientId: this.selectedFilters.client\r\n        ? this.selectedFilters.client\r\n        : this.users.clientId,\r\n      group: [],\r\n    };\r\n    this.auth.getGroups(obj).subscribe({\r\n      next: (res: any) => {\r\n        let checkedGroup = this.selectedFilters?.group\r\n          ?.filter((group: any) => group.checked)\r\n          .map((group: any) => group.groupName);\r\n        const combinedGroups = res?.data?.groupData?.map((groupName: any) => ({\r\n          groupName: groupName.groupName,\r\n          checked: checkedGroup?.includes(groupName.groupName) ? true : false,\r\n          // checked: checkedGroup?.length ? checkedGroup.includes(groupName.groupName) : true,\r\n        }));\r\n        this.groupsData = combinedGroups;\r\n        if (this.searchGroupText.length) {\r\n          this.filteredGroups = combinedGroups.filter((item: any) =>\r\n            item.groupName.toLowerCase().includes(this.searchGroupText)\r\n          );\r\n        } else {\r\n          this.filteredGroups = combinedGroups;\r\n        }\r\n\r\n        // Auto-fetch stores when groups are selected\r\n        const selectedGroups = this.groupsData\r\n          .filter((group) => group.checked)\r\n          .map((group) => group.groupName);\r\n        if (selectedGroups.length > 0) {\r\n          setTimeout(() => {\r\n            this.getStore(); // Fetch stores based on selected groups\r\n          }, 1000);\r\n        }\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch groups\", err);\r\n      },\r\n    });\r\n  }\r\n\r\n  toggleDropdown(\r\n    type: \"country\" | \"location\" | \"group\" | \"store\" | \"zone\"\r\n  ): void {\r\n    if (this.dropdownOpen === type) {\r\n      // If the dropdown is open, close it and avoid resetting the selected values unnecessarily\r\n      this.dropdownOpen = null;\r\n    } else {\r\n      // Open the specific dropdown and handle data fetching only if necessary\r\n      this.dropdownOpen = type;\r\n\r\n      if (type === \"country\") {\r\n        // Fetch countries only if not already fetched and no search text exists\r\n        if (\r\n          (!this.filteredCountries || this.filteredCountries.length === 0) &&\r\n          !this.searchCountryText.trim()\r\n        ) {\r\n          this.getCountry();\r\n        }\r\n      }\r\n\r\n      if (type === \"group\") {\r\n        // Fetch groups only if there are selected cities and no active search text\r\n        const selectedCities = this.locations\r\n          .filter((location) => location.checked)\r\n          .map((location) => location.city);\r\n\r\n        // Fetch groups only if locations are selected, no search text exists, and dropdown is opened\r\n        if (\r\n          this.filteredLocations.length > 0 ||\r\n          (selectedCities.length > 0 && !this.searchGroupText.trim())\r\n        ) {\r\n          this.getGroups();\r\n        } else {\r\n          this.filteredGroups = []; // Clear groups if no locations are selected\r\n        }\r\n      }\r\n\r\n      if (type === \"store\") {\r\n        // Fetch stores only if not already fetched and no search text is active\r\n        if (\r\n          (!this.filteredStores || this.filteredStores.length === 0) &&\r\n          !this.searchStoreText.trim()\r\n        ) {\r\n          this.getStore();\r\n        }\r\n      }\r\n\r\n      if (type === \"zone\") {\r\n        // Fetch stores only if not already fetched and no search text is active\r\n        if (\r\n          (!this.filteredZones || this.filteredZones.length === 0) &&\r\n          !this.searchZoneText.trim()\r\n        ) {\r\n          this.getZone();\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  handleGroupDropdownClick(): void {\r\n    if (this.dropdownOpen === \"group\") {\r\n      this.resetSelectedGroups();\r\n    }\r\n    this.toggleDropdown(\"group\");\r\n  }\r\n\r\n  resetSelectedGroups(): void {\r\n    this.filteredGroups.forEach((group) => (group.checked = false));\r\n    this.searchGroupText = \"\";\r\n  }\r\n  selectedGroupsLabel(): string {\r\n    const selectedGroups = (this.groupLabel = this.searchGroupText.length\r\n      ? this.groupsData.filter((group) => group.checked)\r\n      : this.filteredGroups.filter((group) => group.checked));\r\n    return selectedGroups.length === 0\r\n      ? \"\"\r\n      : selectedGroups.length === 1\r\n      ? selectedGroups[0].groupName\r\n      : `${selectedGroups.length} Clusters`;\r\n  }\r\n  removeGroup(): void {\r\n    this.Reset();\r\n  }\r\n\r\n  isAllGroupsSelected(): boolean {\r\n    return this.filteredGroups.length\r\n      ? this.filteredGroups.every((group) => group.checked)\r\n      : false;\r\n  }\r\n\r\n  getStore(): void {\r\n    const country = this.countries\r\n      .filter((country) => country.checked)\r\n      .map((country) => country.country);\r\n    const city = this.locations\r\n      .filter((location) => location.checked)\r\n      .map((location) => location.city);\r\n    const group = this.groupsData\r\n      .filter((group) => group.checked)\r\n      .map((group) => group.groupName);\r\n\r\n    const data = {\r\n      country,\r\n      city,\r\n      clusters: group,\r\n      clientId: this.users.clientId || this.selectedFilters.client,\r\n    };\r\n\r\n    this.auth.getHeaderStores(data).subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code === 200) {\r\n          // Initialize stores from API response\r\n          this.stores = res.data.storesData;\r\n          // Check if there are previously selected stores\r\n          const checkedStoreIds = this.selectedFilters?.stores\r\n            ? this.selectedFilters.stores\r\n                .filter((store: any) => store.checked)\r\n                .map((store: any) => store.storeId)\r\n            : [];\r\n          // Sync the `checked` state\r\n          this.stores.forEach((store) => {\r\n            store.checked = checkedStoreIds.length\r\n              ? checkedStoreIds.includes(store.storeId) // Use previous selection\r\n              : true; // Default to true if no previous selection\r\n          });\r\n\r\n          // Apply search filter if search text is present\r\n          if (this.searchStoreText.length) {\r\n            this.filteredStores = this.stores.filter((store) =>\r\n              store.storeName\r\n                .toLowerCase()\r\n                .includes(this.searchStoreText.toLowerCase())\r\n            );\r\n          } else {\r\n            this.filteredStores = [...this.stores];\r\n          }\r\n\r\n          // Update `selectedFilters.stores` to reflect the current state\r\n          this.selectedFilters.stores = this.filteredStores.map((store) => ({\r\n            storeId: store.storeId,\r\n            storeName: store.storeName,\r\n            checked: store.checked,\r\n          }));\r\n          // this.selectedFilters.country = country;\r\n\r\n          // Save updated filters to localStorage\r\n          localStorage.setItem(\r\n            \"header-filters\",\r\n            JSON.stringify(this.selectedFilters)\r\n          );\r\n          this.getZone();\r\n          // Trigger UI change detection\r\n          this.cd.detectChanges();\r\n        } else {\r\n          // Handle empty or error response\r\n          this.clearStoresState();\r\n        }\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch stores\", err);\r\n        this.clearStoresState();\r\n      },\r\n    });\r\n  }\r\n\r\n  getZone() {\r\n    const country = this.countries\r\n      .filter((country) => country.checked)\r\n      .map((country) => country.country);\r\n\r\n    const city = this.locations\r\n      .filter((location) => location.checked)\r\n      .map((location) => location.city);\r\n\r\n    const group = this.groupsData\r\n      .filter((group) => group.checked)\r\n      .map((group) => group.groupName);\r\n\r\n    const storeId = this.filteredStores\r\n      .filter((group) => group.checked)\r\n      .map((group) => group.storeId);\r\n\r\n    const data = {\r\n      country,\r\n      city,\r\n      clusters: group,\r\n      clientId: this.users.clientId || this.selectedFilters.client,\r\n      storeId: storeId,\r\n    };\r\n\r\n    this.auth.getHeaderZone(data).subscribe({\r\n      next: (res: any) => {\r\n        if (res && res.code === 200) {\r\n          // Initialize zones with Overall Store first, unchecked by default\r\n          this.zones = [\r\n            { _id: \"overall\", tagName: \"Overall Store\", checked: false },\r\n            ...(res?.data?.zoneData?.map((zone: any) => ({\r\n              _id: zone._id,\r\n              tagName: zone.tagName,\r\n              checked: false, // initialize unchecked; will update below\r\n            })) || []),\r\n          ];\r\n\r\n          // Get previously selected zone IDs (checked ones)\r\n          const checkedStoreIds = this.selectedFilters?.zoneName\r\n            ? this.selectedFilters.zoneName\r\n                .filter((zone: any) => zone.checked)\r\n                .map((zone: any) => zone._id)\r\n            : [];\r\n\r\n          // Sync checked state with previous selections or default:\r\n          // If no previous selection, Overall Store unchecked, others checked\r\n          this.zones.forEach((zone) => {\r\n            if (checkedStoreIds.length) {\r\n              zone.checked = checkedStoreIds.includes(zone._id);\r\n            } else {\r\n              zone.checked = zone._id !== \"overall\";\r\n            }\r\n          });\r\n\r\n          // Apply search filter if any\r\n          if (this.searchZoneText.length) {\r\n            this.filteredZones = this.zones.filter((zone) =>\r\n              zone.tagName\r\n                .toLowerCase()\r\n                .includes(this.searchZoneText.toLowerCase())\r\n            );\r\n          } else {\r\n            this.filteredZones = [...this.zones];\r\n          }\r\n\r\n          // Update selectedFilters.zoneName with current checked states\r\n          this.selectedFilters.zoneName = this.filteredZones.map((zone) => ({\r\n            _id: zone._id,\r\n            tagName: zone.tagName,\r\n            checked: zone.checked,\r\n          }));\r\n\r\n          // Save updated filters to localStorage\r\n          localStorage.setItem(\r\n            \"header-filters\",\r\n            JSON.stringify(this.selectedFilters)\r\n          );\r\n\r\n          // Trigger change detection if needed\r\n          this.cd.detectChanges();\r\n        } else {\r\n          this.clearZoneState();\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        console.error(\"Failed to fetch zones\", err);\r\n        this.clearZoneState();\r\n      },\r\n    });\r\n  }\r\n\r\n  private clearZoneState(): void {\r\n    this.zones = [];\r\n    this.filteredZones = [];\r\n    this.selectedFilters.zonename = [];\r\n    localStorage.setItem(\r\n      \"header-filters\",\r\n      JSON.stringify(this.selectedFilters)\r\n    );\r\n  }\r\n  // Clear stores state and reset filters\r\n  private clearStoresState(): void {\r\n    this.stores = [];\r\n    this.filteredStores = [];\r\n    this.selectedFilters.stores = [];\r\n    localStorage.setItem(\r\n      \"header-filters\",\r\n      JSON.stringify(this.selectedFilters)\r\n    );\r\n  }\r\n\r\n  resetSelectedStores(): void {\r\n    this.filteredStores.forEach((store) => (store.checked = false));\r\n    this.searchStoreText = \"\";\r\n  }\r\n\r\n  selectedStoresLabel(): string {\r\n    const selectedStores = this.searchStoreText.length\r\n      ? this.stores.filter((store) => store.checked)\r\n      : this.filteredStores.filter((store) => store.checked);\r\n    return selectedStores.length === 0\r\n      ? \"0 Stores\"\r\n      : selectedStores.length === 1\r\n      ? selectedStores[0].storeName\r\n      : `${selectedStores.length} Stores`;\r\n  }\r\n\r\n  selectedZonesLabel(): string {\r\n    const selectedStores = this.searchZoneText.length\r\n      ? this.zones.filter((zone) => zone.checked)\r\n      : this.filteredZones.filter((zone) => zone.checked);\r\n    return selectedStores.length === 0\r\n      ? \"0 Zones\"\r\n      : selectedStores.length === 1\r\n      ? selectedStores[0].tagName\r\n      : `${selectedStores.length} Zones`;\r\n  }\r\n\r\n  isAllStoresSelected(): boolean {\r\n    return (\r\n      this.filteredStores.length > 0 &&\r\n      this.filteredStores.every((store) => store.checked)\r\n    );\r\n  }\r\n  isAllZonesSelected(): boolean {\r\n    return this.filteredZones\r\n      .filter((zone) => zone._id !== \"overall\")\r\n      .every((zone) => zone.checked);\r\n  }\r\n\r\n  // Method to handle dropdown item selection\r\n  updateSelectedStores(): void {\r\n    this.filteredStores.forEach((store) => {\r\n      const filteredStore = this.stores.findIndex(\r\n        (fStore) => fStore.storeId === store.storeId\r\n      );\r\n      if (filteredStore != -1) {\r\n        this.stores[filteredStore].checked = store.checked; // Sync the checked state with full store list\r\n      }\r\n    });\r\n    // Update selectedFilters based on the current store selection\r\n    this.selectedFilters.stores = this.stores.filter((store) => store.checked);\r\n\r\n    // Update localStorage with the latest selection\r\n    localStorage.setItem(\r\n      \"header-filters\",\r\n      JSON.stringify(this.selectedFilters)\r\n    );\r\n\r\n    // Emit updated filters via service\r\n    // this.gs.dataRangeValue.next(this.selectedFilters);\r\n\r\n    // Trigger change detection if necessary\r\n    if (this.selectedFilters.stores.length > 0) this.getZone();\r\n    else this.zones = [];\r\n    this.filteredZones = [];\r\n    this.selectedFilters.zoneName = [];\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  updateSelectedZones(clickedZoneId: string): void {\r\n    this.filteredZones.forEach((zone) => {\r\n      const index = this.zones.findIndex((z) => z._id === zone._id);\r\n      if (index !== -1) {\r\n        this.zones[index].checked = zone.checked;\r\n      }\r\n    });\r\n\r\n    const overallZone = this.zones.find((z) => z._id === \"overall\");\r\n    const overallChecked = overallZone?.checked ?? false;\r\n    const othersSelected = this.zones.some(\r\n      (z) => z._id !== \"overall\" && z.checked\r\n    );\r\n\r\n    if (clickedZoneId === \"overall\" && overallChecked) {\r\n      this.zones = this.zones.map((z) => ({\r\n        ...z,\r\n        checked: z._id === \"overall\",\r\n      }));\r\n    }\r\n    if (clickedZoneId !== \"overall\" && overallChecked) {\r\n      if (overallZone) {\r\n        overallZone.checked = false;\r\n      }\r\n    }\r\n    this.filteredZones = [...this.zones];\r\n    this.selectedFilters.zoneName = this.zones.filter((z) => z.checked);\r\n    localStorage.setItem(\r\n      \"header-filters\",\r\n      JSON.stringify(this.selectedFilters)\r\n    );\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  toggleSelectAllLocations(event: any): void {\r\n    const isChecked = event.target.checked;\r\n    this.filteredLocations.forEach(\r\n      (location) => (location.checked = isChecked)\r\n    );\r\n    this.updateSelectedLocations();\r\n  }\r\n\r\n  toggleSelectAllStores(event: Event): void {\r\n    const checked = (event.target as HTMLInputElement).checked;\r\n\r\n    // Apply the selection to both filtered and full list of stores\r\n    this.filteredStores.forEach((store) => (store.checked = checked));\r\n    this.stores.forEach((store) => {\r\n      const filteredStore = this.filteredStores.find(\r\n        (fStore) => fStore.storeId === store.storeId\r\n      );\r\n      if (filteredStore) {\r\n        store.checked = checked; // Sync the checked state with full store list\r\n      }\r\n    });\r\n\r\n    // Update the selected stores and persist the selection\r\n    this.updateSelectedStores();\r\n  }\r\n\r\n  toggleSelectAllZones(event: Event): void {\r\n    const checked = (event.target as HTMLInputElement).checked;\r\n    this.filteredZones.forEach((zone) => {\r\n      if (zone._id !== \"overall\") {\r\n        zone.checked = checked;\r\n      } else {\r\n        zone.checked = false;\r\n      }\r\n    });\r\n    this.zones.forEach((zone) => {\r\n      const match = this.filteredZones.find((fz) => fz._id === zone._id);\r\n      if (match) {\r\n        zone.checked = match.checked;\r\n      }\r\n    });\r\n    // Since this is bulk, pass a dummy value — any non-overall zone is fine\r\n    const anySelectedZone = this.filteredZones.find((z) => z._id !== \"overall\");\r\n    const clickedId = anySelectedZone ? anySelectedZone._id : \"\";\r\n    this.updateSelectedZones(clickedId);\r\n  }\r\n\r\n  updateSelectedLocations(): void {\r\n    // When locations are selected, fetch the related groups\r\n    const selectedCities = this.filteredLocations\r\n      .filter((location) => location.checked)\r\n      .map((location) => location.city);\r\n    this.filteredLocations.forEach((location: any) => {\r\n      let findLocationIndex = this.locations.findIndex(\r\n        (loc: any) => loc.city == location.city\r\n      );\r\n      if (findLocationIndex != -1) {\r\n        this.locations[findLocationIndex].checked = location.checked;\r\n      }\r\n    });\r\n    if (selectedCities.length > 0 || !selectedCities.length) {\r\n      this.selectedFilters.stores = [];\r\n      this.groupsData = [];\r\n      this.getGroups(); // Fetch groups based on selected cities\r\n      // If there are selected groups, fetch the stores based on selected groups\r\n      this.getStore();\r\n      this.selectedFilters.location = this.locations;\r\n    } else {\r\n      this.filteredGroups = []; // Clear groups if no locations are selected\r\n      this.selectedFilters.location = [];\r\n    }\r\n\r\n    this.selectedFilters.group = [];\r\n    this.filteredStores = []; // Reset stores as well\r\n    this.searchGroupText = \"\";\r\n    this.searchStoreText = \"\";\r\n    // this.Opendropdown = false;\r\n  }\r\n\r\n  toggleSelectAllGroups(event: any): void {\r\n    const isChecked = event.target.checked;\r\n    this.filteredGroups.forEach((group) => (group.checked = isChecked));\r\n    this.updateSelectedGroups();\r\n  }\r\n\r\n  updateSelectedGroups(): void {\r\n    // Fetch the relevant stores after groups are selected\r\n    const selectedGroups = this.filteredGroups\r\n      .filter((group) => group.checked)\r\n      .map((group) => group.groupName);\r\n\r\n    this.filteredGroups.forEach((group: any) => {\r\n      let findGroupIndex = this.groupsData.findIndex(\r\n        (item: any) => item.groupName == group.groupName\r\n      );\r\n      if (findGroupIndex != -1) {\r\n        this.groupsData[findGroupIndex].checked = group.checked;\r\n      }\r\n    });\r\n    if (selectedGroups.length > 0 || !selectedGroups.length) {\r\n      this.selectedFilters.stores = [];\r\n      // If there are selected groups, fetch the stores based on selected groups\r\n      this.getStore();\r\n      this.selectedFilters.group = this.groupsData;\r\n    } else {\r\n      // If no groups are selected, clear the stores list\r\n      this.filteredStores = [];\r\n\r\n      // Also, update localStorage to reflect the cleared store selection\r\n      this.selectedFilters.stores = [];\r\n      localStorage.setItem(\r\n        \"header-filters\",\r\n        JSON.stringify(this.selectedFilters)\r\n      );\r\n\r\n      // Emit data via service\r\n      // this.gs.dataRangeValue.next(this.selectedFilters);\r\n    }\r\n\r\n    // Clear the search store text when groups are updated\r\n    this.searchStoreText = \"\";\r\n  }\r\n\r\n  Reset(): void {\r\n    setTimeout(() => {\r\n      this.filteredCountries = [];\r\n      this.filteredGroups = [];\r\n      this.filteredStores = [];\r\n      this.filteredLocations = [];\r\n      this.locations = [];\r\n      this.groupsData = [];\r\n      this.stores = [];\r\n      this.filteredZones = [];\r\n      this.zones = [];\r\n      this.countries = [];\r\n      this.searchLocationText = \"\";\r\n      this.searchGroupText = \"\";\r\n      this.searchStoreText = \"\";\r\n      this.selectedFilters.stores = [];\r\n      this.selectedFilters.group = [];\r\n      this.selectedFilters.location = [];\r\n      this.selectedFilters.country = [];\r\n      this.selectedFilters.zoneName = [];\r\n\r\n      this.getCountry();\r\n      this.getLocations();\r\n      this.getStore();\r\n      this.getGroups();\r\n\r\n      localStorage.setItem(\r\n        \"header-filters\",\r\n        JSON.stringify(this.selectedFilters)\r\n      );\r\n      window.location.reload();\r\n      // this.gs.dataRangeValue.next(this.selectedFilters);\r\n      this.cd.detectChanges();\r\n\r\n      this.Opendropdown = false;\r\n    }, 100);\r\n  }\r\n\r\n  filterLocations(): void {\r\n    const searchText = this.searchLocationText.toLowerCase();\r\n\r\n    if (searchText) {\r\n      // Preserve the checked state during filtering\r\n      this.filteredLocations = this.locations\r\n        .map((location) => ({\r\n          ...location,\r\n          checked:\r\n            this.filteredLocations.find((l) => l.city === location.city)\r\n              ?.checked || false,\r\n        }))\r\n        .filter((location) =>\r\n          location?.city?.toLowerCase().includes(searchText)\r\n        );\r\n    } else {\r\n      // Restore the original checked state when search text is cleared\r\n      this.filteredLocations = this.locations.map((location) => ({\r\n        ...location,\r\n        checked:\r\n          this.selectedFilters.location.find(\r\n            (l: any) => l.city === location.city\r\n          )?.checked || false,\r\n      }));\r\n    }\r\n  }\r\n\r\n  filterGroups(): void {\r\n    const searchText = this.searchGroupText.toLowerCase();\r\n\r\n    if (searchText) {\r\n      // Preserve the checked state during filtering\r\n      this.filteredGroups = this.groupsData\r\n        .map((group) => ({\r\n          ...group,\r\n          checked:\r\n            this.filteredGroups.find((g) => g.groupName === group.groupName)\r\n              ?.checked || false,\r\n        }))\r\n        .filter((group) =>\r\n          group?.groupName?.toLowerCase().includes(searchText)\r\n        );\r\n    } else {\r\n      // Restore the original checked state when search text is cleared\r\n      this.filteredGroups = this.groupsData.map((group) => ({\r\n        ...group,\r\n        checked:\r\n          this.selectedFilters.group.find(\r\n            (g: any) => g.groupName === group.groupName\r\n          )?.checked || false,\r\n      }));\r\n    }\r\n  }\r\n\r\n  filterStores(): void {\r\n    const searchText = this.searchStoreText.toLowerCase();\r\n    // Preserve checked states during filtering\r\n    if (searchText) {\r\n      // Filter based on search text while preserving checked state\r\n      this.filteredStores = this.stores\r\n        .map((store) => ({\r\n          ...store,\r\n          // Check if the store is already checked in filteredStores, fallback to original stores' checked state\r\n          checked:\r\n            this.selectedFilters.stores.find(\r\n              (s: any) => s.storeId === store.storeId\r\n            )?.checked ||\r\n            store.checked ||\r\n            false,\r\n        }))\r\n        .filter((store) => store.storeName.toLowerCase().includes(searchText));\r\n    } else {\r\n      // When the search text is cleared, restore the original list with preserved checked states\r\n      this.filteredStores = this.stores.map((store) => ({\r\n        ...store,\r\n        // Preserve the checked state based on the selected filters\r\n        checked:\r\n          this.selectedFilters.stores.find(\r\n            (s: any) => s.storeId === store.storeId\r\n          )?.checked ||\r\n          store.checked ||\r\n          false,\r\n      }));\r\n    }\r\n  }\r\n\r\n  filterZones(): void {\r\n    const searchText = this.searchZoneText.toLowerCase();\r\n    // Preserve checked states during filtering\r\n    if (searchText) {\r\n      // Filter based on search text while preserving checked state\r\n      this.filteredZones = this.zones\r\n        .map((zone) => ({\r\n          ...zone,\r\n          // Check if the store is already checked in filteredStores, fallback to original stores' checked state\r\n          checked:\r\n            this.selectedFilters.zoneName.find((s: any) => s._id === zone._id)\r\n              ?.checked ||\r\n            zone.checked ||\r\n            false,\r\n        }))\r\n        .filter((zone) => zone.tagName.toLowerCase().includes(searchText));\r\n    } else {\r\n      // When the search text is cleared, restore the original list with preserved checked states\r\n      this.filteredZones = this.zones.map((zone) => ({\r\n        ...zone,\r\n        // Preserve the checked state based on the selected filters\r\n        checked:\r\n          this.selectedFilters.zoneName.find((s: any) => s._id === zone._id)\r\n            ?.checked ||\r\n          zone.checked ||\r\n          false,\r\n      }));\r\n    }\r\n  }\r\n\r\n  closeDropdown(): void {\r\n    this.dropdownOpen = null;\r\n  }\r\n\r\n  @HostListener(\"document:click\", [\"$event\"])\r\n  clickOutside(event: MouseEvent): void {\r\n    const clickedInside = (event.target as HTMLElement).closest(\r\n      \".dropdown-container\"\r\n    );\r\n    const clickedoutSide = (event.target as HTMLElement).closest(\".dropdown2\");\r\n    if (!clickedInside) {\r\n      this.closeDropdown();\r\n    }\r\n    if (!clickedoutSide) {\r\n      this.closeDropdown1();\r\n    }\r\n  }\r\n\r\n  // getCountry(): void {\r\n  //   // const headerFilters: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"{}\");\r\n  //   let obj ={\r\n  //    clientId: this.selectedFilters.client ? this.selectedFilters.client :this.users.clientId,\r\n  //   }\r\n  //   this.auth.getCountry(obj).subscribe({\r\n  //     next: (res: any) => {\r\n  //       let countryList = this.selectedFilters?.country?.filter((country:any) => country.checked).map((loc:any) => loc.allCountry);\r\n  //       // Map the fetched countries with default unchecked state\r\n  //       this.countires = res?.data?.countryData.map((allCountry: any) => ({\r\n  //         allCountry: allCountry.allCountry,\r\n  //         checked: countryList?.includes(allCountry.allCountry) ? true : false,\r\n  //       }));\r\n\r\n  //       // Sync the fetched countries with any stored checked values in localStorage\r\n  //       if (this.selectedFilters.country && Array.isArray(this.selectedFilters.country)) {\r\n  //         this.filteredCountries = this.countries.map(country => {\r\n  //           const matchedLocation = this.selectedFilters.country.find((loc: any) => loc.allCountry === country.allCountry);\r\n  //           return matchedLocation ? { ...country, checked: matchedLocation.checked } : country;\r\n  //         });\r\n  //       } else {\r\n  //         this.filteredCountries = this.countries;\r\n  //       }\r\n\r\n  //       if(this.searchLocationText) {\r\n  //         this.filteredCountries = this.countries.filter((country:any) => country.city.toLowerCase().includes(this.searchLocationText.toLowerCase()))\r\n  //       }\r\n  //       const selectedCountries = this.countries.filter((country) => country.checked).map((country) => country.allCountry);\r\n  //       if (selectedCountries.length > 0) {\r\n  //         setTimeout(()=>{\r\n  //           this.getStore(); // Fetch stores based on selected groups\r\n  //         },1000)\r\n  //       }\r\n  //     },\r\n  //     error: (err) => {\r\n  //       console.error(\"Failed to fetch countries\", err);\r\n  //     },\r\n  //   });\r\n  // }\r\n\r\n  // selectedCountriesLabel(): string {\r\n  //   const selectedCountries = this.countryLabel = this.searchLocationText.length ? this.countries\r\n  //     .filter(country => country.checked).map(country => country.allCountry) :  this.filteredCountries\r\n  //     .filter(country => country.checked).map(country => country.allCountry);\r\n  //   return selectedCountries.length === 0\r\n  //     ? ''\r\n  //     : selectedCountries.length === 1\r\n  //     ? selectedCountries[0]\r\n  //     : `${selectedCountries.length} countries`;\r\n  // }\r\n\r\n  // isAllCountriesSelected(): boolean {\r\n  //   return this.filteredCountries.every(country => country.checked);\r\n\r\n  // }\r\n  // filterCountries(): void {\r\n  //   const searchText = this.searchCountryText.toLowerCase();\r\n\r\n  //   if (searchText) {\r\n  //     // Preserve the checked state during filtering\r\n  //     this.filteredCountries = this.countires\r\n  //       .map(country => ({\r\n  //         ...country,\r\n  //         checked: this.filteredCountries.find(l => l.allCountry === country.allCountry)?.checked || false\r\n  //       }))\r\n  //       .filter(location =>\r\n  //         location?.allCountry?.toLowerCase().includes(searchText)\r\n  //       );\r\n  //   } else {\r\n  //     // Restore the original checked state when search text is cleared\r\n  //     this.filteredCountries = this.countires.map(country => ({\r\n  //       ...country,\r\n  //       checked: this.selectedFilters.country.find((l:any) => l.allCountry === country.allCountry)?.checked || false\r\n  //     }));\r\n  //   }\r\n  // }\r\n\r\n  getCountry(): void {\r\n    let obj = {\r\n      clientId: this.selectedFilters.client\r\n        ? this.selectedFilters.client\r\n        : this.users.clientId,\r\n    };\r\n\r\n    this.auth.getCountry(obj).subscribe({\r\n      next: (res: any) => {\r\n        // Extract selected countries from existing filters (if any)\r\n        let countryList = this.selectedFilters?.country\r\n          ?.filter((country: any) => country.checked)\r\n          .map((loc: any) => loc.country);\r\n\r\n        // Map API response to frontend model\r\n        this.countries = res?.data?.countryData.map((item: any) => ({\r\n          country: item.country,\r\n          // checked: countryList?.length ? countryList.includes(item.country) : true,\r\n          // checked: cityList?.length ? cityList.includes(city.city) : true,\r\n          checked: countryList?.includes(item.country) ? true : false,\r\n        }));\r\n        if (\r\n          this.selectedFilters.country &&\r\n          Array.isArray(this.selectedFilters.country)\r\n        ) {\r\n          this.filteredCountries = this.countries.map((location) => {\r\n            const matchedLocation = this.selectedFilters.country.find(\r\n              (loc: any) => loc.country === location.country\r\n            );\r\n            return matchedLocation\r\n              ? { ...location, checked: matchedLocation.checked }\r\n              : location;\r\n          });\r\n        } else {\r\n          this.filteredCountries = this.countries;\r\n        }\r\n\r\n        // Initially, all countries are visible\r\n        this.filteredCountries = [...this.countries];\r\n\r\n        // If a search text already exists, filter immediately\r\n        if (this.searchCountryText) {\r\n          this.filterCountries();\r\n        }\r\n\r\n        // Fetch stores if at least one country is selected\r\n        let selectedCountries = this.countries.filter(\r\n          (country) => country.checked\r\n        );\r\n        if (selectedCountries.length > 0) {\r\n          setTimeout(() => {\r\n            this.getLocations();\r\n            this.getStore(); // fetch stores\r\n          }, 1000);\r\n        }\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch countries\", err);\r\n      },\r\n    });\r\n  }\r\n\r\n  selectedCountriesLabel(): string {\r\n    const selectedCountries = this.searchCountryText.length\r\n      ? this.filteredCountries\r\n          .filter((country) => country.checked)\r\n          .map((country) => country.country)\r\n      : this.countries\r\n          .filter((country) => country.checked)\r\n          .map((country) => country.country);\r\n\r\n    return selectedCountries.length === 0\r\n      ? \"\"\r\n      : selectedCountries.length === 1\r\n      ? selectedCountries[0]\r\n      : `${selectedCountries.length} countries`;\r\n  }\r\n\r\n  filterCountries(): void {\r\n    const searchText = this.searchCountryText.toLowerCase();\r\n\r\n    if (searchText) {\r\n      // Filter and preserve checked state\r\n      this.filteredCountries = this.countries\r\n        .map((country) => ({\r\n          ...country,\r\n          checked:\r\n            this.filteredCountries.find((c) => c.country === country.country)\r\n              ?.checked || false,\r\n        }))\r\n        .filter((country) =>\r\n          country.country.toLowerCase().includes(searchText)\r\n        );\r\n    } else {\r\n      // Reset to full list\r\n      this.filteredCountries = this.countries.map((country: Country) => ({\r\n        ...country,\r\n        checked:\r\n          this.selectedFilters.country?.find(\r\n            (c: any) => c.country === country.country\r\n          )?.checked || false,\r\n      }));\r\n    }\r\n  }\r\n\r\n  isAllCountriesSelected(): boolean {\r\n    return (\r\n      this.filteredCountries.length > 0 &&\r\n      this.filteredCountries.every((country) => country.checked)\r\n    );\r\n  }\r\n  toggleSelectAllCountries(event: any): void {\r\n    const isChecked = event.target.checked;\r\n    this.filteredCountries.forEach((country) => (country.checked = isChecked));\r\n    this.updateSelectedCountries();\r\n  }\r\n\r\n  updateSelectedCountries(): void {\r\n    // When locations are selected, fetch the related groups\r\n    const selectedCountries = this.filteredCountries\r\n      .filter((country) => country.checked)\r\n      .map((country) => country.country);\r\n    this.filteredCountries.forEach((country: any) => {\r\n      let findCountryIndex = this.countries.findIndex(\r\n        (loc: any) => loc.country == country.country\r\n      );\r\n      if (findCountryIndex != -1) {\r\n        this.countries[findCountryIndex].checked = country.checked;\r\n      }\r\n    });\r\n    if (selectedCountries.length > 0 || !selectedCountries.length) {\r\n      this.selectedFilters.stores = [];\r\n      this.groupsData = [];\r\n      this.locations = [];\r\n      this.selectedFilters.zoneName = [];\r\n      this.getLocations();\r\n      this.getGroups(); // Fetch groups based on selected cities\r\n      // If there are selected groups, fetch the stores based on selected groups\r\n      this.getStore();\r\n      this.getZone();\r\n      this.selectedFilters.country = this.filteredCountries;\r\n    } else {\r\n      this.filteredGroups = []; // Clear groups if no locations are selected\r\n      this.selectedFilters.country = [];\r\n    }\r\n\r\n    this.selectedFilters.group = [];\r\n    this.filteredStores = []; // Reset stores as well\r\n    this.filteredZones = [];\r\n    this.searchGroupText = \"\";\r\n    this.searchStoreText = \"\";\r\n    // this.Opendropdown = false;\r\n  }\r\n\r\n  removeCountry(): void {\r\n    this.Reset();\r\n  }\r\n\r\n  Apply(): void {\r\n    // Close the dropdown\r\n    this.Opendropdown = false;\r\n\r\n    // Fetch existing filters from localStorage\r\n    const headerFilters: any = JSON.parse(\r\n      localStorage.getItem(\"header-filters\") || \"{}\"\r\n    );\r\n    this.selectedFilters.store = null;\r\n\r\n    // Ensure current selections are reflected\r\n    this.selectedFilters.country = this.filteredCountries;\r\n    this.selectedFilters.location = this.locations;\r\n    this.selectedFilters.group = this.groupsData;\r\n    this.selectedFilters.stores = headerFilters.stores\r\n      ? headerFilters.stores\r\n      : this.stores;\r\n    this.selectedFilters.zoneName = headerFilters.zoneName\r\n      ? headerFilters.zoneName\r\n      : this.zones;\r\n    // this.selectedFilters.zoneName = this.filteredZones;\r\n    // Store updated filters back in localStorage\r\n    localStorage.setItem(\r\n      \"header-filters\",\r\n      JSON.stringify(this.selectedFilters)\r\n    );\r\n    // this.gs.dataRangeValue.next(this.selectedFilters);\r\n    window.location.reload();\r\n    // Emit the updated filters via the service\r\n    // this.gs.dataRangeValue.next(this.selectedFilters);\r\n    // Trigger refresh if necessary\r\n    // this.gs.manageRefreshTrigger.next(true);\r\n    this.cd.detectChanges();\r\n  }\r\n}\r\ninterface City {\r\n  city: string;\r\n}\r\n\r\ninterface Location {\r\n  city: City;\r\n  checked: boolean;\r\n}\r\ninterface Country {\r\n  country: string;\r\n  checked: boolean;\r\n}\r\n\r\n","<div class=\"me-3\">\r\n    <label *ngIf=\"selectedCountriesLabel()\" class=\"badge badge-light-default mx-2\">{{selectedCountriesLabel()}} \r\n        <span class=\"cursor-pointer\" (click)=\"removeCountry()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n        <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n        </svg></span>\r\n    </label>\r\n    <label *ngIf=\"selectedLocationsLabel()\" class=\"badge badge-light-default mx-2\">{{selectedLocationsLabel()}} \r\n        <span class=\"cursor-pointer\" (click)=\"removeLocation()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n        <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n        </svg></span>\r\n    </label>\r\n    <label *ngIf=\"selectedGroupsLabel()\"  class=\"badge badge-light-default mx-2\">{{selectedGroupsLabel()}} \r\n        <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n        <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n        </svg></span>\r\n    </label>\r\n    <label  class=\"badge badge-light-default\">{{selectedStoresLabel()}}</label>\r\n      <label class=\"badge badge-light-default mx-2\">{{selectedZonesLabel()}} \r\n        <!-- <span class=\"cursor-pointer\" (click)=\"removeGroup()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\r\n        <path d=\"M9 3L3 9M3 3L9 9\" stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n        </svg></span> -->\r\n    </label>\r\n</div>\r\n\r\n\r\n<div class=\"wrapper me-3\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\">\r\n<lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n(selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n</div>\r\n<div class=\"d-flex align-items-center position-relative my-1\">\r\n    <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n            <path\r\n                d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n                stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n        </svg>\r\n    </span>\r\n    <input class=\"fx-date-range form-control ps-14\" style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n        ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [autoApply]=\"true\"\r\n        [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\"\r\n        [(ngModel)]=\"selectedDateRange\" (startDateChanged)=\"onStartDateChange($event)\" [isCustomDate]=\"isCustomDate\"\r\n        [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n        (datesUpdated)=\"datechange($event)\" name=\"daterange\" [readonly]=\"true\" />\r\n</div>\r\n<div class=\"position-relative\">\r\n    <button type=\"button\" (click)=\"opendropdown($event)\"  class=\"btn btn-default mx-2 rounded-3 text-nowrap border-val\">\r\n        <!-- <span class=\"me-2\">Filter</span> -->\r\n        <svg class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                stroke-linejoin=\"round\" />\r\n        </svg>\r\n    </button>\r\n\r\n    <div *ngIf=\"Opendropdown\" class=\"card p-5 dropdown2 position-absolute z-1 end-0\" style=\"z-index: 1 !important;\" (clickOutside)=\"closeDropdown1()\">\r\n        <div class=\"dropdown-title d-flex justify-content-between mb-2\">Filter Options\r\n            <button class=\"btn btn-outline w-25 ms-3 btn-resize\" (click)=\"Reset()\"> Reset </button>\r\n            <button class=\"btn btn-primary w-25  btn-resize\" (click)=\"Apply()\">Apply</button>\r\n        </div>\r\n\r\n             <!-- Country Dropdown -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('country')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\" \r\n            [value]=\"selectedCountriesLabel()\"\r\n            readonly\r\n            placeholder=\"Select country\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'country'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search\" \r\n            placeholder=\"Search country\" \r\n            [(ngModel)]=\"searchCountryText\" \r\n            (ngModelChange)=\"filterCountries()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllCountries\" \r\n                [checked]=\"isAllCountriesSelected()\" \r\n                (change)=\"toggleSelectAllCountries($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllCountries\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let country of filteredCountries\"\r\n        >\r\n        <input \r\n        class=\"form-check-input cursor-pointer\" \r\n        type=\"checkbox\" \r\n        [id]=\"country.country\" \r\n        [(ngModel)]=\"country.checked\"\r\n        (change)=\"updateSelectedCountries()\" \r\n      />\r\n      <label class=\"form-check-label\" [for]=\"country.country\">\r\n        {{ country.country }}\r\n      </label>\r\n      \r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n     <!-- Location Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('location')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\" \r\n            [value]=\"selectedLocationsLabel()\"\r\n            readonly\r\n            placeholder=\"Select Region\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'location'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search\" \r\n            placeholder=\"Search Region\" \r\n            [(ngModel)]=\"searchLocationText\" \r\n            (ngModelChange)=\"filterLocations()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllLocations\" \r\n                [checked]=\"isAllLocationsSelected()\" \r\n                (change)=\"toggleSelectAllLocations($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllLocations\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let location of filteredLocations\"\r\n        >\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                [id]=\"location.city\" \r\n                [(ngModel)]=\"location.checked\"\r\n                (change)=\"updateSelectedLocations()\" \r\n            />\r\n            <label class=\"form-check-label\" [for]=\"location.city\">\r\n                {{ location.city }}\r\n            </label>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<!-- Group Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('group')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\" \r\n            [value]=\"selectedGroupsLabel()\" readonly\r\n            placeholder=\"Select clusters\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'group'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search\" \r\n            placeholder=\"Search clusters\" \r\n            [(ngModel)]=\"searchGroupText\" \r\n            (ngModelChange)=\"filterGroups()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllGroups\" \r\n                [checked]=\"isAllGroupsSelected()\" \r\n                (change)=\"toggleSelectAllGroups($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllGroups\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let group of filteredGroups\"\r\n        >\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                [id]=\"group.groupName\"\r\n                [(ngModel)]=\"group.checked\"\r\n                (change)=\"updateSelectedGroups()\" \r\n            />\r\n            <label class=\"form-check-label\" [for]=\"group.groupName\">\r\n                {{ group.groupName }}\r\n            </label>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n\r\n<!-- Store Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('store')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\"\r\n            [value]=\"selectedStoresLabel()\"\r\n            readonly\r\n            placeholder=\"Select stores\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'store'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search \" \r\n            placeholder=\"Search stores\" \r\n            [(ngModel)]=\"searchStoreText\" \r\n            (ngModelChange)=\"filterStores()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllStores\" \r\n                [checked]=\"isAllStoresSelected()\" \r\n                (change)=\"toggleSelectAllStores($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllStores\">\r\n                Select All\r\n            </label>\r\n        </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let store of filteredStores\"\r\n        >\r\n            <input \r\n                class=\"form-check-input\" \r\n                type=\"checkbox\" \r\n                [id]=\"store.storeId\"\r\n                [(ngModel)]=\"store.checked\"\r\n                (change)=\"updateSelectedStores()\" \r\n            />\r\n            <label class=\"form-check-label\" [for]=\"store.storeId\">\r\n                {{ store.storeName }}\r\n            </label>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<!-- Zone Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('zone')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\"\r\n            [value]=\"selectedZonesLabel()\"\r\n            readonly\r\n            placeholder=\"Select zones\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'zone'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search \" \r\n            placeholder=\"Search zones\" \r\n            [(ngModel)]=\"searchZoneText\" \r\n            (ngModelChange)=\"filterZones()\" \r\n        />\r\n        <div class=\"form-check mb-2 dropdown-item custom-dropdown-item\">\r\n            <input \r\n                class=\"form-check-input cursor-pointer\" \r\n                type=\"checkbox\" \r\n                id=\"selectAllZones\" \r\n                [checked]=\"isAllZonesSelected()\" \r\n                (change)=\"toggleSelectAllZones($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllZones\">\r\n                Select All\r\n            </label>\r\n       </div>\r\n        <div \r\n            class=\"dropdown-item form-check custom-dropdown-item\" \r\n            *ngFor=\"let zone of filteredZones\"\r\n        >\r\n            <input \r\n                class=\"form-check-input\" \r\n                type=\"checkbox\" \r\n                [id]=\"zone._id\"\r\n                [(ngModel)]=\"zone.checked\"\r\n              (change)=\"updateSelectedZones(zone._id)\"\r\n            />\r\n            <label class=\"form-check-label\" [for]=\"zone._id\">\r\n                {{ zone.tagName }}\r\n            </label>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n\r\n    </div>\r\n</div>"]}
|