tango-app-ui-shared 3.7.3-dev1 → 3.7.3-dev10

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.
@@ -19,8 +19,10 @@ export class TrafficHeaderComponent {
19
19
  const isValidDate = m > this.dayjs();
20
20
  return isValidDate ? "invalid-date" : false;
21
21
  };
22
- selectedDateRange = { startDate: dayjs().subtract(30, 'days'),
23
- endDate: dayjs().subtract(1, "days"), };
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,6 +33,7 @@ export class TrafficHeaderComponent {
31
33
  group: [],
32
34
  location: [],
33
35
  country: [],
36
+ status: []
34
37
  };
35
38
  Opendropdown = false;
36
39
  dropdownOpen = null; // 'location' or 'group'
@@ -42,7 +45,7 @@ export class TrafficHeaderComponent {
42
45
  filteredGroups = [];
43
46
  filteredStores = [];
44
47
  stores = [];
45
- searchStoreText = '';
48
+ searchStoreText = "";
46
49
  clientList = [];
47
50
  selectedClient;
48
51
  locationLabel = [];
@@ -61,7 +64,7 @@ export class TrafficHeaderComponent {
61
64
  }
62
65
  onClick(event) {
63
66
  const target = event.target;
64
- if (!target.closest('.dropdown2')) {
67
+ if (!target.closest(".dropdown2")) {
65
68
  this.Opendropdown = false;
66
69
  }
67
70
  }
@@ -76,12 +79,12 @@ export class TrafficHeaderComponent {
76
79
  // this.setRangesBasedOnRoute();
77
80
  // }
78
81
  // });
79
- this.url = this.router.url.split("?")[0].split('/');
80
- const user = JSON.parse(localStorage.getItem('user-info'));
82
+ this.url = this.router.url.split("?")[0].split("/");
83
+ const user = JSON.parse(localStorage.getItem("user-info"));
81
84
  this.users = user;
82
85
  this.gs?.manageRefreshTrigger?.subscribe((e) => {
83
86
  if (e) {
84
- if (user.userType === 'tango') {
87
+ if (user.userType === "tango") {
85
88
  this.getClient();
86
89
  }
87
90
  else {
@@ -90,28 +93,30 @@ export class TrafficHeaderComponent {
90
93
  const headerFilters = JSON.parse(storedFilters);
91
94
  this.filteredStores = headerFilters?.stores.map((store) => ({
92
95
  ...store,
93
- checked: store.checked
96
+ checked: store.checked,
94
97
  }));
95
98
  }
96
99
  }
97
100
  }
98
101
  });
99
102
  // Fetch client data if the user is of type 'tango'
100
- if (user.userType === 'tango') {
103
+ if (user.userType === "tango") {
101
104
  this.getClient();
102
105
  }
103
106
  else {
104
- this.getCountry();
105
- this.getLocations();
106
- this.getGroups();
107
- this.getStore();
107
+ // this.selectedFilters.status = ['active'];
108
+ // this.getCountry();
109
+ // this.getLocations();
110
+ // this.getGroups();
111
+ // this.getStore();
108
112
  const clientFilters = localStorage.getItem("client-details");
109
113
  if (clientFilters) {
110
114
  const headerclientFilters = JSON.parse(clientFilters);
111
115
  this.selectedClient = {
112
- trafficDateRange: headerclientFilters.trafficDateRange
116
+ trafficDateRange: headerclientFilters.trafficDateRange,
113
117
  };
114
118
  }
119
+ this.getStatus();
115
120
  }
116
121
  // Load filters from localStorage if they exist
117
122
  const storedFilters = localStorage.getItem("header-filters");
@@ -120,14 +125,15 @@ export class TrafficHeaderComponent {
120
125
  // Initialize selectedFilters with defaults or existing values
121
126
  this.selectedFilters = {
122
127
  client: headerFilters.client || this.users.client,
123
- clientName: headerFilters.clientName || '',
128
+ clientName: headerFilters.clientName || "",
124
129
  clients: headerFilters.clients || [],
125
130
  store: headerFilters.store || null,
126
131
  date: headerFilters.date || {},
127
132
  stores: headerFilters.stores || [],
128
133
  group: headerFilters.group || [],
129
134
  location: headerFilters.location || [],
130
- country: headerFilters.country || []
135
+ country: headerFilters.country || [],
136
+ status: headerFilters.status || ["active"],
131
137
  };
132
138
  // Sync filtered data with stored selections
133
139
  this.filteredCountries = this.syncWithLocalStorage(headerFilters.country);
@@ -161,7 +167,7 @@ export class TrafficHeaderComponent {
161
167
  return items
162
168
  ? items.map((item) => ({
163
169
  ...item,
164
- checked: item.checked === true
170
+ checked: item.checked === true,
165
171
  }))
166
172
  : [];
167
173
  }
@@ -176,14 +182,15 @@ export class TrafficHeaderComponent {
176
182
  resetFilters() {
177
183
  this.selectedFilters = {
178
184
  client: null,
179
- clientName: '',
185
+ clientName: "",
180
186
  clients: [],
181
187
  store: null,
182
188
  date: {},
183
189
  stores: [],
184
190
  group: [],
185
191
  location: [],
186
- country: []
192
+ country: [],
193
+ status: []
187
194
  };
188
195
  this.filteredLocations = [];
189
196
  this.filteredGroups = [];
@@ -225,14 +232,16 @@ export class TrafficHeaderComponent {
225
232
  this.selectedFilters.group = headerFilters.group;
226
233
  this.selectedFilters.location = headerFilters.location;
227
234
  this.selectedFilters.country = headerFilters.country;
235
+ this.selectedFilters.status = headerFilters.status || ["active"];
228
236
  this.gs.dataRangeValue.next(this.selectedFilters);
229
237
  // console.log("2")
230
238
  // Ensure locations and groups are loaded before fetching stores
231
- this.getCountry();
232
- this.getLocations();
233
- this.getGroups();
239
+ this.getStatus();
240
+ // this.getCountry();
241
+ // this.getLocations();
242
+ // this.getGroups();
234
243
  // Fetch stores only after locations and groups are set
235
- this.getStore();
244
+ // this.getStore();
236
245
  }
237
246
  else {
238
247
  this.selectedClient = this.clientList[0];
@@ -245,16 +254,18 @@ export class TrafficHeaderComponent {
245
254
  this.selectedFilters.group = headerFilters.group;
246
255
  this.selectedFilters.location = headerFilters.location;
247
256
  this.selectedFilters.country = headerFilters.country;
257
+ this.selectedFilters.status = headerFilters.status || ["active"];
248
258
  localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
249
259
  this.gs.dataRangeValue.next(this.selectedFilters);
250
260
  // console.log("3")
251
261
  this.cd.detectChanges();
252
262
  // Ensure locations and groups are loaded before fetching stores
253
- this.getCountry();
254
- this.getLocations();
255
- this.getGroups();
263
+ this.getStatus();
264
+ // this.getCountry();
265
+ // this.getLocations();
266
+ // this.getGroups();
256
267
  // Fetch stores only after locations and groups are set
257
- this.getStore();
268
+ // this.getStore();
258
269
  }
259
270
  }
260
271
  else {
@@ -262,11 +273,12 @@ export class TrafficHeaderComponent {
262
273
  this.selectedFilters.client = this.selectedClient.clientId;
263
274
  this.selectedFilters.clientName = this.selectedClient.clientName;
264
275
  // Ensure locations and groups are loaded before fetching stores
265
- this.getCountry();
266
- this.getLocations();
267
- this.getGroups();
276
+ this.getStatus();
277
+ // this.getCountry();
278
+ // this.getLocations();
279
+ // this.getGroups();
268
280
  // Fetch stores only after locations and groups are set
269
- this.getStore();
281
+ // this.getStore();
270
282
  localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
271
283
  this.gs.dataRangeValue.next(this.selectedFilters);
272
284
  // console.log("4")
@@ -278,13 +290,13 @@ export class TrafficHeaderComponent {
278
290
  }
279
291
  getUserInfo(client) {
280
292
  let obj = {
281
- clientId: client ? client : ''
293
+ clientId: client ? client : "",
282
294
  };
283
295
  if (client) {
284
296
  this.auth.getHeaderUsers(obj).subscribe({
285
297
  next: (e) => {
286
298
  localStorage.setItem("usersEmail-info", JSON.stringify(e?.data?.userEmailData || []));
287
- }
299
+ },
288
300
  });
289
301
  }
290
302
  }
@@ -295,10 +307,12 @@ export class TrafficHeaderComponent {
295
307
  this.filteredGroups = [];
296
308
  this.filteredStores = [];
297
309
  this.filteredLocations = [];
310
+ this.filteredStatus = [];
298
311
  this.selectedFilters.stores = [];
299
312
  this.selectedFilters.group = [];
300
313
  this.selectedFilters.location = [];
301
314
  this.selectedFilters.country = [];
315
+ this.selectedFilters.status = ['active'];
302
316
  // Fetch header filters from localStorage
303
317
  const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
304
318
  // Update the selected filters with the new client
@@ -309,13 +323,15 @@ export class TrafficHeaderComponent {
309
323
  delete headerFilters.groups;
310
324
  delete headerFilters.location;
311
325
  delete headerFilters.country;
326
+ delete headerFilters.status;
327
+ this.getStatus();
312
328
  // Fetch new data based on the new client
313
- this.getCountry();
314
- this.getLocations();
315
- this.getStore();
316
- this.getGroups();
329
+ // this.getCountry();
330
+ // this.getLocations();
331
+ // this.getStore();
332
+ // this.getGroups();
317
333
  // Update localStorage with the new client selection and empty filter data
318
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
334
+ localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
319
335
  window.location.reload();
320
336
  // Emit data to the global service
321
337
  // this.gs.dataRangeValue.next(this.selectedFilters);
@@ -324,16 +340,16 @@ export class TrafficHeaderComponent {
324
340
  }
325
341
  ranges = {
326
342
  Today: [dayjs(), dayjs()],
327
- Yesterday: [dayjs().subtract(1, 'days'), dayjs().subtract(1, 'days')],
328
- 'This Week': [dayjs().subtract(7, 'days'), dayjs().subtract(1, 'days')],
329
- 'Last Week': [
330
- dayjs().subtract(14, 'days').startOf('day'),
331
- dayjs().subtract(8, 'days').endOf('day'),
343
+ Yesterday: [dayjs().subtract(1, "days"), dayjs().subtract(1, "days")],
344
+ "This Week": [dayjs().subtract(7, "days"), dayjs().subtract(1, "days")],
345
+ "Last Week": [
346
+ dayjs().subtract(14, "days").startOf("day"),
347
+ dayjs().subtract(8, "days").endOf("day"),
332
348
  ],
333
- 'This Month': [dayjs().subtract(30, 'days'), dayjs().subtract(1, 'days')],
334
- 'Last Month': [
335
- dayjs().subtract(1, 'month').startOf('month'),
336
- dayjs().subtract(1, 'month').endOf('month'),
349
+ "This Month": [dayjs().subtract(30, "days"), dayjs().subtract(1, "days")],
350
+ "Last Month": [
351
+ dayjs().subtract(1, "month").startOf("month"),
352
+ dayjs().subtract(1, "month").endOf("month"),
337
353
  ],
338
354
  };
339
355
  onStartDateChange(event) {
@@ -346,7 +362,8 @@ export class TrafficHeaderComponent {
346
362
  }
347
363
  else {
348
364
  this.isCustomDate = (m) => {
349
- const isValidDate = m > this.dayjs() || m > this.dayjs(event.startDate.add(180, "days"));
365
+ const isValidDate = m > this.dayjs() ||
366
+ m > this.dayjs(event.startDate.add(180, "days"));
350
367
  return isValidDate ? "invalid-date" : false;
351
368
  };
352
369
  }
@@ -375,18 +392,24 @@ export class TrafficHeaderComponent {
375
392
  }
376
393
  getLocations() {
377
394
  const country = this.countries
378
- .filter(country => country.checked)
379
- .map(country => country.country);
395
+ .filter((country) => country.checked)
396
+ .map((country) => country.country);
380
397
  // const headerFilters: any = JSON.parse(localStorage.getItem("header-filters") || "{}");
381
398
  let obj = {
382
- clientId: this.selectedFilters.client ? this.selectedFilters.client : this.users.clientId,
399
+ clientId: this.selectedFilters.client
400
+ ? this.selectedFilters.client
401
+ : this.users.clientId,
383
402
  country,
384
403
  city: [],
385
404
  group: [],
405
+ status: this.selectedFilters?.status?.length
406
+ ? this.selectedFilters.status : ['active']
386
407
  };
387
408
  this.auth.getLocation(obj).subscribe({
388
409
  next: (res) => {
389
- let cityList = this.selectedFilters?.location?.filter((location) => location.checked).map((loc) => loc.city);
410
+ let cityList = this.selectedFilters?.location
411
+ ?.filter((location) => location.checked)
412
+ .map((loc) => loc.city);
390
413
  // Map the fetched locations with default unchecked state
391
414
  this.locations = res?.data?.locationData.map((city) => ({
392
415
  city: city.city,
@@ -394,19 +417,26 @@ export class TrafficHeaderComponent {
394
417
  checked: cityList?.includes(city.city) ? true : false,
395
418
  }));
396
419
  // Sync the fetched locations with any stored checked values in localStorage
397
- if (this.selectedFilters.location && Array.isArray(this.selectedFilters.location)) {
398
- this.filteredLocations = this.locations.map(location => {
420
+ if (this.selectedFilters.location &&
421
+ Array.isArray(this.selectedFilters.location)) {
422
+ this.filteredLocations = this.locations.map((location) => {
399
423
  const matchedLocation = this.selectedFilters.location.find((loc) => loc.city === location.city);
400
- return matchedLocation ? { ...location, checked: matchedLocation.checked } : location;
424
+ return matchedLocation
425
+ ? { ...location, checked: matchedLocation.checked }
426
+ : location;
401
427
  });
402
428
  }
403
429
  else {
404
430
  this.filteredLocations = this.locations;
405
431
  }
406
432
  if (this.searchLocationText) {
407
- this.filteredLocations = this.locations.filter((location) => location.city.toLowerCase().includes(this.searchLocationText.toLowerCase()));
433
+ this.filteredLocations = this.locations.filter((location) => location.city
434
+ .toLowerCase()
435
+ .includes(this.searchLocationText.toLowerCase()));
408
436
  }
409
- const selectedLocations = this.locations.filter((location) => location.checked).map((location) => location.city);
437
+ const selectedLocations = this.locations
438
+ .filter((location) => location.checked)
439
+ .map((location) => location.city);
410
440
  if (selectedLocations.length > 0) {
411
441
  setTimeout(() => {
412
442
  this.getGroups();
@@ -423,14 +453,19 @@ export class TrafficHeaderComponent {
423
453
  });
424
454
  }
425
455
  isAllLocationsSelected() {
426
- return this.filteredLocations.every(location => location.checked);
456
+ return this.filteredLocations.every((location) => location.checked);
427
457
  }
428
458
  selectedLocationsLabel() {
429
- const selectedLocations = this.locationLabel = this.searchLocationText.length ? this.locations
430
- .filter(location => location.checked).map(location => location.city) : this.filteredLocations
431
- .filter(location => location.checked).map(location => location.city);
459
+ const selectedLocations = (this.locationLabel = this.searchLocationText
460
+ .length
461
+ ? this.locations
462
+ .filter((location) => location.checked)
463
+ .map((location) => location.city)
464
+ : this.filteredLocations
465
+ .filter((location) => location.checked)
466
+ .map((location) => location.city));
432
467
  return selectedLocations.length === 0
433
- ? ''
468
+ ? ""
434
469
  : selectedLocations.length === 1
435
470
  ? selectedLocations[0]
436
471
  : `${selectedLocations.length} Regions`;
@@ -440,19 +475,29 @@ export class TrafficHeaderComponent {
440
475
  }
441
476
  getGroups() {
442
477
  const country = this.countries
443
- .filter(country => country.checked)
444
- .map(country => country.country);
478
+ .filter((country) => country.checked)
479
+ .map((country) => country.country);
445
480
  let city;
446
481
  city = this.locations
447
- .filter(location => location.checked)
448
- .map(location => location.city);
482
+ .filter((location) => location.checked)
483
+ .map((location) => location.city);
449
484
  if (!city.length && country.length) {
450
485
  city = this.locations.map((loc) => loc.city);
451
486
  }
452
- const obj = { country, city, clientId: this.selectedFilters.client ? this.selectedFilters.client : this.users.clientId, group: [] };
487
+ const obj = {
488
+ country,
489
+ city,
490
+ clientId: this.selectedFilters.client
491
+ ? this.selectedFilters.client
492
+ : this.users.clientId,
493
+ group: [],
494
+ status: this.selectedFilters?.status?.length ? this.selectedFilters.status : ['active']
495
+ };
453
496
  this.auth.getGroups(obj).subscribe({
454
497
  next: (res) => {
455
- let checkedGroup = this.selectedFilters?.group?.filter((group) => group.checked).map((group) => group.groupName);
498
+ let checkedGroup = this.selectedFilters?.group
499
+ ?.filter((group) => group.checked)
500
+ .map((group) => group.groupName);
456
501
  const combinedGroups = res?.data?.groupData?.map((groupName) => ({
457
502
  groupName: groupName.groupName,
458
503
  checked: checkedGroup?.includes(groupName.groupName) ? true : false,
@@ -466,7 +511,9 @@ export class TrafficHeaderComponent {
466
511
  this.filteredGroups = combinedGroups;
467
512
  }
468
513
  // Auto-fetch stores when groups are selected
469
- const selectedGroups = this.groupsData.filter((group) => group.checked).map((group) => group.groupName);
514
+ const selectedGroups = this.groupsData
515
+ .filter((group) => group.checked)
516
+ .map((group) => group.groupName);
470
517
  if (selectedGroups.length > 0) {
471
518
  setTimeout(() => {
472
519
  this.getStore(); // Fetch stores based on selected groups
@@ -486,45 +533,53 @@ export class TrafficHeaderComponent {
486
533
  else {
487
534
  // Open the specific dropdown and handle data fetching only if necessary
488
535
  this.dropdownOpen = type;
489
- if (type === 'country') {
536
+ if (type === "status") {
537
+ this.getStatus();
538
+ }
539
+ if (type === "country") {
490
540
  // Fetch countries only if not already fetched and no search text exists
491
- if ((!this.filteredCountries || this.filteredCountries.length === 0) && !this.searchCountryText.trim()) {
541
+ if ((!this.filteredCountries || this.filteredCountries.length === 0) &&
542
+ !this.searchCountryText.trim()) {
492
543
  this.getCountry();
493
544
  }
494
545
  }
495
- if (type === 'group') {
546
+ if (type === "group") {
496
547
  // Fetch groups only if there are selected cities and no active search text
497
548
  const selectedCities = this.locations
498
549
  .filter((location) => location.checked)
499
550
  .map((location) => location.city);
500
551
  // Fetch groups only if locations are selected, no search text exists, and dropdown is opened
501
- if (this.filteredLocations.length > 0 || (selectedCities.length > 0 && !this.searchGroupText.trim())) {
552
+ if (this.filteredLocations.length > 0 ||
553
+ (selectedCities.length > 0 && !this.searchGroupText.trim())) {
502
554
  this.getGroups();
503
555
  }
504
556
  else {
505
557
  this.filteredGroups = []; // Clear groups if no locations are selected
506
558
  }
507
559
  }
508
- if (type === 'store') {
560
+ if (type === "store") {
509
561
  // Fetch stores only if not already fetched and no search text is active
510
- if ((!this.filteredStores || this.filteredStores.length === 0) && !this.searchStoreText.trim()) {
562
+ if ((!this.filteredStores || this.filteredStores.length === 0) &&
563
+ !this.searchStoreText.trim()) {
511
564
  this.getStore();
512
565
  }
513
566
  }
514
567
  }
515
568
  }
516
569
  handleGroupDropdownClick() {
517
- if (this.dropdownOpen === 'group') {
570
+ if (this.dropdownOpen === "group") {
518
571
  this.resetSelectedGroups();
519
572
  }
520
- this.toggleDropdown('group');
573
+ this.toggleDropdown("group");
521
574
  }
522
575
  resetSelectedGroups() {
523
576
  this.filteredGroups.forEach((group) => (group.checked = false));
524
577
  this.searchGroupText = "";
525
578
  }
526
579
  selectedGroupsLabel() {
527
- const selectedGroups = this.groupLabel = this.searchGroupText.length ? this.groupsData.filter((group) => group.checked) : this.filteredGroups.filter((group) => group.checked);
580
+ const selectedGroups = (this.groupLabel = this.searchGroupText.length
581
+ ? this.groupsData.filter((group) => group.checked)
582
+ : this.filteredGroups.filter((group) => group.checked));
528
583
  return selectedGroups.length === 0
529
584
  ? ""
530
585
  : selectedGroups.length === 1
@@ -535,23 +590,26 @@ export class TrafficHeaderComponent {
535
590
  this.Reset();
536
591
  }
537
592
  isAllGroupsSelected() {
538
- return this.filteredGroups.length ? this.filteredGroups.every((group) => group.checked) : false;
593
+ return this.filteredGroups.length
594
+ ? this.filteredGroups.every((group) => group.checked)
595
+ : false;
539
596
  }
540
597
  getStore() {
541
598
  const country = this.countries
542
- .filter(country => country.checked)
543
- .map(country => country.country);
599
+ .filter((country) => country.checked)
600
+ .map((country) => country.country);
544
601
  const city = this.locations
545
- .filter(location => location.checked)
546
- .map(location => location.city);
602
+ .filter((location) => location.checked)
603
+ .map((location) => location.city);
547
604
  const group = this.groupsData
548
- .filter(group => group.checked)
549
- .map(group => group.groupName);
605
+ .filter((group) => group.checked)
606
+ .map((group) => group.groupName);
550
607
  const data = {
551
608
  country,
552
609
  city,
553
610
  clusters: group,
554
- clientId: this.users.clientId || this.selectedFilters.client
611
+ clientId: this.users.clientId || this.selectedFilters.client,
612
+ status: this.selectedFilters?.status?.length ? this.selectedFilters.status : ['active']
555
613
  };
556
614
  this.auth.getHeaderStores(data).subscribe({
557
615
  next: (res) => {
@@ -560,30 +618,34 @@ export class TrafficHeaderComponent {
560
618
  this.stores = res.data.storesData;
561
619
  // Check if there are previously selected stores
562
620
  const checkedStoreIds = this.selectedFilters?.stores
563
- ? this.selectedFilters.stores.filter((store) => store.checked).map((store) => store.storeId)
621
+ ? this.selectedFilters.stores
622
+ .filter((store) => store.checked)
623
+ .map((store) => store.storeId)
564
624
  : [];
565
625
  // Sync the `checked` state
566
- this.stores.forEach(store => {
626
+ this.stores.forEach((store) => {
567
627
  store.checked = checkedStoreIds.length
568
628
  ? checkedStoreIds.includes(store.storeId) // Use previous selection
569
629
  : true; // Default to true if no previous selection
570
630
  });
571
631
  // Apply search filter if search text is present
572
632
  if (this.searchStoreText.length) {
573
- this.filteredStores = this.stores.filter(store => store.storeName.toLowerCase().includes(this.searchStoreText.toLowerCase()));
633
+ this.filteredStores = this.stores.filter((store) => store.storeName
634
+ .toLowerCase()
635
+ .includes(this.searchStoreText.toLowerCase()));
574
636
  }
575
637
  else {
576
638
  this.filteredStores = [...this.stores];
577
639
  }
578
640
  // Update `selectedFilters.stores` to reflect the current state
579
- this.selectedFilters.stores = this.filteredStores.map(store => ({
641
+ this.selectedFilters.stores = this.filteredStores.map((store) => ({
580
642
  storeId: store.storeId,
581
643
  storeName: store.storeName,
582
- checked: store.checked
644
+ checked: store.checked,
583
645
  }));
584
646
  // this.selectedFilters.country = country;
585
647
  // Save updated filters to localStorage
586
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
648
+ localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
587
649
  // Trigger UI change detection
588
650
  this.cd.detectChanges();
589
651
  }
@@ -595,7 +657,7 @@ export class TrafficHeaderComponent {
595
657
  error: (err) => {
596
658
  console.error("Failed to fetch stores", err);
597
659
  this.clearStoresState();
598
- }
660
+ },
599
661
  });
600
662
  }
601
663
  // Clear stores state and reset filters
@@ -603,14 +665,16 @@ export class TrafficHeaderComponent {
603
665
  this.stores = [];
604
666
  this.filteredStores = [];
605
667
  this.selectedFilters.stores = [];
606
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
668
+ localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
607
669
  }
608
670
  resetSelectedStores() {
609
671
  this.filteredStores.forEach((store) => (store.checked = false));
610
672
  this.searchStoreText = "";
611
673
  }
612
674
  selectedStoresLabel() {
613
- const selectedStores = this.searchStoreText.length ? this.stores.filter((store) => store.checked) : this.filteredStores.filter((store) => store.checked);
675
+ const selectedStores = this.searchStoreText.length
676
+ ? this.stores.filter((store) => store.checked)
677
+ : this.filteredStores.filter((store) => store.checked);
614
678
  return selectedStores.length === 0
615
679
  ? "0 Stores"
616
680
  : selectedStores.length === 1
@@ -618,20 +682,21 @@ export class TrafficHeaderComponent {
618
682
  : `${selectedStores.length} Stores`;
619
683
  }
620
684
  isAllStoresSelected() {
621
- return this.filteredStores.length > 0 && this.filteredStores.every(store => store.checked);
685
+ return (this.filteredStores.length > 0 &&
686
+ this.filteredStores.every((store) => store.checked));
622
687
  }
623
688
  // Method to handle dropdown item selection
624
689
  updateSelectedStores() {
625
- this.filteredStores.forEach(store => {
626
- const filteredStore = this.stores.findIndex(fStore => fStore.storeId === store.storeId);
690
+ this.filteredStores.forEach((store) => {
691
+ const filteredStore = this.stores.findIndex((fStore) => fStore.storeId === store.storeId);
627
692
  if (filteredStore != -1) {
628
693
  this.stores[filteredStore].checked = store.checked; // Sync the checked state with full store list
629
694
  }
630
695
  });
631
696
  // Update selectedFilters based on the current store selection
632
- this.selectedFilters.stores = this.stores.filter(store => store.checked);
697
+ this.selectedFilters.stores = this.stores.filter((store) => store.checked);
633
698
  // Update localStorage with the latest selection
634
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
699
+ localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
635
700
  // Emit updated filters via service
636
701
  // this.gs.dataRangeValue.next(this.selectedFilters);
637
702
  // Trigger change detection if necessary
@@ -645,9 +710,9 @@ export class TrafficHeaderComponent {
645
710
  toggleSelectAllStores(event) {
646
711
  const checked = event.target.checked;
647
712
  // Apply the selection to both filtered and full list of stores
648
- this.filteredStores.forEach(store => store.checked = checked);
649
- this.stores.forEach(store => {
650
- const filteredStore = this.filteredStores.find(fStore => fStore.storeId === store.storeId);
713
+ this.filteredStores.forEach((store) => (store.checked = checked));
714
+ this.stores.forEach((store) => {
715
+ const filteredStore = this.filteredStores.find((fStore) => fStore.storeId === store.storeId);
651
716
  if (filteredStore) {
652
717
  store.checked = checked; // Sync the checked state with full store list
653
718
  }
@@ -680,8 +745,8 @@ export class TrafficHeaderComponent {
680
745
  }
681
746
  this.selectedFilters.group = [];
682
747
  this.filteredStores = []; // Reset stores as well
683
- this.searchGroupText = '';
684
- this.searchStoreText = '';
748
+ this.searchGroupText = "";
749
+ this.searchStoreText = "";
685
750
  // this.Opendropdown = false;
686
751
  }
687
752
  toggleSelectAllGroups(event) {
@@ -711,12 +776,12 @@ export class TrafficHeaderComponent {
711
776
  this.filteredStores = [];
712
777
  // Also, update localStorage to reflect the cleared store selection
713
778
  this.selectedFilters.stores = [];
714
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
779
+ localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
715
780
  // Emit data via service
716
781
  // this.gs.dataRangeValue.next(this.selectedFilters);
717
782
  }
718
783
  // Clear the search store text when groups are updated
719
- this.searchStoreText = '';
784
+ this.searchStoreText = "";
720
785
  }
721
786
  Reset() {
722
787
  setTimeout(() => {
@@ -725,23 +790,28 @@ export class TrafficHeaderComponent {
725
790
  this.filteredGroups = [];
726
791
  this.filteredStores = [];
727
792
  this.filteredLocations = []; // Reset locations as well
793
+ this.filteredStatus = [];
728
794
  this.locations = [];
729
795
  this.groupsData = [];
730
796
  this.stores = [];
731
797
  this.countries = [];
798
+ this.statusVal = [];
732
799
  // Clear search input fields
733
800
  this.searchLocationText = "";
734
801
  this.searchGroupText = "";
735
802
  this.searchStoreText = "";
803
+ this.searchStatusText = "";
736
804
  this.selectedFilters.stores = [];
737
805
  this.selectedFilters.group = [];
738
806
  this.selectedFilters.location = [];
739
807
  this.selectedFilters.country = [];
808
+ this.selectedFilters.status = ['active'];
740
809
  // Fetch locations, groups, and stores again
741
- this.getCountry();
742
- this.getLocations();
743
- this.getStore();
744
- this.getGroups();
810
+ // this.getCountry();
811
+ // this.getLocations();
812
+ // this.getStore();
813
+ // this.getGroups();
814
+ this.getStatus();
745
815
  // Reset the filters in selectedFilters
746
816
  // // Once stores are fetched, mark all as checked
747
817
  // setTimeout(() => {
@@ -755,7 +825,7 @@ export class TrafficHeaderComponent {
755
825
  // checked: true
756
826
  // }));
757
827
  // Update localStorage with the latest selectedFilters
758
- localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
828
+ localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
759
829
  window.location.reload();
760
830
  // Emit the reset filters to update other components if needed
761
831
  // this.gs.dataRangeValue.next(this.selectedFilters);
@@ -771,17 +841,18 @@ export class TrafficHeaderComponent {
771
841
  if (searchText) {
772
842
  // Preserve the checked state during filtering
773
843
  this.filteredLocations = this.locations
774
- .map(location => ({
844
+ .map((location) => ({
775
845
  ...location,
776
- checked: this.filteredLocations.find(l => l.city === location.city)?.checked || false
846
+ checked: this.filteredLocations.find((l) => l.city === location.city)
847
+ ?.checked || false,
777
848
  }))
778
- .filter(location => location?.city?.toLowerCase().includes(searchText));
849
+ .filter((location) => location?.city?.toLowerCase().includes(searchText));
779
850
  }
780
851
  else {
781
852
  // Restore the original checked state when search text is cleared
782
- this.filteredLocations = this.locations.map(location => ({
853
+ this.filteredLocations = this.locations.map((location) => ({
783
854
  ...location,
784
- checked: this.selectedFilters.location.find((l) => l.city === location.city)?.checked || false
855
+ checked: this.selectedFilters.location.find((l) => l.city === location.city)?.checked || false,
785
856
  }));
786
857
  }
787
858
  }
@@ -790,17 +861,18 @@ export class TrafficHeaderComponent {
790
861
  if (searchText) {
791
862
  // Preserve the checked state during filtering
792
863
  this.filteredGroups = this.groupsData
793
- .map(group => ({
864
+ .map((group) => ({
794
865
  ...group,
795
- checked: this.filteredGroups.find(g => g.groupName === group.groupName)?.checked || false
866
+ checked: this.filteredGroups.find((g) => g.groupName === group.groupName)
867
+ ?.checked || false,
796
868
  }))
797
- .filter(group => group?.groupName?.toLowerCase().includes(searchText));
869
+ .filter((group) => group?.groupName?.toLowerCase().includes(searchText));
798
870
  }
799
871
  else {
800
872
  // Restore the original checked state when search text is cleared
801
- this.filteredGroups = this.groupsData.map(group => ({
873
+ this.filteredGroups = this.groupsData.map((group) => ({
802
874
  ...group,
803
- checked: this.selectedFilters.group.find((g) => g.groupName === group.groupName)?.checked || false
875
+ checked: this.selectedFilters.group.find((g) => g.groupName === group.groupName)?.checked || false,
804
876
  }));
805
877
  }
806
878
  }
@@ -810,19 +882,23 @@ export class TrafficHeaderComponent {
810
882
  if (searchText) {
811
883
  // Filter based on search text while preserving checked state
812
884
  this.filteredStores = this.stores
813
- .map(store => ({
885
+ .map((store) => ({
814
886
  ...store,
815
887
  // Check if the store is already checked in filteredStores, fallback to original stores' checked state
816
- checked: this.selectedFilters.stores.find((s) => s.storeId === store.storeId)?.checked || store.checked || false
888
+ checked: this.selectedFilters.stores.find((s) => s.storeId === store.storeId)?.checked ||
889
+ store.checked ||
890
+ false,
817
891
  }))
818
- .filter(store => store.storeName.toLowerCase().includes(searchText));
892
+ .filter((store) => store.storeName.toLowerCase().includes(searchText));
819
893
  }
820
894
  else {
821
895
  // When the search text is cleared, restore the original list with preserved checked states
822
- this.filteredStores = this.stores.map(store => ({
896
+ this.filteredStores = this.stores.map((store) => ({
823
897
  ...store,
824
898
  // Preserve the checked state based on the selected filters
825
- checked: this.selectedFilters.stores.find((s) => s.storeId === store.storeId)?.checked || store.checked || false
899
+ checked: this.selectedFilters.stores.find((s) => s.storeId === store.storeId)?.checked ||
900
+ store.checked ||
901
+ false,
826
902
  }));
827
903
  }
828
904
  }
@@ -889,7 +965,7 @@ export class TrafficHeaderComponent {
889
965
  // isAllCountriesSelected(): boolean {
890
966
  // return this.filteredCountries.every(country => country.checked);
891
967
  // }
892
- // filterCountries(): void {
968
+ // filterCountries(): void {
893
969
  // const searchText = this.searchCountryText.toLowerCase();
894
970
  // if (searchText) {
895
971
  // // Preserve the checked state during filtering
@@ -911,12 +987,17 @@ export class TrafficHeaderComponent {
911
987
  // }
912
988
  getCountry() {
913
989
  let obj = {
914
- clientId: this.selectedFilters.client ? this.selectedFilters.client : this.users.clientId,
990
+ clientId: this.selectedFilters.client
991
+ ? this.selectedFilters.client
992
+ : this.users.clientId,
993
+ status: this.selectedFilters?.status?.length ? this.selectedFilters.status : ['active']
915
994
  };
916
995
  this.auth.getCountry(obj).subscribe({
917
996
  next: (res) => {
918
997
  // Extract selected countries from existing filters (if any)
919
- let countryList = this.selectedFilters?.country?.filter((country) => country.checked).map((loc) => loc.country);
998
+ let countryList = this.selectedFilters?.country
999
+ ?.filter((country) => country.checked)
1000
+ .map((loc) => loc.country);
920
1001
  // Map API response to frontend model
921
1002
  this.countries = res?.data?.countryData.map((item) => ({
922
1003
  country: item.country,
@@ -924,10 +1005,13 @@ export class TrafficHeaderComponent {
924
1005
  // checked: cityList?.length ? cityList.includes(city.city) : true,
925
1006
  checked: countryList?.includes(item.country) ? true : false,
926
1007
  }));
927
- if (this.selectedFilters.country && Array.isArray(this.selectedFilters.country)) {
928
- this.filteredCountries = this.countries.map(location => {
1008
+ if (this.selectedFilters.country &&
1009
+ Array.isArray(this.selectedFilters.country)) {
1010
+ this.filteredCountries = this.countries.map((location) => {
929
1011
  const matchedLocation = this.selectedFilters.country.find((loc) => loc.country === location.country);
930
- return matchedLocation ? { ...location, checked: matchedLocation.checked } : location;
1012
+ return matchedLocation
1013
+ ? { ...location, checked: matchedLocation.checked }
1014
+ : location;
931
1015
  });
932
1016
  }
933
1017
  else {
@@ -955,10 +1039,14 @@ export class TrafficHeaderComponent {
955
1039
  }
956
1040
  selectedCountriesLabel() {
957
1041
  const selectedCountries = this.searchCountryText.length
958
- ? this.filteredCountries.filter(country => country.checked).map(country => country.country)
959
- : this.countries.filter(country => country.checked).map(country => country.country);
1042
+ ? this.filteredCountries
1043
+ .filter((country) => country.checked)
1044
+ .map((country) => country.country)
1045
+ : this.countries
1046
+ .filter((country) => country.checked)
1047
+ .map((country) => country.country);
960
1048
  return selectedCountries.length === 0
961
- ? ''
1049
+ ? ""
962
1050
  : selectedCountries.length === 1
963
1051
  ? selectedCountries[0]
964
1052
  : `${selectedCountries.length} countries`;
@@ -968,22 +1056,24 @@ export class TrafficHeaderComponent {
968
1056
  if (searchText) {
969
1057
  // Filter and preserve checked state
970
1058
  this.filteredCountries = this.countries
971
- .map(country => ({
1059
+ .map((country) => ({
972
1060
  ...country,
973
- checked: this.filteredCountries.find(c => c.country === country.country)?.checked || false
1061
+ checked: this.filteredCountries.find((c) => c.country === country.country)
1062
+ ?.checked || false,
974
1063
  }))
975
- .filter(country => country.country.toLowerCase().includes(searchText));
1064
+ .filter((country) => country.country.toLowerCase().includes(searchText));
976
1065
  }
977
1066
  else {
978
1067
  // Reset to full list
979
1068
  this.filteredCountries = this.countries.map((country) => ({
980
1069
  ...country,
981
- checked: this.selectedFilters.country?.find((c) => c.country === country.country)?.checked || false
1070
+ checked: this.selectedFilters.country?.find((c) => c.country === country.country)?.checked || false,
982
1071
  }));
983
1072
  }
984
1073
  }
985
1074
  isAllCountriesSelected() {
986
- return this.filteredCountries.length > 0 && this.filteredCountries.every(country => country.checked);
1075
+ return (this.filteredCountries.length > 0 &&
1076
+ this.filteredCountries.every((country) => country.checked));
987
1077
  }
988
1078
  toggleSelectAllCountries(event) {
989
1079
  const isChecked = event.target.checked;
@@ -1017,8 +1107,8 @@ export class TrafficHeaderComponent {
1017
1107
  }
1018
1108
  this.selectedFilters.group = [];
1019
1109
  this.filteredStores = []; // Reset stores as well
1020
- this.searchGroupText = '';
1021
- this.searchStoreText = '';
1110
+ this.searchGroupText = "";
1111
+ this.searchStoreText = "";
1022
1112
  // this.Opendropdown = false;
1023
1113
  }
1024
1114
  removeCountry() {
@@ -1031,10 +1121,15 @@ export class TrafficHeaderComponent {
1031
1121
  const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
1032
1122
  this.selectedFilters.store = null;
1033
1123
  // Ensure current selections are reflected
1124
+ this.selectedFilters.status = this.filteredStatus
1125
+ .filter((s) => s.checked)
1126
+ .map((s) => s.status);
1034
1127
  this.selectedFilters.country = this.filteredCountries;
1035
1128
  this.selectedFilters.location = this.locations;
1036
1129
  this.selectedFilters.group = this.groupsData;
1037
- this.selectedFilters.stores = headerFilters.stores ? headerFilters.stores : this.stores;
1130
+ this.selectedFilters.stores = headerFilters.stores
1131
+ ? headerFilters.stores
1132
+ : this.stores;
1038
1133
  // Store updated filters back in localStorage
1039
1134
  localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
1040
1135
  // this.gs.dataRangeValue.next(this.selectedFilters);
@@ -1045,17 +1140,101 @@ export class TrafficHeaderComponent {
1045
1140
  // this.gs.manageRefreshTrigger.next(true);
1046
1141
  this.cd.detectChanges();
1047
1142
  }
1143
+ statusVal;
1144
+ searchStatusText = "";
1145
+ filteredStatus = [];
1146
+ getStatus() {
1147
+ // base status list
1148
+ this.statusVal = [
1149
+ { status: 'active', checked: false },
1150
+ { status: 'deactive', checked: false }
1151
+ ];
1152
+ const storedFilters = localStorage.getItem("header-filters");
1153
+ // if selectedFilters.status exists and has values, use them, otherwise default to ["active"]
1154
+ const statusList = this.selectedFilters?.status && this.selectedFilters?.status.length > 0
1155
+ ? this.selectedFilters.status
1156
+ : storedFilters
1157
+ ? JSON.parse(storedFilters).status || ['active']
1158
+ : ['active'];
1159
+ this.selectedFilters.status = statusList;
1160
+ // mark checked based on values
1161
+ this.filteredStatus = this.statusVal.map((status) => ({
1162
+ status: status.status,
1163
+ checked: statusList.includes(status.status)
1164
+ }));
1165
+ // if a search text already exists, filter immediately
1166
+ if (this.searchStatusText) {
1167
+ this.filterStatus();
1168
+ }
1169
+ // refresh dependent dropdowns
1170
+ this.getCountry();
1171
+ this.getLocations();
1172
+ this.getGroups();
1173
+ this.getStore();
1174
+ }
1175
+ selectedStatusLabel() {
1176
+ const selectedStatus = this.filteredStatus
1177
+ .filter((status) => status.checked)
1178
+ .map((status) => status.status);
1179
+ if (selectedStatus.length === 0) {
1180
+ return "";
1181
+ }
1182
+ if (selectedStatus.length === 1) {
1183
+ return selectedStatus[0]; // show "active" or "deactive"
1184
+ }
1185
+ return `${selectedStatus.length} status`; // e.g. "2 status"
1186
+ }
1187
+ filterStatus() {
1188
+ const searchText = this.searchStatusText.toLowerCase();
1189
+ if (searchText) {
1190
+ this.filteredStatus = this.statusVal
1191
+ .map((status) => ({
1192
+ ...status,
1193
+ checked: this.selectedFilters.status?.includes(status.status) || false
1194
+ }))
1195
+ .filter((status) => status.status.toLowerCase().includes(searchText));
1196
+ }
1197
+ else {
1198
+ this.filteredStatus = this.statusVal.map((status) => ({
1199
+ ...status,
1200
+ checked: this.selectedFilters.status?.includes(status.status) || false
1201
+ }));
1202
+ }
1203
+ }
1204
+ isAllStatusSelected() {
1205
+ return (this.filteredStatus.length > 0 &&
1206
+ this.filteredStatus.every((status) => status.checked));
1207
+ }
1208
+ toggleSelectAllStatus(event) {
1209
+ const isChecked = event.target.checked;
1210
+ // Update UI state
1211
+ this.filteredStatus.forEach((status) => (status.checked = isChecked));
1212
+ // Update selectedFilters with only checked status values
1213
+ this.selectedFilters.status = this.filteredStatus
1214
+ .filter((status) => status.checked)
1215
+ .map((status) => status.status);
1216
+ this.updateSelectedCountries();
1217
+ }
1218
+ updateSelectedStatus() {
1219
+ // keep only the checked statuses
1220
+ const selected = this.filteredStatus
1221
+ .filter((status) => status.checked)
1222
+ .map((status) => status.status); // ✅ pick only the value
1223
+ this.statusVal = selected;
1224
+ this.selectedFilters.status = selected;
1225
+ this.updateSelectedCountries();
1226
+ }
1048
1227
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TrafficHeaderComponent, deps: [{ token: i1.AuthService }, { token: i2.Router }, { token: i3.GlobalStateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
1049
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TrafficHeaderComponent, selector: "lib-traffic-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</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\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" }] });
1228
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TrafficHeaderComponent, selector: "lib-traffic-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</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<!-- status -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('status')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedStatusLabel()\"\r\n readonly\r\n placeholder=\"Select status\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'status'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search status\" \r\n [(ngModel)]=\"searchStatusText\" \r\n (ngModelChange)=\"filterStatus()\" \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=\"selectAllStatus\" \r\n [checked]=\"isAllStatusSelected()\" \r\n (change)=\"toggleSelectAllStatus($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllStatus\">\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 status of filteredStatus\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"status.status\" \r\n [(ngModel)]=\"status.checked\"\r\n (change)=\"updateSelectedStatus()\" \r\n />\r\n <label class=\"form-check-label text-capitalize\" [for]=\"status.status\">\r\n {{ status.status }}\r\n </label>\r\n \r\n </div>\r\n </div>\r\n</div>\r\n\r\n <!-- Country Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (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\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" }] });
1050
1229
  }
1051
1230
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TrafficHeaderComponent, decorators: [{
1052
1231
  type: Component,
1053
- args: [{ selector: "lib-traffic-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</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\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"] }]
1232
+ args: [{ selector: "lib-traffic-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</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<!-- status -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\" (click)=\"toggleDropdown('status')\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedStatusLabel()\"\r\n readonly\r\n placeholder=\"Select status\"\r\n />\r\n </div>\r\n <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'status'\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control mb-2 dropdown-search\" \r\n placeholder=\"Search status\" \r\n [(ngModel)]=\"searchStatusText\" \r\n (ngModelChange)=\"filterStatus()\" \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=\"selectAllStatus\" \r\n [checked]=\"isAllStatusSelected()\" \r\n (change)=\"toggleSelectAllStatus($event)\" \r\n />\r\n <label class=\"form-check-label\" for=\"selectAllStatus\">\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 status of filteredStatus\"\r\n >\r\n <input \r\n class=\"form-check-input cursor-pointer\" \r\n type=\"checkbox\" \r\n [id]=\"status.status\" \r\n [(ngModel)]=\"status.checked\"\r\n (change)=\"updateSelectedStatus()\" \r\n />\r\n <label class=\"form-check-label text-capitalize\" [for]=\"status.status\">\r\n {{ status.status }}\r\n </label>\r\n \r\n </div>\r\n </div>\r\n</div>\r\n\r\n <!-- Country Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (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\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"] }]
1054
1233
  }], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.Router }, { type: i3.GlobalStateService }, { type: i0.ChangeDetectorRef }], propDecorators: { onClick: [{
1055
1234
  type: HostListener,
1056
- args: ['document:click', ['$event']]
1235
+ args: ["document:click", ["$event"]]
1057
1236
  }], clickOutside: [{
1058
1237
  type: HostListener,
1059
1238
  args: ["document:click", ["$event"]]
1060
1239
  }] } });
1061
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"traffic-header.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.ts","../../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-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-traffic-header\",\r\n  templateUrl: \"./traffic-header.component.html\",\r\n  styleUrl: \"./traffic-header.component.scss\",\r\n})\r\nexport class TrafficHeaderComponent 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  };\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  stores:any[] = []\r\n  searchStoreText: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        }\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      };\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  \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    };\r\n    this.filteredLocations = [];\r\n    this.filteredGroups = [];\r\n    this.filteredStores = [];\r\n    this.filteredCountries = [];\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          this.selectedFilters.client = headerFilters.client;\r\n          this.selectedFilters.clientName = headerFilters.clientName;\r\n          this.selectedFilters.clients = headerFilters.clients;\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.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 = headerFilters.clients;\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        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      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\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\n\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} Regions`;\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'): 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  }\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  \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  // 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  isAllStoresSelected(): boolean {\r\n    return this.filteredStores.length > 0 && this.filteredStores.every(store => store.checked);\r\n  }\r\n// Method to handle dropdown item selection\r\nupdateSelectedStores(): 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  this.cd.detectChanges();\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  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.countries =[];\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\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  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.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.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.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    // 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","<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</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\r\n\r\n\r\n\r\n\r\n\r\n    </div>\r\n</div>"]}
1240
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"traffic-header.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.ts","../../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-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-traffic-header\",\r\n  templateUrl: \"./traffic-header.component.html\",\r\n  styleUrl: \"./traffic-header.component.scss\",\r\n})\r\nexport class TrafficHeaderComponent 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    status:[]\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  stores: any[] = [];\r\n  searchStoreText: 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          }\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.selectedFilters.status = ['active'];\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      this.getStatus();\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        status: headerFilters.status || [\"active\"],\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\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      status:[]\r\n    };\r\n    this.filteredLocations = [];\r\n    this.filteredGroups = [];\r\n    this.filteredStores = [];\r\n    this.filteredCountries = [];\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            this.selectedFilters.client = headerFilters.client;\r\n            this.selectedFilters.clientName = headerFilters.clientName;\r\n            this.selectedFilters.clients = headerFilters.clients;\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.status = headerFilters.status || [\"active\"];\r\n            this.gs.dataRangeValue.next(this.selectedFilters);\r\n            \r\n            // console.log(\"2\")\r\n            // Ensure locations and groups are loaded before fetching stores\r\n               this.getStatus();\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 = headerFilters.clients;\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.status = headerFilters.status || [\"active\"];\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.getStatus();\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.getStatus();\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          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.filteredStatus =[];\r\n    this.selectedFilters.stores = [];\r\n    this.selectedFilters.group = [];\r\n    this.selectedFilters.location = [];\r\n    this.selectedFilters.country = [];\r\n    this.selectedFilters.status = ['active'];\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.status;\r\nthis.getStatus();\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      status: this.selectedFilters?.status?.length\r\n        ? this.selectedFilters.status : ['active']\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} Regions`;\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      status: this.selectedFilters?.status?.length ? this.selectedFilters.status : ['active']\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\" | \"status\"\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\nif(type ===\"status\"){\r\n\r\n  this.getStatus();\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  }\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      status: this.selectedFilters?.status?.length ? this.selectedFilters.status : ['active']\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\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  // 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  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  // 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    this.cd.detectChanges();\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  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      // 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\n      this.filteredStatus = [];\r\n      this.locations = [];\r\n      this.groupsData = [];\r\n      this.stores = [];\r\n      this.countries = [];\r\n      this.statusVal = [];\r\n      // Clear search input fields\r\n      this.searchLocationText = \"\";\r\n      this.searchGroupText = \"\";\r\n      this.searchStoreText = \"\";\r\n      this.searchStatusText=\"\"\r\n      this.selectedFilters.stores = [];\r\n      this.selectedFilters.group = [];\r\n      this.selectedFilters.location = [];\r\n      this.selectedFilters.country = [];\r\n      this.selectedFilters.status = ['active'];\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      this.getStatus();\r\n      // Reset the filters in selectedFilters\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(\r\n        \"header-filters\",\r\n        JSON.stringify(this.selectedFilters)\r\n      );\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      // Close dropdown after reset if necessary\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  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        status: this.selectedFilters?.status?.length ? this.selectedFilters.status : ['active']\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.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.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.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.status = this.filteredStatus\r\n    .filter((s: any) => s.checked)\r\n    .map((s: any) => s.status);\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    // 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  statusVal: any;\r\n  searchStatusText: any=\"\";\r\n  filteredStatus: any = [];\r\ngetStatus(): void {\r\n  // base status list\r\n  this.statusVal = [\r\n    { status: 'active', checked: false },\r\n    { status: 'deactive', checked: false }\r\n  ];\r\n  const storedFilters = localStorage.getItem(\"header-filters\");\r\n  // if selectedFilters.status exists and has values, use them, otherwise default to [\"active\"]\r\n  const statusList: any[] =\r\n    this.selectedFilters?.status && this.selectedFilters?.status.length > 0\r\n      ? this.selectedFilters.status\r\n      : storedFilters\r\n        ? JSON.parse(storedFilters).status || ['active']\r\n        : ['active'];\r\n\r\n this.selectedFilters.status = statusList;\r\n\r\n  // mark checked based on values\r\n  this.filteredStatus = this.statusVal.map((status: any) => ({\r\n    status: status.status,\r\n    checked: statusList.includes(status.status)\r\n  }));\r\n\r\n  // if a search text already exists, filter immediately\r\n  if (this.searchStatusText) {\r\n    this.filterStatus();\r\n  }\r\n\r\n  // refresh dependent dropdowns\r\n  this.getCountry();\r\n  this.getLocations();\r\n  this.getGroups();\r\n  this.getStore();\r\n}\r\n\r\n\r\n\r\nselectedStatusLabel(): string {\r\n  const selectedStatus = this.filteredStatus\r\n    .filter((status: any) => status.checked)\r\n    .map((status: any) => status.status);\r\n\r\n  if (selectedStatus.length === 0) {\r\n    return \"\";\r\n  }\r\n\r\n  if (selectedStatus.length === 1) {\r\n    return selectedStatus[0];  // show \"active\" or \"deactive\"\r\n  }\r\n\r\n  return `${selectedStatus.length} status`;  // e.g. \"2 status\"\r\n}\r\n\r\n\r\nfilterStatus(): void {\r\n  const searchText = this.searchStatusText.toLowerCase();\r\n\r\n  if (searchText) {\r\n    this.filteredStatus = this.statusVal\r\n      .map((status: any) => ({\r\n        ...status,\r\n        checked: this.selectedFilters.status?.includes(status.status) || false\r\n      }))\r\n      .filter((status: any) => status.status.toLowerCase().includes(searchText));\r\n  } else {\r\n    this.filteredStatus = this.statusVal.map((status: any) => ({\r\n      ...status,\r\n      checked: this.selectedFilters.status?.includes(status.status) || false\r\n    }));\r\n  }\r\n}\r\n\r\n\r\n    isAllStatusSelected(): boolean {\r\n    return (\r\n      this.filteredStatus.length > 0 &&\r\n      this.filteredStatus.every((status:any) => status.checked)\r\n    );\r\n  }\r\n  toggleSelectAllStatus(event: any): void {\r\n   const isChecked = event.target.checked;\r\n\r\n  // Update UI state\r\n  this.filteredStatus.forEach((status: any) => (status.checked = isChecked));\r\n\r\n  // Update selectedFilters with only checked status values\r\n  this.selectedFilters.status = this.filteredStatus\r\n    .filter((status: any) => status.checked)\r\n    .map((status: any) => status.status);\r\n\r\n    this.updateSelectedCountries();\r\n  }\r\n\r\nupdateSelectedStatus() {\r\n  // keep only the checked statuses\r\n  const selected = this.filteredStatus\r\n    .filter((status: any) => status.checked)\r\n    .map((status: any) => status.status);  // ✅ pick only the value\r\n\r\n  this.statusVal = selected;\r\n  this.selectedFilters.status = selected;\r\n  this.updateSelectedCountries();\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","<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</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<!-- status -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\" (click)=\"toggleDropdown('status')\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\" \r\n            [value]=\"selectedStatusLabel()\"\r\n            readonly\r\n            placeholder=\"Select status\"\r\n        />\r\n    </div>\r\n    <div class=\"dropdown-menu custom-dropdown-menu\" *ngIf=\"dropdownOpen === 'status'\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control mb-2 dropdown-search\" \r\n            placeholder=\"Search status\" \r\n            [(ngModel)]=\"searchStatusText\" \r\n            (ngModelChange)=\"filterStatus()\" \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=\"selectAllStatus\" \r\n                [checked]=\"isAllStatusSelected()\" \r\n                (change)=\"toggleSelectAllStatus($event)\" \r\n            />\r\n            <label class=\"form-check-label\" for=\"selectAllStatus\">\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 status of filteredStatus\"\r\n        >\r\n        <input \r\n        class=\"form-check-input cursor-pointer\" \r\n        type=\"checkbox\" \r\n        [id]=\"status.status\" \r\n        [(ngModel)]=\"status.checked\"\r\n        (change)=\"updateSelectedStatus()\" \r\n      />\r\n      <label class=\"form-check-label text-capitalize\" [for]=\"status.status\">\r\n        {{ status.status }}\r\n      </label>\r\n      \r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n             <!-- Country Dropdown -->\r\n<div class=\"dropdown-container mt-3\" (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\r\n\r\n\r\n\r\n\r\n\r\n    </div>\r\n</div>"]}