tango-app-ui-shared 3.7.3-dev9 → 3.7.4

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