tango-app-ui-shared 3.3.0-beta.0 → 3.3.0-beta.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/modules/common/filters/filters.component.mjs +3 -3
- package/esm2022/lib/modules/layout/layout.module.mjs +5 -2
- package/esm2022/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.mjs +3 -3
- package/esm2022/lib/modules/layout/sidebar/sidebar-menu/sidebar-menu.component.mjs +3 -3
- package/esm2022/lib/modules/layout/toolbar/date-single-select/date-single-select.component.mjs +3 -3
- package/esm2022/lib/modules/layout/toolbar/datepicker/datepicker.component.mjs +3 -3
- package/esm2022/lib/modules/layout/toolbar/single-store/single-store.component.mjs +3 -3
- package/esm2022/lib/modules/layout/toolbar/toolbar.component.mjs +29 -14
- package/esm2022/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.mjs +561 -0
- package/esm2022/lib/services/auth.service.mjs +12 -1
- package/fesm2022/tango-app-ui-shared.mjs +604 -26
- package/fesm2022/tango-app-ui-shared.mjs.map +1 -1
- package/lib/modules/layout/layout.module.d.ts +11 -10
- package/lib/modules/layout/toolbar/toolbar.component.d.ts +2 -1
- package/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.d.ts +66 -0
- package/lib/services/auth.service.d.ts +4 -0
- package/package.json +1 -1
|
@@ -0,0 +1,561 @@
|
|
|
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 "tango-app-ui-global";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
import * as i4 from "../../../../common/custom-select/custom-select.component";
|
|
9
|
+
import * as i5 from "@angular/forms";
|
|
10
|
+
import * as i6 from "ngx-daterangepicker-material";
|
|
11
|
+
export class TrafficHeaderComponent {
|
|
12
|
+
auth;
|
|
13
|
+
gs;
|
|
14
|
+
cd;
|
|
15
|
+
dayjs = dayjs;
|
|
16
|
+
isCustomDate = (m) => {
|
|
17
|
+
const isValidDate = m > this.dayjs();
|
|
18
|
+
return isValidDate ? "invalid-date" : false;
|
|
19
|
+
};
|
|
20
|
+
selectedDateRange = {};
|
|
21
|
+
selectedFilters = {
|
|
22
|
+
client: null,
|
|
23
|
+
clientName: null,
|
|
24
|
+
clients: [],
|
|
25
|
+
store: null,
|
|
26
|
+
stores: [],
|
|
27
|
+
date: null,
|
|
28
|
+
group: [],
|
|
29
|
+
location: [],
|
|
30
|
+
};
|
|
31
|
+
Opendropdown = false;
|
|
32
|
+
dropdownOpen = null; // 'location' or 'group'
|
|
33
|
+
searchLocationText = "";
|
|
34
|
+
searchGroupText = "";
|
|
35
|
+
locations = [];
|
|
36
|
+
filteredLocations = [];
|
|
37
|
+
groupsData = [];
|
|
38
|
+
filteredGroups = [];
|
|
39
|
+
filteredStores = [];
|
|
40
|
+
stores = [];
|
|
41
|
+
searchStoreText = '';
|
|
42
|
+
clientList = [];
|
|
43
|
+
selectedClient;
|
|
44
|
+
constructor(auth, gs, cd) {
|
|
45
|
+
this.auth = auth;
|
|
46
|
+
this.gs = gs;
|
|
47
|
+
this.cd = cd;
|
|
48
|
+
}
|
|
49
|
+
onClick(event) {
|
|
50
|
+
const target = event.target;
|
|
51
|
+
if (!target.closest('.dropdown1')) {
|
|
52
|
+
this.Opendropdown = false;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
closeDropdown1() {
|
|
56
|
+
this.Opendropdown = false;
|
|
57
|
+
}
|
|
58
|
+
ngOnInit() {
|
|
59
|
+
const user = JSON.parse(localStorage.getItem('user-info'));
|
|
60
|
+
// Fetch client data if the user is of type 'tango'
|
|
61
|
+
if (user.userType === 'tango') {
|
|
62
|
+
this.getClient();
|
|
63
|
+
}
|
|
64
|
+
// Load filters from localStorage if they exist
|
|
65
|
+
if ("header-filters" in localStorage) {
|
|
66
|
+
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
67
|
+
// Load and set selected filters from localStorage
|
|
68
|
+
this.selectedFilters.client = headerFilters.client;
|
|
69
|
+
this.selectedFilters.clientName = headerFilters.clientName;
|
|
70
|
+
this.selectedFilters.clients = headerFilters.clients;
|
|
71
|
+
this.selectedFilters.store = headerFilters.store;
|
|
72
|
+
this.selectedFilters.date = headerFilters.date;
|
|
73
|
+
this.selectedFilters.stores = headerFilters.stores;
|
|
74
|
+
this.selectedFilters.group = headerFilters.group;
|
|
75
|
+
this.selectedFilters.location = headerFilters.location;
|
|
76
|
+
// Sync selected locations and groups with filtered data
|
|
77
|
+
this.filteredLocations = headerFilters.location
|
|
78
|
+
? headerFilters.location.map((item) => ({ ...item, checked: item.checked === true }))
|
|
79
|
+
: [];
|
|
80
|
+
this.filteredGroups = headerFilters.group
|
|
81
|
+
? headerFilters.group.map((item) => ({ ...item, checked: item.checked === true }))
|
|
82
|
+
: [];
|
|
83
|
+
// Check if header filters contain stores
|
|
84
|
+
if (headerFilters.stores) {
|
|
85
|
+
this.filteredStores = headerFilters.stores.map((item) => ({
|
|
86
|
+
...item,
|
|
87
|
+
checked: item.checked === true // Ensure `checked` is properly set
|
|
88
|
+
}));
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
this.filteredStores = []; // Handle empty stores array case
|
|
92
|
+
}
|
|
93
|
+
// Format date range if it exists
|
|
94
|
+
if (headerFilters.date) {
|
|
95
|
+
this.selectedDateRange = {
|
|
96
|
+
startDate: this.dayjs(headerFilters.date.startDate, "YYYY-MM-DD").format("DD-MM-YYYY"),
|
|
97
|
+
endDate: this.dayjs(headerFilters.date.endDate, "YYYY-MM-DD").format("DD-MM-YYYY"),
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
// Emit data via service
|
|
101
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
102
|
+
// Update localStorage with the latest selectedFilters
|
|
103
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
getClient() {
|
|
107
|
+
this.auth.getClients().subscribe({
|
|
108
|
+
next: (e) => {
|
|
109
|
+
if (e) {
|
|
110
|
+
this.clientList = e.data.result;
|
|
111
|
+
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
112
|
+
if (headerFilters.client) {
|
|
113
|
+
this.clientList.find((obj) => {
|
|
114
|
+
if (obj.clientId === headerFilters.client) {
|
|
115
|
+
this.selectedClient = obj;
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
this.selectedFilters.client = headerFilters.client;
|
|
119
|
+
this.selectedFilters.clientName = headerFilters.clientName;
|
|
120
|
+
this.selectedFilters.clients = headerFilters.clients;
|
|
121
|
+
this.selectedFilters.store = headerFilters.store;
|
|
122
|
+
this.selectedFilters.date = headerFilters.date;
|
|
123
|
+
this.selectedFilters.stores = headerFilters.stores;
|
|
124
|
+
this.selectedFilters.group = headerFilters.group;
|
|
125
|
+
this.selectedFilters.location = headerFilters.location;
|
|
126
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
this.selectedClient = this.clientList[0];
|
|
130
|
+
this.selectedFilters.client = this.selectedClient.clientId;
|
|
131
|
+
this.selectedFilters.clientName = this.selectedClient.clientName;
|
|
132
|
+
this.selectedFilters.clients = headerFilters.clients;
|
|
133
|
+
this.selectedFilters.store = headerFilters.store;
|
|
134
|
+
this.selectedFilters.date = headerFilters.date;
|
|
135
|
+
this.selectedFilters.stores = headerFilters.stores;
|
|
136
|
+
this.selectedFilters.group = headerFilters.group;
|
|
137
|
+
this.selectedFilters.location = headerFilters.location;
|
|
138
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
139
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
140
|
+
this.cd.detectChanges();
|
|
141
|
+
}
|
|
142
|
+
// Ensure locations and groups are loaded before fetching stores
|
|
143
|
+
this.getLocations();
|
|
144
|
+
// Fetch stores only after locations and groups are set
|
|
145
|
+
this.getStore();
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
this.selectedClient = this.clientList[0];
|
|
149
|
+
this.selectedFilters.client = this.selectedClient.clientId;
|
|
150
|
+
this.selectedFilters.clientName = this.selectedClient.clientName;
|
|
151
|
+
// Ensure locations and groups are loaded before fetching stores
|
|
152
|
+
this.getLocations();
|
|
153
|
+
// Fetch stores only after locations and groups are set
|
|
154
|
+
this.getStore();
|
|
155
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
156
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
157
|
+
this.cd.detectChanges();
|
|
158
|
+
}
|
|
159
|
+
},
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
onClientSelect(event) {
|
|
163
|
+
// Update the selected client
|
|
164
|
+
this.selectedClient = event;
|
|
165
|
+
// Clear the previous filtered stores since the client has changed
|
|
166
|
+
this.filteredStores = [];
|
|
167
|
+
this.selectedFilters.stores = [];
|
|
168
|
+
// Fetch header filters from localStorage
|
|
169
|
+
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
170
|
+
// Update the selected filters with the new client
|
|
171
|
+
this.selectedFilters.client = this.selectedClient.clientId;
|
|
172
|
+
this.selectedFilters.clientName = this.selectedClient.clientName;
|
|
173
|
+
// Remove old store data from the selectedFilters since we are fetching new stores for the new client
|
|
174
|
+
delete headerFilters.stores;
|
|
175
|
+
// Update localStorage with the new client selection and empty store data
|
|
176
|
+
localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
|
|
177
|
+
// Fetch new stores based on the new client
|
|
178
|
+
this.getStore();
|
|
179
|
+
// Emit data to the global service
|
|
180
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
181
|
+
// Trigger change detection to reflect UI changes
|
|
182
|
+
this.cd.detectChanges();
|
|
183
|
+
}
|
|
184
|
+
ranges = {
|
|
185
|
+
Today: [this.dayjs(), this.dayjs()],
|
|
186
|
+
Yesterday: [
|
|
187
|
+
this.dayjs().subtract(1, "days"),
|
|
188
|
+
this.dayjs().subtract(1, "days"),
|
|
189
|
+
],
|
|
190
|
+
"This Week": [this.dayjs().subtract(6, "days"), this.dayjs()],
|
|
191
|
+
"Last Week": [
|
|
192
|
+
this.dayjs().subtract(14, "days").startOf("days"),
|
|
193
|
+
this.dayjs().subtract(8, "days").endOf("days"),
|
|
194
|
+
],
|
|
195
|
+
"This Month": [this.dayjs().startOf("month"), this.dayjs().endOf("month")],
|
|
196
|
+
"Last Month": [
|
|
197
|
+
this.dayjs().subtract(1, "month").startOf("month"),
|
|
198
|
+
this.dayjs().subtract(1, "month").endOf("month"),
|
|
199
|
+
],
|
|
200
|
+
};
|
|
201
|
+
onStartDateChange(event) {
|
|
202
|
+
if (this.dayjs(event.startDate).isValid()) {
|
|
203
|
+
this.isCustomDate = (m) => {
|
|
204
|
+
const isValidDate = m > this.dayjs() || m > this.dayjs(event.startDate.add(90, "days"));
|
|
205
|
+
return isValidDate ? "invalid-date" : false;
|
|
206
|
+
};
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
datechange(event) {
|
|
210
|
+
if (event && event.startDate && event.endDate) {
|
|
211
|
+
if (this.dayjs(event.startDate).isValid() &&
|
|
212
|
+
this.dayjs(event.endDate).isValid()) {
|
|
213
|
+
this.selectedDateRange.startDate = event.startDate;
|
|
214
|
+
this.selectedDateRange.endDate = event.endDate;
|
|
215
|
+
var datetime = {
|
|
216
|
+
startDate: this.dayjs(event.startDate, "DD-MM-YYYY").format("YYYY-MM-DD"),
|
|
217
|
+
endDate: this.dayjs(event.endDate, "DD-MM-YYYY").format("YYYY-MM-DD"),
|
|
218
|
+
};
|
|
219
|
+
this.selectedFilters.date = datetime;
|
|
220
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
221
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
opendropdown(e) {
|
|
226
|
+
e.stopPropagation();
|
|
227
|
+
this.Opendropdown = !this.Opendropdown;
|
|
228
|
+
}
|
|
229
|
+
getLocations() {
|
|
230
|
+
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
231
|
+
let obj = {
|
|
232
|
+
clientId: headerFilters.client,
|
|
233
|
+
city: [],
|
|
234
|
+
group: [],
|
|
235
|
+
};
|
|
236
|
+
this.auth.getLocation(obj).subscribe({
|
|
237
|
+
next: (res) => {
|
|
238
|
+
// Map the fetched locations with default unchecked state
|
|
239
|
+
this.locations = res.data.locationData.map((city) => ({
|
|
240
|
+
city: city.city,
|
|
241
|
+
checked: false,
|
|
242
|
+
}));
|
|
243
|
+
// Sync the fetched locations with any stored checked values in localStorage
|
|
244
|
+
if (this.selectedFilters.location && Array.isArray(this.selectedFilters.location)) {
|
|
245
|
+
this.filteredLocations = this.locations.map(location => {
|
|
246
|
+
const matchedLocation = this.selectedFilters.location.find((loc) => loc.city === location.city);
|
|
247
|
+
return matchedLocation ? { ...location, checked: matchedLocation.checked } : location;
|
|
248
|
+
});
|
|
249
|
+
}
|
|
250
|
+
else {
|
|
251
|
+
this.filteredLocations = this.locations;
|
|
252
|
+
}
|
|
253
|
+
},
|
|
254
|
+
error: (err) => {
|
|
255
|
+
console.error("Failed to fetch locations", err);
|
|
256
|
+
},
|
|
257
|
+
});
|
|
258
|
+
}
|
|
259
|
+
isAllLocationsSelected() {
|
|
260
|
+
return this.filteredLocations.every(location => location.checked);
|
|
261
|
+
}
|
|
262
|
+
selectedLocationsLabel() {
|
|
263
|
+
const selectedLocations = this.filteredLocations
|
|
264
|
+
.filter(location => location.checked)
|
|
265
|
+
.map(location => location.city);
|
|
266
|
+
return selectedLocations.length === 0
|
|
267
|
+
? ''
|
|
268
|
+
: selectedLocations.length === 1
|
|
269
|
+
? selectedLocations[0]
|
|
270
|
+
: `${selectedLocations.length} locations selected`;
|
|
271
|
+
}
|
|
272
|
+
getGroups(cities) {
|
|
273
|
+
const obj = { city: cities, clientId: this.selectedFilters.client, group: [] };
|
|
274
|
+
this.auth.getGroups(obj).subscribe({
|
|
275
|
+
next: (res) => {
|
|
276
|
+
let checkedGroup = this.filteredGroups.filter((group) => group.checked).map((group) => group.groupName);
|
|
277
|
+
const combinedGroups = res.data.groupData.map((groupName) => ({
|
|
278
|
+
groupName: groupName.groupName,
|
|
279
|
+
checked: checkedGroup.includes(groupName.groupName) ? true : false,
|
|
280
|
+
}));
|
|
281
|
+
this.groupsData = combinedGroups;
|
|
282
|
+
this.filteredGroups = combinedGroups;
|
|
283
|
+
// Auto-fetch stores when groups are selected
|
|
284
|
+
const selectedGroups = this.filteredGroups.filter((group) => group.checked).map((group) => group.groupName);
|
|
285
|
+
if (selectedGroups.length > 0) {
|
|
286
|
+
this.getStore(); // Fetch stores based on selected groups
|
|
287
|
+
}
|
|
288
|
+
},
|
|
289
|
+
error: (err) => {
|
|
290
|
+
console.error("Failed to fetch groups", err);
|
|
291
|
+
},
|
|
292
|
+
});
|
|
293
|
+
}
|
|
294
|
+
toggleDropdown(type) {
|
|
295
|
+
if (this.dropdownOpen === type) {
|
|
296
|
+
this.dropdownOpen = null;
|
|
297
|
+
if (type === 'group') {
|
|
298
|
+
this.resetSelectedGroups();
|
|
299
|
+
}
|
|
300
|
+
if (type === 'store') {
|
|
301
|
+
this.resetSelectedStores();
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
else {
|
|
305
|
+
this.dropdownOpen = type;
|
|
306
|
+
if (type === 'group') {
|
|
307
|
+
const selectedCities = this.filteredLocations
|
|
308
|
+
.filter((location) => location.checked)
|
|
309
|
+
.map((location) => location.city);
|
|
310
|
+
if (selectedCities.length > 0 && !this.searchGroupText.trim().length) {
|
|
311
|
+
this.getGroups(selectedCities);
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
if (type === 'store') {
|
|
315
|
+
if (!this.searchStoreText.trim().length) {
|
|
316
|
+
// Only fetch stores if not already fetched
|
|
317
|
+
if (!this.filteredStores || this.filteredStores.length === 0) {
|
|
318
|
+
this.getStore();
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
handleGroupDropdownClick() {
|
|
325
|
+
if (this.dropdownOpen === 'group') {
|
|
326
|
+
this.resetSelectedGroups();
|
|
327
|
+
}
|
|
328
|
+
this.toggleDropdown('group');
|
|
329
|
+
}
|
|
330
|
+
resetSelectedGroups() {
|
|
331
|
+
this.filteredGroups.forEach((group) => (group.checked = false));
|
|
332
|
+
this.searchGroupText = "";
|
|
333
|
+
}
|
|
334
|
+
selectedGroupsLabel() {
|
|
335
|
+
const selectedGroups = this.filteredGroups.filter((group) => group.checked);
|
|
336
|
+
return selectedGroups.length === 0
|
|
337
|
+
? "No groups selected"
|
|
338
|
+
: selectedGroups.length === 1
|
|
339
|
+
? selectedGroups[0].groupName
|
|
340
|
+
: `${selectedGroups.length} groups selected`;
|
|
341
|
+
}
|
|
342
|
+
isAllGroupsSelected() {
|
|
343
|
+
return this.filteredGroups.length ? this.filteredGroups.every((group) => group.checked) : false;
|
|
344
|
+
}
|
|
345
|
+
getStore() {
|
|
346
|
+
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
347
|
+
const city = this.filteredLocations
|
|
348
|
+
.filter(location => location.checked)
|
|
349
|
+
.map(location => location.city);
|
|
350
|
+
const group = this.filteredGroups
|
|
351
|
+
.filter(group => group.checked)
|
|
352
|
+
.map(group => group.groupName);
|
|
353
|
+
const data = { city, group, clientId: this.selectedFilters.client };
|
|
354
|
+
this.auth.getHeaderStores(data).subscribe({
|
|
355
|
+
next: (res) => {
|
|
356
|
+
this.stores = res.data.storesData; // Get stores from response
|
|
357
|
+
// Retrieve checked store IDs from selectedFilters
|
|
358
|
+
const checkedStoreIds = this.selectedFilters.stores
|
|
359
|
+
? this.selectedFilters.stores.map((store) => store.storeId)
|
|
360
|
+
: [];
|
|
361
|
+
// Map the stores and retain the 'checked' status
|
|
362
|
+
this.filteredStores = this.stores.map((store) => ({
|
|
363
|
+
...store,
|
|
364
|
+
checked: checkedStoreIds.length > 0
|
|
365
|
+
? checkedStoreIds.includes(store.storeId) // Keep previously checked state
|
|
366
|
+
: true // Set to checked if no stores were previously selected
|
|
367
|
+
}));
|
|
368
|
+
// If no stores are selected initially, mark all stores as selected
|
|
369
|
+
if (!this.selectedFilters.stores.length) {
|
|
370
|
+
this.selectedFilters.stores = this.filteredStores.map(store => ({
|
|
371
|
+
storeId: store.storeId,
|
|
372
|
+
checked: true // Set default to checked
|
|
373
|
+
}));
|
|
374
|
+
}
|
|
375
|
+
// Update localStorage with the latest selectedFilters
|
|
376
|
+
localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
|
|
377
|
+
// Emit data via service
|
|
378
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
379
|
+
// Trigger change detection to reflect changes in the UI
|
|
380
|
+
this.cd.detectChanges();
|
|
381
|
+
},
|
|
382
|
+
error: (err) => {
|
|
383
|
+
console.error("Failed to fetch stores", err);
|
|
384
|
+
},
|
|
385
|
+
});
|
|
386
|
+
}
|
|
387
|
+
resetSelectedStores() {
|
|
388
|
+
this.filteredStores.forEach((store) => (store.checked = false));
|
|
389
|
+
this.searchStoreText = "";
|
|
390
|
+
}
|
|
391
|
+
selectedStoresLabel() {
|
|
392
|
+
const selectedStores = this.filteredStores.filter((store) => store.checked);
|
|
393
|
+
return selectedStores.length === 0
|
|
394
|
+
? "No Stores selected"
|
|
395
|
+
: selectedStores.length === 1
|
|
396
|
+
? selectedStores[0].storeName
|
|
397
|
+
: `${selectedStores.length} Stores selected`;
|
|
398
|
+
}
|
|
399
|
+
isAllStoresSelected() {
|
|
400
|
+
return this.filteredStores.length > 0 && this.filteredStores.every(store => store.checked);
|
|
401
|
+
}
|
|
402
|
+
// Method to handle dropdown item selection
|
|
403
|
+
updateSelectedStores() {
|
|
404
|
+
// Update logic for store selection
|
|
405
|
+
// Ensure this logic does not reset the store values unintentionally
|
|
406
|
+
this.selectedFilters.stores = this.filteredStores.filter(store => store.checked);
|
|
407
|
+
localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
|
|
408
|
+
}
|
|
409
|
+
toggleSelectAllLocations(event) {
|
|
410
|
+
const isChecked = event.target.checked;
|
|
411
|
+
this.filteredLocations.forEach((location) => (location.checked = isChecked));
|
|
412
|
+
this.updateSelectedLocations();
|
|
413
|
+
}
|
|
414
|
+
toggleSelectAllStores(event) {
|
|
415
|
+
const checked = event.target.checked;
|
|
416
|
+
this.filteredStores.forEach(store => store.checked = checked);
|
|
417
|
+
this.updateSelectedStores();
|
|
418
|
+
}
|
|
419
|
+
updateSelectedLocations() {
|
|
420
|
+
// When locations are selected, fetch the related groups
|
|
421
|
+
const selectedCities = this.filteredLocations
|
|
422
|
+
.filter((location) => location.checked)
|
|
423
|
+
.map((location) => location.city);
|
|
424
|
+
if (selectedCities.length > 0) {
|
|
425
|
+
this.getGroups(selectedCities); // Fetch groups based on selected cities
|
|
426
|
+
}
|
|
427
|
+
else {
|
|
428
|
+
this.filteredGroups = []; // Clear groups if no locations are selected
|
|
429
|
+
}
|
|
430
|
+
this.filteredStores = []; // Reset stores as well
|
|
431
|
+
this.searchGroupText = '';
|
|
432
|
+
this.searchStoreText = '';
|
|
433
|
+
}
|
|
434
|
+
toggleSelectAllGroups(event) {
|
|
435
|
+
const isChecked = event.target.checked;
|
|
436
|
+
this.filteredGroups.forEach((group) => (group.checked = isChecked));
|
|
437
|
+
this.updateSelectedGroups();
|
|
438
|
+
}
|
|
439
|
+
updateSelectedGroups() {
|
|
440
|
+
// Fetch the relevant stores after groups are selected
|
|
441
|
+
const selectedGroups = this.filteredGroups
|
|
442
|
+
.filter((group) => group.checked)
|
|
443
|
+
.map((group) => group.groupName);
|
|
444
|
+
if (selectedGroups.length > 0) {
|
|
445
|
+
this.getStore(); // Fetch stores based on selected groups
|
|
446
|
+
}
|
|
447
|
+
else {
|
|
448
|
+
this.filteredStores = []; // Clear stores if no groups are selected
|
|
449
|
+
}
|
|
450
|
+
this.searchStoreText = '';
|
|
451
|
+
}
|
|
452
|
+
Reset() {
|
|
453
|
+
// Clear groups and stores
|
|
454
|
+
this.filteredGroups = [];
|
|
455
|
+
this.filteredStores = [];
|
|
456
|
+
// Reset locations and checkboxes
|
|
457
|
+
this.filteredLocations.forEach(location => location.checked = false);
|
|
458
|
+
this.searchLocationText = "";
|
|
459
|
+
this.searchGroupText = "";
|
|
460
|
+
this.searchStoreText = "";
|
|
461
|
+
this.groupsData.forEach(group => group.checked = false);
|
|
462
|
+
// Update stores based on conditions
|
|
463
|
+
if (this.filteredLocations.every(location => !location.checked) &&
|
|
464
|
+
this.filteredGroups.every(group => !group.checked)) {
|
|
465
|
+
this.filteredStores = this.stores.map(store => ({
|
|
466
|
+
...store,
|
|
467
|
+
checked: true
|
|
468
|
+
}));
|
|
469
|
+
}
|
|
470
|
+
else {
|
|
471
|
+
this.filteredStores = this.stores.map(store => ({
|
|
472
|
+
...store,
|
|
473
|
+
checked: false
|
|
474
|
+
}));
|
|
475
|
+
}
|
|
476
|
+
// Update localStorage and emit data
|
|
477
|
+
const resetFilters = {
|
|
478
|
+
...this.selectedFilters,
|
|
479
|
+
stores: this.filteredStores,
|
|
480
|
+
group: [],
|
|
481
|
+
location: []
|
|
482
|
+
};
|
|
483
|
+
localStorage.setItem("header-filters", JSON.stringify(resetFilters));
|
|
484
|
+
this.gs.dataRangeValue.next(resetFilters);
|
|
485
|
+
this.Opendropdown = false; // Close dropdown if needed
|
|
486
|
+
}
|
|
487
|
+
Apply() {
|
|
488
|
+
// Close the dropdown
|
|
489
|
+
this.Opendropdown = false;
|
|
490
|
+
// Fetch existing filters from localStorage
|
|
491
|
+
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
492
|
+
// Ensure current selections are reflected
|
|
493
|
+
this.selectedFilters.location = this.filteredLocations;
|
|
494
|
+
this.selectedFilters.group = this.filteredGroups;
|
|
495
|
+
this.selectedFilters.stores = this.filteredStores;
|
|
496
|
+
// Store updated filters back in localStorage
|
|
497
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
498
|
+
// Emit the updated filters via the service
|
|
499
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
500
|
+
// Trigger refresh if necessary
|
|
501
|
+
this.gs.manageRefreshTrigger.next(true);
|
|
502
|
+
this.cd.detectChanges();
|
|
503
|
+
}
|
|
504
|
+
filterLocations() {
|
|
505
|
+
const searchText = this.searchLocationText.toLowerCase();
|
|
506
|
+
if (searchText) {
|
|
507
|
+
// Filter based on search text
|
|
508
|
+
this.filteredLocations = this.locations.filter((location) => location.city.toLowerCase().includes(searchText));
|
|
509
|
+
}
|
|
510
|
+
else {
|
|
511
|
+
// Reset to full array if search text is empty
|
|
512
|
+
this.filteredLocations = [...this.locations];
|
|
513
|
+
}
|
|
514
|
+
}
|
|
515
|
+
filterGroups() {
|
|
516
|
+
if (this.searchGroupText) {
|
|
517
|
+
this.filteredGroups = this.groupsData.filter((group) => group.groupName
|
|
518
|
+
.toLowerCase()
|
|
519
|
+
.includes(this.searchGroupText.toLowerCase()));
|
|
520
|
+
}
|
|
521
|
+
else {
|
|
522
|
+
this.filteredGroups = this.groupsData;
|
|
523
|
+
}
|
|
524
|
+
}
|
|
525
|
+
filterStores() {
|
|
526
|
+
if (this.searchStoreText) {
|
|
527
|
+
this.filteredStores = this.stores.filter((store) => store.storeName
|
|
528
|
+
.toLowerCase()
|
|
529
|
+
.includes(this.searchStoreText.toLowerCase()));
|
|
530
|
+
}
|
|
531
|
+
else {
|
|
532
|
+
this.filteredStores = this.stores;
|
|
533
|
+
}
|
|
534
|
+
}
|
|
535
|
+
closeDropdown() {
|
|
536
|
+
this.dropdownOpen = null;
|
|
537
|
+
}
|
|
538
|
+
clickOutside(event) {
|
|
539
|
+
const clickedInside = event.target.closest(".dropdown-container");
|
|
540
|
+
const clickedoutSide = event.target.closest(".dropdown1");
|
|
541
|
+
if (!clickedInside) {
|
|
542
|
+
this.closeDropdown();
|
|
543
|
+
}
|
|
544
|
+
if (!clickedoutSide) {
|
|
545
|
+
this.closeDropdown1();
|
|
546
|
+
}
|
|
547
|
+
}
|
|
548
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TrafficHeaderComponent, deps: [{ token: i1.AuthService }, { token: i2.GlobalStateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
549
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TrafficHeaderComponent, selector: "lib-traffic-header", host: { listeners: { "document:click": "clickOutside($event)" } }, ngImport: i0, template: "<div class=\"wrapper mx-3\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\">\r\n<lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n(selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n</div>\r\n<div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <input class=\"fx-date-range form-control ps-14\" style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [autoApply]=\"true\"\r\n [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\"\r\n [(ngModel)]=\"selectedDateRange\" (startDateChanged)=\"onStartDateChange($event)\" [isCustomDate]=\"isCustomDate\"\r\n [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n (datesUpdated)=\"datechange($event)\" name=\"daterange\" [readonly]=\"true\" />\r\n</div>\r\n<div class=\"position-relative\">\r\n <button type=\"button\" (click)=\"opendropdown($event)\" class=\"btn btn-default mx-2 rounded-3 text-nowrap border-val\">\r\n <!-- <span class=\"me-2\">Filter</span> -->\r\n <svg class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </button>\r\n\r\n <div *ngIf=\"Opendropdown\" class=\"card p-5 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\" \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\" \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\" \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\" \r\n [value]=\"selectedGroupsLabel()\" readonly\r\n placeholder=\"Select groups...\"\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 groups...\" \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\" \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\" \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\" \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\" \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:200px;overflow-y:auto;display:block;box-sizing:border-box}.dropdown-item{padding:8px 12px}.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}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.CustomSelectComponent, selector: "lib-select", inputs: ["items", "searchField", "multi", "idField", "selectedValues", "disabled", "label"], outputs: ["selected"] }, { 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"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] });
|
|
550
|
+
}
|
|
551
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TrafficHeaderComponent, decorators: [{
|
|
552
|
+
type: Component,
|
|
553
|
+
args: [{ selector: "lib-traffic-header", template: "<div class=\"wrapper mx-3\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\">\r\n<lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n(selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n</div>\r\n<div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <input class=\"fx-date-range form-control ps-14\" style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [autoApply]=\"true\"\r\n [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\"\r\n [(ngModel)]=\"selectedDateRange\" (startDateChanged)=\"onStartDateChange($event)\" [isCustomDate]=\"isCustomDate\"\r\n [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n (datesUpdated)=\"datechange($event)\" name=\"daterange\" [readonly]=\"true\" />\r\n</div>\r\n<div class=\"position-relative\">\r\n <button type=\"button\" (click)=\"opendropdown($event)\" class=\"btn btn-default mx-2 rounded-3 text-nowrap border-val\">\r\n <!-- <span class=\"me-2\">Filter</span> -->\r\n <svg class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </button>\r\n\r\n <div *ngIf=\"Opendropdown\" class=\"card p-5 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\" \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\" \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\" \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\" \r\n [value]=\"selectedGroupsLabel()\" readonly\r\n placeholder=\"Select groups...\"\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 groups...\" \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\" \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\" \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\" \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\" \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:200px;overflow-y:auto;display:block;box-sizing:border-box}.dropdown-item{padding:8px 12px}.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}\n"] }]
|
|
554
|
+
}], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.GlobalStateService }, { type: i0.ChangeDetectorRef }], propDecorators: { onClick: [{
|
|
555
|
+
type: HostListener,
|
|
556
|
+
args: ['document:click', ['$event']]
|
|
557
|
+
}], clickOutside: [{
|
|
558
|
+
type: HostListener,
|
|
559
|
+
args: ["document:click", ["$event"]]
|
|
560
|
+
}] } });
|
|
561
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"traffic-header.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.ts","../../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  HostListener,\r\n  OnInit,\r\n} from \"@angular/core\";\r\nimport dayjs from \"dayjs\";\r\nimport \"dayjs/locale/en\";\r\nimport { AuthService } from \"../../../../../services/auth.service\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\n@Component({\r\n  selector: \"lib-traffic-header\",\r\n  templateUrl: \"./traffic-header.component.html\",\r\n  styleUrl: \"./traffic-header.component.scss\",\r\n})\r\nexport class TrafficHeaderComponent implements OnInit {\r\n  dayjs = dayjs;\r\n  isCustomDate = (m: dayjs.Dayjs) => {\r\n    const isValidDate = m > this.dayjs();\r\n    return isValidDate ? \"invalid-date\" : false;\r\n  };\r\n  selectedDateRange: any = {};\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  constructor(\r\n    private auth: AuthService,\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\nngOnInit(): void {\r\n  const user = JSON.parse(localStorage.getItem('user-info') as string);\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  }\r\n\r\n  // Load filters from localStorage if they exist\r\n  if (\"header-filters\" in localStorage) {\r\n    const headerFilters: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"{}\");\r\n    \r\n    // Load and set selected filters from localStorage\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\r\n    // Sync selected locations and groups with filtered data\r\n    this.filteredLocations = headerFilters.location\r\n      ? headerFilters.location.map((item: any) => ({ ...item, checked: item.checked === true }))\r\n      : [];\r\n\r\n    this.filteredGroups = headerFilters.group\r\n      ? headerFilters.group.map((item: any) => ({ ...item, checked: item.checked === true }))\r\n      : [];\r\n\r\n    // Check if header filters contain stores\r\n    if (headerFilters.stores) {\r\n      this.filteredStores = headerFilters.stores.map((item: any) => ({\r\n        ...item,\r\n        checked: item.checked === true // Ensure `checked` is properly set\r\n      }));\r\n    } else {\r\n      this.filteredStores = []; // Handle empty stores array case\r\n    }\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    }\r\n\r\n   \r\n\r\n    // Emit data via service\r\n    this.gs.dataRangeValue.next(this.selectedFilters);\r\n\r\n    // Update localStorage with the latest selectedFilters\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(this.selectedFilters));\r\n  }\r\n}\r\n\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      } 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        this.cd.detectChanges();\r\n      }\r\n       // Ensure locations and groups are loaded before fetching stores\r\n this.getLocations();\r\n\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       // Ensure locations and groups are loaded before fetching stores\r\n this.getLocations();\r\n\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      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\r\n  // Clear the previous filtered stores since the client has changed\r\n  this.filteredStores = [];\r\n  this.selectedFilters.stores = [];\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 data from the selectedFilters since we are fetching new stores for the new client\r\n  delete headerFilters.stores;\r\n  \r\n  // Update localStorage with the new client selection and empty store data\r\n  localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n\r\n  // Fetch new stores based on the new client\r\n  this.getStore();\r\n \r\n  \r\n  \r\n  // Emit data to the global service\r\n  this.gs.dataRangeValue.next(this.selectedFilters);\r\n\r\n  // Trigger change detection to reflect UI changes\r\n  this.cd.detectChanges();\r\n}\r\n\r\n\r\n\r\n  ranges: any = {\r\n    Today: [this.dayjs(), this.dayjs()],\r\n    Yesterday: [\r\n      this.dayjs().subtract(1, \"days\"),\r\n      this.dayjs().subtract(1, \"days\"),\r\n    ],\r\n    \"This Week\": [this.dayjs().subtract(6, \"days\"), this.dayjs()],\r\n    \"Last Week\": [\r\n      this.dayjs().subtract(14, \"days\").startOf(\"days\"),\r\n      this.dayjs().subtract(8, \"days\").endOf(\"days\"),\r\n    ],\r\n    \"This Month\": [this.dayjs().startOf(\"month\"), this.dayjs().endOf(\"month\")],\r\n    \"Last Month\": [\r\n      this.dayjs().subtract(1, \"month\").startOf(\"month\"),\r\n      this.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      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      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: headerFilters.client,\r\n     city: [],\r\n     group: [],\r\n    }\r\n    this.auth.getLocation(obj).subscribe({\r\n      next: (res: any) => {\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: 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      error: (err) => {\r\n        console.error(\"Failed to fetch locations\", err);\r\n      },\r\n    });\r\n  }\r\n  \r\n  isAllLocationsSelected(): boolean {\r\n    return this.filteredLocations.every(location => location.checked);\r\n  }\r\n  \r\n  selectedLocationsLabel(): string {\r\n    const selectedLocations = this.filteredLocations\r\n      .filter(location => location.checked)\r\n      .map(location => location.city);\r\n  \r\n    return selectedLocations.length === 0\r\n      ? ''\r\n      : selectedLocations.length === 1\r\n      ? selectedLocations[0]\r\n      : `${selectedLocations.length} locations selected`;\r\n  }\r\n\r\n\r\n  getGroups(cities: string[]): void {\r\n    const obj = { city: cities,clientId:this.selectedFilters.client,group:[] };\r\n    this.auth.getGroups(obj).subscribe({\r\n      next: (res: any) => {\r\n        let checkedGroup = this.filteredGroups.filter((group) => group.checked).map((group) => 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        this.filteredGroups = combinedGroups;\r\n  \r\n        // Auto-fetch stores when groups are selected\r\n        const selectedGroups = this.filteredGroups.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      this.dropdownOpen = null;\r\n      if (type === 'group') {\r\n        this.resetSelectedGroups();\r\n      }\r\n      if (type === 'store') {\r\n        this.resetSelectedStores();\r\n      }\r\n    } else {\r\n      this.dropdownOpen = type;\r\n  \r\n      if (type === 'group') {\r\n        const selectedCities = this.filteredLocations\r\n          .filter((location) => location.checked)\r\n          .map((location) => location.city); \r\n  \r\n        if (selectedCities.length > 0 && !this.searchGroupText.trim().length) {\r\n          this.getGroups(selectedCities);\r\n        }\r\n      }\r\n  \r\n      if (type === 'store') {\r\n        if (!this.searchStoreText.trim().length) {\r\n          // Only fetch stores if not already fetched\r\n          if (!this.filteredStores || this.filteredStores.length === 0) {\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.filteredGroups.filter((group) => group.checked);\r\n    return selectedGroups.length === 0\r\n      ? \"No groups selected\"\r\n      : selectedGroups.length === 1\r\n      ? selectedGroups[0].groupName\r\n      : `${selectedGroups.length} groups selected`;\r\n  }\r\n\r\n\r\n  isAllGroupsSelected(): boolean {\r\n    return this.filteredGroups.length ? this.filteredGroups.every((group) => group.checked) : false;\r\n  }\r\n  getStore(): void {\r\n    const headerFilters: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"{}\");\r\n    \r\n    const city = this.filteredLocations\r\n      .filter(location => location.checked)\r\n      .map(location => location.city);\r\n  \r\n    const group = this.filteredGroups\r\n      .filter(group => group.checked)\r\n      .map(group => group.groupName);\r\n  \r\n    const data = { city, group, clientId: this.selectedFilters.client };\r\n  \r\n    this.auth.getHeaderStores(data).subscribe({\r\n      next: (res: any) => {\r\n        this.stores = res.data.storesData; // Get stores from response\r\n  \r\n        // Retrieve checked store IDs from selectedFilters\r\n        const checkedStoreIds = this.selectedFilters.stores\r\n          ? this.selectedFilters.stores.map((store: any) => store.storeId)\r\n          : [];\r\n  \r\n        // Map the stores and retain the 'checked' status\r\n        this.filteredStores = this.stores.map((store: any) => ({\r\n          ...store,\r\n          checked: checkedStoreIds.length > 0\r\n            ? checkedStoreIds.includes(store.storeId) // Keep previously checked state\r\n            : true // Set to checked if no stores were previously selected\r\n        }));\r\n  \r\n        // If no stores are selected initially, mark all stores as selected\r\n        if (!this.selectedFilters.stores.length) {\r\n          this.selectedFilters.stores = this.filteredStores.map(store => ({\r\n            storeId: store.storeId,\r\n            checked: true // Set default to checked\r\n          }));\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  \r\n        // Trigger change detection to reflect changes in the UI\r\n        this.cd.detectChanges();\r\n      },\r\n      error: (err) => {\r\n        console.error(\"Failed to fetch stores\", err);\r\n      },\r\n    });\r\n  }\r\n  \r\n  \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.filteredStores.filter((store) => store.checked);\r\n    return selectedStores.length === 0\r\n      ? \"No Stores selected\"\r\n      : selectedStores.length === 1\r\n      ? selectedStores[0].storeName\r\n      : `${selectedStores.length} Stores selected`;\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  // Update logic for store selection\r\n  // Ensure this logic does not reset the store values unintentionally\r\n  this.selectedFilters.stores = this.filteredStores.filter(store => store.checked);\r\n  localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\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    this.filteredStores.forEach(store => store.checked = checked);\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    \r\n    if (selectedCities.length > 0) {\r\n      this.getGroups(selectedCities); // Fetch groups based on selected cities\r\n    } else {\r\n      this.filteredGroups = []; // Clear groups if no locations are selected\r\n    }\r\n  \r\n    this.filteredStores = []; // Reset stores as well\r\n    this.searchGroupText = '';\r\n    this.searchStoreText = '';\r\n  }\r\n\r\n  toggleSelectAllGroups(event: any): void {\r\n    const isChecked = event.target.checked;\r\n    this.filteredGroups.forEach((group) => (group.checked = isChecked));\r\n    this.updateSelectedGroups();\r\n  }\r\n\r\n  updateSelectedGroups(): void {\r\n    // Fetch the relevant stores after groups are selected\r\n    const selectedGroups = this.filteredGroups\r\n      .filter((group) => group.checked)\r\n      .map((group) => group.groupName);\r\n  \r\n    if (selectedGroups.length > 0) {\r\n      this.getStore(); // Fetch stores based on selected groups\r\n    } else {\r\n      this.filteredStores = []; // Clear stores if no groups are selected\r\n    }\r\n  \r\n    this.searchStoreText = '';\r\n  }\r\n\r\n  Reset(): void {\r\n    // Clear groups and stores\r\n    this.filteredGroups = [];\r\n    this.filteredStores = [];\r\n  \r\n    // Reset locations and checkboxes\r\n    this.filteredLocations.forEach(location => location.checked = false);\r\n    this.searchLocationText = \"\";\r\n    this.searchGroupText = \"\";\r\n    this.searchStoreText = \"\";\r\n    this.groupsData.forEach(group => group.checked = false);\r\n  \r\n    // Update stores based on conditions\r\n    if (this.filteredLocations.every(location => !location.checked) &&\r\n        this.filteredGroups.every(group => !group.checked)) {\r\n      this.filteredStores = this.stores.map(store => ({\r\n        ...store,\r\n        checked: true\r\n      }));\r\n    } else {\r\n      this.filteredStores = this.stores.map(store => ({\r\n        ...store,\r\n        checked: false\r\n      }));\r\n    }\r\n  \r\n    // Update localStorage and emit data\r\n    const resetFilters = {\r\n      ...this.selectedFilters,\r\n      stores: this.filteredStores,\r\n      group: [],\r\n      location: []\r\n    };\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(resetFilters));\r\n    this.gs.dataRangeValue.next(resetFilters);\r\n    this.Opendropdown = false; // Close dropdown if needed\r\n  }\r\n  \r\n  \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  \r\n    // Ensure current selections are reflected\r\n    this.selectedFilters.location = this.filteredLocations;\r\n    this.selectedFilters.group = this.filteredGroups;\r\n    this.selectedFilters.stores = this.filteredStores;\r\n  \r\n  \r\n    // Store updated filters back in localStorage\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(this.selectedFilters));\r\n  \r\n    // Emit the updated filters via the service\r\n    this.gs.dataRangeValue.next(this.selectedFilters);\r\n    // Trigger refresh if necessary\r\n    this.gs.manageRefreshTrigger.next(true);\r\n    this.cd.detectChanges();\r\n  }\r\n  \r\n  \r\n\r\nfilterLocations(): void {\r\n  const searchText = this.searchLocationText.toLowerCase();\r\n  if (searchText) {\r\n    // Filter based on search text\r\n    this.filteredLocations = this.locations.filter((location) =>\r\n      location.city.toLowerCase().includes(searchText)\r\n    );\r\n  } else {\r\n    // Reset to full array if search text is empty\r\n    this.filteredLocations = [...this.locations];\r\n  }\r\n}\r\n\r\nfilterGroups(): void {\r\n  if (this.searchGroupText) {\r\n    this.filteredGroups = this.groupsData.filter((group) =>\r\n      group.groupName\r\n        .toLowerCase()\r\n        .includes(this.searchGroupText.toLowerCase())\r\n    );\r\n  } else {\r\n    this.filteredGroups = this.groupsData;\r\n  }\r\n}\r\n\r\nfilterStores(): void {\r\n  if (this.searchStoreText) {\r\n    this.filteredStores = this.stores.filter((store) =>\r\n      store.storeName\r\n        .toLowerCase()\r\n        .includes(this.searchStoreText.toLowerCase())\r\n    );\r\n  } else {\r\n    this.filteredStores = this.stores;\r\n  }\r\n}\r\n  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","<div class=\"wrapper mx-3\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\">\r\n<lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n(selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n</div>\r\n<div class=\"d-flex align-items-center position-relative my-1\">\r\n    <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n            <path\r\n                d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n                stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n        </svg>\r\n    </span>\r\n    <input class=\"fx-date-range form-control ps-14\" style=\"min-width: 260px !important;\" type=\"text\" matInput\r\n        ngxDaterangepickerMd [drops]=\"'down'\" [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [autoApply]=\"true\"\r\n        [alwaysShowCalendars]=\"false\" [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\"\r\n        [(ngModel)]=\"selectedDateRange\" (startDateChanged)=\"onStartDateChange($event)\" [isCustomDate]=\"isCustomDate\"\r\n        [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n        (datesUpdated)=\"datechange($event)\" name=\"daterange\" [readonly]=\"true\" />\r\n</div>\r\n<div class=\"position-relative\">\r\n    <button type=\"button\" (click)=\"opendropdown($event)\"  class=\"btn btn-default mx-2 rounded-3 text-nowrap border-val\">\r\n        <!-- <span class=\"me-2\">Filter</span> -->\r\n        <svg class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                stroke-linejoin=\"round\" />\r\n        </svg>\r\n    </button>\r\n\r\n    <div *ngIf=\"Opendropdown\" class=\"card p-5 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\" \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\" \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\" \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\" \r\n            [value]=\"selectedGroupsLabel()\" readonly\r\n            placeholder=\"Select groups...\"\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 groups...\" \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\" \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\" \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\" \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\" \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>"]}
|