tango-app-ui-manage-tickets 3.7.0-beta.8 → 3.7.0-beta.80

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.
Files changed (45) hide show
  1. package/esm2022/lib/components/audit-mapping-list/audit-mapping-list.component.mjs +519 -0
  2. package/esm2022/lib/components/audit-report-popup/audit-report-popup.component.mjs +389 -0
  3. package/esm2022/lib/components/audit-retag/audit-retag.component.mjs +464 -0
  4. package/esm2022/lib/components/custom-select/custom-select.component.mjs +187 -0
  5. package/esm2022/lib/components/filter-options/filter-options.component.mjs +41 -0
  6. package/esm2022/lib/components/footfall-dic/footfall-dic.component.mjs +334 -206
  7. package/esm2022/lib/components/footfall-dicview/footfall-dicview.component.mjs +1014 -0
  8. package/esm2022/lib/components/footfall-popup/footfall-popup.component.mjs +15 -0
  9. package/esm2022/lib/components/reactive-select/reactive-select.component.mjs +3 -3
  10. package/esm2022/lib/components/remove-audit/remove-audit.component.mjs +81 -0
  11. package/esm2022/lib/components/start-audit/start-audit.component.mjs +761 -0
  12. package/esm2022/lib/components/tango-manage-tickets/tango-manage-tickets.component.mjs +7 -3
  13. package/esm2022/lib/components/ticket-filter-panel/ticket-filter-panel.component.mjs +519 -0
  14. package/esm2022/lib/components/ticket-footfall-new/ticket-footfall-new.component.mjs +2557 -0
  15. package/esm2022/lib/components/ticketclosepopup/ticketclosepopup.component.mjs +43 -0
  16. package/esm2022/lib/components/tickets/tickets.component.mjs +62 -8
  17. package/esm2022/lib/components/viewcategory/viewcategory.component.mjs +89 -0
  18. package/esm2022/lib/services/audit.service.mjs +88 -0
  19. package/esm2022/lib/services/ticket.service.mjs +196 -35
  20. package/esm2022/lib/services/timer.service.mjs +84 -0
  21. package/esm2022/lib/tango-manage-tickets-routing.module.mjs +22 -2
  22. package/esm2022/lib/tango-manage-tickets.module.mjs +60 -5
  23. package/fesm2022/tango-app-ui-manage-tickets.mjs +7457 -327
  24. package/fesm2022/tango-app-ui-manage-tickets.mjs.map +1 -1
  25. package/lib/components/audit-mapping-list/audit-mapping-list.component.d.ts +73 -0
  26. package/lib/components/audit-report-popup/audit-report-popup.component.d.ts +52 -0
  27. package/lib/components/audit-retag/audit-retag.component.d.ts +59 -0
  28. package/lib/components/custom-select/custom-select.component.d.ts +35 -0
  29. package/lib/components/filter-options/filter-options.component.d.ts +15 -0
  30. package/lib/components/footfall-dic/footfall-dic.component.d.ts +18 -9
  31. package/lib/components/footfall-dicview/footfall-dicview.component.d.ts +132 -0
  32. package/lib/components/footfall-popup/footfall-popup.component.d.ts +8 -0
  33. package/lib/components/remove-audit/remove-audit.component.d.ts +16 -0
  34. package/lib/components/start-audit/start-audit.component.d.ts +86 -0
  35. package/lib/components/tango-manage-tickets/tango-manage-tickets.component.d.ts +1 -0
  36. package/lib/components/ticket-filter-panel/ticket-filter-panel.component.d.ts +89 -0
  37. package/lib/components/ticket-footfall-new/ticket-footfall-new.component.d.ts +301 -0
  38. package/lib/components/ticketclosepopup/ticketclosepopup.component.d.ts +15 -0
  39. package/lib/components/tickets/tickets.component.d.ts +4 -0
  40. package/lib/components/viewcategory/viewcategory.component.d.ts +16 -0
  41. package/lib/services/audit.service.d.ts +36 -0
  42. package/lib/services/ticket.service.d.ts +46 -8
  43. package/lib/services/timer.service.d.ts +22 -0
  44. package/lib/tango-manage-tickets.module.d.ts +22 -5
  45. package/package.json +1 -1
