tango-app-ui-shared 3.3.1-beta.74 → 3.3.1-beta.76

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.
@@ -0,0 +1,784 @@
1
+ import { Component, HostListener, } from "@angular/core";
2
+ import dayjs from "dayjs";
3
+ import "dayjs/locale/en";
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../../../services/auth.service";
6
+ import * as i2 from "@angular/router";
7
+ import * as i3 from "tango-app-ui-global";
8
+ import * as i4 from "@angular/common";
9
+ import * as i5 from "@angular/forms";
10
+ import * as i6 from "ngx-daterangepicker-material";
11
+ export class TrafficNobComponent {
12
+ auth;
13
+ router;
14
+ gs;
15
+ cd;
16
+ dayjs = dayjs;
17
+ isCustomDate = (m) => {
18
+ const isValidDate = m > this.dayjs();
19
+ return isValidDate ? "invalid-date" : false;
20
+ };
21
+ selectedDateRange = { startDate: dayjs().subtract(30, 'days'),
22
+ endDate: dayjs().subtract(1, "days"), };
23
+ selectedFilters = {
24
+ client: null,
25
+ clientName: null,
26
+ clients: [],
27
+ store: null,
28
+ stores: [],
29
+ date: null,
30
+ group: [],
31
+ location: [],
32
+ };
33
+ Opendropdown = false;
34
+ dropdownOpen = null; // 'location' or 'group'
35
+ searchLocationText = "";
36
+ searchGroupText = "";
37
+ locations = [];
38
+ filteredLocations = [];
39
+ groupsData = [];
40
+ filteredGroups = [];
41
+ filteredStores = [];
42
+ stores = [];
43
+ searchStoreText = '';
44
+ clientList = [];
45
+ selectedClient;
46
+ locationLabel = [];
47
+ groupLabel = [];
48
+ users;
49
+ url;
50
+ constructor(auth, router, gs, cd) {
51
+ this.auth = auth;
52
+ this.router = router;
53
+ this.gs = gs;
54
+ this.cd = cd;
55
+ }
56
+ onClick(event) {
57
+ const target = event.target;
58
+ if (!target.closest('.dropdown1')) {
59
+ this.Opendropdown = false;
60
+ }
61
+ }
62
+ closeDropdown1() {
63
+ this.Opendropdown = false;
64
+ }
65
+ ngOnInit() {
66
+ this.url = this.router.url.split("?")[0].split('/');
67
+ const user = JSON.parse(localStorage.getItem('user-info'));
68
+ this.users = user;
69
+ this.gs?.manageRefreshTrigger?.subscribe((e) => {
70
+ if (e) {
71
+ if (user.userType === 'tango') {
72
+ this.getClient();
73
+ }
74
+ else {
75
+ const storedFilters = localStorage.getItem("header-filters");
76
+ if (storedFilters) {
77
+ const headerFilters = JSON.parse(storedFilters);
78
+ this.filteredStores = headerFilters?.stores.map((store) => ({
79
+ ...store,
80
+ checked: store.checked
81
+ }));
82
+ }
83
+ }
84
+ }
85
+ });
86
+ // Fetch client data if the user is of type 'tango'
87
+ if (user.userType === 'tango') {
88
+ this.getClient();
89
+ }
90
+ else {
91
+ this.getLocations();
92
+ this.getGroups();
93
+ this.getStore();
94
+ // this.emitAndStoreFilters();
95
+ // console.log("1")
96
+ }
97
+ // Load filters from localStorage if they exist
98
+ const storedFilters = localStorage.getItem("header-filters");
99
+ if (storedFilters) {
100
+ const headerFilters = JSON.parse(storedFilters);
101
+ // Initialize selectedFilters with defaults or existing values
102
+ this.selectedFilters = {
103
+ client: headerFilters.client || this.users.client,
104
+ clientName: headerFilters.clientName || '',
105
+ clients: headerFilters.clients || [],
106
+ store: headerFilters.store || null,
107
+ date: headerFilters.date || {},
108
+ stores: headerFilters.stores || [],
109
+ group: headerFilters.group || [],
110
+ location: headerFilters.location || []
111
+ };
112
+ // Sync filtered data with stored selections
113
+ this.filteredLocations = this.syncWithLocalStorage(headerFilters.location);
114
+ this.filteredGroups = this.syncWithLocalStorage(headerFilters.group);
115
+ this.filteredStores = this.syncWithLocalStorage(headerFilters.stores);
116
+ // Format date range if it exists
117
+ if (headerFilters.date) {
118
+ this.selectedDateRange = {
119
+ startDate: this.dayjs(headerFilters.date.startDate, "YYYY-MM-DD").format("DD-MM-YYYY"),
120
+ endDate: this.dayjs(headerFilters.date.endDate, "YYYY-MM-DD").format("DD-MM-YYYY"),
121
+ };
122
+ }
123
+ else {
124
+ this.selectedDateRange = {
125
+ startDate: this.dayjs(this.selectedDateRange.startDate, "YYYY-MM-DD").format("DD-MM-YYYY"),
126
+ endDate: this.dayjs(this.selectedDateRange.endDate, "YYYY-MM-DD").format("DD-MM-YYYY"),
127
+ };
128
+ }
129
+ // console.log("3")
130
+ // Emit data via service and update localStorage
131
+ this.emitAndStoreFilters();
132
+ }
133
+ else {
134
+ // Initialize empty states if no header filters are present in localStorage
135
+ this.resetFilters();
136
+ // console.log("2")
137
+ }
138
+ }
139
+ syncWithLocalStorage(items) {
140
+ return items
141
+ ? items.map((item) => ({
142
+ ...item,
143
+ checked: item.checked === true
144
+ }))
145
+ : [];
146
+ }
147
+ emitAndStoreFilters() {
148
+ this.gs.dataRangeValue.next(this.selectedFilters);
149
+ localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
150
+ // console.log("1")
151
+ }
152
+ /**
153
+ * Reset selectedFilters and all related arrays to empty states
154
+ */
155
+ resetFilters() {
156
+ this.selectedFilters = {
157
+ client: null,
158
+ clientName: '',
159
+ clients: [],
160
+ store: null,
161
+ date: {},
162
+ stores: [],
163
+ group: [],
164
+ location: []
165
+ };
166
+ this.filteredLocations = [];
167
+ this.filteredGroups = [];
168
+ this.filteredStores = [];
169
+ }
170
+ getClient() {
171
+ this.auth.getClients().subscribe({
172
+ next: (e) => {
173
+ if (e) {
174
+ this.clientList = e.data.result;
175
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
176
+ if (headerFilters.client) {
177
+ this.clientList.find((obj) => {
178
+ if (obj.clientId === headerFilters.client) {
179
+ this.selectedClient = obj;
180
+ }
181
+ });
182
+ this.selectedFilters.client = headerFilters.client;
183
+ this.selectedFilters.clientName = headerFilters.clientName;
184
+ this.selectedFilters.clients = headerFilters.clients;
185
+ this.selectedFilters.store = headerFilters.store;
186
+ this.selectedFilters.date = headerFilters.date;
187
+ this.selectedFilters.stores = headerFilters.stores;
188
+ this.selectedFilters.group = headerFilters.group;
189
+ this.selectedFilters.location = headerFilters.location;
190
+ this.gs.dataRangeValue.next(this.selectedFilters);
191
+ // console.log("2")
192
+ // Ensure locations and groups are loaded before fetching stores
193
+ this.getLocations();
194
+ this.getGroups();
195
+ // Fetch stores only after locations and groups are set
196
+ this.getStore();
197
+ }
198
+ else {
199
+ this.selectedClient = this.clientList[0];
200
+ this.selectedFilters.client = this.selectedClient.clientId;
201
+ this.selectedFilters.clientName = this.selectedClient.clientName;
202
+ this.selectedFilters.clients = headerFilters.clients;
203
+ this.selectedFilters.store = headerFilters.store;
204
+ this.selectedFilters.date = headerFilters.date;
205
+ this.selectedFilters.stores = headerFilters.stores;
206
+ this.selectedFilters.group = headerFilters.group;
207
+ this.selectedFilters.location = headerFilters.location;
208
+ localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
209
+ this.gs.dataRangeValue.next(this.selectedFilters);
210
+ // console.log("3")
211
+ this.cd.detectChanges();
212
+ // Ensure locations and groups are loaded before fetching stores
213
+ this.getLocations();
214
+ this.getGroups();
215
+ // Fetch stores only after locations and groups are set
216
+ this.getStore();
217
+ }
218
+ }
219
+ else {
220
+ this.selectedClient = this.clientList[0];
221
+ this.selectedFilters.client = this.selectedClient.clientId;
222
+ this.selectedFilters.clientName = this.selectedClient.clientName;
223
+ // Ensure locations and groups are loaded before fetching stores
224
+ this.getLocations();
225
+ this.getGroups();
226
+ // Fetch stores only after locations and groups are set
227
+ this.getStore();
228
+ localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
229
+ this.gs.dataRangeValue.next(this.selectedFilters);
230
+ // console.log("4")
231
+ this.cd.detectChanges();
232
+ }
233
+ },
234
+ });
235
+ }
236
+ onClientSelect(event) {
237
+ // Update the selected client
238
+ this.selectedClient = event;
239
+ // Clear previous filtered data and selections
240
+ this.filteredGroups = [];
241
+ this.filteredStores = [];
242
+ this.filteredLocations = [];
243
+ this.selectedFilters.stores = [];
244
+ this.selectedFilters.group = [];
245
+ this.selectedFilters.location = [];
246
+ // Fetch header filters from localStorage
247
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
248
+ // Update the selected filters with the new client
249
+ this.selectedFilters.client = this.selectedClient.clientId;
250
+ this.selectedFilters.clientName = this.selectedClient.clientName;
251
+ // Remove old store, group, and location data from the header filters
252
+ delete headerFilters.stores;
253
+ delete headerFilters.groups;
254
+ delete headerFilters.location;
255
+ // Fetch new data based on the new client
256
+ this.getLocations();
257
+ this.getStore();
258
+ this.getGroups();
259
+ // Update localStorage with the new client selection and empty filter data
260
+ localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
261
+ window.location.reload();
262
+ // Emit data to the global service
263
+ // this.gs.dataRangeValue.next(this.selectedFilters);
264
+ // Trigger change detection to reflect UI changes
265
+ this.cd.detectChanges();
266
+ }
267
+ ranges = {
268
+ Today: [dayjs(), dayjs()],
269
+ Yesterday: [dayjs().subtract(1, 'days'), dayjs().subtract(1, 'days')],
270
+ 'This Week': [dayjs().subtract(7, 'days'), dayjs().subtract(1, 'days')],
271
+ 'Last Week': [
272
+ dayjs().subtract(14, 'days').startOf('day'),
273
+ dayjs().subtract(8, 'days').endOf('day'),
274
+ ],
275
+ 'This Month': [dayjs().subtract(30, 'days'), dayjs().subtract(1, 'days')],
276
+ 'Last Month': [
277
+ dayjs().subtract(1, 'month').startOf('month'),
278
+ dayjs().subtract(1, 'month').endOf('month'),
279
+ ],
280
+ };
281
+ onStartDateChange(event) {
282
+ if (this.dayjs(event.startDate).isValid()) {
283
+ this.isCustomDate = (m) => {
284
+ const isValidDate = m > this.dayjs() || m > this.dayjs(event.startDate.add(90, "days"));
285
+ return isValidDate ? "invalid-date" : false;
286
+ };
287
+ }
288
+ }
289
+ datechange(event) {
290
+ if (event && event.startDate && event.endDate) {
291
+ if (this.dayjs(event.startDate).isValid() &&
292
+ this.dayjs(event.endDate).isValid()) {
293
+ this.selectedDateRange.startDate = event.startDate;
294
+ this.selectedDateRange.endDate = event.endDate;
295
+ var datetime = {
296
+ startDate: this.dayjs(event.startDate, "DD-MM-YYYY").format("YYYY-MM-DD"),
297
+ endDate: this.dayjs(event.endDate, "DD-MM-YYYY").format("YYYY-MM-DD"),
298
+ };
299
+ this.selectedFilters.date = datetime;
300
+ localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
301
+ window.location.reload();
302
+ // this.gs.dataRangeValue.next(this.selectedFilters);
303
+ }
304
+ }
305
+ }
306
+ opendropdown(e) {
307
+ e.stopPropagation();
308
+ this.Opendropdown = !this.Opendropdown;
309
+ }
310
+ getLocations() {
311
+ // const headerFilters: any = JSON.parse(localStorage.getItem("header-filters") || "{}");
312
+ let obj = {
313
+ clientId: this.selectedFilters.client ? this.selectedFilters.client : this.users.clientId,
314
+ city: [],
315
+ group: [],
316
+ };
317
+ this.auth.getLocation(obj).subscribe({
318
+ next: (res) => {
319
+ let cityList = this.selectedFilters?.location?.filter((location) => location.checked).map((loc) => loc.city);
320
+ // Map the fetched locations with default unchecked state
321
+ this.locations = res?.data?.locationData.map((city) => ({
322
+ city: city.city,
323
+ checked: cityList?.includes(city.city) ? true : false,
324
+ }));
325
+ // Sync the fetched locations with any stored checked values in localStorage
326
+ if (this.selectedFilters.location && Array.isArray(this.selectedFilters.location)) {
327
+ this.filteredLocations = this.locations.map(location => {
328
+ const matchedLocation = this.selectedFilters.location.find((loc) => loc.city === location.city);
329
+ return matchedLocation ? { ...location, checked: matchedLocation.checked } : location;
330
+ });
331
+ }
332
+ else {
333
+ this.filteredLocations = this.locations;
334
+ }
335
+ if (this.searchLocationText) {
336
+ this.filteredLocations = this.locations.filter((location) => location.city.toLowerCase().includes(this.searchLocationText.toLowerCase()));
337
+ }
338
+ },
339
+ error: (err) => {
340
+ console.error("Failed to fetch locations", err);
341
+ },
342
+ });
343
+ }
344
+ isAllLocationsSelected() {
345
+ return this.filteredLocations.every(location => location.checked);
346
+ }
347
+ selectedLocationsLabel() {
348
+ const selectedLocations = this.locationLabel = this.searchLocationText.length ? this.locations
349
+ .filter(location => location.checked).map(location => location.city) : this.filteredLocations
350
+ .filter(location => location.checked).map(location => location.city);
351
+ return selectedLocations.length === 0
352
+ ? ''
353
+ : selectedLocations.length === 1
354
+ ? selectedLocations[0]
355
+ : `${selectedLocations.length} locations`;
356
+ }
357
+ removeLocation() {
358
+ this.Reset();
359
+ }
360
+ getGroups() {
361
+ const city = this.locations
362
+ .filter(location => location.checked)
363
+ .map(location => location.city);
364
+ const obj = { city, clientId: this.selectedFilters.client ? this.selectedFilters.client : this.users.clientId, group: [] };
365
+ this.auth.getGroups(obj).subscribe({
366
+ next: (res) => {
367
+ let checkedGroup = this.selectedFilters?.group?.filter((group) => group.checked).map((group) => group.groupName);
368
+ const combinedGroups = res?.data?.groupData?.map((groupName) => ({
369
+ groupName: groupName.groupName,
370
+ checked: checkedGroup?.includes(groupName.groupName) ? true : false,
371
+ }));
372
+ this.groupsData = combinedGroups;
373
+ if (this.searchGroupText.length) {
374
+ this.filteredGroups = combinedGroups.filter((item) => item.groupName.toLowerCase().includes(this.searchGroupText));
375
+ }
376
+ else {
377
+ this.filteredGroups = combinedGroups;
378
+ }
379
+ // Auto-fetch stores when groups are selected
380
+ const selectedGroups = this.groupsData.filter((group) => group.checked).map((group) => group.groupName);
381
+ if (selectedGroups.length > 0) {
382
+ this.getStore(); // Fetch stores based on selected groups
383
+ }
384
+ },
385
+ error: (err) => {
386
+ console.error("Failed to fetch groups", err);
387
+ },
388
+ });
389
+ }
390
+ toggleDropdown(type) {
391
+ if (this.dropdownOpen === type) {
392
+ // If the dropdown is open, close it and avoid resetting the selected values unnecessarily
393
+ this.dropdownOpen = null;
394
+ }
395
+ else {
396
+ // Open the specific dropdown and handle data fetching only if necessary
397
+ this.dropdownOpen = type;
398
+ if (type === 'group') {
399
+ // Fetch groups only if there are selected cities and no active search text
400
+ const selectedCities = this.locations
401
+ .filter((location) => location.checked)
402
+ .map((location) => location.city);
403
+ // Fetch groups only if locations are selected, no search text exists, and dropdown is opened
404
+ if (this.filteredLocations.length > 0 || (selectedCities.length > 0 && !this.searchGroupText.trim())) {
405
+ this.getGroups();
406
+ }
407
+ else {
408
+ this.filteredGroups = []; // Clear groups if no locations are selected
409
+ }
410
+ }
411
+ if (type === 'store') {
412
+ // Fetch stores only if not already fetched and no search text is active
413
+ if ((!this.filteredStores || this.filteredStores.length === 0) && !this.searchStoreText.trim()) {
414
+ this.getStore();
415
+ }
416
+ }
417
+ }
418
+ }
419
+ handleGroupDropdownClick() {
420
+ if (this.dropdownOpen === 'group') {
421
+ this.resetSelectedGroups();
422
+ }
423
+ this.toggleDropdown('group');
424
+ }
425
+ resetSelectedGroups() {
426
+ this.filteredGroups.forEach((group) => (group.checked = false));
427
+ this.searchGroupText = "";
428
+ }
429
+ selectedGroupsLabel() {
430
+ const selectedGroups = this.groupLabel = this.searchGroupText.length ? this.groupsData.filter((group) => group.checked) : this.filteredGroups.filter((group) => group.checked);
431
+ return selectedGroups.length === 0
432
+ ? ""
433
+ : selectedGroups.length === 1
434
+ ? selectedGroups[0].groupName
435
+ : `${selectedGroups.length} groups`;
436
+ }
437
+ removeGroup() {
438
+ this.Reset();
439
+ }
440
+ isAllGroupsSelected() {
441
+ return this.filteredGroups.length ? this.filteredGroups.every((group) => group.checked) : false;
442
+ }
443
+ getStore() {
444
+ const city = this.locations
445
+ .filter(location => location.checked)
446
+ .map(location => location.city);
447
+ const group = this.groupsData
448
+ .filter(group => group.checked)
449
+ .map(group => group.groupName);
450
+ const data = { city, clusters: group, clientId: this.users.clientId ? this.users.clientId : this.selectedFilters.client };
451
+ this.auth.getHeaderStores(data).subscribe({
452
+ next: (res) => {
453
+ if (res && res.code === 200) {
454
+ this.stores = res.data.storesData;
455
+ // Retrieve checked store IDs from selectedFilters
456
+ const checkedStoreIds = this.selectedFilters?.stores
457
+ ? this.selectedFilters.stores.filter((store) => store.checked).map((store) => store.storeId)
458
+ : [];
459
+ this.stores.forEach(store => {
460
+ if (checkedStoreIds.includes(store.storeId)) {
461
+ store.checked = true; // Sync the checked state with full store list
462
+ }
463
+ });
464
+ // Map the stores and retain the 'checked' status
465
+ if (this.searchStoreText.length) {
466
+ this.filteredStores = this.stores?.filter(store => store.storeName.toLowerCase().includes(this.searchStoreText));
467
+ }
468
+ else {
469
+ this.filteredStores = this.stores;
470
+ }
471
+ // Ensure selectedFilters is in sync with filteredStores
472
+ if (!this.selectedFilters.stores || !this.selectedFilters.stores.length) {
473
+ this.stores.forEach(store => {
474
+ store.checked = true; // Sync the checked state with full store list
475
+ });
476
+ // No previously selected stores, mark all as checked
477
+ this.filteredStores = this.selectedFilters.stores = this.filteredStores.map(store => ({
478
+ ...store,
479
+ checked: true
480
+ }));
481
+ }
482
+ else {
483
+ // Update selectedFilters to reflect current state of stores
484
+ this.selectedFilters.stores = this.filteredStores.map(store => ({
485
+ ...store,
486
+ checked: store.checked
487
+ }));
488
+ }
489
+ // Update localStorage with the latest selectedFilters
490
+ localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
491
+ // Emit data via service
492
+ // this.gs.dataRangeValue.next(this.selectedFilters);
493
+ // Trigger change detection to reflect changes in the UI
494
+ this.cd.detectChanges();
495
+ }
496
+ else {
497
+ this.stores = [];
498
+ this.selectedFilters.stores = [];
499
+ this.filteredStores = [];
500
+ this.selectedFilters.stores = this.filteredStores.map(store => ({
501
+ ...store,
502
+ checked: false
503
+ }));
504
+ localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
505
+ }
506
+ },
507
+ error: (err) => {
508
+ this.stores = [];
509
+ this.selectedFilters.stores = this.filteredStores.map(store => ({
510
+ ...store,
511
+ checked: false
512
+ }));
513
+ this.filteredStores = [];
514
+ this.selectedFilters.stores = [];
515
+ localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
516
+ console.error("Failed to fetch stores", err);
517
+ },
518
+ });
519
+ }
520
+ resetSelectedStores() {
521
+ this.filteredStores.forEach((store) => (store.checked = false));
522
+ this.searchStoreText = "";
523
+ }
524
+ selectedStoresLabel() {
525
+ const selectedStores = this.searchStoreText.length ? this.stores.filter((store) => store.checked) : this.filteredStores.filter((store) => store.checked);
526
+ return selectedStores.length === 0
527
+ ? "0 Stores"
528
+ : selectedStores.length === 1
529
+ ? selectedStores[0].storeName
530
+ : `${selectedStores.length} Stores`;
531
+ }
532
+ isAllStoresSelected() {
533
+ return this.filteredStores.length > 0 && this.filteredStores.every(store => store.checked);
534
+ }
535
+ // Method to handle dropdown item selection
536
+ updateSelectedStores() {
537
+ this.filteredStores.forEach(store => {
538
+ const filteredStore = this.stores.findIndex(fStore => fStore.storeId === store.storeId);
539
+ if (filteredStore != -1) {
540
+ this.stores[filteredStore].checked = store.checked; // Sync the checked state with full store list
541
+ }
542
+ });
543
+ // Update selectedFilters based on the current store selection
544
+ this.selectedFilters.stores = this.stores.filter(store => store.checked);
545
+ // Update localStorage with the latest selection
546
+ localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
547
+ // Emit updated filters via service
548
+ // this.gs.dataRangeValue.next(this.selectedFilters);
549
+ // Trigger change detection if necessary
550
+ this.cd.detectChanges();
551
+ }
552
+ toggleSelectAllLocations(event) {
553
+ const isChecked = event.target.checked;
554
+ this.filteredLocations.forEach((location) => (location.checked = isChecked));
555
+ this.updateSelectedLocations();
556
+ }
557
+ toggleSelectAllStores(event) {
558
+ const checked = event.target.checked;
559
+ // Apply the selection to both filtered and full list of stores
560
+ this.filteredStores.forEach(store => store.checked = checked);
561
+ this.stores.forEach(store => {
562
+ const filteredStore = this.filteredStores.find(fStore => fStore.storeId === store.storeId);
563
+ if (filteredStore) {
564
+ store.checked = checked; // Sync the checked state with full store list
565
+ }
566
+ });
567
+ // Update the selected stores and persist the selection
568
+ this.updateSelectedStores();
569
+ }
570
+ updateSelectedLocations() {
571
+ // When locations are selected, fetch the related groups
572
+ const selectedCities = this.filteredLocations
573
+ .filter((location) => location.checked)
574
+ .map((location) => location.city);
575
+ this.filteredLocations.forEach((location) => {
576
+ let findLocationIndex = this.locations.findIndex((loc) => loc.city == location.city);
577
+ if (findLocationIndex != -1) {
578
+ this.locations[findLocationIndex].checked = location.checked;
579
+ }
580
+ });
581
+ if (selectedCities.length > 0 || !selectedCities.length) {
582
+ this.selectedFilters.stores = [];
583
+ this.selectedFilters.location = this.locations;
584
+ this.getGroups(); // Fetch groups based on selected cities
585
+ // If there are selected groups, fetch the stores based on selected groups
586
+ this.getStore();
587
+ }
588
+ else {
589
+ this.filteredGroups = []; // Clear groups if no locations are selected
590
+ this.selectedFilters.location = [];
591
+ }
592
+ this.selectedFilters.group = [];
593
+ this.filteredStores = []; // Reset stores as well
594
+ this.searchGroupText = '';
595
+ this.searchStoreText = '';
596
+ // this.Opendropdown = false;
597
+ }
598
+ toggleSelectAllGroups(event) {
599
+ const isChecked = event.target.checked;
600
+ this.filteredGroups.forEach((group) => (group.checked = isChecked));
601
+ this.updateSelectedGroups();
602
+ // if (!isChecked) {
603
+ // this.selectedFilters.stores =[];
604
+ // // If there are selected groups, fetch the stores based on selected groups
605
+ // this.getStore();
606
+ // }
607
+ }
608
+ updateSelectedGroups() {
609
+ // Fetch the relevant stores after groups are selected
610
+ const selectedGroups = this.filteredGroups
611
+ .filter((group) => group.checked)
612
+ .map((group) => group.groupName);
613
+ this.filteredGroups.forEach((group) => {
614
+ let findGroupIndex = this.groupsData.findIndex((item) => item.groupName == group.groupName);
615
+ if (findGroupIndex != -1) {
616
+ this.groupsData[findGroupIndex].checked = group.checked;
617
+ }
618
+ });
619
+ if (selectedGroups.length > 0 || !selectedGroups.length) {
620
+ this.selectedFilters.stores = [];
621
+ // If there are selected groups, fetch the stores based on selected groups
622
+ this.getStore();
623
+ this.selectedFilters.group = this.groupsData;
624
+ }
625
+ else {
626
+ // If no groups are selected, clear the stores list
627
+ this.filteredStores = [];
628
+ // Also, update localStorage to reflect the cleared store selection
629
+ this.selectedFilters.stores = [];
630
+ localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
631
+ // Emit data via service
632
+ // this.gs.dataRangeValue.next(this.selectedFilters);
633
+ }
634
+ // Clear the search store text when groups are updated
635
+ this.searchStoreText = '';
636
+ }
637
+ Reset() {
638
+ // Clear selected groups, stores, and locations
639
+ this.filteredGroups = [];
640
+ this.filteredStores = [];
641
+ this.filteredLocations = []; // Reset locations as well
642
+ // Clear search input fields
643
+ this.searchLocationText = "";
644
+ this.searchGroupText = "";
645
+ this.searchStoreText = "";
646
+ // Fetch locations, groups, and stores again
647
+ this.getLocations();
648
+ this.getStore();
649
+ this.getGroups();
650
+ // Reset the filters in selectedFilters
651
+ this.selectedFilters = {
652
+ ...this.selectedFilters,
653
+ stores: [],
654
+ group: [],
655
+ location: [] // Clear locations selection
656
+ };
657
+ // // Once stores are fetched, mark all as checked
658
+ // setTimeout(() => {
659
+ // this.filteredStores = this.stores.map(store => ({
660
+ // ...store,
661
+ // checked: true // Mark all stores as checked
662
+ // }));
663
+ // // Sync selectedFilters with the updated store state
664
+ // this.selectedFilters.stores = this.filteredStores.map(store => ({
665
+ // ...store,
666
+ // checked: true
667
+ // }));
668
+ // Update localStorage with the latest selectedFilters
669
+ localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
670
+ window.location.reload();
671
+ // Emit the reset filters to update other components if needed
672
+ // this.gs.dataRangeValue.next(this.selectedFilters);
673
+ // Trigger change detection
674
+ this.cd.detectChanges();
675
+ // Adding a slight delay to ensure stores are fetched first
676
+ // Close dropdown after reset if necessary
677
+ this.Opendropdown = false;
678
+ }
679
+ Apply() {
680
+ // Close the dropdown
681
+ this.Opendropdown = false;
682
+ // Fetch existing filters from localStorage
683
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
684
+ this.selectedFilters.store = null;
685
+ // Ensure current selections are reflected
686
+ this.selectedFilters.location = this.locations;
687
+ this.selectedFilters.group = this.groupsData;
688
+ this.selectedFilters.stores = headerFilters.stores ? headerFilters.stores : this.stores;
689
+ // Store updated filters back in localStorage
690
+ localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
691
+ window.location.reload();
692
+ // Emit the updated filters via the service
693
+ // this.gs.dataRangeValue.next(this.selectedFilters);
694
+ // Trigger refresh if necessary
695
+ // this.gs.manageRefreshTrigger.next(true);
696
+ this.cd.detectChanges();
697
+ }
698
+ filterLocations() {
699
+ const searchText = this.searchLocationText.toLowerCase();
700
+ if (searchText) {
701
+ // Preserve the checked state during filtering
702
+ this.filteredLocations = this.locations
703
+ .map(location => ({
704
+ ...location,
705
+ checked: this.filteredLocations.find(l => l.city === location.city)?.checked || false
706
+ }))
707
+ .filter(location => location?.city?.toLowerCase().includes(searchText));
708
+ }
709
+ else {
710
+ // Restore the original checked state when search text is cleared
711
+ this.filteredLocations = this.locations.map(location => ({
712
+ ...location,
713
+ checked: this.selectedFilters.location.find((l) => l.city === location.city)?.checked || false
714
+ }));
715
+ }
716
+ }
717
+ filterGroups() {
718
+ const searchText = this.searchGroupText.toLowerCase();
719
+ if (searchText) {
720
+ // Preserve the checked state during filtering
721
+ this.filteredGroups = this.groupsData
722
+ .map(group => ({
723
+ ...group,
724
+ checked: this.filteredGroups.find(g => g.groupName === group.groupName)?.checked || false
725
+ }))
726
+ .filter(group => group?.groupName?.toLowerCase().includes(searchText));
727
+ }
728
+ else {
729
+ // Restore the original checked state when search text is cleared
730
+ this.filteredGroups = this.groupsData.map(group => ({
731
+ ...group,
732
+ checked: this.selectedFilters.group.find((g) => g.groupName === group.groupName)?.checked || false
733
+ }));
734
+ }
735
+ }
736
+ filterStores() {
737
+ const searchText = this.searchStoreText.toLowerCase();
738
+ // Preserve checked states during filtering
739
+ if (searchText) {
740
+ // Filter based on search text while preserving checked state
741
+ this.filteredStores = this.stores
742
+ .map(store => ({
743
+ ...store,
744
+ // Check if the store is already checked in filteredStores, fallback to original stores' checked state
745
+ checked: this.selectedFilters.stores.find((s) => s.storeId === store.storeId)?.checked || store.checked || false
746
+ }))
747
+ .filter(store => store.storeName.toLowerCase().includes(searchText));
748
+ }
749
+ else {
750
+ // When the search text is cleared, restore the original list with preserved checked states
751
+ this.filteredStores = this.stores.map(store => ({
752
+ ...store,
753
+ // Preserve the checked state based on the selected filters
754
+ checked: this.selectedFilters.stores.find((s) => s.storeId === store.storeId)?.checked || store.checked || false
755
+ }));
756
+ }
757
+ }
758
+ closeDropdown() {
759
+ this.dropdownOpen = null;
760
+ }
761
+ clickOutside(event) {
762
+ const clickedInside = event.target.closest(".dropdown-container");
763
+ const clickedoutSide = event.target.closest(".dropdown1");
764
+ if (!clickedInside) {
765
+ this.closeDropdown();
766
+ }
767
+ if (!clickedoutSide) {
768
+ this.closeDropdown1();
769
+ }
770
+ }
771
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TrafficNobComponent, deps: [{ token: i1.AuthService }, { token: i2.Router }, { token: i3.GlobalStateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
772
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TrafficNobComponent, selector: "lib-traffic-nob", host: { listeners: { "document:click": "clickOutside($event)" } }, ngImport: i0, template: "<div class=\"me-3\">\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<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 dropdown1 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 <!-- Location Dropdown -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedLocationsLabel()\"\r\n (focus)=\"toggleDropdown('location')\" \r\n readonly\r\n placeholder=\"Select locations...\"\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 locations...\" \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 Locations\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}.dropdown1{position:absolute;top:70px;min-width:270px!important}.dropdown1 .dropdown-title{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:24px}.dropdown1 .dropdown{position:relative;display:inline-block}.dropdown1 .dropdown span{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:20px}::ng-deep .dropdown1{z-index:1!important}.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: "directive", type: i5.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: i5.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i6.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"] }] });
773
+ }
774
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TrafficNobComponent, decorators: [{
775
+ type: Component,
776
+ args: [{ selector: 'lib-traffic-nob', template: "<div class=\"me-3\">\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<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 dropdown1 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 <!-- Location Dropdown -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n <div class=\"dropdown-header\">\r\n <input \r\n type=\"text\" \r\n class=\"form-control dropdown-input cursor-pointer\" \r\n [value]=\"selectedLocationsLabel()\"\r\n (focus)=\"toggleDropdown('location')\" \r\n readonly\r\n placeholder=\"Select locations...\"\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 locations...\" \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 Locations\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}.dropdown1{position:absolute;top:70px;min-width:270px!important}.dropdown1 .dropdown-title{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:24px}.dropdown1 .dropdown{position:relative;display:inline-block}.dropdown1 .dropdown span{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:20px}::ng-deep .dropdown1{z-index:1!important}.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"] }]
777
+ }], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.Router }, { type: i3.GlobalStateService }, { type: i0.ChangeDetectorRef }], propDecorators: { onClick: [{
778
+ type: HostListener,
779
+ args: ['document:click', ['$event']]
780
+ }], clickOutside: [{
781
+ type: HostListener,
782
+ args: ["document:click", ["$event"]]
783
+ }] } });
784
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"traffic-nob.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/traffic-nob/traffic-nob.component.ts","../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/traffic-nob/traffic-nob.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  HostListener,\r\n  OnDestroy,\r\n  OnInit,\r\n} from \"@angular/core\";\r\nimport dayjs from \"dayjs\";\r\nimport \"dayjs/locale/en\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\nimport { NavigationEnd, Router } from \"@angular/router\";\r\nimport { AuthService } from \"../../../../services/auth.service\";\r\n@Component({\r\n  selector: 'lib-traffic-nob',\r\n  templateUrl: './traffic-nob.component.html',\r\n  styleUrl: './traffic-nob.component.scss'\r\n})\r\nexport class TrafficNobComponent 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  };\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  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('.dropdown1')) {\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.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.getLocations();\r\n      this.getGroups();\r\n      this.getStore();\r\n//       this.emitAndStoreFilters();\r\n// console.log(\"1\")\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      };\r\n  \r\n      // Sync filtered data with stored selections\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        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  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    };\r\n    this.filteredLocations = [];\r\n    this.filteredGroups = [];\r\n    this.filteredStores = [];\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        \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.gs.dataRangeValue.next(this.selectedFilters);\r\n          // console.log(\"2\")\r\n                 // Ensure locations and groups are loaded before fetching stores\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        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.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.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    },\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\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  \r\n  // Fetch new data based on the new client\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     \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    }\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 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     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?.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      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch locations\", err);\r\n      },\r\n    });\r\n  }\r\n  \r\n  isAllLocationsSelected(): boolean {\r\n    return this.filteredLocations.every(location => location.checked);\r\n\r\n  }\r\n  \r\n  selectedLocationsLabel(): string {\r\n    const selectedLocations = this.locationLabel = this.searchLocationText.length ? this.locations\r\n      .filter(location => location.checked).map(location => location.city) :  this.filteredLocations\r\n      .filter(location => location.checked).map(location => location.city);\r\n    return selectedLocations.length === 0\r\n      ? ''\r\n      : selectedLocations.length === 1\r\n      ? selectedLocations[0]\r\n      : `${selectedLocations.length} locations`;\r\n  }\r\n\r\n  removeLocation(): void {\r\n    this.Reset();\r\n  }\r\n  \r\n  getGroups(): void {    \r\n    const city = this.locations\r\n      .filter(location => location.checked)\r\n      .map(location => location.city);\r\n    const obj = { 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        }));\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          this.getStore(); // Fetch stores based on selected groups\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: '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 === '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} groups`;\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 city = this.locations\r\n      .filter(location => location.checked)\r\n      .map(location => location.city);\r\n  \r\n    const group = this.groupsData\r\n      .filter(group => group.checked)\r\n      .map(group => group.groupName);\r\n  \r\n    const data = { city, clusters:group, clientId: this.users.clientId ? this.users.clientId : this.selectedFilters.client };\r\n  \r\n    this.auth.getHeaderStores(data).subscribe({\r\n      next: (res: any) => {\r\n        if(res &&res.code ===200){\r\n        this.stores = res.data.storesData;      \r\n        // Retrieve checked store IDs from selectedFilters\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\r\n        this.stores.forEach(store => {\r\n          if (checkedStoreIds.includes(store.storeId)) {\r\n            store.checked = true; // Sync the checked state with full store list\r\n          }\r\n        });\r\n        \r\n  \r\n        // Map the stores and retain the 'checked' status\r\n        if(this.searchStoreText.length) {\r\n          this.filteredStores = this.stores?.filter(store => store.storeName.toLowerCase().includes(this.searchStoreText));\r\n        }\r\n        else {\r\n          this.filteredStores = this.stores;\r\n        }\r\n        // Ensure selectedFilters is in sync with filteredStores\r\n        if (!this.selectedFilters.stores || !this.selectedFilters.stores.length) {\r\n          this.stores.forEach(store => {\r\n            store.checked = true; // Sync the checked state with full store list\r\n          });\r\n          \r\n          // No previously selected stores, mark all as checked\r\n       this.filteredStores = this.selectedFilters.stores = this.filteredStores.map(store => ({\r\n            ...store,\r\n            checked: true\r\n          }));\r\n        } else {\r\n          // Update selectedFilters to reflect current state of stores\r\n          this.selectedFilters.stores = this.filteredStores.map(store => ({\r\n            ...store,\r\n            checked: store.checked\r\n          }));\r\n        }\r\n        // Update localStorage with the latest selectedFilters\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        // Trigger change detection to reflect changes in the UI\r\n        this.cd.detectChanges();\r\n      } else {\r\n        this.stores =[];\r\n        this.selectedFilters.stores=[];\r\n        this.filteredStores =[];\r\n        this.selectedFilters.stores = this.filteredStores.map(store => ({\r\n          ...store,\r\n          checked: false\r\n        }));\r\n        localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n      }\r\n    },\r\n      error: (err) => {\r\n        this.stores =[];   \r\n        this.selectedFilters.stores = this.filteredStores.map(store => ({\r\n          ...store,\r\n          checked: false\r\n        }));\r\n        this.filteredStores =[];\r\n        this.selectedFilters.stores=[];\r\n        localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n        console.error(\"Failed to fetch stores\", err);\r\n      },\r\n    });\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 ? 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.selectedFilters.location = this.locations;\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    } else {\r\n      this.filteredGroups = []; // Clear groups if no locations are selected\r\n      this.selectedFilters.location = []\r\n    }\r\n    this.selectedFilters.group = [];\r\n  \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    // if (!isChecked) {\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    //  }\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     // Clear selected groups, stores, and locations\r\n  this.filteredGroups = [];\r\n  this.filteredStores = [];\r\n  this.filteredLocations = []; // Reset locations as well\r\n\r\n  // Clear search input fields\r\n  this.searchLocationText = \"\";\r\n  this.searchGroupText = \"\";\r\n  this.searchStoreText = \"\";\r\n\r\n  // Fetch locations, groups, and stores again\r\n  this.getLocations();\r\n  this.getStore();\r\n  this.getGroups();\r\n  // Reset the filters in selectedFilters\r\n  this.selectedFilters = {\r\n    ...this.selectedFilters,\r\n    stores: [],  // Clear stores selection\r\n    group: [],   // Clear groups selection\r\n    location: [] // Clear locations selection\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  }\r\n  \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    // Ensure current selections are reflected\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  \r\n  \r\n    // Store updated filters back in localStorage\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(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  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  \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      \".dropdown1\"\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\ninterface City {\r\n  city: string;\r\n}\r\n\r\ninterface Location {\r\n  city: City;\r\n  checked: boolean;\r\n}\r\n\r\n\r\n","<div class=\"me-3\">\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<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 dropdown1 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     <!-- Location Dropdown -->\r\n<div class=\"dropdown-container\" (clickOutside)=\"closeDropdown()\">\r\n    <div class=\"dropdown-header\">\r\n        <input \r\n            type=\"text\" \r\n            class=\"form-control dropdown-input cursor-pointer\" \r\n            [value]=\"selectedLocationsLabel()\"\r\n            (focus)=\"toggleDropdown('location')\" \r\n            readonly\r\n            placeholder=\"Select locations...\"\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 locations...\" \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 Locations\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>"]}