@@ -0,0 +1,519 @@
1
+ import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';
2
+ import { Validators } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/forms";
5
+ import * as i2 from "../../services/ticket.service";
6
+ import * as i3 from "@angular/common";
7
+ export class TicketFilterPanelComponent {
8
+ fb;
9
+ eRef;
10
+ service;
11
+ apply = new EventEmitter();
12
+ panelClosed = new EventEmitter(); // ✅ not `close`
13
+ permissionType = null;
14
+ userType = null; // e.g. 'tango' or others
15
+ client;
16
+ tab;
17
+ onDocumentClick(event) {
18
+ // 1️⃣ Always close dropdowns first
19
+ this.dropdownState.status = false;
20
+ this.dropdownState.reviewer = false;
21
+ this.dropdownState.approver = false;
22
+ this.dropdownState.ticketStatus = false;
23
+ // 2️⃣ If filter is not open → nothing to close
24
+ if (!this.isOpen)
25
+ return;
26
+ // 3️⃣ Check if clicked inside filter card
27
+ const clickedInside = this.eRef.nativeElement.contains(event.target);
28
+ // 4️⃣ If clicked OUTSIDE → close entire filter panel
29
+ if (!clickedInside) {
30
+ this.isOpen = false;
31
+ this.panelClosed.emit();
32
+ this.filterForm.reset({
33
+ status: [],
34
+ type: null,
35
+ ticketStatus: [],
36
+ reviewerCondition: null,
37
+ reviewerFrom: null,
38
+ reviewerTo: null,
39
+ approverCondition: null,
40
+ approverFrom: null,
41
+ approverTo: null,
42
+ tangoCondition: null,
43
+ tangoFrom: null,
44
+ tangoTo: null,
45
+ reviewedBy: [],
46
+ approvedBy: []
47
+ });
48
+ this.onReset();
49
+ }
50
+ }
51
+ isOpen = false; // controls visibility
52
+ // called from parent via #filterPanel.open()
53
+ open() {
54
+ this.isOpen = true;
55
+ }
56
+ // called from close button inside the panel
57
+ close() {
58
+ this.isOpen = false;
59
+ this.panelClosed.emit();
60
+ }
61
+ showPanel = false; // you can also control this from parent
62
+ statusOptions = [
63
+ 'Open',
64
+ 'In-Progress',
65
+ 'Closed',
66
+ // 'Open - Accuracy Issue',
67
+ // 'Closed - Accuracy Issue',
68
+ 'Expired',
69
+ ];
70
+ ticketStatusOptions = [
71
+ 'Reviewer - Open',
72
+ 'Reviewer - In-Progress',
73
+ 'Reviewer - Closed',
74
+ 'Reviewer - Expired',
75
+ 'Approver - Open',
76
+ 'Approver - In-Progress',
77
+ 'Approver - Closed',
78
+ 'Approver - Expired',
79
+ ];
80
+ conditionOptions = [
81
+ { value: 'gt', label: '> Greater than' },
82
+ { value: 'lt', label: '< Lesser than' },
83
+ { value: 'gte', label: '>= Greater than or equal to' },
84
+ { value: 'lte', label: '<= Lesser than or equal to' },
85
+ { value: 'between', label: 'Between' },
86
+ ];
87
+ filterForm;
88
+ constructor(fb, eRef, service) {
89
+ this.fb = fb;
90
+ this.eRef = eRef;
91
+ this.service = service;
92
+ this.filterForm = this.fb.group({
93
+ status: [[]],
94
+ type: null,
95
+ ticketStatus: [[]],
96
+ reviewerCondition: [null],
97
+ reviewerFrom: [null, [Validators.min(0), Validators.max(100)]],
98
+ reviewerTo: [null, [Validators.min(0), Validators.max(100)]],
99
+ approverCondition: [null],
100
+ approverFrom: [null, [Validators.min(0), Validators.max(100)]],
101
+ approverTo: [null, [Validators.min(0), Validators.max(100)]],
102
+ tangoCondition: [null],
103
+ tangoFrom: [null, [Validators.min(0), Validators.max(100)]],
104
+ tangoTo: [null, [Validators.min(0), Validators.max(100)]],
105
+ reviewedBy: [[]],
106
+ approvedBy: [[]],
107
+ });
108
+ this.onReset();
109
+ }
110
+ limitValue(event, controlName) {
111
+ let value = Number(event.target.value);
112
+ if (value < 0)
113
+ value = 0;
114
+ if (value > 100)
115
+ value = 100;
116
+ event.target.value = value;
117
+ this.filterForm.get(controlName)?.setValue(value, { emitEvent: false });
118
+ }
119
+ get isTango() {
120
+ return this.userType === 'tango';
121
+ }
122
+ // SHOW / HIDE RULES
123
+ // Reviewer accuracy and "Reviewed by" visible for tango + reviewer
124
+ get showReviewerAccuracy() {
125
+ return this.isTango || this.permissionType === 'review';
126
+ }
127
+ get showReviewedBy() {
128
+ return this.permissionType === 'review';
129
+ }
130
+ // Approver accuracy and "Approved by" visible for tango + approver
131
+ get showApproverAccuracy() {
132
+ return this.isTango || this.permissionType === 'approve';
133
+ }
134
+ get showApprovedBy() {
135
+ return this.permissionType === 'approve';
136
+ }
137
+ // Tango accuracy only for tango users
138
+ get showTangoAccuracy() {
139
+ return this.isTango;
140
+ }
141
+ statusDropdownOpen = false;
142
+ isStatusSelected(status) {
143
+ const selected = this.filterForm.value.status || [];
144
+ return selected.includes(status);
145
+ }
146
+ onStatusChange(event, status) {
147
+ const checkbox = event.target;
148
+ const selected = this.filterForm.value.status || [];
149
+ let next;
150
+ if (checkbox.checked) {
151
+ next = selected.includes(status) ? selected : [...selected, status];
152
+ }
153
+ else {
154
+ next = selected.filter(s => s !== status);
155
+ }
156
+ this.filterForm.patchValue({ status: next });
157
+ }
158
+ toggleStatusDropdown(event) {
159
+ if (event) {
160
+ event.stopPropagation(); // avoid document click closing it
161
+ }
162
+ this.statusDropdownOpen = !this.statusDropdownOpen;
163
+ }
164
+ // Are all statuses currently selected?
165
+ areAllStatusesSelected() {
166
+ const selected = this.filterForm.value.status || [];
167
+ return selected.length > 0 && selected.length === this.statusOptions.length;
168
+ }
169
+ // Handle "Select All" checkbox change
170
+ onStatusSelectAllChange(event) {
171
+ const checkbox = event.target;
172
+ if (checkbox.checked) {
173
+ // Select every status
174
+ this.filterForm.patchValue({ status: [...this.statusOptions] });
175
+ }
176
+ else {
177
+ // Clear all
178
+ this.filterForm.patchValue({ status: [] });
179
+ }
180
+ }
181
+ get selectedStatuses() {
182
+ return this.filterForm.value.status || [];
183
+ }
184
+ isTicketStatusSelected(status) {
185
+ const selected = this.filterForm.value.ticketStatus || [];
186
+ return selected.includes(status);
187
+ }
188
+ onTicketStatusChange(event, status) {
189
+ const checkbox = event.target;
190
+ const selected = this.filterForm.value.ticketStatus || [];
191
+ let next;
192
+ if (checkbox.checked) {
193
+ next = selected.includes(status) ? selected : [...selected, status];
194
+ }
195
+ else {
196
+ next = selected.filter(s => s !== status);
197
+ }
198
+ this.filterForm.patchValue({ status: next });
199
+ }
200
+ toggleTicketStatusDropdown(event) {
201
+ if (event) {
202
+ event.stopPropagation(); // avoid document click closing it
203
+ }
204
+ this.statusDropdownOpen = !this.statusDropdownOpen;
205
+ }
206
+ // Are all statuses currently selected?
207
+ areAllTicketStatusesSelected() {
208
+ const selected = this.filterForm.value.ticketStatus || [];
209
+ return selected.length > 0 && selected.length === this.ticketStatusOptions.length;
210
+ }
211
+ // Handle "Select All" checkbox change
212
+ onTicketStatusSelectAllChange(event) {
213
+ const checkbox = event.target;
214
+ if (checkbox.checked) {
215
+ // Select every status
216
+ this.filterForm.patchValue({ ticketStatus: [...this.ticketStatusOptions] });
217
+ }
218
+ else {
219
+ // Clear all
220
+ this.filterForm.patchValue({ ticketStatus: [] });
221
+ }
222
+ }
223
+ get selectedTicketStatuses() {
224
+ return this.filterForm.value.ticketStatus || [];
225
+ }
226
+ isBetween(controlName) {
227
+ return this.filterForm.get(controlName)?.value === 'between';
228
+ }
229
+ ngOnChanges(changes) {
230
+ if (changes['client'] || changes['permissionType'] || changes['userType']) {
231
+ this.loadReviewerList();
232
+ }
233
+ this.onReset();
234
+ }
235
+ // full user list you already have
236
+ userList = [];
237
+ reviewerSearchTerm = '';
238
+ // ✅ simple computed list for *ngFor
239
+ get filteredReviewerList() {
240
+ const term = (this.reviewerSearchTerm || '').trim().toLowerCase();
241
+ if (!term) {
242
+ return this.userList;
243
+ }
244
+ return this.userList.filter(u => {
245
+ const email = (u.email || '').toLowerCase();
246
+ const name = (u.name || '').toLowerCase();
247
+ if (this.reviewerSearchTerm.length) {
248
+ return email.includes(term) || name.includes(term);
249
+ }
250
+ });
251
+ }
252
+ approverSearchTerm;
253
+ get filteredApproverList() {
254
+ const term = (this.approverSearchTerm || '').trim().toLowerCase();
255
+ if (!term) {
256
+ return this.userList;
257
+ }
258
+ return this.userList.filter((u) => {
259
+ const email = (u.email || '').toLowerCase();
260
+ const name = (u.name || '').toLowerCase();
261
+ if (this.approverSearchTerm.length) {
262
+ return email.includes(term) || name.includes(term);
263
+ }
264
+ });
265
+ }
266
+ onApproverSearch(value) {
267
+ this.approverSearchTerm = value;
268
+ }
269
+ loadReviewerList() {
270
+ if (!this.client) {
271
+ this.userList = [];
272
+ return;
273
+ }
274
+ let type;
275
+ if (this.userType === 'tango') {
276
+ type = 'tango'; // or 'all'
277
+ }
278
+ else if (this.permissionType === 'review') {
279
+ type = 'review';
280
+ }
281
+ else if (this.permissionType === 'approve') {
282
+ type = 'approve';
283
+ }
284
+ else {
285
+ this.userList = [];
286
+ return;
287
+ }
288
+ this.service.getReviewerApi(this.client, type, '').subscribe({
289
+ next: (res) => {
290
+ if (res && res.code === 200) {
291
+ this.userList = res.data;
292
+ }
293
+ else {
294
+ this.userList = [];
295
+ }
296
+ },
297
+ error: () => {
298
+ this.userList = [];
299
+ }
300
+ });
301
+ }
302
+ // open flags
303
+ reviewerDropdownOpen = false;
304
+ approverDropdownOpen = false;
305
+ // convenience getters
306
+ get selectedReviewedBy() {
307
+ return this.filterForm.value.reviewedBy || [];
308
+ }
309
+ get selectedApprovedBy() {
310
+ return this.filterForm.value.approvedBy || [];
311
+ }
312
+ // --- Reviewed By helpers ---
313
+ toggleReviewerDropdown(event) {
314
+ if (event)
315
+ event.stopPropagation();
316
+ this.reviewerDropdownOpen = !this.reviewerDropdownOpen;
317
+ }
318
+ isReviewerSelected(email) {
319
+ return this.selectedReviewedBy.includes(email);
320
+ }
321
+ onReviewerChange(event, email) {
322
+ const checkbox = event.target;
323
+ const selected = [...this.selectedReviewedBy];
324
+ if (checkbox.checked) {
325
+ if (!selected.includes(email))
326
+ selected.push(email);
327
+ }
328
+ else {
329
+ const i = selected.indexOf(email);
330
+ if (i >= 0)
331
+ selected.splice(i, 1);
332
+ }
333
+ this.filterForm.patchValue({ reviewedBy: selected });
334
+ }
335
+ areAllReviewersSelected() {
336
+ return (this.userList.length > 0 &&
337
+ this.selectedReviewedBy.length === this.userList.length);
338
+ }
339
+ onReviewerSelectAll(event) {
340
+ const checkbox = event.target;
341
+ if (checkbox.checked) {
342
+ this.filterForm.patchValue({
343
+ reviewedBy: this.userList.map((u) => u.email),
344
+ });
345
+ }
346
+ else {
347
+ this.filterForm.patchValue({ reviewedBy: [] });
348
+ }
349
+ }
350
+ // --- Approved By helpers ---
351
+ toggleApproverDropdown(event) {
352
+ if (event)
353
+ event.stopPropagation();
354
+ this.approverDropdownOpen = !this.approverDropdownOpen;
355
+ }
356
+ isApproverSelected(email) {
357
+ return this.selectedApprovedBy.includes(email);
358
+ }
359
+ onApproverChange(event, email) {
360
+ const checkbox = event.target;
361
+ const selected = [...this.selectedApprovedBy];
362
+ if (checkbox.checked) {
363
+ if (!selected.includes(email))
364
+ selected.push(email);
365
+ }
366
+ else {
367
+ const i = selected.indexOf(email);
368
+ if (i >= 0)
369
+ selected.splice(i, 1);
370
+ }
371
+ this.filterForm.patchValue({ approvedBy: selected });
372
+ }
373
+ areAllApproversSelected() {
374
+ return (this.userList.length > 0 &&
375
+ this.selectedApprovedBy.length === this.userList.length);
376
+ }
377
+ onApproverSelectAll(event) {
378
+ const checkbox = event.target;
379
+ if (checkbox.checked) {
380
+ this.filterForm.patchValue({
381
+ approvedBy: this.userList.map((u) => u.email),
382
+ });
383
+ }
384
+ else {
385
+ this.filterForm.patchValue({ approvedBy: [] });
386
+ }
387
+ }
388
+ onReset() {
389
+ this.filterForm.reset({
390
+ status: [],
391
+ reviewerCondition: null,
392
+ reviewerFrom: null,
393
+ reviewerTo: null,
394
+ approverCondition: null,
395
+ approverFrom: null,
396
+ approverTo: null,
397
+ tangoCondition: null,
398
+ tangoFrom: null,
399
+ tangoTo: null,
400
+ reviewedBy: [],
401
+ approvedBy: []
402
+ });
403
+ // 2️⃣ Reset search terms
404
+ this.reviewerSearchTerm = '';
405
+ this.approverSearchTerm = '';
406
+ // 3️⃣ Build empty payload to send back
407
+ const payload = {
408
+ filterByStatus: [],
409
+ filterByReviewer: null,
410
+ filterByApprover: null,
411
+ filterByTango: null,
412
+ filterByReviewedBy: [],
413
+ fileterByApprovedBy: [],
414
+ ...(this.tab === 'internal' && {
415
+ filterByTicketType: null,
416
+ filterByTangoStatus: []
417
+ })
418
+ };
419
+ // 4️⃣ Emit the now-empty filter result
420
+ this.apply.emit(payload);
421
+ // 5️⃣ Close the filter panel
422
+ this.close();
423
+ }
424
+ mapAccuracy(condition, from, to) {
425
+ // nothing selected
426
+ if (!condition || from == null)
427
+ return null;
428
+ // "between" → "90 to 100"
429
+ if (condition === 'between') {
430
+ if (to == null)
431
+ return null;
432
+ return `${from} to ${to}`;
433
+ }
434
+ // other conditions (gt, lt, gte, lte)
435
+ const opMap = {
436
+ gt: '>',
437
+ lt: '<',
438
+ gte: '>=',
439
+ lte: '<=',
440
+ between: '', // already handled above
441
+ };
442
+ return `${opMap[condition]}${from}`; // e.g. ">= 90"
443
+ }
444
+ onTicketTypeChange(event) {
445
+ const value = event.target.value;
446
+ console.log('Ticket type changed:', value);
447
+ // this.ticketType = value
448
+ // do what you need here
449
+ // example:
450
+ // this.tab = value;
451
+ // this.reloadData();
452
+ }
453
+ onApply() {
454
+ const raw = this.filterForm.value;
455
+ const reviewerStr = this.mapAccuracy(raw.reviewerCondition, raw.reviewerFrom, raw.reviewerTo);
456
+ const approverStr = this.mapAccuracy(raw.approverCondition, raw.approverFrom, raw.approverTo);
457
+ const tangoStr = this.mapAccuracy(raw.tangoCondition, raw.tangoFrom, raw.tangoTo);
458
+ const payload = {
459
+ filterByStatus: raw.status || [],
460
+ filterByReviewer: reviewerStr,
461
+ filterByApprover: approverStr,
462
+ filterByTango: tangoStr,
463
+ filterByReviewedBy: raw.reviewedBy || [],
464
+ fileterByApprovedBy: raw.approvedBy || [],
465
+ ...(this.tab === 'internal' && {
466
+ filterByTicketType: raw.ticketType,
467
+ filterByTangoStatus: raw.tangoStatus || []
468
+ })
469
+ };
470
+ this.apply.emit(payload);
471
+ this.close();
472
+ this.showPanel = false;
473
+ }
474
+ dropdownState = {
475
+ status: false,
476
+ reviewer: false,
477
+ approver: false,
478
+ ticketStatus: false
479
+ };
480
+ // @HostListener('document:click')
481
+ closeAll() {
482
+ this.dropdownState.status = false;
483
+ this.dropdownState.reviewer = false;
484
+ this.dropdownState.approver = false;
485
+ this.dropdownState.ticketStatus = false;
486
+ }
487
+ toggleDropdown(type, event) {
488
+ event.stopPropagation();
489
+ // Close all before opening a new one
490
+ this.closeAll();
491
+ // Toggle only the selected one
492
+ this.dropdownState[type] = !this.dropdownState[type];
493
+ }
494
+ isDropdownOpen(type) {
495
+ return this.dropdownState[type];
496
+ }
497
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TicketFilterPanelComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ElementRef }, { token: i2.TicketService }], target: i0.ɵɵFactoryTarget.Component });
498
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TicketFilterPanelComponent, selector: "lib-ticket-filter-panel", inputs: { permissionType: "permissionType", userType: "userType", client: "client", tab: "tab" }, outputs: { apply: "apply", panelClosed: "panelClosed" }, host: { listeners: { "document:click": "onDocumentClick($event)" } }, usesOnChanges: true, ngImport: i0, template: "<!-- ticket-filter-panel.component.html -->\r\n<div class=\"filter-wrapper\" *ngIf=\"isOpen\">\r\n <div class=\"filter-card\">\r\n <div class=\"filter-header d-flex justify-content-between align-items-center mb-3\">\r\n <div class=\"title\">Filter Options</div>\r\n <!-- <button type=\"button\" class=\"btn-close\" (click)=\"close()\">\u2715</button> -->\r\n </div>\r\n\r\n <form [formGroup]=\"filterForm\">\r\n\r\n <div *ngIf=\"tab ==='internal'\" class=\"mb-3 position-relative\" (click)=\"$event.stopPropagation()\">\r\n\r\n <label class=\"form-label\">Ticket Type</label>\r\n <select class=\"form-select w-100\" formControlName=\"type\" (change)=\"onTicketTypeChange($event)\">\r\n <option disabled [ngValue]=\"null\">Select</option>\r\n <option value=\"store\">Store</option>\r\n <option value=\"internal\">Internal</option>\r\n </select>\r\n </div>\r\n <!-- Status -->\r\n<div class=\"mb-3 position-relative\" (click)=\"$event.stopPropagation()\">\r\n <label *ngIf=\"tab !=='internal'\" class=\"form-label\">Status</label>\r\n <label *ngIf=\"tab ==='internal'\" class=\"form-label\">Tango Status</label>\r\n <!-- Header / trigger -->\r\n <div\r\n class=\"status-select border rounded px-3 py-2 d-flex justify-content-between align-items-center\"\r\n (click)=\"toggleDropdown('status', $event)\"\r\n >\r\n <span *ngIf=\"!selectedStatuses.length\">Select</span>\r\n\r\n <span *ngIf=\"selectedStatuses.length === 1\">\r\n {{ selectedStatuses[0] }}\r\n </span>\r\n\r\n <span *ngIf=\"selectedStatuses.length > 1\" class=\"d-flex align-items-center\">\r\n <span>{{ selectedStatuses[0] }}</span>\r\n <span class=\"badge ms-2\">\r\n +{{ selectedStatuses.length - 1 }}\r\n </span>\r\n </span>\r\n\r\n </div>\r\n\r\n <!-- DROPDOWN PANEL (OVERLAY) -->\r\n <div\r\n class=\"status-dropdown position-absolute w-100 mt-1 border rounded p-1 bg-white\"\r\n style=\"z-index: 1000; max-height: 220px; overflow-y: auto;\"\r\n *ngIf=\"isDropdownOpen('status')\"\r\n (click)=\"$event.stopPropagation()\"\r\n >\r\n <!-- Select All -->\r\n <div class=\"form-check px-0 d-flex align-items-center mb-2\">\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input \"\r\n id=\"status-select-all\"\r\n [checked]=\"areAllStatusesSelected()\"\r\n (change)=\"onStatusSelectAllChange($event)\"\r\n />\r\n <label class=\"form-check-label text-dark ms-2\" for=\"status-select-all\">\r\n Select All\r\n </label>\r\n </div>\r\n\r\n\r\n <!-- Options -->\r\n <div\r\n class=\"form-check px-0 d-flex align-items-center mb-1\"\r\n *ngFor=\"let s of statusOptions\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input \"\r\n [id]=\"'status-' + s\"\r\n [checked]=\"isStatusSelected(s)\"\r\n (change)=\"onStatusChange($event, s)\"\r\n />\r\n <label class=\"form-check-label text-dark ms-2\" [for]=\"'status-' + s\">\r\n {{ s }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n<div *ngIf=\"tab ==='internal'\" class=\"mb-3 position-relative\" (click)=\"$event.stopPropagation()\">\r\n <label class=\"form-label\">Ticket Status</label>\r\n\r\n <!-- Header / trigger -->\r\n <div\r\n class=\"status-select border rounded px-3 py-2 d-flex justify-content-between align-items-center\"\r\n (click)=\"toggleDropdown('ticketStatus', $event)\"\r\n >\r\n <span *ngIf=\"!selectedTicketStatuses.length\">Select</span>\r\n\r\n <span *ngIf=\"selectedTicketStatuses.length === 1\">\r\n {{ selectedTicketStatuses[0] }}\r\n </span>\r\n\r\n <span *ngIf=\"selectedTicketStatuses.length > 1\" class=\"d-flex align-items-center\">\r\n <span>{{ selectedTicketStatuses[0] }}</span>\r\n <span class=\"badge ms-2\">\r\n +{{ selectedTicketStatuses.length - 1 }}\r\n </span>\r\n </span>\r\n\r\n </div>\r\n\r\n <!-- DROPDOWN PANEL (OVERLAY) -->\r\n <div\r\n class=\"status-dropdown position-absolute w-100 mt-1 border rounded p-1 bg-white\"\r\n style=\"z-index: 1000; max-height: 220px; overflow-y: auto;\"\r\n *ngIf=\"isDropdownOpen('ticketStatus')\"\r\n (click)=\"$event.stopPropagation()\"\r\n >\r\n <!-- Select All -->\r\n <div class=\"form-check px-0 d-flex align-items-center mb-2\">\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input \"\r\n id=\"status-select-all\"\r\n [checked]=\"areAllTicketStatusesSelected()\"\r\n (change)=\"onTicketStatusSelectAllChange($event)\"\r\n />\r\n <label class=\"form-check-label text-dark ms-2\" for=\"status-select-all\">\r\n Select All\r\n </label>\r\n </div>\r\n\r\n\r\n <!-- Options -->\r\n <div\r\n class=\"form-check px-0 d-flex align-items-center mb-1\"\r\n *ngFor=\"let s of ticketStatusOptions\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input \"\r\n [id]=\"'ticketStatus-' + s\"\r\n [checked]=\"isTicketStatusSelected(s)\"\r\n (change)=\"onTicketStatusChange($event, s)\"\r\n />\r\n <label class=\"form-check-label text-dark ms-2\" [for]=\"'ticketStatus-' + s\">\r\n {{ s }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n <!-- Reviewer accuracy -->\r\n <div class=\"mb-3\" *ngIf=\"showReviewerAccuracy\" (click)=\"closeAll()\">\r\n <label class=\"form-label\">Reviewer accuracy (%) by condition</label>\r\n <div class=\"d-flex gap-2\">\r\n <select class=\"form-select w-100\" formControlName=\"reviewerCondition\">\r\n <option disabled [ngValue]=\"null\">Select</option>\r\n <option *ngFor=\"let c of conditionOptions\" [ngValue]=\"c.value\">\r\n {{ c.label }}\r\n </option>\r\n </select>\r\n\r\n <!-- one or two inputs -->\r\n <ng-container *ngIf=\"isBetween('reviewerCondition'); else singleReviewer\">\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"reviewerFrom\"\r\n placeholder=\"From\" (input)=\"limitValue($event, 'reviewerFrom')\" />\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"reviewerTo\"\r\n placeholder=\"To\" (input)=\"limitValue($event, 'reviewerTo')\" />\r\n </ng-container>\r\n <ng-template #singleReviewer>\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"reviewerFrom\"\r\n placeholder=\"1 to 100%\" (input)=\"limitValue($event, 'reviewerFrom')\" />\r\n </ng-template>\r\n </div>\r\n </div>\r\n\r\n <!-- Approver accuracy -->\r\n <div class=\"mb-3\" *ngIf=\"showApproverAccuracy\" (click)=\"closeAll()\">\r\n <label class=\"form-label\">Approver accuracy (%) by condition</label>\r\n <div class=\"d-flex gap-2\">\r\n <select class=\"form-select w-100\" formControlName=\"approverCondition\">\r\n <option disabled [ngValue]=\"null\">Select</option>\r\n <option *ngFor=\"let c of conditionOptions\" [ngValue]=\"c.value\">\r\n {{ c.label }}\r\n </option>\r\n </select>\r\n\r\n <ng-container *ngIf=\"isBetween('approverCondition'); else singleApprover\">\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"approverFrom\"\r\n placeholder=\"From\" \r\n (input)=\"limitValue($event, 'approverFrom')\"/>\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"approverTo\"\r\n placeholder=\"To\" (input)=\"limitValue($event, 'approverTo')\" />\r\n </ng-container>\r\n <ng-template #singleApprover>\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"approverFrom\"\r\n placeholder=\"1 to 100%\" (input)=\"limitValue($event, 'approverFrom')\" />\r\n </ng-template>\r\n </div>\r\n </div>\r\n\r\n <!-- Tango accuracy -->\r\n <div class=\"mb-3\" *ngIf=\"showTangoAccuracy\" (click)=\"closeAll()\">\r\n <label class=\"form-label\">Tango accuracy (%) by condition</label>\r\n <div class=\"d-flex gap-2\">\r\n <select class=\"form-select w-100\" formControlName=\"tangoCondition\">\r\n <option disabled [ngValue]=\"null\">Select</option>\r\n <option *ngFor=\"let c of conditionOptions\" [ngValue]=\"c.value\">\r\n {{ c.label }}\r\n </option>\r\n </select>\r\n\r\n <ng-container *ngIf=\"isBetween('tangoCondition'); else singleTango\">\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"tangoFrom\"\r\n placeholder=\"From\" (input)=\"limitValue($event, 'tangoFrom')\" />\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"tangoTo\"\r\n placeholder=\"To\" (input)=\"limitValue($event, 'tangoTo')\" />\r\n </ng-container>\r\n <ng-template #singleTango>\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"tangoFrom\"\r\n placeholder=\"1 to 100%\" (input)=\"limitValue($event, 'tangoFrom')\" />\r\n </ng-template>\r\n </div>\r\n </div>\r\n<div\r\n class=\"mb-3 position-relative\"\r\n *ngIf=\"showReviewedBy\"\r\n (click)=\"$event.stopPropagation()\"\r\n>\r\n <label class=\"form-label\">Reviewed by</label>\r\n\r\n <!-- Trigger / display -->\r\n <div\r\n class=\"border rounded px-3 py-2 d-flex justify-content-between align-items-center\"\r\n (click)=\"toggleDropdown('reviewer', $event)\"\r\n >\r\n <!-- 0 selected -->\r\n <span *ngIf=\"!selectedReviewedBy.length\">\r\n Select\r\n </span>\r\n\r\n <!-- 1 selected -->\r\n <span *ngIf=\"selectedReviewedBy.length === 1\">\r\n {{ selectedReviewedBy[0] }}\r\n </span>\r\n\r\n <!-- >1 selected -->\r\n <span\r\n *ngIf=\"selectedReviewedBy.length > 1\"\r\n class=\"d-flex align-items-center\"\r\n >\r\n <span>{{ selectedReviewedBy[0] }}</span>\r\n <span class=\"badge ms-2\">\r\n +{{ selectedReviewedBy.length - 1 }}\r\n </span>\r\n </span>\r\n </div>\r\n\r\n<div\r\n *ngIf=\"isDropdownOpen('reviewer')\"\r\n class=\"position-absolute w-100 border rounded bg-white p-1 mt-1\"\r\n style=\"z-index: 1000; max-height: 220px; overflow-y: auto;\"\r\n (click)=\"$event.stopPropagation()\"\r\n>\r\n\r\n <!-- \uD83D\uDD0D Search box -->\r\n <div class=\"mb-2 px-0\">\r\n <input\r\n type=\"text\"\r\n class=\"form-control form-control-sm\"\r\n placeholder=\"Search by email\"\r\n [(ngModel)]=\"reviewerSearchTerm\"\r\n [ngModelOptions]=\"{standalone: true}\"\r\n (click)=\"$event.stopPropagation()\"\r\n />\r\n </div>\r\n\r\n <!-- Select All -->\r\n <div class=\"form-check px-0 mb-2 d-flex align-items-center\">\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input\"\r\n id=\"reviewer-all\"\r\n [checked]=\"areAllReviewersSelected()\"\r\n (change)=\"onReviewerSelectAll($event)\"\r\n />\r\n <label for=\"reviewer-all\" class=\"form-check-label text-dark ms-2\">\r\n Select All\r\n </label>\r\n </div>\r\n\r\n <!-- Options \u2013 now use getter filteredReviewerList -->\r\n <div\r\n class=\"form-check mb-1 px-0 d-flex align-items-center\"\r\n *ngFor=\"let u of filteredReviewerList\"\r\n >\r\n <input\r\n class=\"form-check-input\"\r\n type=\"checkbox\"\r\n [id]=\"'rev-' + u.email\"\r\n [checked]=\"isReviewerSelected(u.email)\"\r\n (change)=\"onReviewerChange($event, u.email)\"\r\n />\r\n <label class=\"form-check-label text-dark ms-2\" [for]=\"'rev-' + u.email\">\r\n {{ u.email }}\r\n </label>\r\n </div>\r\n</div>\r\n\r\n\r\n</div>\r\n\r\n\r\n <!-- Approved By -->\r\n<div\r\n class=\"mb-3 position-relative\"\r\n *ngIf=\"showApprovedBy\"\r\n (click)=\"$event.stopPropagation()\"\r\n>\r\n <label class=\"form-label\">Approved by</label>\r\n\r\n <!-- Trigger / display -->\r\n <div\r\n class=\"border rounded px-3 py-2 d-flex justify-content-between align-items-center\"\r\n (click)=\"toggleDropdown('approver', $event)\"\r\n >\r\n <!-- 0 selected -->\r\n <span *ngIf=\"!selectedApprovedBy.length\">\r\n Select\r\n </span>\r\n\r\n <!-- 1 selected -->\r\n <span *ngIf=\"selectedApprovedBy.length === 1\">\r\n {{ selectedApprovedBy[0] }}\r\n </span>\r\n\r\n <!-- >1 selected -->\r\n <span\r\n *ngIf=\"selectedApprovedBy.length > 1\"\r\n class=\"d-flex align-items-center\"\r\n >\r\n <span>{{ selectedApprovedBy[0] }}</span>\r\n <span class=\"badge ms-2\">\r\n +{{ selectedApprovedBy.length - 1 }}\r\n </span>\r\n </span>\r\n\r\n </div>\r\n<!-- Dropdown panel -->\r\n<div\r\n *ngIf=\"isDropdownOpen('approver')\"\r\n class=\"position-absolute w-100 border rounded bg-white p-1 mt-1\"\r\n style=\"z-index: 1000; max-height: 220px; overflow-y: auto;\"\r\n (click)=\"$event.stopPropagation()\"\r\n>\r\n\r\n <!-- \uD83D\uDD0D Search box -->\r\n <div class=\"mb-2 px-0\">\r\n <input\r\n type=\"text\"\r\n class=\"form-control form-control-sm\"\r\n placeholder=\"Search by email\"\r\n [(ngModel)]=\"approverSearchTerm\"\r\n [ngModelOptions]=\"{standalone: true}\"\r\n (click)=\"$event.stopPropagation()\"\r\n />\r\n <!-- email.includes(term) || name.includes(term) -->\r\n </div>\r\n\r\n <!-- Select All -->\r\n <div class=\"form-check px-0 mb-2 d-flex align-items-center\">\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input\"\r\n id=\"reviewer-all\"\r\n [checked]=\"areAllApproversSelected()\"\r\n (change)=\"onApproverSelectAll($event)\"\r\n />\r\n <label for=\"reviewer-all\" class=\"form-check-label text-dark ms-2\">\r\n Select All\r\n </label>\r\n </div>\r\n\r\n <!-- Options (use filteredReviewerList instead of userList) -->\r\n <div\r\n class=\"form-check mb-1 px-0 d-flex align-items-center\"\r\n *ngFor=\"let u of filteredApproverList\"\r\n >\r\n <input\r\n class=\"form-check-input\"\r\n type=\"checkbox\"\r\n [id]=\"'rev-' + u.email\"\r\n [checked]=\"isApproverSelected(u.email)\"\r\n (change)=\"onApproverChange($event, u.email)\"\r\n />\r\n <label class=\"form-check-label text-dark ms-2\" [for]=\"'rev-' + u.email\">\r\n {{ u.email }}\r\n </label>\r\n </div>\r\n</div>\r\n\r\n <!-- Dropdown panel -->\r\n\r\n</div>\r\n\r\n\r\n <!-- Footer buttons -->\r\n <div class=\"d-flex justify-content-between w-100 mt-4\">\r\n <button type=\"button\" class=\"btn btn-outline w-50 me-1\" (click)=\"onReset()\">\r\n Reset\r\n </button>\r\n <button type=\"button\" class=\"btn btn-primary w-50 ms-1\" (click)=\"onApply()\">\r\n Apply\r\n </button>\r\n </div>\r\n </form>\r\n </div>\r\n</div>\r\n", styles: [".filter-wrapper{position:absolute;top:0;right:0;padding:16px;z-index:1050}.filter-card{width:350px;background:#fff;border-radius:12px;padding:16px 18px;box-shadow:0 8px 30px #00000014;font-size:13px}.filter-header .title{font-weight:600;font-size:14px}.btn-close{border:none;background:transparent;font-size:16px;cursor:pointer}.form-label{font-size:12px;margin-bottom:4px}.form-select,.form-control{font-size:13px}.gap-2{gap:4px}.badge{padding:0 6px;border-radius:999px;font-size:11px;background:#e5f3ff;color:#007bff}input[type=checkbox]{width:16px!important;height:16px!important;margin:-2px 5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-600, #D0D5DD)!important;box-shadow:none;font-size:.5em;text-align:center;line-height:1em;background:#fff}input[type=checkbox]{outline:1px solid var(--primary-600, #00A3FF)!important;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:.5em;padding-left:3px;padding-top:10px;padding-right:0}.text-dark{color:#344054!important}\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: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.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: i1.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i1.MaxValidator, selector: "input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]", inputs: ["max"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
499
+ }
500
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TicketFilterPanelComponent, decorators: [{
501
+ type: Component,
502
+ args: [{ selector: 'lib-ticket-filter-panel', template: "<!-- ticket-filter-panel.component.html -->\r\n<div class=\"filter-wrapper\" *ngIf=\"isOpen\">\r\n <div class=\"filter-card\">\r\n <div class=\"filter-header d-flex justify-content-between align-items-center mb-3\">\r\n <div class=\"title\">Filter Options</div>\r\n <!-- <button type=\"button\" class=\"btn-close\" (click)=\"close()\">\u2715</button> -->\r\n </div>\r\n\r\n <form [formGroup]=\"filterForm\">\r\n\r\n <div *ngIf=\"tab ==='internal'\" class=\"mb-3 position-relative\" (click)=\"$event.stopPropagation()\">\r\n\r\n <label class=\"form-label\">Ticket Type</label>\r\n <select class=\"form-select w-100\" formControlName=\"type\" (change)=\"onTicketTypeChange($event)\">\r\n <option disabled [ngValue]=\"null\">Select</option>\r\n <option value=\"store\">Store</option>\r\n <option value=\"internal\">Internal</option>\r\n </select>\r\n </div>\r\n <!-- Status -->\r\n<div class=\"mb-3 position-relative\" (click)=\"$event.stopPropagation()\">\r\n <label *ngIf=\"tab !=='internal'\" class=\"form-label\">Status</label>\r\n <label *ngIf=\"tab ==='internal'\" class=\"form-label\">Tango Status</label>\r\n <!-- Header / trigger -->\r\n <div\r\n class=\"status-select border rounded px-3 py-2 d-flex justify-content-between align-items-center\"\r\n (click)=\"toggleDropdown('status', $event)\"\r\n >\r\n <span *ngIf=\"!selectedStatuses.length\">Select</span>\r\n\r\n <span *ngIf=\"selectedStatuses.length === 1\">\r\n {{ selectedStatuses[0] }}\r\n </span>\r\n\r\n <span *ngIf=\"selectedStatuses.length > 1\" class=\"d-flex align-items-center\">\r\n <span>{{ selectedStatuses[0] }}</span>\r\n <span class=\"badge ms-2\">\r\n +{{ selectedStatuses.length - 1 }}\r\n </span>\r\n </span>\r\n\r\n </div>\r\n\r\n <!-- DROPDOWN PANEL (OVERLAY) -->\r\n <div\r\n class=\"status-dropdown position-absolute w-100 mt-1 border rounded p-1 bg-white\"\r\n style=\"z-index: 1000; max-height: 220px; overflow-y: auto;\"\r\n *ngIf=\"isDropdownOpen('status')\"\r\n (click)=\"$event.stopPropagation()\"\r\n >\r\n <!-- Select All -->\r\n <div class=\"form-check px-0 d-flex align-items-center mb-2\">\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input \"\r\n id=\"status-select-all\"\r\n [checked]=\"areAllStatusesSelected()\"\r\n (change)=\"onStatusSelectAllChange($event)\"\r\n />\r\n <label class=\"form-check-label text-dark ms-2\" for=\"status-select-all\">\r\n Select All\r\n </label>\r\n </div>\r\n\r\n\r\n <!-- Options -->\r\n <div\r\n class=\"form-check px-0 d-flex align-items-center mb-1\"\r\n *ngFor=\"let s of statusOptions\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input \"\r\n [id]=\"'status-' + s\"\r\n [checked]=\"isStatusSelected(s)\"\r\n (change)=\"onStatusChange($event, s)\"\r\n />\r\n <label class=\"form-check-label text-dark ms-2\" [for]=\"'status-' + s\">\r\n {{ s }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n<div *ngIf=\"tab ==='internal'\" class=\"mb-3 position-relative\" (click)=\"$event.stopPropagation()\">\r\n <label class=\"form-label\">Ticket Status</label>\r\n\r\n <!-- Header / trigger -->\r\n <div\r\n class=\"status-select border rounded px-3 py-2 d-flex justify-content-between align-items-center\"\r\n (click)=\"toggleDropdown('ticketStatus', $event)\"\r\n >\r\n <span *ngIf=\"!selectedTicketStatuses.length\">Select</span>\r\n\r\n <span *ngIf=\"selectedTicketStatuses.length === 1\">\r\n {{ selectedTicketStatuses[0] }}\r\n </span>\r\n\r\n <span *ngIf=\"selectedTicketStatuses.length > 1\" class=\"d-flex align-items-center\">\r\n <span>{{ selectedTicketStatuses[0] }}</span>\r\n <span class=\"badge ms-2\">\r\n +{{ selectedTicketStatuses.length - 1 }}\r\n </span>\r\n </span>\r\n\r\n </div>\r\n\r\n <!-- DROPDOWN PANEL (OVERLAY) -->\r\n <div\r\n class=\"status-dropdown position-absolute w-100 mt-1 border rounded p-1 bg-white\"\r\n style=\"z-index: 1000; max-height: 220px; overflow-y: auto;\"\r\n *ngIf=\"isDropdownOpen('ticketStatus')\"\r\n (click)=\"$event.stopPropagation()\"\r\n >\r\n <!-- Select All -->\r\n <div class=\"form-check px-0 d-flex align-items-center mb-2\">\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input \"\r\n id=\"status-select-all\"\r\n [checked]=\"areAllTicketStatusesSelected()\"\r\n (change)=\"onTicketStatusSelectAllChange($event)\"\r\n />\r\n <label class=\"form-check-label text-dark ms-2\" for=\"status-select-all\">\r\n Select All\r\n </label>\r\n </div>\r\n\r\n\r\n <!-- Options -->\r\n <div\r\n class=\"form-check px-0 d-flex align-items-center mb-1\"\r\n *ngFor=\"let s of ticketStatusOptions\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input \"\r\n [id]=\"'ticketStatus-' + s\"\r\n [checked]=\"isTicketStatusSelected(s)\"\r\n (change)=\"onTicketStatusChange($event, s)\"\r\n />\r\n <label class=\"form-check-label text-dark ms-2\" [for]=\"'ticketStatus-' + s\">\r\n {{ s }}\r\n </label>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n <!-- Reviewer accuracy -->\r\n <div class=\"mb-3\" *ngIf=\"showReviewerAccuracy\" (click)=\"closeAll()\">\r\n <label class=\"form-label\">Reviewer accuracy (%) by condition</label>\r\n <div class=\"d-flex gap-2\">\r\n <select class=\"form-select w-100\" formControlName=\"reviewerCondition\">\r\n <option disabled [ngValue]=\"null\">Select</option>\r\n <option *ngFor=\"let c of conditionOptions\" [ngValue]=\"c.value\">\r\n {{ c.label }}\r\n </option>\r\n </select>\r\n\r\n <!-- one or two inputs -->\r\n <ng-container *ngIf=\"isBetween('reviewerCondition'); else singleReviewer\">\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"reviewerFrom\"\r\n placeholder=\"From\" (input)=\"limitValue($event, 'reviewerFrom')\" />\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"reviewerTo\"\r\n placeholder=\"To\" (input)=\"limitValue($event, 'reviewerTo')\" />\r\n </ng-container>\r\n <ng-template #singleReviewer>\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"reviewerFrom\"\r\n placeholder=\"1 to 100%\" (input)=\"limitValue($event, 'reviewerFrom')\" />\r\n </ng-template>\r\n </div>\r\n </div>\r\n\r\n <!-- Approver accuracy -->\r\n <div class=\"mb-3\" *ngIf=\"showApproverAccuracy\" (click)=\"closeAll()\">\r\n <label class=\"form-label\">Approver accuracy (%) by condition</label>\r\n <div class=\"d-flex gap-2\">\r\n <select class=\"form-select w-100\" formControlName=\"approverCondition\">\r\n <option disabled [ngValue]=\"null\">Select</option>\r\n <option *ngFor=\"let c of conditionOptions\" [ngValue]=\"c.value\">\r\n {{ c.label }}\r\n </option>\r\n </select>\r\n\r\n <ng-container *ngIf=\"isBetween('approverCondition'); else singleApprover\">\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"approverFrom\"\r\n placeholder=\"From\" \r\n (input)=\"limitValue($event, 'approverFrom')\"/>\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"approverTo\"\r\n placeholder=\"To\" (input)=\"limitValue($event, 'approverTo')\" />\r\n </ng-container>\r\n <ng-template #singleApprover>\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"approverFrom\"\r\n placeholder=\"1 to 100%\" (input)=\"limitValue($event, 'approverFrom')\" />\r\n </ng-template>\r\n </div>\r\n </div>\r\n\r\n <!-- Tango accuracy -->\r\n <div class=\"mb-3\" *ngIf=\"showTangoAccuracy\" (click)=\"closeAll()\">\r\n <label class=\"form-label\">Tango accuracy (%) by condition</label>\r\n <div class=\"d-flex gap-2\">\r\n <select class=\"form-select w-100\" formControlName=\"tangoCondition\">\r\n <option disabled [ngValue]=\"null\">Select</option>\r\n <option *ngFor=\"let c of conditionOptions\" [ngValue]=\"c.value\">\r\n {{ c.label }}\r\n </option>\r\n </select>\r\n\r\n <ng-container *ngIf=\"isBetween('tangoCondition'); else singleTango\">\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"tangoFrom\"\r\n placeholder=\"From\" (input)=\"limitValue($event, 'tangoFrom')\" />\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"tangoTo\"\r\n placeholder=\"To\" (input)=\"limitValue($event, 'tangoTo')\" />\r\n </ng-container>\r\n <ng-template #singleTango>\r\n <input\r\n type=\"number\"\r\n min=\"1\"\r\n max=\"100\"\r\n class=\"form-control\"\r\n formControlName=\"tangoFrom\"\r\n placeholder=\"1 to 100%\" (input)=\"limitValue($event, 'tangoFrom')\" />\r\n </ng-template>\r\n </div>\r\n </div>\r\n<div\r\n class=\"mb-3 position-relative\"\r\n *ngIf=\"showReviewedBy\"\r\n (click)=\"$event.stopPropagation()\"\r\n>\r\n <label class=\"form-label\">Reviewed by</label>\r\n\r\n <!-- Trigger / display -->\r\n <div\r\n class=\"border rounded px-3 py-2 d-flex justify-content-between align-items-center\"\r\n (click)=\"toggleDropdown('reviewer', $event)\"\r\n >\r\n <!-- 0 selected -->\r\n <span *ngIf=\"!selectedReviewedBy.length\">\r\n Select\r\n </span>\r\n\r\n <!-- 1 selected -->\r\n <span *ngIf=\"selectedReviewedBy.length === 1\">\r\n {{ selectedReviewedBy[0] }}\r\n </span>\r\n\r\n <!-- >1 selected -->\r\n <span\r\n *ngIf=\"selectedReviewedBy.length > 1\"\r\n class=\"d-flex align-items-center\"\r\n >\r\n <span>{{ selectedReviewedBy[0] }}</span>\r\n <span class=\"badge ms-2\">\r\n +{{ selectedReviewedBy.length - 1 }}\r\n </span>\r\n </span>\r\n </div>\r\n\r\n<div\r\n *ngIf=\"isDropdownOpen('reviewer')\"\r\n class=\"position-absolute w-100 border rounded bg-white p-1 mt-1\"\r\n style=\"z-index: 1000; max-height: 220px; overflow-y: auto;\"\r\n (click)=\"$event.stopPropagation()\"\r\n>\r\n\r\n <!-- \uD83D\uDD0D Search box -->\r\n <div class=\"mb-2 px-0\">\r\n <input\r\n type=\"text\"\r\n class=\"form-control form-control-sm\"\r\n placeholder=\"Search by email\"\r\n [(ngModel)]=\"reviewerSearchTerm\"\r\n [ngModelOptions]=\"{standalone: true}\"\r\n (click)=\"$event.stopPropagation()\"\r\n />\r\n </div>\r\n\r\n <!-- Select All -->\r\n <div class=\"form-check px-0 mb-2 d-flex align-items-center\">\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input\"\r\n id=\"reviewer-all\"\r\n [checked]=\"areAllReviewersSelected()\"\r\n (change)=\"onReviewerSelectAll($event)\"\r\n />\r\n <label for=\"reviewer-all\" class=\"form-check-label text-dark ms-2\">\r\n Select All\r\n </label>\r\n </div>\r\n\r\n <!-- Options \u2013 now use getter filteredReviewerList -->\r\n <div\r\n class=\"form-check mb-1 px-0 d-flex align-items-center\"\r\n *ngFor=\"let u of filteredReviewerList\"\r\n >\r\n <input\r\n class=\"form-check-input\"\r\n type=\"checkbox\"\r\n [id]=\"'rev-' + u.email\"\r\n [checked]=\"isReviewerSelected(u.email)\"\r\n (change)=\"onReviewerChange($event, u.email)\"\r\n />\r\n <label class=\"form-check-label text-dark ms-2\" [for]=\"'rev-' + u.email\">\r\n {{ u.email }}\r\n </label>\r\n </div>\r\n</div>\r\n\r\n\r\n</div>\r\n\r\n\r\n <!-- Approved By -->\r\n<div\r\n class=\"mb-3 position-relative\"\r\n *ngIf=\"showApprovedBy\"\r\n (click)=\"$event.stopPropagation()\"\r\n>\r\n <label class=\"form-label\">Approved by</label>\r\n\r\n <!-- Trigger / display -->\r\n <div\r\n class=\"border rounded px-3 py-2 d-flex justify-content-between align-items-center\"\r\n (click)=\"toggleDropdown('approver', $event)\"\r\n >\r\n <!-- 0 selected -->\r\n <span *ngIf=\"!selectedApprovedBy.length\">\r\n Select\r\n </span>\r\n\r\n <!-- 1 selected -->\r\n <span *ngIf=\"selectedApprovedBy.length === 1\">\r\n {{ selectedApprovedBy[0] }}\r\n </span>\r\n\r\n <!-- >1 selected -->\r\n <span\r\n *ngIf=\"selectedApprovedBy.length > 1\"\r\n class=\"d-flex align-items-center\"\r\n >\r\n <span>{{ selectedApprovedBy[0] }}</span>\r\n <span class=\"badge ms-2\">\r\n +{{ selectedApprovedBy.length - 1 }}\r\n </span>\r\n </span>\r\n\r\n </div>\r\n<!-- Dropdown panel -->\r\n<div\r\n *ngIf=\"isDropdownOpen('approver')\"\r\n class=\"position-absolute w-100 border rounded bg-white p-1 mt-1\"\r\n style=\"z-index: 1000; max-height: 220px; overflow-y: auto;\"\r\n (click)=\"$event.stopPropagation()\"\r\n>\r\n\r\n <!-- \uD83D\uDD0D Search box -->\r\n <div class=\"mb-2 px-0\">\r\n <input\r\n type=\"text\"\r\n class=\"form-control form-control-sm\"\r\n placeholder=\"Search by email\"\r\n [(ngModel)]=\"approverSearchTerm\"\r\n [ngModelOptions]=\"{standalone: true}\"\r\n (click)=\"$event.stopPropagation()\"\r\n />\r\n <!-- email.includes(term) || name.includes(term) -->\r\n </div>\r\n\r\n <!-- Select All -->\r\n <div class=\"form-check px-0 mb-2 d-flex align-items-center\">\r\n <input\r\n type=\"checkbox\"\r\n class=\"form-check-input\"\r\n id=\"reviewer-all\"\r\n [checked]=\"areAllApproversSelected()\"\r\n (change)=\"onApproverSelectAll($event)\"\r\n />\r\n <label for=\"reviewer-all\" class=\"form-check-label text-dark ms-2\">\r\n Select All\r\n </label>\r\n </div>\r\n\r\n <!-- Options (use filteredReviewerList instead of userList) -->\r\n <div\r\n class=\"form-check mb-1 px-0 d-flex align-items-center\"\r\n *ngFor=\"let u of filteredApproverList\"\r\n >\r\n <input\r\n class=\"form-check-input\"\r\n type=\"checkbox\"\r\n [id]=\"'rev-' + u.email\"\r\n [checked]=\"isApproverSelected(u.email)\"\r\n (change)=\"onApproverChange($event, u.email)\"\r\n />\r\n <label class=\"form-check-label text-dark ms-2\" [for]=\"'rev-' + u.email\">\r\n {{ u.email }}\r\n </label>\r\n </div>\r\n</div>\r\n\r\n <!-- Dropdown panel -->\r\n\r\n</div>\r\n\r\n\r\n <!-- Footer buttons -->\r\n <div class=\"d-flex justify-content-between w-100 mt-4\">\r\n <button type=\"button\" class=\"btn btn-outline w-50 me-1\" (click)=\"onReset()\">\r\n Reset\r\n </button>\r\n <button type=\"button\" class=\"btn btn-primary w-50 ms-1\" (click)=\"onApply()\">\r\n Apply\r\n </button>\r\n </div>\r\n </form>\r\n </div>\r\n</div>\r\n", styles: [".filter-wrapper{position:absolute;top:0;right:0;padding:16px;z-index:1050}.filter-card{width:350px;background:#fff;border-radius:12px;padding:16px 18px;box-shadow:0 8px 30px #00000014;font-size:13px}.filter-header .title{font-weight:600;font-size:14px}.btn-close{border:none;background:transparent;font-size:16px;cursor:pointer}.form-label{font-size:12px;margin-bottom:4px}.form-select,.form-control{font-size:13px}.gap-2{gap:4px}.badge{padding:0 6px;border-radius:999px;font-size:11px;background:#e5f3ff;color:#007bff}input[type=checkbox]{width:16px!important;height:16px!important;margin:-2px 5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-600, #D0D5DD)!important;box-shadow:none;font-size:.5em;text-align:center;line-height:1em;background:#fff}input[type=checkbox]{outline:1px solid var(--primary-600, #00A3FF)!important;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:.5em;padding-left:3px;padding-top:10px;padding-right:0}.text-dark{color:#344054!important}\n"] }]
503
+ }], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i0.ElementRef }, { type: i2.TicketService }], propDecorators: { apply: [{
504
+ type: Output
505
+ }], panelClosed: [{
506
+ type: Output
507
+ }], permissionType: [{
508
+ type: Input
509
+ }], userType: [{
510
+ type: Input
511
+ }], client: [{
512
+ type: Input
513
+ }], tab: [{
514
+ type: Input
515
+ }], onDocumentClick: [{
516
+ type: HostListener,
517
+ args: ['document:click', ['$event']]
518
+ }] } });
519
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ticket-filter-panel.component.js","sourceRoot":"","sources":["../../../../../../projects/tango-manage-tickets/src/lib/components/ticket-filter-panel/ticket-filter-panel.component.ts","../../../../../../projects/tango-manage-tickets/src/lib/components/ticket-filter-panel/ticket-filter-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { TicketService } from '../../services/ticket.service';\r\n\r\ntype Condition = 'gt' | 'lt' | 'gte' | 'lte' | 'between';\r\n\r\n@Component({\r\n  selector: 'lib-ticket-filter-panel',\r\n  templateUrl: './ticket-filter-panel.component.html',\r\n  styleUrl: './ticket-filter-panel.component.scss'\r\n})\r\nexport class TicketFilterPanelComponent implements OnChanges {\r\n   @Output() apply = new EventEmitter<any>();\r\n  @Output() panelClosed = new EventEmitter<void>();   // ✅ not `close`\r\n  @Input() permissionType: string | null = null;\r\n@Input() userType: string | null = null; // e.g. 'tango' or others\r\n@Input() client :any;\r\n@Input() tab:any;\r\n @HostListener('document:click', ['$event'])\r\nonDocumentClick(event: MouseEvent): void {\r\n\r\n  // 1️⃣ Always close dropdowns first\r\n  this.dropdownState.status = false;\r\n  this.dropdownState.reviewer = false;\r\n  this.dropdownState.approver = false;\r\n   this.dropdownState.ticketStatus =false;\r\n\r\n  // 2️⃣ If filter is not open → nothing to close\r\n  if (!this.isOpen) return;\r\n\r\n  // 3️⃣ Check if clicked inside filter card\r\n  const clickedInside = this.eRef.nativeElement.contains(event.target);\r\n\r\n  // 4️⃣ If clicked OUTSIDE → close entire filter panel\r\n  if (!clickedInside) {\r\n    this.isOpen = false;\r\n    this.panelClosed.emit();\r\n   this.filterForm.reset({\r\n     status: [],\r\n     type:null,\r\n    ticketStatus :[],\r\n    reviewerCondition: null,\r\n    reviewerFrom: null,\r\n    reviewerTo: null,\r\n\r\n    approverCondition: null,\r\n    approverFrom: null,\r\n    approverTo: null,\r\n\r\n    tangoCondition: null,\r\n    tangoFrom: null,\r\n    tangoTo: null,\r\n\r\n    reviewedBy: [],\r\n    approvedBy: []\r\n  });\r\nthis.onReset();\r\n  }\r\n}\r\n  isOpen = false;                                     // controls visibility\r\n\r\n  // called from parent via #filterPanel.open()\r\n  open() {\r\n    this.isOpen = true;\r\n   \r\n  }\r\n\r\n  // called from close button inside the panel\r\n  close() {\r\n    this.isOpen = false;\r\n    this.panelClosed.emit();\r\n  }\r\n\r\n  showPanel = false;           // you can also control this from parent\r\n\r\nstatusOptions: any[] = [\r\n  'Open',\r\n  'In-Progress',\r\n  'Closed',\r\n  // 'Open - Accuracy Issue',\r\n  // 'Closed - Accuracy Issue',\r\n  'Expired',\r\n];\r\nticketStatusOptions: any[] = [\r\n  'Reviewer - Open',\r\n  'Reviewer - In-Progress',\r\n  'Reviewer - Closed',\r\n  'Reviewer - Expired',\r\n  'Approver - Open',\r\n  'Approver - In-Progress',\r\n  'Approver - Closed',\r\n  'Approver - Expired',\r\n];\r\n\r\n  conditionOptions = [\r\n    { value: 'gt', label: '> Greater than' },\r\n    { value: 'lt', label: '< Lesser than' },\r\n    { value: 'gte', label: '>= Greater than or equal to' },\r\n    { value: 'lte', label: '<= Lesser than or equal to' },\r\n    { value: 'between', label: 'Between' },\r\n  ];\r\n\r\n  filterForm: FormGroup;\r\n\r\n  constructor(private fb: FormBuilder,private eRef: ElementRef,private service:TicketService) {\r\n    this.filterForm = this.fb.group({\r\n      status: [[]],\r\n      type:null,\r\n      ticketStatus :[[]],\r\n      reviewerCondition: [null as Condition | null],\r\n      reviewerFrom: [null,[Validators.min(0), Validators.max(100)]],\r\n      reviewerTo: [null,[Validators.min(0), Validators.max(100)]],\r\n\r\n      approverCondition: [null as Condition | null],\r\n      approverFrom: [null,[Validators.min(0), Validators.max(100)]],\r\n      approverTo: [null,[Validators.min(0), Validators.max(100)]],\r\n\r\n      tangoCondition: [null as Condition | null],\r\n      tangoFrom: [null,[Validators.min(0), Validators.max(100)]],\r\n      tangoTo: [null,[Validators.min(0), Validators.max(100)]],\r\n\r\n      reviewedBy: [[]],\r\n  approvedBy: [[]],  \r\n    });\r\n    this.onReset();\r\n  }\r\n\r\n\r\nlimitValue(event: any, controlName: string) {\r\n  let value = Number(event.target.value);\r\n\r\n  if (value < 0) value = 0;\r\n  if (value > 100) value = 100;\r\n\r\n  event.target.value = value;\r\n  this.filterForm.get(controlName)?.setValue(value, { emitEvent: false });\r\n}\r\n\r\nget isTango(): boolean {\r\n  return this.userType === 'tango';\r\n}\r\n\r\n// SHOW / HIDE RULES\r\n\r\n// Reviewer accuracy and \"Reviewed by\" visible for tango + reviewer\r\nget showReviewerAccuracy(): boolean {\r\n  return this.isTango || this.permissionType === 'review';\r\n}\r\n\r\nget showReviewedBy(): boolean {\r\n  return  this.permissionType === 'review';\r\n}\r\n\r\n// Approver accuracy and \"Approved by\" visible for tango + approver\r\nget showApproverAccuracy(): boolean {\r\n  return this.isTango || this.permissionType === 'approve';\r\n}\r\n\r\nget showApprovedBy(): boolean {\r\n  return  this.permissionType === 'approve';\r\n}\r\n\r\n// Tango accuracy only for tango users\r\nget showTangoAccuracy(): boolean {\r\n  return this.isTango;\r\n}\r\nstatusDropdownOpen = false;\r\nisStatusSelected(status: string): boolean {\r\n  const selected: string[] = this.filterForm.value.status || [];\r\n  return selected.includes(status);\r\n}\r\n\r\nonStatusChange(event: Event, status: string) {\r\n  const checkbox = event.target as HTMLInputElement;\r\n  const selected: string[] = this.filterForm.value.status || [];\r\n  let next: string[];\r\n\r\n  if (checkbox.checked) {\r\n    next = selected.includes(status) ? selected : [...selected, status];\r\n  } else {\r\n    next = selected.filter(s => s !== status);\r\n  }\r\n\r\n  this.filterForm.patchValue({ status: next });\r\n}\r\n\r\ntoggleStatusDropdown(event?: MouseEvent) {\r\n  if (event) {\r\n    event.stopPropagation(); // avoid document click closing it\r\n  }\r\n  this.statusDropdownOpen = !this.statusDropdownOpen;\r\n}\r\n\r\n// Are all statuses currently selected?\r\nareAllStatusesSelected(): boolean {\r\n  const selected: string[] = this.filterForm.value.status || [];\r\n  return selected.length > 0 && selected.length === this.statusOptions.length;\r\n}\r\n\r\n// Handle \"Select All\" checkbox change\r\nonStatusSelectAllChange(event: Event) {\r\n  const checkbox = event.target as HTMLInputElement;\r\n\r\n  if (checkbox.checked) {\r\n    // Select every status\r\n    this.filterForm.patchValue({ status: [...this.statusOptions] });\r\n  } else {\r\n    // Clear all\r\n    this.filterForm.patchValue({ status: [] });\r\n  }\r\n}\r\nget selectedStatuses(): string[] {\r\n  return this.filterForm.value.status || [];\r\n}\r\n\r\nisTicketStatusSelected(status: string): boolean {\r\n  const selected: string[] = this.filterForm.value.ticketStatus || [];\r\n  return selected.includes(status);\r\n}\r\n\r\nonTicketStatusChange(event: Event, status: string) {\r\n  const checkbox = event.target as HTMLInputElement;\r\n  const selected: string[] = this.filterForm.value.ticketStatus || [];\r\n  let next: string[];\r\n\r\n  if (checkbox.checked) {\r\n    next = selected.includes(status) ? selected : [...selected, status];\r\n  } else {\r\n    next = selected.filter(s => s !== status);\r\n  }\r\n\r\n  this.filterForm.patchValue({ status: next });\r\n}\r\n\r\ntoggleTicketStatusDropdown(event?: MouseEvent) {\r\n  if (event) {\r\n    event.stopPropagation(); // avoid document click closing it\r\n  }\r\n  this.statusDropdownOpen = !this.statusDropdownOpen;\r\n}\r\n\r\n// Are all statuses currently selected?\r\nareAllTicketStatusesSelected(): boolean {\r\n  const selected: string[] = this.filterForm.value.ticketStatus || [];\r\n  return selected.length > 0 && selected.length === this.ticketStatusOptions.length;\r\n}\r\n\r\n// Handle \"Select All\" checkbox change\r\nonTicketStatusSelectAllChange(event: Event) {\r\n  const checkbox = event.target as HTMLInputElement;\r\n\r\n  if (checkbox.checked) {\r\n    // Select every status\r\n    this.filterForm.patchValue({ ticketStatus: [...this.ticketStatusOptions] });\r\n  } else {\r\n    // Clear all\r\n    this.filterForm.patchValue({ ticketStatus: [] });\r\n  }\r\n}\r\nget selectedTicketStatuses(): string[] {\r\n  return this.filterForm.value.ticketStatus || [];\r\n}\r\n\r\n  isBetween(controlName: string): boolean {\r\n    return this.filterForm.get(controlName)?.value === 'between';\r\n  }\r\nngOnChanges(changes: SimpleChanges): void {\r\n  if (changes['client'] || changes['permissionType'] || changes['userType']) {\r\n    this.loadReviewerList();\r\n  }\r\n  this.onReset();\r\n}\r\n// full user list you already have\r\nuserList: any[] = [];\r\n\r\n\r\nreviewerSearchTerm: string = '';\r\n\r\n// ✅ simple computed list for *ngFor\r\nget filteredReviewerList(): { email: string; name?: string }[] {\r\n  const term = (this.reviewerSearchTerm || '').trim().toLowerCase();\r\n\r\n  if (!term) {\r\n    return this.userList;\r\n  }\r\n\r\n  return this.userList.filter(u => {\r\n    const email = (u.email || '').toLowerCase();\r\n    const name = (u.name || '').toLowerCase();\r\n    if(this.reviewerSearchTerm.length){\r\n    return email.includes(term) || name.includes(term);\r\n    }\r\n  });\r\n}\r\napproverSearchTerm:any;\r\nget filteredApproverList(): any[] {\r\n  const term = (this.approverSearchTerm || '').trim().toLowerCase();\r\n  if (!term) {\r\n    return this.userList;\r\n  }\r\n  return this.userList.filter((u: any) => {\r\n    const email = (u.email || '').toLowerCase();\r\n    const name = (u.name || '').toLowerCase();\r\n    if(this.approverSearchTerm.length){\r\n      return email.includes(term) || name.includes(term)\r\n    }\r\n  });\r\n}\r\n\r\nonApproverSearch(value: string) {\r\n  this.approverSearchTerm = value;\r\n}\r\nprivate loadReviewerList(): void {\r\n  if (!this.client) {\r\n    this.userList = [];\r\n    return;\r\n  }\r\n\r\n  let type: string;\r\n\r\n  if (this.userType === 'tango') {\r\n    type = 'tango';    // or 'all'\r\n  } else if (this.permissionType === 'review') {\r\n    type = 'review';\r\n  } else if (this.permissionType === 'approve') {\r\n    type = 'approve';\r\n  } else {\r\n    this.userList = [];\r\n    return;\r\n  }\r\n\r\n  this.service.getReviewerApi(this.client, type,'').subscribe({\r\n    next: (res: any) => {\r\n      if (res && res.code === 200) {\r\n        this.userList = res.data;\r\n      } else {\r\n        this.userList = [];\r\n      }\r\n    },\r\n    error: () => {\r\n      this.userList = [];\r\n    }\r\n  });\r\n}\r\n\r\n// open flags\r\nreviewerDropdownOpen = false;\r\napproverDropdownOpen = false;\r\n\r\n// convenience getters\r\nget selectedReviewedBy(): string[] {\r\n  return this.filterForm.value.reviewedBy || [];\r\n}\r\n\r\nget selectedApprovedBy(): string[] {\r\n  return this.filterForm.value.approvedBy || [];\r\n}\r\n\r\n// --- Reviewed By helpers ---\r\n\r\ntoggleReviewerDropdown(event?: MouseEvent) {\r\n  if (event) event.stopPropagation();\r\n  this.reviewerDropdownOpen = !this.reviewerDropdownOpen;\r\n}\r\n\r\nisReviewerSelected(email: string): boolean {\r\n  return this.selectedReviewedBy.includes(email);\r\n}\r\n\r\nonReviewerChange(event: Event, email: string) {\r\n  const checkbox = event.target as HTMLInputElement;\r\n  const selected = [...this.selectedReviewedBy];\r\n\r\n  if (checkbox.checked) {\r\n    if (!selected.includes(email)) selected.push(email);\r\n  } else {\r\n    const i = selected.indexOf(email);\r\n    if (i >= 0) selected.splice(i, 1);\r\n  }\r\n\r\n  this.filterForm.patchValue({ reviewedBy: selected });\r\n}\r\n\r\nareAllReviewersSelected(): boolean {\r\n  return (\r\n    this.userList.length > 0 &&\r\n    this.selectedReviewedBy.length === this.userList.length\r\n  );\r\n}\r\n\r\nonReviewerSelectAll(event: Event) {\r\n  const checkbox = event.target as HTMLInputElement;\r\n\r\n  if (checkbox.checked) {\r\n    this.filterForm.patchValue({\r\n      reviewedBy: this.userList.map((u:any) => u.email),\r\n    });\r\n  } else {\r\n    this.filterForm.patchValue({ reviewedBy: [] });\r\n  }\r\n}\r\n\r\n// --- Approved By helpers ---\r\n\r\ntoggleApproverDropdown(event?: MouseEvent) {\r\n  if (event) event.stopPropagation();\r\n  this.approverDropdownOpen = !this.approverDropdownOpen;\r\n}\r\n\r\nisApproverSelected(email: string): boolean {\r\n  return this.selectedApprovedBy.includes(email);\r\n}\r\n\r\nonApproverChange(event: Event, email: string) {\r\n  const checkbox = event.target as HTMLInputElement;\r\n  const selected = [...this.selectedApprovedBy];\r\n\r\n  if (checkbox.checked) {\r\n    if (!selected.includes(email)) selected.push(email);\r\n  } else {\r\n    const i = selected.indexOf(email);\r\n    if (i >= 0) selected.splice(i, 1);\r\n  }\r\n\r\n  this.filterForm.patchValue({ approvedBy: selected });\r\n}\r\n\r\nareAllApproversSelected(): boolean {\r\n  return (\r\n    this.userList.length > 0 &&\r\n    this.selectedApprovedBy.length === this.userList.length\r\n  );\r\n}\r\n\r\nonApproverSelectAll(event: Event) {\r\n  const checkbox = event.target as HTMLInputElement;\r\n\r\n  if (checkbox.checked) {\r\n    this.filterForm.patchValue({\r\n      approvedBy: this.userList.map((u:any) => u.email),\r\n    });\r\n  } else {\r\n    this.filterForm.patchValue({ approvedBy: [] });\r\n  }\r\n}\r\n\r\nonReset(): void {\r\n  this.filterForm.reset({\r\n    status: [],\r\n    reviewerCondition: null,\r\n    reviewerFrom: null,\r\n    reviewerTo: null,\r\n\r\n    approverCondition: null,\r\n    approverFrom: null,\r\n    approverTo: null,\r\n\r\n    tangoCondition: null,\r\n    tangoFrom: null,\r\n    tangoTo: null,\r\n\r\n    reviewedBy: [],\r\n    approvedBy: []\r\n  });\r\n\r\n  // 2️⃣ Reset search terms\r\n  this.reviewerSearchTerm = '';\r\n  this.approverSearchTerm = '';\r\n\r\n  // 3️⃣ Build empty payload to send back\r\n  const payload = {\r\n    filterByStatus: [],\r\n    filterByReviewer: null,\r\n    filterByApprover: null,\r\n    filterByTango: null,\r\n    filterByReviewedBy: [],\r\n    fileterByApprovedBy: [],\r\n        ...(this.tab === 'internal' && {\r\n    filterByTicketType: null,\r\n    filterByTangoStatus: []\r\n  })\r\n  };\r\n\r\n  // 4️⃣ Emit the now-empty filter result\r\n  this.apply.emit(payload);\r\n\r\n  // 5️⃣ Close the filter panel\r\n  this.close();\r\n}\r\n\r\nprivate mapAccuracy(\r\n  condition: Condition | null,\r\n  from: number | null,\r\n  to: number | null\r\n): string | null {\r\n\r\n  // nothing selected\r\n  if (!condition || from == null) return null;\r\n\r\n  // \"between\" → \"90 to 100\"\r\n  if (condition === 'between') {\r\n    if (to == null) return null;\r\n    return `${from} to ${to}`;\r\n  }\r\n\r\n  // other conditions (gt, lt, gte, lte)\r\n  const opMap: Record<Condition, string> = {\r\n    gt: '>',\r\n    lt: '<',\r\n    gte: '>=',\r\n    lte: '<=',\r\n    between: '', // already handled above\r\n  };\r\n\r\n  return `${opMap[condition]}${from}`;  // e.g. \">= 90\"\r\n}\r\nonTicketTypeChange(event: Event): void {\r\n  const value = (event.target as HTMLSelectElement).value;\r\n  console.log('Ticket type changed:', value);\r\n// this.ticketType = value\r\n  // do what you need here\r\n  // example:\r\n  // this.tab = value;\r\n  // this.reloadData();\r\n}\r\n\r\n  onApply(): void {\r\n\r\n   const raw = this.filterForm.value;\r\n\r\n  const reviewerStr = this.mapAccuracy(raw.reviewerCondition, raw.reviewerFrom, raw.reviewerTo);\r\n  const approverStr = this.mapAccuracy(raw.approverCondition, raw.approverFrom, raw.approverTo);\r\n  const tangoStr    = this.mapAccuracy(raw.tangoCondition, raw.tangoFrom, raw.tangoTo);\r\n  const payload = {\r\n    filterByStatus: raw.status || [],\r\n    filterByReviewer: reviewerStr,\r\n    filterByApprover: approverStr,\r\n    filterByTango: tangoStr,\r\n    filterByReviewedBy: raw.reviewedBy || [],        \r\n    fileterByApprovedBy: raw.approvedBy || [],\r\n    ...(this.tab === 'internal' && {\r\n    filterByTicketType: raw.ticketType,\r\n    filterByTangoStatus: raw.tangoStatus || []\r\n  })        \r\n  };\r\n  this.apply.emit(payload);\r\n  this.close();\r\n    this.showPanel = false;\r\n  }\r\n\r\ndropdownState = {\r\n  status: false,\r\n  reviewer: false,\r\n  approver: false,\r\n  ticketStatus :false\r\n};\r\n// @HostListener('document:click')\r\ncloseAll() {\r\n  this.dropdownState.status = false;\r\n  this.dropdownState.reviewer = false;\r\n  this.dropdownState.approver = false;\r\n  this.dropdownState.ticketStatus =false;\r\n}\r\n\r\ntoggleDropdown(type: 'status' | 'reviewer' | 'approver' | 'ticketStatus', event: MouseEvent) {\r\n  event.stopPropagation();\r\n\r\n  // Close all before opening a new one\r\n  this.closeAll();\r\n\r\n  // Toggle only the selected one\r\n  this.dropdownState[type] = !this.dropdownState[type];\r\n}\r\n\r\nisDropdownOpen(type: 'status' | 'reviewer' | 'approver' | 'ticketStatus') {\r\n  return this.dropdownState[type];\r\n}\r\n\r\n\r\n\r\n\r\n}\r\n","<!-- ticket-filter-panel.component.html -->\r\n<div class=\"filter-wrapper\" *ngIf=\"isOpen\">\r\n  <div class=\"filter-card\">\r\n    <div class=\"filter-header d-flex justify-content-between align-items-center mb-3\">\r\n  <div class=\"title\">Filter Options</div>\r\n      <!-- <button type=\"button\" class=\"btn-close\" (click)=\"close()\">✕</button> -->\r\n    </div>\r\n\r\n    <form [formGroup]=\"filterForm\">\r\n\r\n      <div *ngIf=\"tab ==='internal'\" class=\"mb-3 position-relative\" (click)=\"$event.stopPropagation()\">\r\n\r\n <label class=\"form-label\">Ticket Type</label>\r\n <select class=\"form-select w-100\" formControlName=\"type\"  (change)=\"onTicketTypeChange($event)\">\r\n   <option disabled [ngValue]=\"null\">Select</option>\r\n            <option value=\"store\">Store</option>\r\n             <option value=\"internal\">Internal</option>\r\n          </select>\r\n          </div>\r\n      <!-- Status -->\r\n<div class=\"mb-3 position-relative\" (click)=\"$event.stopPropagation()\">\r\n  <label *ngIf=\"tab !=='internal'\" class=\"form-label\">Status</label>\r\n <label *ngIf=\"tab ==='internal'\" class=\"form-label\">Tango Status</label>\r\n  <!-- Header / trigger -->\r\n  <div\r\n    class=\"status-select border rounded px-3 py-2 d-flex justify-content-between align-items-center\"\r\n    (click)=\"toggleDropdown('status', $event)\"\r\n  >\r\n    <span *ngIf=\"!selectedStatuses.length\">Select</span>\r\n\r\n    <span *ngIf=\"selectedStatuses.length === 1\">\r\n      {{ selectedStatuses[0] }}\r\n    </span>\r\n\r\n    <span *ngIf=\"selectedStatuses.length > 1\" class=\"d-flex align-items-center\">\r\n      <span>{{ selectedStatuses[0] }}</span>\r\n      <span class=\"badge ms-2\">\r\n        +{{ selectedStatuses.length - 1 }}\r\n      </span>\r\n    </span>\r\n\r\n  </div>\r\n\r\n  <!-- DROPDOWN PANEL (OVERLAY) -->\r\n  <div\r\n    class=\"status-dropdown position-absolute w-100 mt-1 border rounded p-1 bg-white\"\r\n    style=\"z-index: 1000; max-height: 220px; overflow-y: auto;\"\r\n   *ngIf=\"isDropdownOpen('status')\"\r\n    (click)=\"$event.stopPropagation()\"\r\n  >\r\n    <!-- Select All -->\r\n    <div class=\"form-check px-0 d-flex align-items-center mb-2\">\r\n      <input\r\n        type=\"checkbox\"\r\n        class=\"form-check-input \"\r\n        id=\"status-select-all\"\r\n        [checked]=\"areAllStatusesSelected()\"\r\n        (change)=\"onStatusSelectAllChange($event)\"\r\n      />\r\n      <label class=\"form-check-label text-dark ms-2\" for=\"status-select-all\">\r\n        Select All\r\n      </label>\r\n    </div>\r\n\r\n\r\n    <!-- Options -->\r\n    <div\r\n      class=\"form-check px-0 d-flex align-items-center mb-1\"\r\n      *ngFor=\"let s of statusOptions\"\r\n    >\r\n      <input\r\n        type=\"checkbox\"\r\n        class=\"form-check-input \"\r\n        [id]=\"'status-' + s\"\r\n        [checked]=\"isStatusSelected(s)\"\r\n        (change)=\"onStatusChange($event, s)\"\r\n      />\r\n      <label class=\"form-check-label text-dark ms-2\" [for]=\"'status-' + s\">\r\n        {{ s }}\r\n      </label>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n\r\n<div *ngIf=\"tab ==='internal'\"  class=\"mb-3 position-relative\" (click)=\"$event.stopPropagation()\">\r\n  <label class=\"form-label\">Ticket Status</label>\r\n\r\n  <!-- Header / trigger -->\r\n  <div\r\n    class=\"status-select border rounded px-3 py-2 d-flex justify-content-between align-items-center\"\r\n    (click)=\"toggleDropdown('ticketStatus', $event)\"\r\n  >\r\n    <span *ngIf=\"!selectedTicketStatuses.length\">Select</span>\r\n\r\n    <span *ngIf=\"selectedTicketStatuses.length === 1\">\r\n      {{ selectedTicketStatuses[0] }}\r\n    </span>\r\n\r\n    <span *ngIf=\"selectedTicketStatuses.length > 1\" class=\"d-flex align-items-center\">\r\n      <span>{{ selectedTicketStatuses[0] }}</span>\r\n      <span class=\"badge ms-2\">\r\n        +{{ selectedTicketStatuses.length - 1 }}\r\n      </span>\r\n    </span>\r\n\r\n  </div>\r\n\r\n  <!-- DROPDOWN PANEL (OVERLAY) -->\r\n  <div\r\n    class=\"status-dropdown position-absolute w-100 mt-1 border rounded p-1 bg-white\"\r\n    style=\"z-index: 1000; max-height: 220px; overflow-y: auto;\"\r\n   *ngIf=\"isDropdownOpen('ticketStatus')\"\r\n    (click)=\"$event.stopPropagation()\"\r\n  >\r\n    <!-- Select All -->\r\n    <div class=\"form-check px-0 d-flex align-items-center mb-2\">\r\n      <input\r\n        type=\"checkbox\"\r\n        class=\"form-check-input \"\r\n        id=\"status-select-all\"\r\n        [checked]=\"areAllTicketStatusesSelected()\"\r\n        (change)=\"onTicketStatusSelectAllChange($event)\"\r\n      />\r\n      <label class=\"form-check-label text-dark ms-2\" for=\"status-select-all\">\r\n        Select All\r\n      </label>\r\n    </div>\r\n\r\n\r\n    <!-- Options -->\r\n    <div\r\n      class=\"form-check px-0 d-flex align-items-center mb-1\"\r\n      *ngFor=\"let s of ticketStatusOptions\"\r\n    >\r\n      <input\r\n        type=\"checkbox\"\r\n        class=\"form-check-input \"\r\n        [id]=\"'ticketStatus-' + s\"\r\n        [checked]=\"isTicketStatusSelected(s)\"\r\n        (change)=\"onTicketStatusChange($event, s)\"\r\n      />\r\n      <label class=\"form-check-label text-dark ms-2\" [for]=\"'ticketStatus-' + s\">\r\n        {{ s }}\r\n      </label>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n\r\n\r\n      <!-- Reviewer accuracy -->\r\n      <div class=\"mb-3\" *ngIf=\"showReviewerAccuracy\" (click)=\"closeAll()\">\r\n        <label class=\"form-label\">Reviewer accuracy (%) by condition</label>\r\n        <div class=\"d-flex gap-2\">\r\n          <select class=\"form-select w-100\" formControlName=\"reviewerCondition\">\r\n            <option disabled [ngValue]=\"null\">Select</option>\r\n            <option *ngFor=\"let c of conditionOptions\" [ngValue]=\"c.value\">\r\n              {{ c.label }}\r\n            </option>\r\n          </select>\r\n\r\n          <!-- one or two inputs -->\r\n          <ng-container *ngIf=\"isBetween('reviewerCondition'); else singleReviewer\">\r\n            <input\r\n              type=\"number\"\r\n              min=\"1\"\r\n              max=\"100\"\r\n              class=\"form-control\"\r\n              formControlName=\"reviewerFrom\"\r\n              placeholder=\"From\" (input)=\"limitValue($event, 'reviewerFrom')\" />\r\n            <input\r\n              type=\"number\"\r\n              min=\"1\"\r\n              max=\"100\"\r\n              class=\"form-control\"\r\n              formControlName=\"reviewerTo\"\r\n              placeholder=\"To\" (input)=\"limitValue($event, 'reviewerTo')\" />\r\n          </ng-container>\r\n          <ng-template #singleReviewer>\r\n            <input\r\n              type=\"number\"\r\n              min=\"1\"\r\n              max=\"100\"\r\n              class=\"form-control\"\r\n              formControlName=\"reviewerFrom\"\r\n              placeholder=\"1 to 100%\" (input)=\"limitValue($event, 'reviewerFrom')\" />\r\n          </ng-template>\r\n        </div>\r\n      </div>\r\n\r\n      <!-- Approver accuracy -->\r\n      <div class=\"mb-3\" *ngIf=\"showApproverAccuracy\" (click)=\"closeAll()\">\r\n        <label class=\"form-label\">Approver accuracy (%) by condition</label>\r\n        <div class=\"d-flex gap-2\">\r\n          <select class=\"form-select w-100\" formControlName=\"approverCondition\">\r\n            <option disabled [ngValue]=\"null\">Select</option>\r\n            <option *ngFor=\"let c of conditionOptions\" [ngValue]=\"c.value\">\r\n              {{ c.label }}\r\n            </option>\r\n          </select>\r\n\r\n          <ng-container *ngIf=\"isBetween('approverCondition'); else singleApprover\">\r\n            <input\r\n              type=\"number\"\r\n              min=\"1\"\r\n              max=\"100\"\r\n              class=\"form-control\"\r\n              formControlName=\"approverFrom\"\r\n              placeholder=\"From\" \r\n              (input)=\"limitValue($event, 'approverFrom')\"/>\r\n            <input\r\n              type=\"number\"\r\n              min=\"1\"\r\n              max=\"100\"\r\n              class=\"form-control\"\r\n              formControlName=\"approverTo\"\r\n              placeholder=\"To\" (input)=\"limitValue($event, 'approverTo')\" />\r\n          </ng-container>\r\n          <ng-template #singleApprover>\r\n            <input\r\n              type=\"number\"\r\n              min=\"1\"\r\n              max=\"100\"\r\n              class=\"form-control\"\r\n              formControlName=\"approverFrom\"\r\n              placeholder=\"1 to 100%\" (input)=\"limitValue($event, 'approverFrom')\" />\r\n          </ng-template>\r\n        </div>\r\n      </div>\r\n\r\n      <!-- Tango accuracy -->\r\n      <div class=\"mb-3\" *ngIf=\"showTangoAccuracy\" (click)=\"closeAll()\">\r\n        <label class=\"form-label\">Tango accuracy (%) by condition</label>\r\n        <div class=\"d-flex gap-2\">\r\n          <select class=\"form-select w-100\" formControlName=\"tangoCondition\">\r\n            <option disabled [ngValue]=\"null\">Select</option>\r\n            <option *ngFor=\"let c of conditionOptions\" [ngValue]=\"c.value\">\r\n              {{ c.label }}\r\n            </option>\r\n          </select>\r\n\r\n          <ng-container *ngIf=\"isBetween('tangoCondition'); else singleTango\">\r\n            <input\r\n              type=\"number\"\r\n              min=\"1\"\r\n              max=\"100\"\r\n              class=\"form-control\"\r\n              formControlName=\"tangoFrom\"\r\n              placeholder=\"From\" (input)=\"limitValue($event, 'tangoFrom')\" />\r\n            <input\r\n              type=\"number\"\r\n              min=\"1\"\r\n              max=\"100\"\r\n              class=\"form-control\"\r\n              formControlName=\"tangoTo\"\r\n              placeholder=\"To\" (input)=\"limitValue($event, 'tangoTo')\" />\r\n          </ng-container>\r\n          <ng-template #singleTango>\r\n            <input\r\n              type=\"number\"\r\n              min=\"1\"\r\n              max=\"100\"\r\n              class=\"form-control\"\r\n              formControlName=\"tangoFrom\"\r\n              placeholder=\"1 to 100%\" (input)=\"limitValue($event, 'tangoFrom')\" />\r\n          </ng-template>\r\n        </div>\r\n      </div>\r\n<div\r\n  class=\"mb-3 position-relative\"\r\n  *ngIf=\"showReviewedBy\"\r\n  (click)=\"$event.stopPropagation()\"\r\n>\r\n  <label class=\"form-label\">Reviewed by</label>\r\n\r\n  <!-- Trigger / display -->\r\n  <div\r\n    class=\"border rounded px-3 py-2 d-flex justify-content-between align-items-center\"\r\n    (click)=\"toggleDropdown('reviewer', $event)\"\r\n  >\r\n    <!-- 0 selected -->\r\n    <span *ngIf=\"!selectedReviewedBy.length\">\r\n      Select\r\n    </span>\r\n\r\n    <!-- 1 selected -->\r\n    <span *ngIf=\"selectedReviewedBy.length === 1\">\r\n      {{ selectedReviewedBy[0] }}\r\n    </span>\r\n\r\n    <!-- >1 selected -->\r\n    <span\r\n      *ngIf=\"selectedReviewedBy.length > 1\"\r\n      class=\"d-flex align-items-center\"\r\n    >\r\n      <span>{{ selectedReviewedBy[0] }}</span>\r\n      <span class=\"badge ms-2\">\r\n        +{{ selectedReviewedBy.length - 1 }}\r\n      </span>\r\n    </span>\r\n  </div>\r\n\r\n<div\r\n  *ngIf=\"isDropdownOpen('reviewer')\"\r\n  class=\"position-absolute w-100 border rounded bg-white p-1 mt-1\"\r\n  style=\"z-index: 1000; max-height: 220px; overflow-y: auto;\"\r\n  (click)=\"$event.stopPropagation()\"\r\n>\r\n\r\n  <!-- 🔍 Search box -->\r\n  <div class=\"mb-2 px-0\">\r\n    <input\r\n      type=\"text\"\r\n      class=\"form-control form-control-sm\"\r\n      placeholder=\"Search by email\"\r\n      [(ngModel)]=\"reviewerSearchTerm\"\r\n      [ngModelOptions]=\"{standalone: true}\"\r\n      (click)=\"$event.stopPropagation()\"\r\n    />\r\n  </div>\r\n\r\n  <!-- Select All -->\r\n  <div class=\"form-check px-0 mb-2 d-flex align-items-center\">\r\n    <input\r\n      type=\"checkbox\"\r\n      class=\"form-check-input\"\r\n      id=\"reviewer-all\"\r\n      [checked]=\"areAllReviewersSelected()\"\r\n      (change)=\"onReviewerSelectAll($event)\"\r\n    />\r\n    <label for=\"reviewer-all\" class=\"form-check-label text-dark ms-2\">\r\n      Select All\r\n    </label>\r\n  </div>\r\n\r\n  <!-- Options – now use getter filteredReviewerList -->\r\n  <div\r\n    class=\"form-check mb-1 px-0 d-flex align-items-center\"\r\n    *ngFor=\"let u of filteredReviewerList\"\r\n  >\r\n    <input\r\n      class=\"form-check-input\"\r\n      type=\"checkbox\"\r\n      [id]=\"'rev-' + u.email\"\r\n      [checked]=\"isReviewerSelected(u.email)\"\r\n      (change)=\"onReviewerChange($event, u.email)\"\r\n    />\r\n    <label class=\"form-check-label text-dark ms-2\" [for]=\"'rev-' + u.email\">\r\n      {{ u.email }}\r\n    </label>\r\n  </div>\r\n</div>\r\n\r\n\r\n</div>\r\n\r\n\r\n      <!-- Approved By -->\r\n<div\r\n  class=\"mb-3 position-relative\"\r\n  *ngIf=\"showApprovedBy\"\r\n  (click)=\"$event.stopPropagation()\"\r\n>\r\n  <label class=\"form-label\">Approved by</label>\r\n\r\n  <!-- Trigger / display -->\r\n  <div\r\n    class=\"border rounded px-3 py-2 d-flex justify-content-between align-items-center\"\r\n    (click)=\"toggleDropdown('approver', $event)\"\r\n  >\r\n    <!-- 0 selected -->\r\n    <span *ngIf=\"!selectedApprovedBy.length\">\r\n      Select\r\n    </span>\r\n\r\n    <!-- 1 selected -->\r\n    <span *ngIf=\"selectedApprovedBy.length === 1\">\r\n      {{ selectedApprovedBy[0] }}\r\n    </span>\r\n\r\n    <!-- >1 selected -->\r\n    <span\r\n      *ngIf=\"selectedApprovedBy.length > 1\"\r\n      class=\"d-flex align-items-center\"\r\n    >\r\n      <span>{{ selectedApprovedBy[0] }}</span>\r\n      <span class=\"badge ms-2\">\r\n        +{{ selectedApprovedBy.length - 1 }}\r\n      </span>\r\n    </span>\r\n\r\n  </div>\r\n<!-- Dropdown panel -->\r\n<div\r\n *ngIf=\"isDropdownOpen('approver')\"\r\n  class=\"position-absolute w-100 border rounded bg-white p-1 mt-1\"\r\n  style=\"z-index: 1000; max-height: 220px; overflow-y: auto;\"\r\n  (click)=\"$event.stopPropagation()\"\r\n>\r\n\r\n  <!-- 🔍 Search box -->\r\n  <div class=\"mb-2 px-0\">\r\n    <input\r\n      type=\"text\"\r\n      class=\"form-control form-control-sm\"\r\n      placeholder=\"Search by email\"\r\n      [(ngModel)]=\"approverSearchTerm\"\r\n  [ngModelOptions]=\"{standalone: true}\"\r\n      (click)=\"$event.stopPropagation()\"\r\n    />\r\n    <!-- email.includes(term) || name.includes(term) -->\r\n  </div>\r\n\r\n  <!-- Select All -->\r\n  <div class=\"form-check px-0 mb-2 d-flex align-items-center\">\r\n    <input\r\n      type=\"checkbox\"\r\n      class=\"form-check-input\"\r\n      id=\"reviewer-all\"\r\n      [checked]=\"areAllApproversSelected()\"\r\n      (change)=\"onApproverSelectAll($event)\"\r\n    />\r\n    <label for=\"reviewer-all\" class=\"form-check-label text-dark ms-2\">\r\n      Select All\r\n    </label>\r\n  </div>\r\n\r\n  <!-- Options (use filteredReviewerList instead of userList) -->\r\n  <div\r\n    class=\"form-check mb-1 px-0 d-flex align-items-center\"\r\n    *ngFor=\"let u of filteredApproverList\"\r\n  >\r\n    <input\r\n      class=\"form-check-input\"\r\n      type=\"checkbox\"\r\n      [id]=\"'rev-' + u.email\"\r\n      [checked]=\"isApproverSelected(u.email)\"\r\n      (change)=\"onApproverChange($event, u.email)\"\r\n    />\r\n    <label class=\"form-check-label text-dark ms-2\" [for]=\"'rev-' + u.email\">\r\n      {{ u.email }}\r\n    </label>\r\n  </div>\r\n</div>\r\n\r\n  <!-- Dropdown panel -->\r\n\r\n</div>\r\n\r\n\r\n      <!-- Footer buttons -->\r\n      <div class=\"d-flex justify-content-between w-100 mt-4\">\r\n        <button type=\"button\" class=\"btn btn-outline w-50 me-1\" (click)=\"onReset()\">\r\n          Reset\r\n        </button>\r\n        <button type=\"button\" class=\"btn btn-primary w-50 ms-1\" (click)=\"onApply()\">\r\n          Apply\r\n        </button>\r\n      </div>\r\n    </form>\r\n  </div>\r\n</div>\r\n"]}