tango-app-ui-analyse-traffic 3.8.0-alpha.26 → 3.8.0-alpha.27
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/components/img-rvps/img-rvps.component.mjs +487 -42
- package/esm2022/lib/services/traffic-rvps.service.mjs +5 -1
- package/esm2022/lib/services/traffic.service.mjs +4 -1
- package/fesm2022/tango-app-ui-analyse-traffic.mjs +493 -40
- package/fesm2022/tango-app-ui-analyse-traffic.mjs.map +1 -1
- package/lib/components/img-rvps/img-rvps.component.d.ts +47 -0
- package/lib/services/traffic-rvps.service.d.ts +1 -0
- package/lib/services/traffic.service.d.ts +1 -0
- package/package.json +1 -1
|
@@ -9,7 +9,6 @@ import * as i4 from "tango-app-ui-shared";
|
|
|
9
9
|
import * as i5 from "../../services/traffic-rvps.service";
|
|
10
10
|
import * as i6 from "@angular/common";
|
|
11
11
|
import * as i7 from "@angular/forms";
|
|
12
|
-
import * as i8 from "../../directive/magnifier.directive";
|
|
13
12
|
export class ImgRvpsComponent {
|
|
14
13
|
service;
|
|
15
14
|
gs;
|
|
@@ -22,6 +21,10 @@ export class ImgRvpsComponent {
|
|
|
22
21
|
loading = true;
|
|
23
22
|
noData = false;
|
|
24
23
|
normalize;
|
|
24
|
+
overallCardData = [];
|
|
25
|
+
cardDataMap = {};
|
|
26
|
+
ticketReviewStatus = [];
|
|
27
|
+
userComment;
|
|
25
28
|
constructor(service, gs, cd, modalService, toast, rvpsService) {
|
|
26
29
|
this.service = service;
|
|
27
30
|
this.gs = gs;
|
|
@@ -49,6 +52,7 @@ export class ImgRvpsComponent {
|
|
|
49
52
|
this.gs.dataRangeValue
|
|
50
53
|
.pipe(takeUntil(this.destroy$), debounceTime(100))
|
|
51
54
|
.subscribe((data) => {
|
|
55
|
+
console.log('data :', data);
|
|
52
56
|
if (data !== null || data?.client !== null) {
|
|
53
57
|
this.headerData = data;
|
|
54
58
|
this.storeIdarray = this.headerData?.stores
|
|
@@ -56,6 +60,7 @@ export class ImgRvpsComponent {
|
|
|
56
60
|
.map((store) => store.storeId);
|
|
57
61
|
this.backToFootfall();
|
|
58
62
|
this.displayDateRange();
|
|
63
|
+
this.loadCardData();
|
|
59
64
|
if (this.headerData?.date?.startDate === this.headerData?.date?.endDate) {
|
|
60
65
|
this.backnav = false;
|
|
61
66
|
this.displayDateRange();
|
|
@@ -76,6 +81,10 @@ export class ImgRvpsComponent {
|
|
|
76
81
|
this.noData = false;
|
|
77
82
|
this.type = "footfall";
|
|
78
83
|
this.selectedTime = "";
|
|
84
|
+
this.splitScreenEnabled = false;
|
|
85
|
+
this.selectImageArray = null;
|
|
86
|
+
this.remainingImageArray = [];
|
|
87
|
+
this.remainingImagesGroups = [];
|
|
79
88
|
}
|
|
80
89
|
folderView;
|
|
81
90
|
backnav;
|
|
@@ -100,6 +109,48 @@ export class ImgRvpsComponent {
|
|
|
100
109
|
}
|
|
101
110
|
return dateArray;
|
|
102
111
|
}
|
|
112
|
+
// Load card data
|
|
113
|
+
loadCardData() {
|
|
114
|
+
const storeId = this.storeIdarray && this.storeIdarray.length > 0 ? this.storeIdarray[0] : null;
|
|
115
|
+
if (!storeId || !this.headerData?.date) {
|
|
116
|
+
this.overallCardData = [];
|
|
117
|
+
this.cardDataMap = {};
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
this.rvpsService
|
|
121
|
+
.getImageDirectoryCardData(storeId, this.headerData.date.startDate, this.headerData.date.endDate)
|
|
122
|
+
.pipe(takeUntil(this.destroy$))
|
|
123
|
+
?.subscribe({
|
|
124
|
+
next: (res) => {
|
|
125
|
+
if (res && res.code === 200) {
|
|
126
|
+
this.overallCardData = res?.data || [];
|
|
127
|
+
this.cardDataMap = (this.overallCardData || []).reduce((acc, item) => {
|
|
128
|
+
const normalizedDate = item?.date
|
|
129
|
+
? new Date(item.date).toISOString().split("T")[0]
|
|
130
|
+
: null;
|
|
131
|
+
if (normalizedDate) {
|
|
132
|
+
acc[normalizedDate] = {
|
|
133
|
+
...item,
|
|
134
|
+
ticketStatusLower: item?.ticketStatus
|
|
135
|
+
? String(item.ticketStatus).toLowerCase()
|
|
136
|
+
: "",
|
|
137
|
+
};
|
|
138
|
+
}
|
|
139
|
+
return acc;
|
|
140
|
+
}, {});
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
this.overallCardData = [];
|
|
144
|
+
this.cardDataMap = {};
|
|
145
|
+
}
|
|
146
|
+
},
|
|
147
|
+
error: (err) => {
|
|
148
|
+
console.error("Error fetching loadCardData:", err);
|
|
149
|
+
this.overallCardData = [];
|
|
150
|
+
this.cardDataMap = {};
|
|
151
|
+
},
|
|
152
|
+
});
|
|
153
|
+
}
|
|
103
154
|
selectedTime;
|
|
104
155
|
folderName;
|
|
105
156
|
selectedTimes(val) {
|
|
@@ -111,14 +162,17 @@ export class ImgRvpsComponent {
|
|
|
111
162
|
}
|
|
112
163
|
folderDate;
|
|
113
164
|
imageFlow = false;
|
|
165
|
+
splitScreenEnabled = false; // Flag to enable split-screen view
|
|
114
166
|
// get Revops Api
|
|
115
167
|
getRvpsList;
|
|
116
168
|
getRvpsImageList;
|
|
117
169
|
objectsArray;
|
|
118
170
|
imagesArrayData;
|
|
171
|
+
listViewGroups = [];
|
|
119
172
|
selectIndex = 0;
|
|
120
173
|
footfallDate;
|
|
121
174
|
lengthValue;
|
|
175
|
+
viewMode = "grid";
|
|
122
176
|
getimages(index, obj) {
|
|
123
177
|
this.objectsArray = [];
|
|
124
178
|
this.selectIndex = index;
|
|
@@ -133,7 +187,7 @@ export class ImgRvpsComponent {
|
|
|
133
187
|
this.getRvpsImageList = [];
|
|
134
188
|
this.objectsArray = [];
|
|
135
189
|
this.getRevops();
|
|
136
|
-
this.getTotal();
|
|
190
|
+
// this.getTotal();
|
|
137
191
|
}
|
|
138
192
|
else {
|
|
139
193
|
this.lengthValue = false;
|
|
@@ -156,7 +210,6 @@ export class ImgRvpsComponent {
|
|
|
156
210
|
if (res && res.code === 200) {
|
|
157
211
|
if (this.getRvpsList?.length)
|
|
158
212
|
this.countData = res.data;
|
|
159
|
-
// console.log(this.countData)
|
|
160
213
|
}
|
|
161
214
|
else {
|
|
162
215
|
this.countData = [];
|
|
@@ -201,6 +254,9 @@ export class ImgRvpsComponent {
|
|
|
201
254
|
this.getRvpsList = res?.data;
|
|
202
255
|
this.imageUrl = this.rvpsService?.footfallCDN;
|
|
203
256
|
this.getRvpsImageList = res?.data?.result;
|
|
257
|
+
this.ticketReviewStatus = res?.data?.ticketStatus;
|
|
258
|
+
console.log('revops getRvpsListApi :', res?.data);
|
|
259
|
+
console.log('revops ticketReviewStatus :', this.ticketReviewStatus);
|
|
204
260
|
// Save the full footfall data (grouped by timeRange)
|
|
205
261
|
this.allFootfallData = res?.data?.result?.footfallData || [];
|
|
206
262
|
// Create timeRange + count object
|
|
@@ -350,11 +406,88 @@ export class ImgRvpsComponent {
|
|
|
350
406
|
backToFootfall1() {
|
|
351
407
|
this.selectedRadioType = undefined;
|
|
352
408
|
this.imageFlow = false;
|
|
409
|
+
this.splitScreenEnabled = false; // Disable split-screen when going back
|
|
410
|
+
this.selectImageArray = null;
|
|
353
411
|
}
|
|
354
412
|
selectImageArray;
|
|
355
413
|
remainingImageArray;
|
|
356
414
|
revopsTypeValue = false;
|
|
357
415
|
editBtnShow = false;
|
|
416
|
+
selectImageForSplitView(obj) {
|
|
417
|
+
this.splitScreenEnabled = true; // Enable split-screen when image is clicked
|
|
418
|
+
this.selectImageArray = obj;
|
|
419
|
+
// If duplicate is already selected, preserve the duplicate context
|
|
420
|
+
const isDuplicateMode = this.selectedRadioType === "duplicate";
|
|
421
|
+
if (!isDuplicateMode) {
|
|
422
|
+
this.revopsTypeValue = false;
|
|
423
|
+
this.selectedType = "";
|
|
424
|
+
this.selectedRadioType = undefined;
|
|
425
|
+
this.remainingImageArray = []; // Reset remaining images initially
|
|
426
|
+
this.remainingImagesGroups = []; // Reset groups
|
|
427
|
+
}
|
|
428
|
+
let filteredByType = [];
|
|
429
|
+
const selectedType = obj.revopsType?.toLowerCase();
|
|
430
|
+
// If we're in duplicate mode and clicking on a remaining image, keep the duplicate context
|
|
431
|
+
if (isDuplicateMode) {
|
|
432
|
+
// Keep the existing remaining images but update the selected image
|
|
433
|
+
// Don't reset the duplicate selection context
|
|
434
|
+
this.revopsTypeValue = false; // Allow editing this image
|
|
435
|
+
this.selectedType = ""; // Reset to allow new selection
|
|
436
|
+
// Keep selectedRadioType as 'duplicate' to maintain context
|
|
437
|
+
}
|
|
438
|
+
else if (selectedType === "duplicate" && Array.isArray(obj.duplicateImagePath)) {
|
|
439
|
+
const children = obj.duplicateImagePath.map((child) => {
|
|
440
|
+
const matched = this.overallArrayData.find((img) => img.templd === child.tempId);
|
|
441
|
+
return {
|
|
442
|
+
...child,
|
|
443
|
+
...(matched || {}),
|
|
444
|
+
parent: obj.templd,
|
|
445
|
+
};
|
|
446
|
+
});
|
|
447
|
+
filteredByType = [obj, ...children];
|
|
448
|
+
this.currentImageIndex = 0;
|
|
449
|
+
this.remainingImageArray = children;
|
|
450
|
+
}
|
|
451
|
+
else {
|
|
452
|
+
// For non-duplicate images, don't populate remainingImageArray initially
|
|
453
|
+
// It will be populated when user selects a radio button
|
|
454
|
+
filteredByType = this.overallArrayData.filter((img) => img.revopsType?.toLowerCase() === selectedType);
|
|
455
|
+
this.currentImageIndex = filteredByType.findIndex((img) => img.templd === obj.templd);
|
|
456
|
+
// Only set remainingImageArray if there are other images of the same type
|
|
457
|
+
// Otherwise, leave it empty for radio button selection to populate
|
|
458
|
+
if (filteredByType.length > 1) {
|
|
459
|
+
this.remainingImageArray = filteredByType.filter((_, i) => i !== this.currentImageIndex);
|
|
460
|
+
}
|
|
461
|
+
}
|
|
462
|
+
// Only auto-set revopsTypeValue if not in duplicate mode
|
|
463
|
+
if (!isDuplicateMode) {
|
|
464
|
+
if (obj?.revopsType === "duplicate" ||
|
|
465
|
+
obj?.revopsType === "employee" ||
|
|
466
|
+
obj?.revopsType === "house-keeping" || obj?.revopsType === "junk") {
|
|
467
|
+
if (obj?.revopsType === "duplicate" &&
|
|
468
|
+
obj?.duplicateImagePath?.length > 0) {
|
|
469
|
+
this.editBtnShow = true;
|
|
470
|
+
}
|
|
471
|
+
else if (obj?.revopsType === "employee" ||
|
|
472
|
+
obj?.revopsType === "house-keeping" || obj?.revopsType === "junk") {
|
|
473
|
+
this.editBtnShow = true;
|
|
474
|
+
}
|
|
475
|
+
else {
|
|
476
|
+
this.editBtnShow = false;
|
|
477
|
+
}
|
|
478
|
+
this.revopsTypeValue = true;
|
|
479
|
+
this.selectedType = obj?.revopsType;
|
|
480
|
+
this.onRadioChange(obj?.revopsType);
|
|
481
|
+
}
|
|
482
|
+
}
|
|
483
|
+
else {
|
|
484
|
+
// In duplicate mode, allow editing the selected image
|
|
485
|
+
this.revopsTypeValue = false;
|
|
486
|
+
this.editBtnShow = false;
|
|
487
|
+
}
|
|
488
|
+
// Build remaining images groups by time range
|
|
489
|
+
this.buildRemainingImagesGroups();
|
|
490
|
+
}
|
|
358
491
|
imgFullView(obj) {
|
|
359
492
|
this.selectImageArray = obj;
|
|
360
493
|
this.imageFlow = true;
|
|
@@ -422,6 +555,8 @@ export class ImgRvpsComponent {
|
|
|
422
555
|
this.selectImageArray = obj;
|
|
423
556
|
// Remove selected from remaining list
|
|
424
557
|
this.remainingImageArray = this.remainingImageArray.filter((img) => img.templd !== obj.templd);
|
|
558
|
+
// Rebuild remaining images groups
|
|
559
|
+
this.buildRemainingImagesGroups();
|
|
425
560
|
this.imageFlow = true;
|
|
426
561
|
}
|
|
427
562
|
selectedType = ""; // default selected
|
|
@@ -434,7 +569,7 @@ export class ImgRvpsComponent {
|
|
|
434
569
|
if (this.selectImageArray?.revopsType?.toLowerCase() === "duplicate" &&
|
|
435
570
|
Array.isArray(this.selectImageArray?.duplicateImagePath) &&
|
|
436
571
|
this.selectImageArray.duplicateImagePath.length > 0) {
|
|
437
|
-
// 🔹 Case 1: Already in duplicate flow → keep children set by
|
|
572
|
+
// 🔹 Case 1: Already in duplicate flow → keep children set by selectImageForSplitView
|
|
438
573
|
this.remainingImageArray = this.remainingImageArray.map((child) => {
|
|
439
574
|
return { ...child, selected: false, isChecked: false };
|
|
440
575
|
});
|
|
@@ -451,6 +586,14 @@ export class ImgRvpsComponent {
|
|
|
451
586
|
img.isChecked = false;
|
|
452
587
|
});
|
|
453
588
|
}
|
|
589
|
+
// Rebuild remaining images groups after updating
|
|
590
|
+
this.buildRemainingImagesGroups();
|
|
591
|
+
console.log('remain image array ::', this.remainingImageArray);
|
|
592
|
+
}
|
|
593
|
+
else {
|
|
594
|
+
// For non-duplicate types, clear remaining images
|
|
595
|
+
this.remainingImageArray = [];
|
|
596
|
+
this.remainingImagesGroups = [];
|
|
454
597
|
}
|
|
455
598
|
}
|
|
456
599
|
type = "footfall";
|
|
@@ -460,6 +603,8 @@ export class ImgRvpsComponent {
|
|
|
460
603
|
}
|
|
461
604
|
applyFilters() {
|
|
462
605
|
this.imageFlow = false;
|
|
606
|
+
this.splitScreenEnabled = false; // Reset split-screen when filters change
|
|
607
|
+
this.selectImageArray = null;
|
|
463
608
|
// Convert type to lowercase safely
|
|
464
609
|
const selectedType = this.type?.toLowerCase();
|
|
465
610
|
if (selectedType === "footfall") {
|
|
@@ -478,51 +623,136 @@ export class ImgRvpsComponent {
|
|
|
478
623
|
// }
|
|
479
624
|
// Set noData based on result
|
|
480
625
|
this.noData = !this.imagesArrayData?.length;
|
|
626
|
+
this.buildListViewGroups();
|
|
481
627
|
this.cd.detectChanges();
|
|
482
628
|
}
|
|
629
|
+
setViewMode(mode) {
|
|
630
|
+
if (this.viewMode !== mode) {
|
|
631
|
+
this.viewMode = mode;
|
|
632
|
+
}
|
|
633
|
+
}
|
|
634
|
+
// Convert minutes → hr + mins
|
|
635
|
+
convertMinutes(totalMinutes) {
|
|
636
|
+
if (!totalMinutes && totalMinutes !== 0)
|
|
637
|
+
return { hours: 0, mins: 0 };
|
|
638
|
+
const hours = Math.floor(totalMinutes / 60);
|
|
639
|
+
const mins = totalMinutes % 60;
|
|
640
|
+
return { hours, mins };
|
|
641
|
+
}
|
|
642
|
+
remainingImagesGroups = [];
|
|
643
|
+
buildRemainingImagesGroups() {
|
|
644
|
+
if (!this.remainingImageArray || this.remainingImageArray.length === 0) {
|
|
645
|
+
this.remainingImagesGroups = [];
|
|
646
|
+
return;
|
|
647
|
+
}
|
|
648
|
+
const order = [];
|
|
649
|
+
const map = new Map();
|
|
650
|
+
this.remainingImageArray.forEach((img) => {
|
|
651
|
+
const key = img?.timeRange || "NA";
|
|
652
|
+
if (!map.has(key)) {
|
|
653
|
+
map.set(key, []);
|
|
654
|
+
order.push(key);
|
|
655
|
+
}
|
|
656
|
+
map.get(key)?.push(img);
|
|
657
|
+
});
|
|
658
|
+
this.remainingImagesGroups = order.map((key) => ({
|
|
659
|
+
timeRange: key,
|
|
660
|
+
data: map.get(key) || [],
|
|
661
|
+
}));
|
|
662
|
+
console.log('my methd =>', this.remainingImageArray);
|
|
663
|
+
}
|
|
664
|
+
buildListViewGroups() {
|
|
665
|
+
if (this.type === "footfall") {
|
|
666
|
+
this.listViewGroups = (this.allFootfallData || [])
|
|
667
|
+
.filter((group) => Array.isArray(group?.data) && group.data.length)
|
|
668
|
+
.map((group) => ({
|
|
669
|
+
timeRange: group?.timeRange || "NA",
|
|
670
|
+
data: group?.data || [],
|
|
671
|
+
}));
|
|
672
|
+
return;
|
|
673
|
+
}
|
|
674
|
+
const order = [];
|
|
675
|
+
const map = new Map();
|
|
676
|
+
(this.imagesArrayData || []).forEach((img) => {
|
|
677
|
+
const key = img?.timeRange || "NA";
|
|
678
|
+
if (!map.has(key)) {
|
|
679
|
+
map.set(key, []);
|
|
680
|
+
order.push(key);
|
|
681
|
+
}
|
|
682
|
+
map.get(key)?.push(img);
|
|
683
|
+
});
|
|
684
|
+
this.listViewGroups = order.map((key) => ({
|
|
685
|
+
timeRange: key,
|
|
686
|
+
data: map.get(key) || [],
|
|
687
|
+
}));
|
|
688
|
+
}
|
|
483
689
|
handleImageClick(evt, obj) {
|
|
484
|
-
//
|
|
485
|
-
if (this.selectedRadioType === "duplicate" &&
|
|
486
|
-
|
|
487
|
-
|
|
690
|
+
// When duplicate is selected, clicking on images should open them in zoom modal
|
|
691
|
+
if (this.selectedRadioType === "duplicate" && this.splitScreenEnabled) {
|
|
692
|
+
// Open image in zoom modal when duplicate is selected
|
|
693
|
+
// Store the clicked image temporarily for modal display
|
|
694
|
+
this.openImageZoomModal(this.imageUrl, obj);
|
|
695
|
+
return;
|
|
696
|
+
}
|
|
697
|
+
// For split-screen view, clicking on related images should swap to that image
|
|
698
|
+
if (this.splitScreenEnabled && this.selectedRadioType !== "duplicate") {
|
|
699
|
+
this.selectImageForSplitView(obj);
|
|
488
700
|
}
|
|
489
701
|
else if (this.selectedRadioType !== "duplicate") {
|
|
490
702
|
this.imgSwap(obj); // existing non-duplicate click behavior
|
|
491
703
|
}
|
|
492
704
|
}
|
|
705
|
+
tempModalImage = null; // Temporary storage for modal image when duplicate is selected
|
|
706
|
+
openImageZoomModal(imageUrl, imageData) {
|
|
707
|
+
// Store the image data temporarily for modal display
|
|
708
|
+
this.tempModalImage = imageData;
|
|
709
|
+
this.isModalOpen = true;
|
|
710
|
+
const modalRef = this.modalService.open(this.imagePopup, {
|
|
711
|
+
centered: true,
|
|
712
|
+
size: "lg",
|
|
713
|
+
backdrop: "static",
|
|
714
|
+
keyboard: false,
|
|
715
|
+
});
|
|
716
|
+
}
|
|
493
717
|
selectedDuplicateImagesList = [];
|
|
718
|
+
toggleDuplicateSelection(img) {
|
|
719
|
+
if (!img || img.duplicateImagePath?.length > 0) {
|
|
720
|
+
return;
|
|
721
|
+
}
|
|
722
|
+
const totalImages = this.overallArrayData.length;
|
|
723
|
+
const alreadyTaggedCount = this.countData?.duplicate || 0;
|
|
724
|
+
const maxSelectable = Math.round(totalImages * 0.2);
|
|
725
|
+
const currentlySelectedCount = this.remainingImageArray.filter((item) => item.selected).length;
|
|
726
|
+
const willSelect = !img.selected;
|
|
727
|
+
// ⛔ Block selection if trying to go beyond 20% cap
|
|
728
|
+
if (willSelect &&
|
|
729
|
+
currentlySelectedCount + alreadyTaggedCount >= maxSelectable) {
|
|
730
|
+
this.toast.getWarningToast(`You can select only ${maxSelectable} images (${this.getRvpsList?.data?.config?.duplicate ?? "20%"} of total footfall)`);
|
|
731
|
+
return;
|
|
732
|
+
}
|
|
733
|
+
// ✅ Proceed with selection toggle
|
|
734
|
+
img.selected = !img.selected;
|
|
735
|
+
img.isChecked = img.selected;
|
|
736
|
+
// ✅ Always rebuild the selected list
|
|
737
|
+
this.selectedDuplicateImagesList = this.remainingImageArray
|
|
738
|
+
.filter((item) => item.selected)
|
|
739
|
+
.map((item) => ({
|
|
740
|
+
...item,
|
|
741
|
+
parent: item.parent || this.selectImageArray?.templd,
|
|
742
|
+
isChecked: true,
|
|
743
|
+
}));
|
|
744
|
+
// Rebuild remaining images groups after checkbox change
|
|
745
|
+
this.buildRemainingImagesGroups();
|
|
746
|
+
this.cd.detectChanges();
|
|
747
|
+
}
|
|
494
748
|
onImageCheckboxChange(evt, img, type) {
|
|
495
749
|
if (type === "duplicate") {
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
//
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
const maxSelectable = Math.round(totalImages * 0.2);
|
|
502
|
-
// console.log(maxSelectable)
|
|
503
|
-
// Count selected now (in UI)
|
|
504
|
-
const currentlySelectedCount = this.overallArrayData.filter((item) => item.selected).length;
|
|
505
|
-
const willSelect = !img.selected;
|
|
506
|
-
// ⛔ Block selection if trying to go beyond 10% cap
|
|
507
|
-
if (willSelect &&
|
|
508
|
-
currentlySelectedCount + alreadyTaggedCount >= maxSelectable) {
|
|
509
|
-
this.toast.getWarningToast(`You can select only ${maxSelectable} images (${this.getRvpsList?.data?.config?.duplicate ?? "20%"} of total footfall)`);
|
|
510
|
-
evt.target.checked = false;
|
|
511
|
-
this.cd.detectChanges();
|
|
512
|
-
return;
|
|
750
|
+
// Use the toggle method for duplicate selection
|
|
751
|
+
this.toggleDuplicateSelection(img);
|
|
752
|
+
// Update checkbox state to match selection
|
|
753
|
+
if (evt && evt.target) {
|
|
754
|
+
evt.target.checked = img.selected;
|
|
513
755
|
}
|
|
514
|
-
// ✅ Proceed with selection toggle
|
|
515
|
-
img.selected = !img.selected;
|
|
516
|
-
img.isChecked = img.selected;
|
|
517
|
-
// ✅ Always rebuild the selected list
|
|
518
|
-
this.selectedDuplicateImagesList = this.remainingImageArray
|
|
519
|
-
.filter((item) => item.selected)
|
|
520
|
-
.map((item) => ({
|
|
521
|
-
...item,
|
|
522
|
-
parent: item.parent || this.selectImageArray?.templd,
|
|
523
|
-
isChecked: true,
|
|
524
|
-
}));
|
|
525
|
-
// console.log('✅ selectedDuplicateImagesList:', this.selectedDuplicateImagesList);
|
|
526
756
|
}
|
|
527
757
|
}
|
|
528
758
|
clearValue() {
|
|
@@ -542,12 +772,16 @@ export class ImgRvpsComponent {
|
|
|
542
772
|
}));
|
|
543
773
|
// 3. Close image flow/full-view if open
|
|
544
774
|
this.imageFlow = false;
|
|
545
|
-
// 4. Reset
|
|
775
|
+
// 4. Reset split-screen and selected image
|
|
776
|
+
this.splitScreenEnabled = false;
|
|
546
777
|
this.selectImageArray = null;
|
|
547
778
|
this.currentImageIndex = 0;
|
|
548
779
|
this.remainingImageArray = [];
|
|
780
|
+
this.remainingImagesGroups = [];
|
|
549
781
|
// 5. (Optional) Reset radio buttons — if you have any specific flag
|
|
550
782
|
this.selectedRadioType = undefined;
|
|
783
|
+
this.selectedType = "";
|
|
784
|
+
this.revopsTypeValue = false;
|
|
551
785
|
}
|
|
552
786
|
popupType;
|
|
553
787
|
zoomPopup;
|
|
@@ -594,6 +828,8 @@ export class ImgRvpsComponent {
|
|
|
594
828
|
entryTime: img?.entryTime || img?.entryTme || "",
|
|
595
829
|
exitTime: img?.exitTime || "",
|
|
596
830
|
filePath: img?.filePath || "",
|
|
831
|
+
comments: this.userComment || "",
|
|
832
|
+
mode: 'web'
|
|
597
833
|
};
|
|
598
834
|
this.rvpsService
|
|
599
835
|
.getRvpsTag(obj)
|
|
@@ -605,6 +841,7 @@ export class ImgRvpsComponent {
|
|
|
605
841
|
this.imageFlow = false;
|
|
606
842
|
this.getRevops();
|
|
607
843
|
this.cancelSubmit();
|
|
844
|
+
this.loadCardData();
|
|
608
845
|
this.selectedRadioType = undefined;
|
|
609
846
|
this.selectedType = "";
|
|
610
847
|
}
|
|
@@ -628,6 +865,7 @@ export class ImgRvpsComponent {
|
|
|
628
865
|
tempRaisedPayload = null; // class-level variable for preview
|
|
629
866
|
prepareRaisedPayload(showOnly = false) { }
|
|
630
867
|
raisedPopup;
|
|
868
|
+
resetRequestPopup;
|
|
631
869
|
Raised() {
|
|
632
870
|
const payload = {
|
|
633
871
|
dateString: this.folderDate,
|
|
@@ -732,8 +970,16 @@ export class ImgRvpsComponent {
|
|
|
732
970
|
commentText;
|
|
733
971
|
getRaisedData;
|
|
734
972
|
submitRaised() {
|
|
735
|
-
const payload = this.tempRaisedPayload; // fresh data for API
|
|
973
|
+
// const payload = this.tempRaisedPayload; // fresh data for API
|
|
974
|
+
const payload = {
|
|
975
|
+
ticketName: "footfall-directory",
|
|
976
|
+
storeId: this.tempRaisedPayload.storeId,
|
|
977
|
+
dateString: this.tempRaisedPayload.dateString,
|
|
978
|
+
type: "create",
|
|
979
|
+
mode: "web"
|
|
980
|
+
};
|
|
736
981
|
this.getRaisedData = payload;
|
|
982
|
+
console.log('submit raised :', payload);
|
|
737
983
|
this.rvpsService
|
|
738
984
|
.getCreateRaisedTag(payload)
|
|
739
985
|
.pipe(takeUntil(this.destroy$))
|
|
@@ -743,12 +989,15 @@ export class ImgRvpsComponent {
|
|
|
743
989
|
this.toast.getSuccessToast(res?.message || "Ticket updated successfully");
|
|
744
990
|
this.imageFlow = false;
|
|
745
991
|
this.getRevops();
|
|
992
|
+
this.loadCardData();
|
|
746
993
|
this.cancelRasied();
|
|
747
994
|
this.selectedRadioType = undefined;
|
|
748
995
|
this.selectedType = "";
|
|
996
|
+
this.countData = [];
|
|
749
997
|
}
|
|
750
998
|
else {
|
|
751
999
|
this.toast.getErrorToast("Failed to update");
|
|
1000
|
+
this.cancelRasied();
|
|
752
1001
|
}
|
|
753
1002
|
},
|
|
754
1003
|
error: (err) => {
|
|
@@ -758,6 +1007,7 @@ export class ImgRvpsComponent {
|
|
|
758
1007
|
err.message ||
|
|
759
1008
|
"Unknown error";
|
|
760
1009
|
this.toast.getErrorToast(msg);
|
|
1010
|
+
this.cancelRasied();
|
|
761
1011
|
},
|
|
762
1012
|
});
|
|
763
1013
|
}
|
|
@@ -824,6 +1074,7 @@ export class ImgRvpsComponent {
|
|
|
824
1074
|
}
|
|
825
1075
|
closeImage() {
|
|
826
1076
|
this.isModalOpen = false;
|
|
1077
|
+
this.tempModalImage = null; // Clear temporary image when closing modal
|
|
827
1078
|
this.modalService.dismissAll();
|
|
828
1079
|
}
|
|
829
1080
|
canEnableButton() {
|
|
@@ -866,20 +1117,214 @@ export class ImgRvpsComponent {
|
|
|
866
1117
|
// Update remaining images
|
|
867
1118
|
this.remainingImageArray = this.imagesArrayData.filter((_, i) => i !== this.currentImageIndex);
|
|
868
1119
|
}
|
|
1120
|
+
// Get current footfall count for selected date
|
|
1121
|
+
getCurrentFootfall() {
|
|
1122
|
+
if (!this.folderDate)
|
|
1123
|
+
return 0;
|
|
1124
|
+
const normalizedDate = new Date(this.folderDate).toISOString().split("T")[0];
|
|
1125
|
+
return this.cardDataMap[normalizedDate]?.footfallCount || 0;
|
|
1126
|
+
}
|
|
1127
|
+
// Get percentage change from footfallCountTrend
|
|
1128
|
+
getFootfallPercentageChange() {
|
|
1129
|
+
if (!this.folderDate)
|
|
1130
|
+
return 0;
|
|
1131
|
+
const normalizedDate = new Date(this.folderDate).toISOString().split("T")[0];
|
|
1132
|
+
return this.cardDataMap[normalizedDate]?.footfallCountTrend || 0;
|
|
1133
|
+
}
|
|
1134
|
+
// Format downtime from downtime key (in minutes)
|
|
1135
|
+
getFormattedDowntime() {
|
|
1136
|
+
if (!this.folderDate)
|
|
1137
|
+
return '-';
|
|
1138
|
+
const normalizedDate = new Date(this.folderDate).toISOString().split("T")[0];
|
|
1139
|
+
const downtimeMinutes = this.cardDataMap[normalizedDate]?.downtime || 0;
|
|
1140
|
+
if (!downtimeMinutes || downtimeMinutes === 0)
|
|
1141
|
+
return '-';
|
|
1142
|
+
const { hours, mins } = this.convertMinutes(downtimeMinutes);
|
|
1143
|
+
if (hours > 0 && mins > 0) {
|
|
1144
|
+
return `${hours}hr ${mins} mins`;
|
|
1145
|
+
}
|
|
1146
|
+
else if (hours > 0) {
|
|
1147
|
+
return `${hours}hr`;
|
|
1148
|
+
}
|
|
1149
|
+
else if (mins > 0) {
|
|
1150
|
+
return `${mins} mins`;
|
|
1151
|
+
}
|
|
1152
|
+
return '-';
|
|
1153
|
+
}
|
|
1154
|
+
// Get ticket status
|
|
1155
|
+
getTicketStatus() {
|
|
1156
|
+
if (!this.folderDate)
|
|
1157
|
+
return '-';
|
|
1158
|
+
const normalizedDate = new Date(this.folderDate).toISOString().split("T")[0];
|
|
1159
|
+
const status = this.cardDataMap[normalizedDate]?.ticketStatus;
|
|
1160
|
+
return status || '-';
|
|
1161
|
+
}
|
|
1162
|
+
// Check if there's downtime
|
|
1163
|
+
hasDowntime() {
|
|
1164
|
+
if (!this.folderDate)
|
|
1165
|
+
return false;
|
|
1166
|
+
const normalizedDate = new Date(this.folderDate).toISOString().split("T")[0];
|
|
1167
|
+
const downtime = this.cardDataMap[normalizedDate]?.downtime || 0;
|
|
1168
|
+
return downtime > 0;
|
|
1169
|
+
}
|
|
1170
|
+
// Get tagging data from ticketReviewStatus where actionType = "tagging"
|
|
1171
|
+
getTaggingData(type) {
|
|
1172
|
+
if (!this.ticketReviewStatus || !Array.isArray(this.ticketReviewStatus) || !type) {
|
|
1173
|
+
return null;
|
|
1174
|
+
}
|
|
1175
|
+
return this.ticketReviewStatus.find((item) => item?.actionType === type) || null;
|
|
1176
|
+
}
|
|
1177
|
+
// Check if ticket status is raised
|
|
1178
|
+
isTicketRaised() {
|
|
1179
|
+
const status = this.getTicketStatus();
|
|
1180
|
+
return status !== '-' && status?.toLowerCase() === "raised";
|
|
1181
|
+
}
|
|
1182
|
+
// Check if ticket status is closed
|
|
1183
|
+
isTicketClosed() {
|
|
1184
|
+
const status = this.getTicketStatus();
|
|
1185
|
+
return status !== '-' && status?.toLowerCase() === "closed";
|
|
1186
|
+
}
|
|
1187
|
+
// Get all tagging data items (for initial and final revisions)
|
|
1188
|
+
getAllTaggingData() {
|
|
1189
|
+
if (!this.ticketReviewStatus || !Array.isArray(this.ticketReviewStatus)) {
|
|
1190
|
+
return [];
|
|
1191
|
+
}
|
|
1192
|
+
return this.ticketReviewStatus.filter((item) => item?.actionType === "tagging") || [];
|
|
1193
|
+
}
|
|
1194
|
+
// Get initial revision data (first tagging item)
|
|
1195
|
+
getInitialRevisionData() {
|
|
1196
|
+
const allTagging = this.getAllTaggingData();
|
|
1197
|
+
return allTagging.length > 0 ? allTagging[0] : null;
|
|
1198
|
+
}
|
|
1199
|
+
// Get final revision data (last tagging item, or second if exists)
|
|
1200
|
+
getFinalRevisionData() {
|
|
1201
|
+
const allTagging = this.getAllTaggingData();
|
|
1202
|
+
return allTagging.length > 1 ? allTagging[allTagging.length - 1] : (allTagging.length > 0 ? allTagging[0] : null);
|
|
1203
|
+
}
|
|
1204
|
+
// Helper method to get count value by type from count array
|
|
1205
|
+
getCountByType(data, countType) {
|
|
1206
|
+
if (!data || !data.count) {
|
|
1207
|
+
return 0;
|
|
1208
|
+
}
|
|
1209
|
+
// Check if count is an array (new format)
|
|
1210
|
+
if (Array.isArray(data.count)) {
|
|
1211
|
+
const countItem = data.count.find((item) => item?.type === countType);
|
|
1212
|
+
return countItem?.value || 0;
|
|
1213
|
+
}
|
|
1214
|
+
// Fallback for old format (object)
|
|
1215
|
+
const keyMap = {
|
|
1216
|
+
'duplicate': 'duplicateCount',
|
|
1217
|
+
'employee': 'employeeCount',
|
|
1218
|
+
'junk': 'junkCount',
|
|
1219
|
+
'houseKeeping': 'houseKeepingCount'
|
|
1220
|
+
};
|
|
1221
|
+
const key = keyMap[countType];
|
|
1222
|
+
return key ? (data.count[key] || 0) : 0;
|
|
1223
|
+
}
|
|
1224
|
+
// Calculate total percentage: (sum of all count values / revicedFootfall) * 100
|
|
1225
|
+
// type: 'raised' | 'finalreview'
|
|
1226
|
+
getRevisionCalculation(type) {
|
|
1227
|
+
if (!this.ticketReviewStatus || !Array.isArray(this.ticketReviewStatus || !type)) {
|
|
1228
|
+
return 0;
|
|
1229
|
+
}
|
|
1230
|
+
// Filter items based on actionType
|
|
1231
|
+
const taggingItems = this.ticketReviewStatus.filter((item) => item?.actionType === type);
|
|
1232
|
+
if (taggingItems.length === 0) {
|
|
1233
|
+
return 0;
|
|
1234
|
+
}
|
|
1235
|
+
if (!taggingItems[0] || !taggingItems[0].revicedFootfall || taggingItems[0].revicedFootfall === 0) {
|
|
1236
|
+
return 0;
|
|
1237
|
+
}
|
|
1238
|
+
const count = taggingItems[0].count || [];
|
|
1239
|
+
// Check if count is an array (new format) or object (old format)
|
|
1240
|
+
let totalCount = 0;
|
|
1241
|
+
if (Array.isArray(count)) {
|
|
1242
|
+
// New format: count is an array of objects with type and value
|
|
1243
|
+
const typesToSum = ['duplicate', 'employee', 'houseKeeping', 'junk'];
|
|
1244
|
+
totalCount = count
|
|
1245
|
+
.filter((item) => typesToSum.includes(item?.type))
|
|
1246
|
+
.reduce((sum, item) => sum + (item?.value || 0), 0);
|
|
1247
|
+
}
|
|
1248
|
+
// else {
|
|
1249
|
+
// // Old format: count is an object with keys
|
|
1250
|
+
// totalCount = (count.duplicateCount || 0) +
|
|
1251
|
+
// (count.employeeCount || 0) +
|
|
1252
|
+
// (count.junkCount || 0) +
|
|
1253
|
+
// (count.houseKeepingCount || 0);
|
|
1254
|
+
// }
|
|
1255
|
+
return Math.round((totalCount / taggingItems[0].revicedFootfall) * 100);
|
|
1256
|
+
}
|
|
1257
|
+
requestReset() {
|
|
1258
|
+
const modalRef = this.modalService.open(this.resetRequestPopup, {
|
|
1259
|
+
centered: true,
|
|
1260
|
+
size: "md",
|
|
1261
|
+
backdrop: "static",
|
|
1262
|
+
keyboard: false,
|
|
1263
|
+
});
|
|
1264
|
+
}
|
|
1265
|
+
cancelResetRequest() {
|
|
1266
|
+
this.modalService.dismissAll();
|
|
1267
|
+
}
|
|
1268
|
+
submitResetRequest() {
|
|
1269
|
+
let payload = {
|
|
1270
|
+
storeId: this.storeIdarray && this.storeIdarray.length > 0 ? this.storeIdarray[0] : null,
|
|
1271
|
+
dateString: this.folderDate || ""
|
|
1272
|
+
};
|
|
1273
|
+
console.log('submitResetRequest Payload:', payload);
|
|
1274
|
+
// Close modal after submission
|
|
1275
|
+
this.modalService.dismissAll();
|
|
1276
|
+
this.service
|
|
1277
|
+
.sendVMSResetRequest(payload)
|
|
1278
|
+
.pipe(takeUntil(this.destroy$))
|
|
1279
|
+
?.subscribe({
|
|
1280
|
+
next: (res) => {
|
|
1281
|
+
if (res && res.code === 200) {
|
|
1282
|
+
this.loadCardData();
|
|
1283
|
+
this.toast.getSuccessToast("Request reset successfully");
|
|
1284
|
+
}
|
|
1285
|
+
else {
|
|
1286
|
+
this.toast.getErrorToast("Failed to reset request");
|
|
1287
|
+
}
|
|
1288
|
+
},
|
|
1289
|
+
error: (err) => {
|
|
1290
|
+
const msg = err.error?.error ||
|
|
1291
|
+
err.error ||
|
|
1292
|
+
err?.error?.message ||
|
|
1293
|
+
err.message ||
|
|
1294
|
+
"Unknown error";
|
|
1295
|
+
console.error('Error in submitResetRequest :', err);
|
|
1296
|
+
this.toast.getErrorToast(msg || "Unknown error occurred");
|
|
1297
|
+
},
|
|
1298
|
+
});
|
|
1299
|
+
}
|
|
1300
|
+
// Get normalized date for current folderDate
|
|
1301
|
+
getNormalizedDate() {
|
|
1302
|
+
if (!this.folderDate)
|
|
1303
|
+
return null;
|
|
1304
|
+
return new Date(this.folderDate).toISOString().split("T")[0];
|
|
1305
|
+
}
|
|
1306
|
+
// Get selected date's card data
|
|
1307
|
+
getSelectedDateCardData() {
|
|
1308
|
+
const normalizedDate = this.getNormalizedDate();
|
|
1309
|
+
return normalizedDate ? this.cardDataMap[normalizedDate] : null;
|
|
1310
|
+
}
|
|
869
1311
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ImgRvpsComponent, deps: [{ token: i1.TrafficService }, { token: i2.GlobalStateService }, { token: i0.ChangeDetectorRef }, { token: i3.NgbModal }, { token: i4.ToastService }, { token: i5.TrafficRvpsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
870
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ImgRvpsComponent, selector: "lib-img-rvps", viewQueries: [{ propertyName: "zoomPopup", first: true, predicate: ["zoomPopup"], descendants: true }, { propertyName: "raisedPopup", first: true, predicate: ["raisedPopup"], descendants: true }, { propertyName: "imagePopup", first: true, predicate: ["imagePopup"], descendants: true }], ngImport: i0, template: "<div class=\"card mt-3\">\r\n <div class=\"card-header mt-3 px-0 border-bottom-0\">\r\n <div class=\"custom-accordion\">\r\n <div class=\"custom-accordion-item\">\r\n <button class=\"mainheading pb-0 custom-accordion-header\" (click)=\"toggleAccordion()\">\r\n <div class=\"header-row\">\r\n <span class=\"img-direc\">Image Directory</span>\r\n\r\n <span class=\"divider\"></span>\r\n <span class=\"accordion-arrow\">\r\n <!-- Down arrow for collapsed state, up arrow for expanded state -->\r\n <svg *ngIf=\"!isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\r\n viewBox=\"0 0 16 6\" fill=\"none\">\r\n <path d=\"M1 1L5 5L9 1\" stroke=\"#071437\" stroke-width=\"1\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n <svg *ngIf=\"isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\r\n viewBox=\"0 0 16 6\" fill=\"none\">\r\n <path d=\"M1 5L5 1L9 5\" stroke=\"#1b84ff\" stroke-width=\"1\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n </div>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n\r\n </div>\r\n <section *ngIf=\"isAccordionExpanded\">\r\n\r\n <div *ngIf=\"folderView\" class=\"card-body px-0\">\r\n <div class=\"scroll-container\">\r\n <div class=\"row\">\r\n <div class=\"col-md-1 mt-5 text-center\" *ngFor=\"let obj of dateArray;let i = index\">\r\n <div (click)=\"getimages(i,obj)\">\r\n <div *ngIf=\"i === selectIndex;\">\r\n <span class=\"cursor-pointer\"><svg width=\"57\" height=\"56\" viewBox=\"0 0 57 56\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"0.154297\" width=\"56\" height=\"56\" rx=\"12\" fill=\"#33B5FF\" />\r\n <path\r\n d=\"M39.8216 36.1667C39.8216 36.7855 39.5758 37.379 39.1382 37.8166C38.7006 38.2542 38.1071 38.5 37.4883 38.5H18.8216C18.2028 38.5 17.6093 38.2542 17.1717 37.8166C16.7341 37.379 16.4883 36.7855 16.4883 36.1667V19.8333C16.4883 19.2145 16.7341 18.621 17.1717 18.1834C17.6093 17.7458 18.2028 17.5 18.8216 17.5H24.6549L26.9883 21H37.4883C38.1071 21 38.7006 21.2458 39.1382 21.6834C39.5758 22.121 39.8216 22.7145 39.8216 23.3333V36.1667Z\"\r\n stroke=\"white\" stroke-width=\"2.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></span>\r\n <div class=\"text-center mt-2\">{{obj | date:'dd MMM'}}</div>\r\n </div>\r\n <div *ngIf=\"i !== selectIndex;\">\r\n <span class=\"cursor-pointer\"><svg width=\"57\" height=\"56\" viewBox=\"0 0 57 56\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"0.462891\" width=\"56\" height=\"56\" rx=\"12\" fill=\"#EAF8FF\" />\r\n <path\r\n d=\"M40.1302 36.1667C40.1302 36.7855 39.8844 37.379 39.4468 37.8166C39.0092 38.2542 38.4157 38.5 37.7969 38.5H19.1302C18.5114 38.5 17.9179 38.2542 17.4803 37.8166C17.0427 37.379 16.7969 36.7855 16.7969 36.1667V19.8333C16.7969 19.2145 17.0427 18.621 17.4803 18.1834C17.9179 17.7458 18.5114 17.5 19.1302 17.5H24.9635L27.2969 21H37.7969C38.4157 21 39.0092 21.2458 39.4468 21.6834C39.8844 22.121 40.1302 22.7145 40.1302 23.3333V36.1667Z\"\r\n stroke=\"#00A3FF\" stroke-width=\"2.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></span>\r\n <div class=\"text-center mt-2\">{{obj | date:'dd MMM'}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n\r\n <div *ngIf=\"!folderView\" class=\"card-body\">\r\n <section *ngIf=\"!imageFlow\">\r\n\r\n\r\n <div class=\"row\">\r\n <div class=\"d-flex flex-shrink-0 mt-3 justify-content-start align-items-center px-0\">\r\n <span *ngIf=\"backnav\" class=\"cursor-pointer\" (click)=\"backToFootfall()\">\r\n <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <g filter=\"url(#filter0_d_2585_7036)\">\r\n <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\r\n <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\r\n <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\r\n filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\r\n <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\r\n values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\r\n <feOffset dy=\"1\" />\r\n <feGaussianBlur stdDeviation=\"1\" />\r\n <feColorMatrix type=\"matrix\"\r\n values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\r\n <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\r\n result=\"effect1_dropShadow_2585_7036\" />\r\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\r\n result=\"shape\" />\r\n </filter>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span class=\"img-direc ms-2 mt-1\">{{folderDate | date:'dd MMM, yyyy'}} \r\n <span class=\"badge badge-light-warning mx-2\" *ngIf=\"!getTicketStatuses().includes('closed') && getTicketStatuses().includes('open')\">\r\n Ticket Raised\r\n</span>\r\n<span class=\"badge badge-light-success mx-2\" *ngIf=\"getTicketStatuses().includes('closed')\">Ticket Closed</span>\r\n\r\n </span>\r\n <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\" class=\"ms-auto text-end\">\r\n \r\n<button \r\n [disabled]=\"!canEnableButton()\" \r\n class=\"btn btn-primary\" \r\n type=\"button\" \r\n (click)=\"Raised()\">\r\n Raise ticket for footfall\r\n</button>\r\n</div>\r\n </div>\r\n <div *ngIf=\"!folderView\" class=\"nav-group bg-white border-1 btn-group w-auto my-2\">\r\n<ng-container *ngIf=\"!(countData?.length > 0)\">\r\n\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n [ngClass]=\"type === 'footfall' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n (click)=\"selectPlanTrends('footfall')\">\r\n Total Footfall\r\n <span\r\n [ngClass]=\"type === 'footfall' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\r\n {{ countData?.footfallCount || 0 }}\r\n </span>\r\n </button>\r\n\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n (click)=\"selectPlanTrends('non-tagging')\">\r\n Non-tags\r\n <span\r\n [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\r\n {{ countData?.nonTags || 0 }}\r\n </span>\r\n </button>\r\n\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n [ngClass]=\"type === 'duplicate' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n (click)=\"selectPlanTrends('duplicate')\">\r\n Duplicated\r\n <span\r\n [ngClass]=\"type === 'duplicate' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\r\n {{ countData?.duplicate || 0 }}\r\n </span>\r\n </button>\r\n\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n [ngClass]=\"type === 'employee' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n (click)=\"selectPlanTrends('employee')\">\r\n Employee/Staff\r\n <span\r\n [ngClass]=\"type === 'employee' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\r\n {{ countData?.employee || 0 }}\r\n </span>\r\n </button>\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n [ngClass]=\"type === 'junk' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n (click)=\"selectPlanTrends('junk')\">\r\n Junk\r\n <span\r\n [ngClass]=\"type === 'junk' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\r\n {{ countData?.junk || 0 }}\r\n </span>\r\n </button>\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n [ngClass]=\"type === 'house-keeping' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n (click)=\"selectPlanTrends('house-keeping')\">\r\n House Keeping\r\n <span\r\n [ngClass]=\"type === 'house-keeping' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\r\n {{ countData?.housekeeping || 0 }}\r\n </span>\r\n </button>\r\n \r\n\r\n</ng-container>\r\n\r\n </div>\r\n<ng-container *ngIf=\"!imageFlow\">\r\n\r\n <div *ngIf=\"type === 'footfall'\" class=\"d-flex mt-2 mb-2 w-100 overflow-x px-0\">\r\n\r\n <div class=\"col text-nowrap\" *ngFor=\"let obj of objectsArray\">\r\n <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\r\n <li class=\"nav-item cursor-pointer\">\r\n <a (click)=\"selectedTimes(obj.timeRange)\"\r\n [ngClass]=\"selectedTime === obj?.timeRange ? 'active' : ''\"\r\n class=\"nav-link cursor-pointer no-border mx-3 mb-2\">\r\n {{obj?.timeRange}}<span class=\"mx-2\"\r\n [ngClass]=\"selectedTime === obj?.timeRange ? 'badge-num-primary' :'badge-num-muted'\">\r\n {{ obj?.count ? obj?.count : 0 }}\r\n </span>\r\n </a>\r\n </li>\r\n </ul>\r\n </div>\r\n\r\n\r\n </div>\r\n</ng-container>\r\n <div *ngIf=\"loading\" class=\"row loader d-flex justify-content-center align-items-center\">\r\n <div class=\"shimmer\">\r\n <div class=\"wrapper\">\r\n <div class=\"stroke animate title\"></div>\r\n <div class=\"stroke animate link\"></div>\r\n <div class=\"stroke animate description\"></div>\r\n </div>\r\n </div>\r\n <div class=\"shimmer\">\r\n <div class=\"wrapper\">\r\n <div class=\"stroke animate title\"></div>\r\n <div class=\"stroke animate link\"></div>\r\n <div class=\"stroke animate description\"></div>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"noData\" class=\"row\">\r\n\r\n <div class=\"col-lg-12 mb-3\">\r\n\r\n <div class=\"card-body d-flex justify-content-center align-items-center flex-column \" style=\"margin: 64px;border-radius: 8px;\r\nbackground: var(--Gray-50, #F9FAFB);\">\r\n <svg width=\"94\" height=\"94\" viewBox=\"0 0 94 94\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"7\" y=\"7\" width=\"80\" height=\"80\" rx=\"40\" fill=\"#DAF1FF\" />\r\n <rect x=\"7\" y=\"7\" width=\"80\" height=\"80\" rx=\"40\" stroke=\"#EAF8FF\"\r\n stroke-width=\"13.3333\" />\r\n <path\r\n d=\"M35.332 51.9999H33.6654C32.7813 51.9999 31.9335 51.6487 31.3083 51.0236C30.6832 50.3985 30.332 49.5506 30.332 48.6666V33.6666C30.332 32.7825 30.6832 31.9347 31.3083 31.3096C31.9335 30.6844 32.7813 30.3333 33.6654 30.3333H48.6654C49.5494 30.3333 50.3973 30.6844 51.0224 31.3096C51.6475 31.9347 51.9987 32.7825 51.9987 33.6666V35.3333M45.332 41.9999H60.332C62.173 41.9999 63.6654 43.4923 63.6654 45.3333V60.3333C63.6654 62.1742 62.173 63.6666 60.332 63.6666H45.332C43.4911 63.6666 41.9987 62.1742 41.9987 60.3333V45.3333C41.9987 43.4923 43.4911 41.9999 45.332 41.9999Z\"\r\n stroke=\"#00A3FF\" stroke-width=\"4\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n <div class=\"nodata-title my-3\">\r\n {{ noDataMessages[type?.toLowerCase()] || 'No data found' }}\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n <div class=\"row px-0 img-traffic contain high-400px scroll-y\" *ngIf=\"!noData && !loading\">\r\n <ng-container\r\n\r\n*ngFor=\"let obj of imagesArrayData\"\r\n>\r\n<div *ngIf=\"type !== 'duplicate' || (type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\" class=\"col-md-3 border-gray mx-2 p-2 mt-5\">\r\n<!-- Condition: Only show if not duplicate OR duplicate with non-empty duplicateImagePath -->\r\n<ng-container >\r\n<img\r\nclass=\"img-src cursor-pointer\"\r\n[src]=\"imageUrl + obj?.filePath\"\r\n(error)=\"obj.filePath = null\"\r\nalt=\"\"\r\n(click)=\"imgFullView(obj)\"\r\n/>\r\n</ng-container>\r\n\r\n <div *ngIf=\"!obj?.filePath\" class=\"no-preview\">\r\n <span class=\"mb-5\">\r\n <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <g id=\"Group\">\r\n <path id=\"Vector\"\r\n d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\r\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n <path id=\"Vector_2\"\r\n d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\r\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n </svg>\r\n\r\n </span>\r\n <span class=\"header mb-5 text-center\">Preview not available</span>\r\n <span class=\"description mb-5 text-center\">The selected camera is not available at the\r\n moment.</span>\r\n </div>\r\n <div *ngIf=\"type !== 'duplicate' || (type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\" class=\"row px-2 mb-2\">\r\n <div class=\"col-md-7\">\r\n <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd}} <span *ngIf=\"(type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\" class=\"mx-2 badge badge-light-primary\">{{obj.duplicateImagePath?.length}}</span>\r\n <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\r\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\r\n fill=\"#12B76A\" />\r\n </svg></span>\r\n <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_1428_59484)\">\r\n <path\r\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n fill=\"#FEE4E2\" />\r\n <path\r\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n stroke=\"#D92D20\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_1428_59484\">\r\n <rect width=\"12\" height=\"12\" fill=\"white\"\r\n transform=\"translate(0.599609 0.5)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n </div>\r\n <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme}}</div>\r\n </div>\r\n <div class=\"col-md-5 text-end py-3\">\r\n <span *ngIf=\"obj?.revopsType ==='non-tagging'\" ngbTooltip=\"Yet to tag the customer\"\r\n placement=\"top\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\r\n viewBox=\"0 0 19 18\" fill=\"none\">\r\n <path\r\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='duplicate'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94635)\">\r\n <path\r\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94635\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='employee'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94639)\">\r\n <path\r\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94639\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\r\n viewBox=\"0 0 21 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94643)\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n fill=\"#475467\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94643\">\r\n <rect width=\"21\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='junk'\">\r\n\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n<path d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg>\r\n </span>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n </div>\r\n </section>\r\n\r\n <!-- full image View -->\r\n <section *ngIf=\"imageFlow\">\r\n <div class=\"row\">\r\n <div class=\"d-flex flex-shrink-0 mt-3 justify-content-start align-items-center px-0\">\r\n <span class=\"cursor-pointer\" (click)=\"backToFootfall1()\">\r\n <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <g filter=\"url(#filter0_d_2585_7036)\">\r\n <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\r\n <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\r\n <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\r\n filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\r\n <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\r\n values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\r\n <feOffset dy=\"1\" />\r\n <feGaussianBlur stdDeviation=\"1\" />\r\n <feColorMatrix type=\"matrix\"\r\n values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\r\n <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\r\n result=\"effect1_dropShadow_2585_7036\" />\r\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\r\n result=\"shape\" />\r\n </filter>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span class=\"img-direc ms-2 mt-1\">{{folderDate | date:'dd MMM, yyyy'}}</span>\r\n </div>\r\n <div class=\"d-flex mt-2 mb-2 w-100 overflow-x px-0\">\r\n\r\n <!-- <div class=\"col text-nowrap\" *ngFor=\"let obj of objectsArray\">\r\n <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\r\n <li class=\"nav-item cursor-pointer\">\r\n <a (click)=\"selectedTimes(obj.timeRange)\"\r\n [ngClass]=\"selectedTime === obj?.timeRange ? 'active' : ''\"\r\n class=\"nav-link cursor-pointer no-border mx-3 mb-2\">\r\n {{obj?.timeRange}}<span class=\"mx-2\"\r\n [ngClass]=\"selectedTime === obj?.timeRange ? 'badge-num-primary' :'badge-num-muted'\">\r\n {{ obj?.count ? obj?.count : 0 }}\r\n </span>\r\n </a>\r\n </li>\r\n </ul>\r\n </div> -->\r\n\r\n\r\n </div>\r\n\r\n <div class=\"row mx-0 border-gray img-traffic\" *ngIf=\"!noData && !loading\">\r\n <div class=\"col-md-6 p-2 mb-2 mt-5\">\r\n <div class=\"position-relative border-gray p-2 \">\r\n <!-- <button *ngIf=\"canNavigateLeft\" (click)=\"navigateImage('left')\"\r\n class=\"btn btn-light position-absolute start-0 top-50 z-index-10\">\r\n \u25C0\r\n </button> -->\r\n\r\n <!-- Main Image -->\r\n <img class=\"img-src cursor-pointer h-450px\" (click)=\"selectedImageArray(imageUrl, selectImageArray)\"\r\n [src]=\"imageUrl + selectImageArray?.filePath\" appMagnifier alt=\"\">\r\n <!-- <button *ngIf=\"canNavigateRight\" (click)=\"navigateImage('right')\"\r\n class=\"btn btn-light position-absolute end-0 top-50 z-index-10\">\r\n \u25B6\r\n </button> -->\r\n\r\n <!-- Right arrow button -->\r\n <div class=\"row px-2 mb-2\">\r\n <div class=\"col-md-7\">\r\n <div class=\"py-2 img-doc-time\">Tango ID : {{selectImageArray?.templd}}\r\n <span *ngIf=\"selectImageArray?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\r\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\r\n fill=\"#12B76A\" />\r\n </svg></span>\r\n <span *ngIf=\"selectImageArray?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_1428_59484)\">\r\n <path\r\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n fill=\"#FEE4E2\" />\r\n <path\r\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n stroke=\"#D92D20\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_1428_59484\">\r\n <rect width=\"12\" height=\"12\" fill=\"white\"\r\n transform=\"translate(0.599609 0.5)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n </div>\r\n <div class=\"img-doc-value\">Entry Time : {{selectImageArray?.entryTme}}</div>\r\n </div>\r\n <div class=\"col-md-5 text-end py-3\">\r\n <span *ngIf=\"selectImageArray?.revopsType ==='non-tagging'\"\r\n ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\r\n viewBox=\"0 0 19 18\" fill=\"none\">\r\n <path\r\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span *ngIf=\"selectImageArray?.revopsType ==='duplicate'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94635)\">\r\n <path\r\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94635\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"selectImageArray?.revopsType ==='employee'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94639)\">\r\n <path\r\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94639\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"selectImageArray?.revopsType ==='house-keeping'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\r\n viewBox=\"0 0 21 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94643)\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n fill=\"#475467\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94643\">\r\n <rect width=\"21\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"col-md-6 p-2 mb-2 mt-5\">\r\n <div class=\"mx-2 \">\r\n <div class=\"row\">\r\n <div class=\"col-md-6 title-type\">\r\n Select non-shopper type\r\n </div>\r\n \r\n\r\n <section class=\"col-md-6 text-end\" *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\r\n \r\n <div *ngIf=\"!revopsTypeValue\" class=\"mb-5 text-end\" role=\"group\">\r\n <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\">\r\n \r\n <button [disabled]=\"\r\n (selectedRadioType === undefined || selectedRadioType === '') ||\r\n (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\r\n \"\r\n class=\"btn btn-default\" type=\"button\" (click)=\"clearValue()\">Clear</button>\r\n <button class=\"btn btn-outline me-2\" (click)=\"cancel()\">Cancel</button>\r\n <button\r\n class=\"btn btn-primary\"\r\n id=\"alert-toast\"\r\n (click)=\"save(selectedType)\"\r\n [disabled]=\"\r\n (selectedRadioType === undefined || selectedRadioType === '') ||\r\n (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\r\n \"\r\n >\r\n Save\r\n </button>\r\n </div>\r\n </div>\r\n \r\n <div *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\r\n <ng-container *ngIf=\"editBtnShow\">\r\n <div *ngIf=\"revopsTypeValue\" class=\"mb-5 text-end\" role=\"group\">\r\n <button *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\" class=\"btn btn-outline me-2\" (click)=\"editValue()\"><span\r\n class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\"\r\n height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M14.6554 1.71047C14.8927 1.47315 15.1745 1.2849 15.4845 1.15646C15.7946 1.02802 16.1269 0.961914 16.4626 0.961914C16.7982 0.961914 17.1305 1.02802 17.4406 1.15646C17.7507 1.2849 18.0324 1.47315 18.2697 1.71047C18.5071 1.94779 18.6953 2.22953 18.8238 2.53961C18.9522 2.84969 19.0183 3.18202 19.0183 3.51765C19.0183 3.85327 18.9522 4.18561 18.8238 4.49568C18.6953 4.80576 18.5071 5.0875 18.2697 5.32482L6.0713 17.5233L1.10156 18.8786L2.45695 13.9089L14.6554 1.71047Z\"\r\n stroke=\"#344054\" stroke-width=\"1.81079\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></span>Edit</button>\r\n \r\n </div>\r\n </ng-container>\r\n </div>\r\n </section>\r\n \r\n </div>\r\n\r\n <div class=\"form-check my-15\">\r\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"duplicate\"\r\n id=\"duplicate\" [(ngModel)]=\"selectedType\" [value]=\"'duplicate'\"\r\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\r\n <label class=\"form-check-label\" for=\"duplicate\">\r\n <span class=\"ms-5\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94635)\">\r\n <path\r\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94635\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span class=\"ms-5 tag-class\">Duplicate</span>\r\n </label>\r\n </div>\r\n <div class=\"form-check my-15\">\r\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"employee\"\r\n id=\"employee\" [(ngModel)]=\"selectedType\" [value]=\"'employee'\"\r\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\r\n <label class=\"form-check-label\" for=\"employee\">\r\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\"\r\n height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94639)\">\r\n <path\r\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94639\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n <span class=\"ms-5 tag-class\">Employee/Staff</span>\r\n </label>\r\n </div>\r\n <div class=\"form-check my-15\">\r\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"house-keeping\"\r\n id=\"house-keeping\" [(ngModel)]=\"selectedType\" [value]=\"'house-keeping'\"\r\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\r\n <label class=\"form-check-label\" for=\"house-keeping\">\r\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\"\r\n height=\"21\" viewBox=\"0 0 21 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94643)\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n fill=\"#475467\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94643\">\r\n <rect width=\"21\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n <span class=\"ms-5 tag-class\"> House Keeping</span>\r\n </label>\r\n </div>\r\n <div class=\"form-check my-15\">\r\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"junk\"\r\n id=\"junk\" [(ngModel)]=\"selectedType\" [value]=\"'junk'\"\r\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"users?.role ==='user' && this.users?.userType ==='client' || revopsTypeValue\">\r\n <label class=\"form-check-label\" for=\"junk\">\r\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n <path d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg></span>\r\n <span class=\"ms-5 tag-class\"> Junk</span>\r\n </label>\r\n </div>\r\n </div>\r\n\r\n\r\n </div>\r\n </div>\r\n\r\n \r\n <div class=\"row px-0 img-traffic mt-3 high-400px scroll-y\">\r\n <div class=\"col-md-3 border-gray mx-2 p-2 mt-5\" *ngFor=\"let obj of remainingImageArray\">\r\n <div class=\"position-relative\">\r\n <!-- <input *ngIf=\"selectedRadioType === 'duplicate'\" type=\"checkbox\" \r\n [(ngModel)]=\"obj.selected\" class=\"position-absolute absolute form-check-input\"\r\n (change)=\"onImageCheckboxChange(obj, 'duplicate')\" /> -->\r\n <input \r\n *ngIf=\"!revopsTypeValue && selectedRadioType === 'duplicate'\"\r\n type=\"checkbox\"\r\n [checked]=\"obj.selected\"\r\n class=\"position-absolute absolute form-check-input cursor-pointer\"\r\n (change)=\"onImageCheckboxChange($event, obj, 'duplicate')\"\r\n [disabled]=\"obj.duplicateImagePath?.length > 0\"\r\n/>\r\n\r\n<img\r\n class=\"img-src\"\r\n [ngClass]=\"selectedRadioType !== 'duplicate' ? 'cursor-pointer' : 'cursor-pointer'\"\r\n [src]=\"imageUrl + obj?.filePath\"\r\n (error)=\"obj.filePath = null\"\r\n alt=\"\"\r\n (click)=\"handleImageClick($event, obj)\"\r\n/>\r\n\r\n <div *ngIf=\"!obj?.filePath\" class=\"no-preview\">\r\n <span class=\"mb-5\">\r\n <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <g id=\"Group\">\r\n <path id=\"Vector\"\r\n d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\r\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n <path id=\"Vector_2\"\r\n d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\r\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n </svg>\r\n\r\n </span>\r\n <span class=\"header mb-5 text-center\">Preview not available</span>\r\n <span class=\"description mb-5 text-center\">The selected camera is not available at\r\n the\r\n moment.</span>\r\n </div>\r\n <div class=\"row px-2 mb-2\">\r\n <div class=\"col-md-7\">\r\n <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd ? obj?.templd : obj?.tempId}} \r\n <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\r\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\r\n fill=\"#12B76A\" />\r\n </svg></span>\r\n <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_1428_59484)\">\r\n <path\r\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n fill=\"#FEE4E2\" />\r\n <path\r\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n stroke=\"#D92D20\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_1428_59484\">\r\n <rect width=\"12\" height=\"12\" fill=\"white\"\r\n transform=\"translate(0.599609 0.5)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n </div>\r\n <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme ? obj?.entryTme :obj?.entryTime}}</div>\r\n </div>\r\n <div class=\"col-md-5 text-end py-3\">\r\n <span *ngIf=\"obj?.revopsType ==='non-tagging'\"\r\n ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\r\n viewBox=\"0 0 19 18\" fill=\"none\">\r\n <path\r\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='duplicate'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94635)\">\r\n <path\r\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94635\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='employee'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94639)\">\r\n <path\r\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94639\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\r\n viewBox=\"0 0 21 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94643)\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n fill=\"#475467\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94643\">\r\n <rect width=\"21\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='junk'\">\r\n\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n<path d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg>\r\n </span>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </section>\r\n </div>\r\n </section>\r\n</div>\r\n\r\n\r\n<ng-template #zoomPopup let-model>\r\n <div class=\"p-4 m-4\">\r\n <div class=\"modal-header border-0 p-0 w-100 flex-column align-items-start\">\r\n <span *ngIf=\"popupType === 'non-tagging'\" class=\"my-3\">\r\n\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\r\n <rect width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\r\n <g clip-path=\"url(#clip0_2088_98337)\">\r\n <path\r\n d=\"M29.1693 13.3333V18.3333M29.1693 18.3333H24.1693M29.1693 18.3333L25.3026 14.7C24.407 13.8039 23.299 13.1493 22.0819 12.7973C20.8649 12.4453 19.5785 12.4073 18.3428 12.6869C17.1072 12.9665 15.9624 13.5545 15.0155 14.3962C14.0685 15.2378 13.3502 16.3056 12.9276 17.5M10.8359 26.6666V21.6666M10.8359 21.6666H15.8359M10.8359 21.6666L14.7026 25.3C15.5982 26.1961 16.7062 26.8506 17.9233 27.2027C19.1403 27.5547 20.4267 27.5927 21.6624 27.3131C22.898 27.0335 24.0428 26.4455 24.9897 25.6038C25.9367 24.7621 26.655 23.6943 27.0776 22.5\"\r\n stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2088_98337\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(10 10)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <!-- Heading -->\r\n <h5 class=\"modal-title mb-2\">\r\n <span *ngIf=\"popupType === 'employee'\">Tagging as employee/staff </span>\r\n <span *ngIf=\"popupType === 'duplicate'\">Tagging as duplicates </span>\r\n <span *ngIf=\"popupType === 'house-keeping'\">Tagging as house keeping </span>\r\n <span *ngIf=\"popupType === 'non-tagging'\">Clear duplicates</span>\r\n <span *ngIf=\"popupType ==='junk'\">Tagging as junk</span>\r\n \r\n </h5>\r\n <p class=\"mb-3\">\r\n <span *ngIf=\"popupType === 'employee'\">Are you sure you want to tag this as employee/staff?</span>\r\n <span *ngIf=\"popupType === 'duplicate'\">Are you sure you want to tag this as duplicates? </span>\r\n <span *ngIf=\"popupType === 'house-keeping'\">Are you sure you want to tag this as house keeping? </span>\r\n <span *ngIf=\"popupType === 'non-tagging'\">This will remove tagged duplicates and move them to\r\n 'Non-tag'.</span>\r\n <span *ngIf=\"popupType ==='junk'\">Are you sure you want to tag this as junk?</span>\r\n\r\n </p>\r\n </div>\r\n\r\n <div class=\"w-100 mt-5 d-flex justify-content-end\">\r\n <button class=\"btn btn-outline me-2\" (click)=\"cancelSubmit()\">Cancel</button>\r\n <button *ngIf=\"popupType !== 'non-tagging'\" class=\"btn btn-primary\" (click)=\"submitValue(popupType)\">\r\n Yes, Tag\r\n </button>\r\n <button *ngIf=\"popupType === 'non-tagging'\" class=\"btn btn-primary\" (click)=\"submitValue(popupType)\">\r\n Yes, clear\r\n </button>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n\r\n<ng-template #raisedPopup let-model>\r\n <div class=\"p-4 m-4\">\r\n <div class=\"modal-header border-0 p-0 w-100 flex-column align-items-start\">\r\n <span class=\"my-3\">\r\n\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\r\n <rect width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\r\n <path\r\n d=\"M21.251 11.0806C21.7405 11.0699 22.2153 11.2487 22.5762 11.5796L23.4922 12.4204C23.8089 12.7097 23.893 13.1017 23.8652 13.4263V13.4272C23.836 13.7478 23.6954 14.0592 23.4785 14.2944C23.3699 14.413 23.2865 14.5525 23.2314 14.7036C23.1764 14.8548 23.1512 15.0155 23.1582 15.1763C23.1652 15.337 23.2035 15.4953 23.2715 15.6411C23.3394 15.7869 23.4362 15.9172 23.5547 16.0259C23.6733 16.1346 23.8117 16.2198 23.9629 16.2749C24.1141 16.33 24.2748 16.3541 24.4355 16.3472C24.5961 16.3402 24.7537 16.3017 24.8994 16.2339C25.0089 16.1829 25.1106 16.116 25.2002 16.0356L25.3701 15.8657C25.5759 15.6748 25.8385 15.5408 26.1152 15.4907C26.2972 15.4546 26.485 15.4617 26.6641 15.5103C26.8439 15.5591 27.0103 15.649 27.1494 15.7729L27.1514 15.7749L28.2598 16.7905C28.445 16.9605 28.5948 17.1658 28.7002 17.394C28.8056 17.6223 28.8648 17.8694 28.874 18.1206C28.8832 18.372 28.8423 18.6234 28.7539 18.8589C28.6655 19.0941 28.5316 19.3096 28.3594 19.4927L20.1113 28.2583C19.937 28.4434 19.7268 28.5912 19.4941 28.6938C19.2614 28.7965 19.0102 28.8522 18.7559 28.856C18.5016 28.8597 18.2493 28.8119 18.0137 28.7163C17.7779 28.6206 17.5636 28.4784 17.3838 28.2983L16.2539 27.1685C15.7511 26.6656 15.8832 25.9552 16.1514 25.5542L16.2061 25.4644C16.3241 25.2486 16.3742 25.0008 16.3496 24.7544C16.3214 24.4731 16.197 24.2102 15.9971 24.0103C15.7971 23.8103 15.5343 23.6859 15.2529 23.6577C14.9715 23.6297 14.6887 23.6995 14.4531 23.856H14.4521C14.0494 24.1222 13.3407 24.2552 12.8379 23.7515L11.6797 22.5933C11.5034 22.4169 11.364 22.2074 11.2686 21.9771C11.1731 21.7467 11.1231 21.4999 11.123 21.2505C11.123 21.001 11.1731 20.7535 11.2686 20.5229C11.364 20.2926 11.5034 20.0831 11.6797 19.9067L19.9492 11.6362C20.2954 11.2902 20.7616 11.0912 21.251 11.0806ZM21.2783 12.3804C21.1237 12.3838 20.9765 12.4468 20.8672 12.5562L12.5967 20.8257C12.5409 20.8814 12.497 20.9482 12.4668 21.021C12.4367 21.0938 12.4209 21.1717 12.4209 21.2505C12.4209 21.3292 12.4367 21.4073 12.4668 21.48C12.497 21.5528 12.541 21.6196 12.5967 21.6753L13.7061 22.7837L13.7314 22.772C14.2169 22.4485 14.7993 22.3035 15.3799 22.3608C15.9608 22.4183 16.5042 22.6747 16.917 23.0874C17.3298 23.5002 17.587 24.0436 17.6445 24.6245C17.702 25.2055 17.5565 25.7892 17.2324 26.2749L17.2305 26.2759C17.2261 26.2822 17.2226 26.2893 17.2197 26.2964L18.3018 27.3804C18.3585 27.4372 18.4266 27.482 18.501 27.5122C18.5755 27.5425 18.6559 27.5574 18.7363 27.5562C18.8166 27.5549 18.8963 27.5378 18.9697 27.5054C19.043 27.4729 19.1091 27.4261 19.1641 27.3677L27.4131 18.6021C27.4673 18.5442 27.5093 18.4761 27.5371 18.4019C27.5649 18.3276 27.5781 18.2487 27.5752 18.1694C27.5722 18.0902 27.5538 18.0119 27.5205 17.9399C27.4872 17.8679 27.4394 17.8032 27.3809 17.7495L26.3223 16.7778C26.2925 16.7885 26.2648 16.8053 26.2432 16.8286C26.0217 17.0788 25.7529 17.2827 25.4521 17.4282C25.15 17.5743 24.8214 17.6585 24.4863 17.6763C24.1511 17.694 23.815 17.6452 23.499 17.5317C23.1832 17.4183 22.8928 17.2429 22.6455 17.0161C22.3982 16.7893 22.1988 16.5153 22.0586 16.2104C21.9183 15.9055 21.8404 15.5752 21.8291 15.2397C21.8178 14.9043 21.8737 14.57 21.9932 14.2563C22.1121 13.9442 22.2915 13.6587 22.5215 13.4165L22.5547 13.3657C22.5594 13.3552 22.5607 13.3437 22.5635 13.3325L21.6973 12.5386V12.5376C21.5833 12.4331 21.4329 12.377 21.2783 12.3804Z\"\r\n fill=\"#00A3FF\" stroke=\"#00A3FF\" stroke-width=\"0.3\" />\r\n </svg>\r\n </span>\r\n <!-- Heading -->\r\n <h5 class=\"modal-title mb-2\">\r\n <span>Raise tickets for the following</span>\r\n\r\n </h5>\r\n <p class=\"mb-3\">\r\n <span>Raising a ticket for footfall count issues. Make sure all records are identified for\r\n validation.</span>\r\n\r\n\r\n </p>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-3 my-4\">\r\n <div class=\"border border-1 rounded p-3 h-100\">\r\n <div class=\"fw-semibold fs-5 mb-2\">\r\n {{tempRaisedPayload?.duplicateCount ? tempRaisedPayload?.duplicateCount :'0'}}\r\n </div>\r\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n Duplicates\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"col-md-3 my-4\">\r\n <div class=\"border border-1 rounded p-3 h-100\">\r\n <div class=\"fw-semibold fs-5 mb-2\">\r\n {{tempRaisedPayload?.employeeCount ? tempRaisedPayload?.employeeCount:'0' }}\r\n </div>\r\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n Employee\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"col-md-3 my-4\">\r\n <div class=\"border border-1 rounded p-3 h-100\">\r\n <div class=\"fw-semibold fs-5 mb-2\">\r\n {{tempRaisedPayload?.houseKeepingCount ? tempRaisedPayload?.houseKeepingCount :'0'}}\r\n </div>\r\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n House Keeping\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-md-3 my-4\">\r\n <div class=\"border border-1 rounded p-3 h-100\">\r\n <div class=\"fw-semibold fs-5 mb-2\">\r\n {{tempRaisedPayload?.junkCount ? tempRaisedPayload?.junkCount :'0'}}\r\n </div>\r\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n Junk\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n <!-- Label and Textarea -->\r\n <div class=\"my-3\">\r\n <label class=\"form-label\">Description (Optional)</label>\r\n <textarea rows=\"3\" [(ngModel)]=\"commentText\" class=\"form-control\"\r\n placeholder=\"Enter description\"></textarea>\r\n </div>\r\n <div class=\"w-100 mt-5 d-flex justify-content-end\">\r\n\r\n <button class=\"btn btn-outline w-50 me-2\" (click)=\"cancelRasied()\">Cancel</button>\r\n <button class=\"btn btn-primary w-50\" (click)=\"submitRaised()\">\r\n Raise Ticket\r\n </button>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n\r\n<ng-template #imagePopup let-model>\r\n <div class=\"mx-4\">\r\n <div class=\"row\">\r\n <div class=\" p-2 mb-2 mt-5\">\r\n <div *ngIf=\"isModalOpen\" class=\"position-relative border-gray p-2 \">\r\n <!-- <button *ngIf=\"canNavigateLeft\" (click)=\"navigateImage('left')\"\r\n class=\"btn btn-light position-absolute start-0 top-50 z-index-10\">\r\n \u25C0\r\n </button> -->\r\n\r\n <!-- Main Image -->\r\n <img class=\" cursor-pointer w-100 h-525px\"\r\n [src]=\"imageUrl + selectImageArray?.filePath\" appMagnifier alt=\"\">\r\n <!-- <button *ngIf=\"canNavigateRight\" (click)=\"navigateImage('right')\"\r\n class=\"btn btn-light position-absolute end-0 top-50 z-index-10\">\r\n \u25B6\r\n </button> -->\r\n\r\n <!-- Right arrow button -->\r\n <div class=\"row px-2 mb-2\">\r\n <div class=\"col-md-7\">\r\n <div class=\"py-2 img-doc-time\">Tango ID : {{selectImageArray?.templd}}\r\n <span *ngIf=\"selectImageArray?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\r\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\r\n fill=\"#12B76A\" />\r\n </svg></span>\r\n <span *ngIf=\"selectImageArray?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_1428_59484)\">\r\n <path\r\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n fill=\"#FEE4E2\" />\r\n <path\r\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n stroke=\"#D92D20\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_1428_59484\">\r\n <rect width=\"12\" height=\"12\" fill=\"white\"\r\n transform=\"translate(0.599609 0.5)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n </div>\r\n <div class=\"img-doc-value\">Entry Time : {{selectImageArray?.entryTme}}</div>\r\n </div>\r\n <div class=\"col-md-5 text-end py-3\">\r\n <span *ngIf=\"selectImageArray?.revopsType ==='non-tagging'\"\r\n ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\r\n viewBox=\"0 0 19 18\" fill=\"none\">\r\n <path\r\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span *ngIf=\"selectImageArray?.revopsType ==='duplicate'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94635)\">\r\n <path\r\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94635\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"selectImageArray?.revopsType ==='employee'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94639)\">\r\n <path\r\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94639\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"selectImageArray?.revopsType ==='house-keeping'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\r\n viewBox=\"0 0 21 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94643)\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n fill=\"#475467\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94643\">\r\n <rect width=\"21\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- <div class=\"modal-footer py-2 px-0\"> -->\r\n\r\n <div class=\"w-100 py-2 mb-2 px-0 d-flex justify-content-end\">\r\n \r\n <button class=\"btn btn-outline\" (click)=\"closeImage()\">Close</button>\r\n \r\n </div>\r\n <!-- </div> -->\r\n </div>\r\n</ng-template>", styles: [".switch-form-card{padding:8px 16px;border-radius:4px;border-left:2px solid var(--Primary-600, #00A3FF);background:var(--Primary-25, #F6FCFF);display:flex;align-items:center;justify-content:space-between}.switch-form-card .txt-one{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:140%}.nav-item .nav-link.active{border:none;border-radius:6px;background:var(--Primary-50, #EAF8FF);padding:8px 12px}.nav-item .nav-link:hover{border:none}.badge-num-primary{border-radius:16px!important;background:var(--Primary-50, #EAF8FF)!important;color:var(--Primary-700, #009BF3)!important;text-align:center;font-size:14px!important;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}.badge-num-muted{border-radius:16px!important;background:var(--Primary-50, #F2F4F7)!important;color:var(--Gray-700, #344054)!important;text-align:center;font-size:14px;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}.img-src{width:100%;height:195px;border-radius:.625rem}.img-traffic .col-md-3{width:24%!important}.border-gray{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF)}.img-doc-directory{color:var(--Gray-900, #101828)!important;font-size:14px!important;font-weight:600;line-height:20px;text-decoration-line:underline}.img-doc-time{color:var(--Gray-800, #1D2939);font-size:14px;font-weight:500;line-height:20px}.img-doc-value{color:var(--Gray-600, #667085);font-size:14px;font-weight:500;line-height:20px}.overflow-x{overflow-x:auto}.no-preview{border:1px solid #F04438;background:#fee4e2;border-radius:8px;stroke-width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:41px 16px}.no-preview .header{color:#f04438;font-size:20px;font-weight:700;line-height:20px}.no-preview .description{color:#f04438;font-size:12px;font-weight:500;line-height:18px}.img-nodata{width:25%;height:15%}.img-nodata1{width:15%;height:15%}.nodata-title{font-size:14px!important;font-weight:600}.img-direc{color:var(--Gray-900, #101828)!important;font-size:18px!important;font-weight:500;line-height:28px}.custom-accordion{border-radius:5px}.custom-accordion-item{margin-bottom:10px}.custom-accordion-header{background-color:#fff;border:none;cursor:pointer;padding:10px;text-align:left;width:100%;display:flex;justify-content:space-between;align-items:center}.custom-accordion{width:100%}.mainheading{width:100%;display:flex;justify-content:space-between;align-items:center;padding:19px;border:none;background:none;cursor:pointer}.header-row{display:flex;align-items:center;width:100%;justify-content:space-between}.img-dire{font-size:16px;font-weight:700}.divider{flex-grow:1;height:1px;background-color:#ddd;margin:0 10px}.accordion-arrow{display:flex;align-items:center}.scroll-container{max-height:400px;overflow-y:auto;overflow-x:hidden}.high-400px{min-height:auto!important;max-height:800px!important}.scroll-y{overflow-y:auto}.absolute{top:5px;right:5px;z-index:2}.slider{position:relative}.slider .previous{position:absolute;top:30%;left:2%;width:32px;height:32px;background-color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.slider .next{position:absolute;top:30%;right:2%;width:32px;height:32px;background-color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.img-src1{border-radius:12px;border:1px solid var(--Gray-400, #98A2B3);background:var(--Gray-50, #F9FAFB);width:100%;height:375px}.border-gray{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);padding:0 4px}.border-gray-active{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--Primary-50, #EAF8FF);padding:0 4px}.zone-header{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:20px}.last-visit{color:var(--Gray-500, #667085);font-size:14px;font-weight:400;line-height:20px}.toggle-label{color:var(--Gray-900, #101828);font-size:16px;font-weight:600;line-height:24px}.nav-dev{border-radius:8px!important;border:1px solid var(--Primary-200, #99DAFF)!important;background:var(--Primary-25, #F6FCFF)!important}.tab-active{border-radius:6px;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3)!important;font-size:14px;font-weight:500;line-height:20px}.tab-text-default{color:var(--Gray-500, #667085);font-size:14px;font-weight:500;line-height:20px}.border-gray-active1{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--Primary-50, #ffffff);padding:12px!important}.nav-item1 .nav-link1.active{border:none;border-radius:0;background:var(--Primary-50, #EAF8FF);border-bottom:2px solid #009BF3!important;padding:12px;color:var(--Primary-700, #009BF3);font-size:14px;font-style:normal;font-weight:500;line-height:20px}.active-normal{padding:12px;color:var(--Gray-500, #667085);font-size:14px;font-style:normal;font-weight:500;line-height:20px}.nav-item1 .nav-link1:hover{border:none}.tag-class{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:20px}.spent-title{color:var(--Gray-600, #475467);font-size:14px;font-weight:600;line-height:20px}.spent-value{color:var(--Gray-500, #667085);font-size:14px;font-weight:400;line-height:20px}.spent-value1{color:var(--Primary-500, #33B5FF);font-size:14px;font-weight:500;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font}.w-33{width:30%}.w-45{width:45%}.view-tetory{color:var(--Primary-700, #009BF3);font-size:14px;font-weight:600;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font;text-transform:capitalize}.border-gray-tagged{border-radius:4px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--Primary-50, #ffffff);padding:8px!important}.desc-id{color:var(--Gray-900, #101828);font-size:12px;font-style:normal;font-weight:400;line-height:20px}.active-tab{border-bottom:2px solid #0d6efd;font-weight:600;color:#0d6efd}.badge-selected{background-color:#e0f3ff;color:#0d6efd;border:1px solid #0d6efd;border-radius:20px;padding:6px 12px}.badge-unselected{background-color:#f0f0f0;color:#333;border-radius:20px;padding:6px 12px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.cursor-not-allowed{cursor:not-allowed!important}.title-type{color:var(--Gray-800, #1D2939);font-size:16px;font-weight:600;line-height:24px}.top-50{top:35%!important}.activePlanBtn{border-radius:6px;background:var(--Primary-50, #EAF8FF);color:var(--Gray-700, #344054);font-size:14px!important;font-weight:500!important;line-height:20px}.inactivePlanBtn{color:var(--Gray-500, #344054)!important;font-size:14px;font-weight:500!important;line-height:20px}.badge-active{border-radius:16px;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3);text-align:center;font-size:12px;font-style:normal;font-weight:500;line-height:20px;mix-blend-mode:multiply}input[type=checkbox]{width:18px!important;height:18px!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}::ng-deep .modal-backdrop{pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.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: i7.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "popperOptions", "triggers", "positionTarget", "container", "disableTooltip", "tooltipClass", "tooltipContext", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "directive", type: i8.MagnifierDirective, selector: "[appMagnifier]" }, { kind: "pipe", type: i6.DatePipe, name: "date" }] });
|
|
1312
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ImgRvpsComponent, selector: "lib-img-rvps", viewQueries: [{ propertyName: "zoomPopup", first: true, predicate: ["zoomPopup"], descendants: true }, { propertyName: "raisedPopup", first: true, predicate: ["raisedPopup"], descendants: true }, { propertyName: "resetRequestPopup", first: true, predicate: ["resetRequestPopup"], descendants: true }, { propertyName: "imagePopup", first: true, predicate: ["imagePopup"], descendants: true }], ngImport: i0, template: "<div class=\"card mt-3\">\n <div class=\"card-header mt-3 px-0 border-bottom-0\">\n <div class=\"custom-accordion\">\n <div class=\"custom-accordion-item\">\n <!-- for new navigation changes -->\n <!-- old view while folder view -->\n <button *ngIf=\"folderView\" class=\"mainheading pb-0 custom-accordion-header\" (click)=\"toggleAccordion()\">\n <div class=\"header-row\">\n <span class=\"img-direc\">Image Directory</span>\n\n <span class=\"divider\"></span>\n <span class=\"accordion-arrow\">\n <!-- Down arrow for collapsed state, up arrow for expanded state -->\n <svg *ngIf=\"!isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\n viewBox=\"0 0 16 6\" fill=\"none\">\n <path d=\"M1 1L5 5L9 1\" stroke=\"#071437\" stroke-width=\"1\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <svg *ngIf=\"isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\n viewBox=\"0 0 16 6\" fill=\"none\">\n <path d=\"M1 5L5 1L9 5\" stroke=\"#1b84ff\" stroke-width=\"1\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n </div>\n </button>\n <!-- new view while not in folder view view -->\n <div *ngIf=\"!folderView\" class=\"header-row\">\n <span *ngIf=\"backnav && !imageFlow\" class=\"cursor-pointer\" (click)=\"backToFootfall()\">\n <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g filter=\"url(#filter0_d_2585_7036)\">\n <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\n <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\n <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\n filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\n <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\n values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\n <feOffset dy=\"1\" />\n <feGaussianBlur stdDeviation=\"1\" />\n <feColorMatrix type=\"matrix\"\n values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\n <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\n result=\"effect1_dropShadow_2585_7036\" />\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\n result=\"shape\" />\n </filter>\n </defs>\n </svg>\n </span>\n <!-- back from image flow -->\n <span *ngIf=\"imageFlow\" class=\"cursor-pointer\" (click)=\"backToFootfall1()\">\n <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g filter=\"url(#filter0_d_2585_7036)\">\n <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\n <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\n <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\n filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\n <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\n values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\n <feOffset dy=\"1\" />\n <feGaussianBlur stdDeviation=\"1\" />\n <feColorMatrix type=\"matrix\"\n values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\n <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\n result=\"effect1_dropShadow_2585_7036\" />\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\n result=\"shape\" />\n </filter>\n </defs>\n </svg>\n </span>\n <span class=\"img-direc\">Image Directory | {{folderDate | date:'dd MMM, yyyy'}}</span>\n <button *ngIf=\"!folderView\" class=\"mainheading-1 pb-0 custom-accordion-header\"\n (click)=\"toggleAccordion()\">\n <span class=\"divider\"></span>\n <span class=\"accordion-arrow\">\n <!-- Down arrow for collapsed state, up arrow for expanded state -->\n <svg *ngIf=\"!isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\n viewBox=\"0 0 16 6\" fill=\"none\">\n <path d=\"M1 1L5 5L9 1\" stroke=\"#071437\" stroke-width=\"1\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <svg *ngIf=\"isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\n viewBox=\"0 0 16 6\" fill=\"none\">\n <path d=\"M1 5L5 1L9 5\" stroke=\"#1b84ff\" stroke-width=\"1\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <section *ngIf=\"isAccordionExpanded\">\n\n <div *ngIf=\"folderView\" class=\"card-body px-0\">\n <div class=\"date-list-container\">\n <div class=\"date-list-scroll\">\n <div class=\"date-card\" *ngFor=\"let obj of dateArray; let i = index\"\n [ngClass]=\"{'date-card-active': i === selectIndex}\" (click)=\"getimages(i, obj)\">\n <div class=\"date-card-header\">\n <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\" class=\"calendar-icon\">\n <path\n d=\"M12.6667 2.66667H12V2C12 1.63181 11.7015 1.33333 11.3333 1.33333C10.9651 1.33333 10.6667 1.63181 10.6667 2V2.66667H5.33333V2C5.33333 1.63181 5.03486 1.33333 4.66667 1.33333C4.29848 1.33333 4 1.63181 4 2V2.66667H3.33333C2.59695 2.66667 2 3.26362 2 4V13.3333C2 14.0697 2.59695 14.6667 3.33333 14.6667H12.6667C13.403 14.6667 14 14.0697 14 13.3333V4C14 3.26362 13.403 2.66667 12.6667 2.66667ZM12.6667 13.3333H3.33333V6H12.6667V13.3333Z\"\n fill=\"#667085\" />\n </svg>\n <span class=\"date-text\">{{obj | date:'dd MMM'}}</span>\n <span *ngIf=\"cardDataMap[obj]?.ticketStatusLower as status\" class=\"badge ms-2\" [ngClass]=\"{\n 'badge-light-success': status === 'closed',\n 'badge-light-warning': status === 'raised',\n 'badge-light-default': status !== 'closed' && status !== 'raised'\n }\">\n {{ status === 'closed' ? 'Ticket closed' : (status === 'raised' ? 'Ticket raised' :\n (cardDataMap[obj]?.ticketStatus || '')) }}\n </span>\n </div>\n <div class=\"footfall-count\">{{ cardDataMap[obj]?.footfallCount || 0 }}</div>\n <div class=\"footfall-label\">Total footfall</div>\n </div>\n </div>\n </div>\n </div>\n\n\n\n <div *ngIf=\"!folderView\" class=\"card-body\">\n <section *ngIf=\"!imageFlow\">\n <div class=\"row\">\n <!-- Ticket Block Alert -->\n <div *ngIf=\"getSelectedDateCardData()?.raisedStatusEnabled === 'block'\" class=\"col-12 mb-3\">\n <div class=\"ticket-block-alert\">\n <div class=\"ticket-block-alert-content\">\n <div class=\"ticket-block-alert-icon\">\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <circle cx=\"12\" cy=\"12\" r=\"12\" fill=\"#F04438\" />\n <path d=\"M12 8V13\" stroke=\"white\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n </svg>\n </div>\n <div class=\"ticket-block-alert-text\">\n <div class=\"ticket-block-alert-title\">\n You cannot raise ticket for next {{ getSelectedDateCardData()?.noOfBlockedDays\n || '0' }} days\n </div>\n <div class=\"ticket-block-alert-description\">\n It looks like you have achieved 95% accuracy for the three tickets raised this\n month. This limits you from raising more tickets to avoid redundancy.\n </div>\n <div class=\"ticket-block-alert-action\">\n If you still want to raise tickets, <span class=\"ticket-block-alert-link\"\n (click)=\"requestReset()\">send request</span> to reset.\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- Ticket Request Success Alert -->\n <div *ngIf=\"getSelectedDateCardData()?.raisedStatusEnabled === 'request'\" class=\"col-12 mb-3\">\n <div class=\"ticket-request-alert\">\n <div class=\"ticket-request-alert-content\">\n <div class=\"ticket-request-alert-icon\">\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M2 21L23 12L2 3V10L17 12L2 14V21Z\" fill=\"#10B981\" />\n </svg>\n </div>\n <div class=\"ticket-request-alert-text\">\n <div class=\"ticket-request-alert-title\">\n Reset Request Sent\n </div>\n <div class=\"ticket-request-alert-description\">\n Your request to enable ticket raising has been submitted. You'll be notified\n once it's approved. Please ensure future ticket accuracy remains within the 95%\n threshold.\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- footfall trends feature -->\n <ng-container *ngTemplateOutlet=\"footfallTrendsTemplate\"></ng-container>\n <ng-container *ngTemplateOutlet=\"ticketStatusTemplate\"></ng-container>\n <span class=\"divider\"></span>\n <!-- footfall trends feature end -->\n <div class=\"d-flex flex-shrink-0 mt-3 justify-content-start align-items-center px-0\">\n <!-- <span *ngIf=\"backnav\" class=\"cursor-pointer\" (click)=\"backToFootfall()\">\n <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <g filter=\"url(#filter0_d_2585_7036)\">\n <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\n <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\n <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\n filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\n <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\n values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\n <feOffset dy=\"1\" />\n <feGaussianBlur stdDeviation=\"1\" />\n <feColorMatrix type=\"matrix\"\n values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\n <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\n result=\"effect1_dropShadow_2585_7036\" />\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\n result=\"shape\" />\n </filter>\n </defs>\n </svg>\n </span> -->\n <!-- <span class=\"img-direc ms-2 mt-1\">{{folderDate | date:'dd MMM, yyyy'}}\n <span class=\"badge badge-light-warning mx-2\"\n *ngIf=\"!getTicketStatuses().includes('closed') && getTicketStatuses().includes('open')\">\n Ticket Raised\n </span>\n <span class=\"badge badge-light-success mx-2\"\n *ngIf=\"getTicketStatuses().includes('closed')\">Ticket Closed</span>\n\n </span> -->\n <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\"\n class=\"ms-auto text-end\">\n <button [disabled]=\"!canEnableButton()\" class=\"btn btn-primary\" type=\"button\"\n (click)=\"Raised()\">\n Raise ticket\n </button>\n </div>\n </div>\n <div *ngIf=\"!folderView\" class=\"d-flex flex-wrap align-items-center justify-content-between w-100 my-2 gap-3\">\n <div class=\"nav-group bg-white border-1 btn-group w-auto\">\n <ng-container *ngIf=\"!(countData?.length > 0)\">\n \n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'footfall' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('footfall')\">\n Total Footfall\n <span\n [ngClass]=\"type === 'footfall' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.footfallCount || 0 }}\n </span>\n </button>\n \n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('non-tagging')\">\n Non-tags\n <span\n [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.nonTags || 0 }}\n </span>\n </button>\n \n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'duplicate' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('duplicate')\">\n Duplicated\n <span\n [ngClass]=\"type === 'duplicate' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.duplicate || 0 }}\n </span>\n </button>\n \n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'employee' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('employee')\">\n Employee/Staff\n <span\n [ngClass]=\"type === 'employee' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.employee || 0 }}\n </span>\n </button>\n <button class=\"btn btn-outline px-6 py-3\" [ngClass]=\"type === 'junk' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('junk')\">\n Junk\n <span\n [ngClass]=\"type === 'junk' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\n {{ countData?.junk || 0 }}\n </span>\n </button>\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'house-keeping' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('house-keeping')\">\n House Keeping\n <span\n [ngClass]=\"type === 'house-keeping' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\n {{ countData?.housekeeping || 0 }}\n </span>\n </button>\n \n \n </ng-container>\n \n </div>\n \n <div class=\"btn-group view-toggle ms-auto\" role=\"group\" aria-label=\"Toggle view\">\n <button type=\"button\" class=\"btn btn-outline px-3 py-2\" [ngClass]=\"{'active': viewMode === 'grid'}\"\n (click)=\"setViewMode('grid')\" aria-label=\"Grid view\">\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"3\" y=\"3\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n [attr.fill]=\"viewMode === 'grid' ? '#EAF8FF' : 'none'\"></rect>\n <rect x=\"11\" y=\"3\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n [attr.fill]=\"viewMode === 'grid' ? '#EAF8FF' : 'none'\"></rect>\n <rect x=\"3\" y=\"11\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n [attr.fill]=\"viewMode === 'grid' ? '#EAF8FF' : 'none'\"></rect>\n <rect x=\"11\" y=\"11\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n [attr.fill]=\"viewMode === 'grid' ? '#EAF8FF' : 'none'\"></rect>\n </svg>\n </button>\n <button type=\"button\" class=\"btn btn-outline px-3 py-2\" [ngClass]=\"{'active': viewMode === 'list'}\"\n (click)=\"setViewMode('list')\" aria-label=\"List view\">\n <svg width=\"20\" height=\"18\" viewBox=\"0 0 20 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"2\" y=\"3\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n [attr.fill]=\"viewMode === 'list' ? '#EAF8FF' : 'none'\"></rect>\n <rect x=\"8\" y=\"4.5\" width=\"10\" height=\"1.5\" rx=\"0.75\" fill=\"#475467\"></rect>\n <rect x=\"8\" y=\"12.5\" width=\"10\" height=\"1.5\" rx=\"0.75\" fill=\"#475467\"></rect>\n <rect x=\"2\" y=\"11\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n [attr.fill]=\"viewMode === 'list' ? '#EAF8FF' : 'none'\"></rect>\n </svg>\n </button>\n </div>\n </div>\n <ng-container *ngIf=\"!imageFlow\">\n <div *ngIf=\"type === 'footfall' && viewMode === 'grid'\" class=\"d-flex mt-2 mb-2 w-100 overflow-x px-0\">\n <div class=\"col text-nowrap\" *ngFor=\"let obj of objectsArray\">\n <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\n <li class=\"nav-item cursor-pointer\">\n <a (click)=\"selectedTimes(obj.timeRange)\"\n [ngClass]=\"selectedTime === obj?.timeRange ? 'active' : ''\"\n class=\"nav-link cursor-pointer no-border mx-3 mb-2\">\n {{obj?.timeRange}}<span class=\"mx-2\"\n [ngClass]=\"selectedTime === obj?.timeRange ? 'badge-num-primary' :'badge-num-muted'\">\n {{ obj?.count ? obj?.count : 0 }}\n </span>\n </a>\n </li>\n </ul>\n </div>\n </div>\n </ng-container>\n\n <div *ngIf=\"loading\" class=\"row loader d-flex justify-content-center align-items-center\">\n <div class=\"shimmer\">\n <div class=\"wrapper\">\n <div class=\"stroke animate title\"></div>\n <div class=\"stroke animate link\"></div>\n <div class=\"stroke animate description\"></div>\n </div>\n </div>\n <div class=\"shimmer\">\n <div class=\"wrapper\">\n <div class=\"stroke animate title\"></div>\n <div class=\"stroke animate link\"></div>\n <div class=\"stroke animate description\"></div>\n </div>\n </div>\n </div>\n <div *ngIf=\"noData\" class=\"row\">\n\n <div class=\"col-lg-12 mb-3\">\n\n <div class=\"card-body d-flex justify-content-center align-items-center flex-column \" style=\"margin: 64px;border-radius: 8px;\nbackground: var(--Gray-50, #F9FAFB);\">\n <svg width=\"94\" height=\"94\" viewBox=\"0 0 94 94\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"7\" y=\"7\" width=\"80\" height=\"80\" rx=\"40\" fill=\"#DAF1FF\" />\n <rect x=\"7\" y=\"7\" width=\"80\" height=\"80\" rx=\"40\" stroke=\"#EAF8FF\"\n stroke-width=\"13.3333\" />\n <path\n d=\"M35.332 51.9999H33.6654C32.7813 51.9999 31.9335 51.6487 31.3083 51.0236C30.6832 50.3985 30.332 49.5506 30.332 48.6666V33.6666C30.332 32.7825 30.6832 31.9347 31.3083 31.3096C31.9335 30.6844 32.7813 30.3333 33.6654 30.3333H48.6654C49.5494 30.3333 50.3973 30.6844 51.0224 31.3096C51.6475 31.9347 51.9987 32.7825 51.9987 33.6666V35.3333M45.332 41.9999H60.332C62.173 41.9999 63.6654 43.4923 63.6654 45.3333V60.3333C63.6654 62.1742 62.173 63.6666 60.332 63.6666H45.332C43.4911 63.6666 41.9987 62.1742 41.9987 60.3333V45.3333C41.9987 43.4923 43.4911 41.9999 45.332 41.9999Z\"\n stroke=\"#00A3FF\" stroke-width=\"4\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <div class=\"nodata-title my-3\">\n {{ noDataMessages[type?.toLowerCase()] || 'No data found' }}\n </div>\n\n </div>\n </div>\n\n </div>\n\n\n <!-- Split-screen layout (only shown after clicking an image) -->\n <div class=\"split-screen-container\" *ngIf=\"splitScreenEnabled && !noData && !loading\">\n <!-- Left Panel: Thumbnail List + Related Images -->\n <div class=\"left-panel\">\n <!-- Main Images List (hidden when duplicate is selected) -->\n <ng-container *ngIf=\"selectedRadioType !== 'duplicate'\">\n <div class=\"thumbnail-list-section\" *ngFor=\"let group of listViewGroups\">\n <div class=\"time-range-header\">\n <span class=\"time-range-title\">{{ group?.timeRange }}</span>\n <span class=\"time-range-count\">#{{ group?.data?.length || 0 }}</span>\n </div>\n <div class=\"thumbnail-grid\">\n <div class=\"thumbnail-item\" *ngFor=\"let obj of group?.data\"\n [ngClass]=\"{'selected': selectImageArray?.templd === obj?.templd}\"\n (click)=\"selectImageForSplitView(obj)\">\n <img class=\"thumbnail-image\" [src]=\"imageUrl + obj?.filePath\"\n (error)=\"obj.filePath = null\" alt=\"\" *ngIf=\"obj?.filePath\" />\n <div *ngIf=\"!obj?.filePath\" class=\"no-preview\"\n style=\"height: 120px; padding: 20px;\">\n <span style=\"color: #667085; font-size: 11px;\">No preview</span>\n </div>\n <div class=\"thumbnail-info\">\n <div class=\"tango-id\">Tango ID: {{ obj?.templd }}</div>\n <div class=\"entry-time\">Entry Time: {{ obj?.entryTme || obj?.entryTime\n }}</div>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n\n <!-- Related Images Section (ONLY shown when duplicate is selected) -->\n <div class=\"thumbnail-list-section\"\n *ngIf=\"selectedRadioType === 'duplicate' && remainingImagesGroups && remainingImagesGroups.length > 0\">\n <!-- <div class=\"time-range-header\">\n <span class=\"time-range-title\">Select related images</span>\n </div> -->\n <div class=\"thumbnail-list-section\" *ngFor=\"let group of remainingImagesGroups\">\n <div class=\"time-range-header\" style=\"margin-top: 16px;\">\n <span class=\"time-range-title\">{{ group?.timeRange }}</span>\n <span class=\"time-range-count\">#{{ group?.data?.length || 0 }}</span>\n </div>\n <div class=\"thumbnail-grid\">\n <div class=\"thumbnail-item\" *ngFor=\"let obj of group?.data\"\n [ngClass]=\"{'selected': obj.selected}\">\n <div class=\"position-relative\">\n <input *ngIf=\"!revopsTypeValue && selectedRadioType === 'duplicate'\"\n type=\"checkbox\" [checked]=\"obj.selected\"\n class=\"position-absolute absolute form-check-input cursor-pointer\"\n style=\"top: 5px; right: 5px; z-index: 2;\"\n (change)=\"onImageCheckboxChange($event, obj, 'duplicate')\"\n (click)=\"$event.stopPropagation()\"\n [disabled]=\"obj.duplicateImagePath?.length > 0\" />\n <img class=\"thumbnail-image cursor-pointer\"\n [src]=\"imageUrl + obj?.filePath\" (error)=\"obj.filePath = null\"\n alt=\"\" *ngIf=\"obj?.filePath\"\n (click)=\"handleImageClick($event, obj)\" />\n <div *ngIf=\"!obj?.filePath\" class=\"no-preview cursor-pointer\"\n style=\"height: 120px; padding: 20px;\"\n (click)=\"handleImageClick($event, obj)\">\n <span style=\"color: #667085; font-size: 11px;\">No preview</span>\n </div>\n <div class=\"thumbnail-info\">\n <div class=\"tango-id\">Tango ID: {{ obj?.templd || obj?.tempId }}\n </div>\n <div class=\"entry-time\">Entry Time: {{ obj?.entryTme ||\n obj?.entryTime }}</div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Right Panel: Selected Image Details -->\n <div class=\"right-panel\" *ngIf=\"selectImageArray\">\n <ng-container\n *ngTemplateOutlet=\"imageDetailView; context: { $implicit: selectImageArray }\"></ng-container>\n </div>\n <div class=\"right-panel\" *ngIf=\"!selectImageArray\"\n style=\"display: flex; align-items: center; justify-content: center; color: var(--Gray-500, #667085);\">\n <div style=\"text-align: center;\">\n <p style=\"font-size: 16px; font-weight: 500;\">Select an image to view details</p>\n </div>\n </div>\n </div>\n\n <!-- Image Detail View Template for Split-Screen Right Panel -->\n <ng-template #imageDetailView let-obj>\n <div class=\"border-gray p-3 mb-3\">\n <div class=\"position-relative\">\n <img class=\"img-src1\" [src]=\"imageUrl + obj?.filePath\" alt=\"\" *ngIf=\"obj?.filePath\" />\n <!-- Zoom Icon -->\n <div class=\"zoom-icon-button\" (click)=\"openImageZoomModal(imageUrl, obj)\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\"\n fill=\"none\">\n <path\n d=\"M18.3333 18.3333L15 15M16.6667 9.16667C16.6667 13.3067 13.3067 16.6667 9.16667 16.6667C5.02667 16.6667 1.66667 13.3067 1.66667 9.16667C1.66667 5.02667 5.02667 1.66667 9.16667 1.66667C13.3067 1.66667 16.6667 5.02667 16.6667 9.16667Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n <path d=\"M9.16667 6.66667V11.6667M6.66667 9.16667H11.6667\" stroke=\"#475467\"\n stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </div>\n <div *ngIf=\"!obj?.filePath\" class=\"no-preview\" style=\"height: 375px;\">\n <span class=\"mb-5\">\n <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"Group\">\n <path id=\"Vector\"\n d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n <path id=\"Vector_2\"\n d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n </svg>\n </span>\n <span class=\"header mb-5 text-center\">Preview not available</span>\n <span class=\"description mb-5 text-center\">The selected camera is not available at\n the moment.</span>\n </div>\n </div>\n <div class=\"row px-2 mb-2 mt-3\">\n <div class=\"col-md-7\">\n <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd}}\n <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\">\n <svg style=\"width: 20px; height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\"\n width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n fill=\"#12B76A\" />\n </svg>\n </span>\n <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\">\n <svg style=\"width: 20px; height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\"\n width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n <g clip-path=\"url(#clip0_1428_59484)\">\n <path\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n fill=\"#FEE4E2\" />\n <path\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n stroke=\"#D92D20\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_1428_59484\">\n <rect width=\"12\" height=\"12\" fill=\"white\"\n transform=\"translate(0.599609 0.5)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n </div>\n <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme || obj?.entryTime}}</div>\n </div>\n <div class=\"col-md-5 text-end py-3\">\n <span *ngIf=\"obj?.revopsType ==='non-tagging'\" ngbTooltip=\"Yet to tag the customer\"\n placement=\"top\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\n viewBox=\"0 0 19 18\" fill=\"none\">\n <path\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='duplicate'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='employee'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\n viewBox=\"0 0 21 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='junk'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\n viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n </div>\n </div>\n </div>\n <div class=\"border-gray p-3\">\n <div class=\"row mb-3\">\n <div class=\"col-md-6 title-type\">Select non-shopper type</div>\n <div class=\"col-md-6 text-end\"\n *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\n <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\" class=\"mb-3 text-end d-inline-flex align-items-center gap-2\">\n <!-- Clear Tag Button (visible when Edit button OR Save/Cancel buttons are visible) -->\n <button\n *ngIf=\"!revopsTypeValue || (revopsTypeValue && editBtnShow)\"\n [disabled]=\"(selectedRadioType === undefined || selectedRadioType === '') || (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\"\n class=\"btn btn-clear-tag d-inline-flex align-items-center justify-content-center\" type=\"button\"\n (click)=\"clearValue()\">\n <svg width=\"49\" height=\"49\" viewBox=\"0 0 49 49\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g filter=\"url(#filter0_d_516_96841)\">\n <rect x=\"2.16797\" y=\"1.08447\" width=\"44.0342\" height=\"44.0284\" rx=\"8.67445\" fill=\"#FEF3F2\" />\n <rect x=\"2.71012\" y=\"1.62663\" width=\"42.9499\" height=\"42.9441\" rx=\"8.13229\" stroke=\"#FEF3F2\"\n stroke-width=\"1.08431\" />\n <path\n d=\"M33.4893 21.3613L33.4912 21.3643C34.0533 21.9297 34.369 22.6949 34.3691 23.4922C34.3691 24.2895 34.0533 25.0546 33.4912 25.6201L26.7256 32.3857C26.4454 32.6661 26.1122 32.8882 25.7461 33.04C25.3798 33.1919 24.9873 33.2705 24.5908 33.2705C24.1942 33.2705 23.801 33.1919 23.4346 33.04C23.0686 32.8883 22.7361 32.6659 22.4561 32.3857L20.7676 30.6992L22.3682 29.0986L24.0557 30.7842L24.0566 30.7852C24.1267 30.8553 24.2102 30.9112 24.3018 30.9492C24.3933 30.9872 24.4917 31.0068 24.5908 31.0068C24.6899 31.0068 24.7883 30.9872 24.8799 30.9492C24.9713 30.9113 25.0541 30.8552 25.124 30.7852H25.125L31.8877 24.0215C32.0267 23.8804 32.1055 23.6903 32.1055 23.4922C32.1054 23.2941 32.0267 23.1039 31.8877 22.9629L30.1963 21.2715L31.7979 19.6699L33.4893 21.3613ZM24.6982 12.9336C24.9571 12.9594 25.2011 13.0733 25.3867 13.2588L30.1973 18.0693L28.5957 19.6709L24.1162 15.1914H16.2852V23.0225L20.7666 27.499L19.166 29.0996L14.3535 24.293C14.1411 24.0807 14.0215 23.7925 14.0215 23.4922V14.0596C14.0217 13.4346 14.5283 12.9277 15.1533 12.9277H24.5859L24.6982 12.9336ZM19.8789 17.6436C20.5038 17.6436 21.0103 18.1506 21.0107 18.7754C21.0107 19.4005 20.504 19.9082 19.8789 19.9082H19.8691C19.2442 19.908 18.7373 19.4004 18.7373 18.7754C18.7378 18.1508 19.2445 17.6438 19.8691 17.6436H19.8789Z\"\n fill=\"#B42318\" />\n <path d=\"M33.1699 14.0845L15.1699 32.0845\" stroke=\"#B42318\" stroke-width=\"2\" stroke-linecap=\"round\" />\n </g>\n <defs>\n <filter id=\"filter0_d_516_96841\" x=\"-0.000643253\" y=\"0.000166655\" width=\"48.3724\" height=\"48.3655\"\n filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\n <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\"\n result=\"hardAlpha\" />\n <feOffset dy=\"1.08431\" />\n <feGaussianBlur stdDeviation=\"1.08431\" />\n <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\n <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_516_96841\" />\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_516_96841\" result=\"shape\" />\n </filter>\n </defs>\n </svg>\n </button>\n <!-- Cancel and Save Buttons (when !revopsTypeValue) -->\n <div *ngIf=\"!revopsTypeValue\">\n <button class=\"btn btn-outline me-2\" (click)=\"cancel()\">Cancel</button>\n <button class=\"btn btn-primary\" id=\"alert-toast\"\n (click)=\"save(selectedType)\"\n [disabled]=\"(selectedRadioType === undefined || selectedRadioType === '') || (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\">Save</button>\n </div>\n <!-- Edit Button (when revopsTypeValue && editBtnShow) -->\n <div *ngIf=\"revopsTypeValue && editBtnShow\">\n <button\n class=\"btn btn-outline me-2\" (click)=\"editValue()\">\n <span class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\"\n height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M14.6554 1.71047C14.8927 1.47315 15.1745 1.2849 15.4845 1.15646C15.7946 1.02802 16.1269 0.961914 16.4626 0.961914C16.7982 0.961914 17.1305 1.02802 17.4406 1.15646C17.7507 1.2849 18.0324 1.47315 18.2697 1.71047C18.5071 1.94779 18.6953 2.22953 18.8238 2.53961C18.9522 2.84969 19.0183 3.18202 19.0183 3.51765C19.0183 3.85327 18.9522 4.18561 18.8238 4.49568C18.6953 4.80576 18.5071 5.0875 18.2697 5.32482L6.0713 17.5233L1.10156 18.8786L2.45695 13.9089L14.6554 1.71047Z\"\n stroke=\"#344054\" stroke-width=\"1.81079\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg></span>Edit\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"duplicate\"\n id=\"duplicate-split\" [(ngModel)]=\"selectedType\" [value]=\"'duplicate'\"\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n <label class=\"form-check-label\" for=\"duplicate-split\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg></span>\n <span class=\"ms-5 tag-class\">Duplicate</span>\n </label>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"employee\"\n id=\"employee-split\" [(ngModel)]=\"selectedType\" [value]=\"'employee'\"\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n <label class=\"form-check-label\" for=\"employee-split\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg></span>\n <span class=\"ms-5 tag-class\">Employee/Staff</span>\n </label>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"house-keeping\"\n id=\"house-keeping-split\" [(ngModel)]=\"selectedType\" [value]=\"'house-keeping'\"\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n <label class=\"form-check-label\" for=\"house-keeping-split\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\n viewBox=\"0 0 21 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg></span>\n <span class=\"ms-5 tag-class\">House Keeping</span>\n </label>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"junk\" id=\"junk-split\"\n [(ngModel)]=\"selectedType\" [value]=\"'junk'\" (change)=\"onRadioChange(selectedType)\"\n [disabled]=\"users?.role ==='user' && users?.userType ==='client' || revopsTypeValue\">\n <label class=\"form-check-label\" for=\"junk-split\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\n viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg></span>\n <span class=\"ms-5 tag-class\">Junk</span>\n </label>\n </div>\n <div class=\"mt-3\">\n <label class=\"form-label\">Remarks (Optional)</label>\n <textarea class=\"form-control\" rows=\"3\" placeholder=\"Comment here\"\n [(ngModel)]=\"userComment\"></textarea>\n </div>\n </div>\n </ng-template>\n\n <!-- Grid/List View (shown when split-screen is not enabled) -->\n <div class=\"row px-0 img-traffic contain high-400px scroll-y\"\n *ngIf=\"viewMode === 'grid' && !noData && !loading && !splitScreenEnabled\">\n <ng-container *ngFor=\"let obj of imagesArrayData\">\n <ng-container *ngTemplateOutlet=\"imageCard; context: { $implicit: obj }\"></ng-container>\n </ng-container>\n </div>\n\n <div class=\"list-view-wrapper\"\n *ngIf=\"viewMode === 'list' && !noData && !loading && !splitScreenEnabled\">\n <div class=\"list-group mb-5\" *ngFor=\"let group of listViewGroups\">\n <div class=\"list-group-header d-flex align-items-center mb-3\">\n <div class=\"group-title\">{{ group?.timeRange }}</div>\n <span class=\"group-count badge badge-light-default ms-2\">\n #{{ group?.data?.length || 0 }}\n </span>\n </div>\n <div class=\"row gx-4 list-group-row\">\n <ng-container *ngFor=\"let obj of group?.data\">\n <ng-container\n *ngTemplateOutlet=\"imageCard; context: { $implicit: obj }\"></ng-container>\n </ng-container>\n </div>\n </div>\n </div>\n\n <ng-template #imageCard let-obj>\n <div *ngIf=\"type !== 'duplicate' || (type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\"\n class=\"col-md-3 border-gray mx-2 p-2 mt-5\">\n <!-- Condition: Only show if not duplicate OR duplicate with non-empty duplicateImagePath -->\n <ng-container>\n <img class=\"img-src cursor-pointer\" [src]=\"imageUrl + obj?.filePath\" (error)=\"obj.filePath = null\" alt=\"\"\n (click)=\"selectImageForSplitView(obj)\" />\n </ng-container>\n \n <div *ngIf=\"!obj?.filePath\" class=\"no-preview\">\n <span class=\"mb-5\">\n <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"Group\">\n <path id=\"Vector\" d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path id=\"Vector_2\"\n d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n </svg>\n \n </span>\n <span class=\"header mb-5 text-center\">Preview not available</span>\n <span class=\"description mb-5 text-center\">The selected camera is not available at\n the\n moment.</span>\n </div>\n <div *ngIf=\"type !== 'duplicate' || (type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\"\n class=\"row px-2 mb-2\">\n <div class=\"col-md-7\">\n <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd}} <span\n *ngIf=\"(type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\"\n class=\"mx-2 badge badge-light-primary\">{{obj.duplicateImagePath?.length}}\n </span>\n <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\">\n <svg style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\"\n height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n fill=\"#12B76A\" />\n </svg>\n </span>\n <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\">\n <svg style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\"\n height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n <g clip-path=\"url(#clip0_1428_59484)\">\n <path\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n fill=\"#FEE4E2\" />\n <path\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n stroke=\"#D92D20\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_1428_59484\">\n <rect width=\"12\" height=\"12\" fill=\"white\" transform=\"translate(0.599609 0.5)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n </div>\n <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme}}</div>\n </div>\n <div class=\"col-md-5 text-end py-3\">\n <span *ngIf=\"obj?.revopsType ==='non-tagging'\" ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 19 18\" fill=\"none\">\n <path\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='duplicate'\">\n <svg *ngIf=\"obj?.isParent\" width=\"20\" height=\"21\" viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g clip-path=\"url(#clip0_568_103657)\">\n <path\n d=\"M2.08398 6.25001H1.66732C1.4463 6.25001 1.23434 6.16221 1.07806 6.00593C0.921782 5.84965 0.833984 5.63769 0.833984 5.41668V1.66668C0.833984 1.44566 0.921782 1.2337 1.07806 1.07742C1.23434 0.921141 1.4463 0.833344 1.66732 0.833344H5.41732C5.63833 0.833344 5.85029 0.921141 6.00657 1.07742C6.16285 1.2337 6.25065 1.44566 6.25065 1.66668V2.08334M4.58398 3.75001H8.33398C8.79422 3.75001 9.16732 4.12311 9.16732 4.58334V8.33334C9.16732 8.79358 8.79422 9.16668 8.33398 9.16668H4.58398C4.12375 9.16668 3.75065 8.79358 3.75065 8.33334V4.58334C3.75065 4.12311 4.12375 3.75001 4.58398 3.75001Z\"\n stroke=\"#475467\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n <rect x=\"4\" y=\"4\" width=\"5\" height=\"5\" fill=\"#475467\" />\n <defs>\n <clipPath id=\"clip0_568_103657\">\n <rect width=\"10\" height=\"10\" fill=\"white\" />\n </clipPath>\n </defs>\n </svg>\n <svg *ngIf=\"!obj?.isParent\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='employee'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 21 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\" transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='junk'\">\n \n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </span>\n </div>\n </div>\n </div>\n </ng-template>\n\n </div>\n </section>\n\n <!-- full image View -->\n <section *ngIf=\"imageFlow\">\n <div class=\"row\">\n <!-- Ticket Block Alert -->\n <div *ngIf=\"getSelectedDateCardData()?.raisedStatusEnabled === 'block'\" class=\"col-12 mb-3\">\n <div class=\"ticket-block-alert\">\n <div class=\"ticket-block-alert-content\">\n <div class=\"ticket-block-alert-icon\">\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <circle cx=\"12\" cy=\"12\" r=\"12\" fill=\"#F04438\" />\n <path d=\"M12 8V13\" stroke=\"white\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n </svg>\n </div>\n <div class=\"ticket-block-alert-text\">\n <div class=\"ticket-block-alert-title\">\n You cannot raise ticket for next {{ getSelectedDateCardData()?.noOfBlockedDays\n || '0' }} days\n </div>\n <div class=\"ticket-block-alert-description\">\n It looks like you have achieved 95% accuracy for the three tickets raised this\n month. This limits you from raising more tickets to avoid redundancy.\n </div>\n <div class=\"ticket-block-alert-action\">\n If you still want to raise tickets, <span class=\"ticket-block-alert-link\"\n (click)=\"requestReset()\">send request</span> to reset.\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- Ticket Request Success Alert -->\n <div *ngIf=\"getSelectedDateCardData()?.raisedStatusEnabled === 'request'\" class=\"col-12 mb-3\">\n <div class=\"ticket-request-alert\">\n <div class=\"ticket-request-alert-content\">\n <div class=\"ticket-request-alert-icon\">\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M2 21L23 12L2 3V10L17 12L2 14V21Z\" fill=\"#10B981\" />\n </svg>\n </div>\n <div class=\"ticket-request-alert-text\">\n <div class=\"ticket-request-alert-title\">\n Reset Request Sent\n </div>\n <div class=\"ticket-request-alert-description\">\n Your request to enable ticket raising has been submitted. You'll be notified\n once it's approved. Please ensure future ticket accuracy remains within the 95%\n threshold.\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"d-flex mt-2 mb-2 w-100 overflow-x px-0\">\n <ng-container *ngTemplateOutlet=\"footfallTrendsTemplate\"></ng-container>\n </div>\n <ng-container *ngTemplateOutlet=\"ticketStatusTemplate\"></ng-container>\n <span class=\"divider\"></span>\n <div class=\"d-flex flex-shrink-0 mt-3 justify-content-start align-items-center px-0\">\n <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\"\n class=\"ms-auto text-end\">\n\n <button [disabled]=\"!canEnableButton()\" class=\"btn btn-primary\" type=\"button\"\n (click)=\"Raised()\">\n Raise ticket\n </button>\n </div>\n </div>\n <div class=\"nav-group bg-white border-1 btn-group w-auto\">\n <ng-container *ngIf=\"!(countData?.length > 0)\">\n\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'footfall' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('footfall')\">\n Total Footfall\n <span\n [ngClass]=\"type === 'footfall' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.footfallCount || 0 }}\n </span>\n </button>\n\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('non-tagging')\">\n Non-tags\n <span\n [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.nonTags || 0 }}\n </span>\n </button>\n\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'duplicate' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('duplicate')\">\n Duplicated\n <span\n [ngClass]=\"type === 'duplicate' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.duplicate || 0 }}\n </span>\n </button>\n\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'employee' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('employee')\">\n Employee/Staff\n <span\n [ngClass]=\"type === 'employee' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.employee || 0 }}\n </span>\n </button>\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'junk' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('junk')\">\n Junk\n <span\n [ngClass]=\"type === 'junk' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\n {{ countData?.junk || 0 }}\n </span>\n </button>\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'house-keeping' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('house-keeping')\">\n House Keeping\n <span\n [ngClass]=\"type === 'house-keeping' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\n {{ countData?.housekeeping || 0 }}\n </span>\n </button>\n\n </ng-container>\n\n </div>\n\n <div class=\"row mx-0 border-gray img-traffic\" *ngIf=\"!noData && !loading\">\n <div class=\"col-md-6 p-2 mb-2 mt-5\">\n <div class=\"position-relative border-gray p-2 \">\n <!-- Main Image -->\n <!-- <img class=\"img-src cursor-pointer h-450px\"\n (click)=\"selectedImageArray(imageUrl, selectImageArray)\"\n [src]=\"imageUrl + selectImageArray?.filePath\" appMagnifier alt=\"\"> -->\n <img class=\"img-src cursor-pointer h-450px\"\n (click)=\"selectedImageArray(imageUrl, selectImageArray)\"\n [src]=\"imageUrl + selectImageArray?.filePath\" alt=\"\">\n\n <!-- Right arrow button -->\n <div class=\"row px-2 mb-2\">\n <div class=\"col-md-7\">\n <div class=\"py-2 img-doc-time\">Tango ID : {{selectImageArray?.templd}}\n <span *ngIf=\"selectImageArray?.status ==='approved'\" class=\"ms-2\"><svg\n style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n fill=\"#12B76A\" />\n </svg></span>\n <span *ngIf=\"selectImageArray?.status ==='rejected'\" class=\"ms-2\"><svg\n style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n <g clip-path=\"url(#clip0_1428_59484)\">\n <path\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n fill=\"#FEE4E2\" />\n <path\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n stroke=\"#D92D20\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_1428_59484\">\n <rect width=\"12\" height=\"12\" fill=\"white\"\n transform=\"translate(0.599609 0.5)\" />\n </clipPath>\n </defs>\n </svg></span>\n </div>\n <div class=\"img-doc-value\">Entry Time : {{(tempModalImage ||\n selectImageArray)?.entryTme || (tempModalImage ||\n selectImageArray)?.entryTime}}</div>\n </div>\n <div class=\"col-md-5 text-end py-3\">\n <span *ngIf=\"(tempModalImage || selectImageArray)?.revopsType ==='non-tagging'\"\n ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\n viewBox=\"0 0 19 18\" fill=\"none\">\n <path\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n <span *ngIf=\"selectImageArray?.revopsType ==='duplicate'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"selectImageArray?.revopsType ==='employee'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"selectImageArray?.revopsType ==='house-keeping'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\n viewBox=\"0 0 21 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"col-md-6 p-2 mb-2 mt-5\">\n <div class=\"mx-2 \">\n <div class=\"row\">\n <div class=\"col-md-6 title-type\">\n Select non-shopper type\n </div>\n\n\n <section class=\"col-md-6 text-end\"\n *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\n\n <div *ngIf=\"!revopsTypeValue\" class=\"mb-5 text-end\" role=\"group\">\n <div\n *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\">\n\n <button [disabled]=\"\n (selectedRadioType === undefined || selectedRadioType === '') ||\n (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\n \" class=\"btn btn-default\" type=\"button\" (click)=\"clearValue()\">Clear</button>\n <button class=\"btn btn-outline me-2\" (click)=\"cancel()\">Cancel</button>\n <button class=\"btn btn-primary\" id=\"alert-toast\"\n (click)=\"save(selectedType)\" [disabled]=\"\n (selectedRadioType === undefined || selectedRadioType === '') ||\n (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\n \">\n Save\n </button>\n </div>\n </div>\n\n <div\n *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\n <ng-container *ngIf=\"editBtnShow\">\n <div *ngIf=\"revopsTypeValue\" class=\"mb-5 text-end\" role=\"group\">\n <button\n *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\"\n class=\"btn btn-outline me-2\" (click)=\"editValue()\"><span\n class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\"\n width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M14.6554 1.71047C14.8927 1.47315 15.1745 1.2849 15.4845 1.15646C15.7946 1.02802 16.1269 0.961914 16.4626 0.961914C16.7982 0.961914 17.1305 1.02802 17.4406 1.15646C17.7507 1.2849 18.0324 1.47315 18.2697 1.71047C18.5071 1.94779 18.6953 2.22953 18.8238 2.53961C18.9522 2.84969 19.0183 3.18202 19.0183 3.51765C19.0183 3.85327 18.9522 4.18561 18.8238 4.49568C18.6953 4.80576 18.5071 5.0875 18.2697 5.32482L6.0713 17.5233L1.10156 18.8786L2.45695 13.9089L14.6554 1.71047Z\"\n stroke=\"#344054\" stroke-width=\"1.81079\"\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg></span>Edit</button>\n\n </div>\n </ng-container>\n </div>\n </section>\n\n </div>\n\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"duplicate\"\n id=\"duplicate\" [(ngModel)]=\"selectedType\" [value]=\"'duplicate'\"\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n <label class=\"form-check-label\" for=\"duplicate\">\n <span class=\"ms-5\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span class=\"ms-5 tag-class\">Duplicate</span>\n </label>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"employee\"\n id=\"employee\" [(ngModel)]=\"selectedType\" [value]=\"'employee'\"\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n <label class=\"form-check-label\" for=\"employee\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\"\n height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg></span>\n <span class=\"ms-5 tag-class\">Employee/Staff</span>\n </label>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"house-keeping\"\n id=\"house-keeping\" [(ngModel)]=\"selectedType\" [value]=\"'house-keeping'\"\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n <label class=\"form-check-label\" for=\"house-keeping\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\"\n height=\"21\" viewBox=\"0 0 21 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg></span>\n <span class=\"ms-5 tag-class\"> House Keeping</span>\n </label>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"junk\" id=\"junk\"\n [(ngModel)]=\"selectedType\" [value]=\"'junk'\"\n (change)=\"onRadioChange(selectedType)\"\n [disabled]=\"users?.role ==='user' && this.users?.userType ==='client' || revopsTypeValue\">\n <label class=\"form-check-label\" for=\"junk\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\"\n height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg></span>\n <span class=\"ms-5 tag-class\"> Junk</span>\n </label>\n </div>\n </div>\n\n\n </div>\n </div>\n\n\n <div class=\"row px-0 img-traffic mt-3 high-400px scroll-y\">\n <div class=\"col-md-3 border-gray mx-2 p-2 mt-5\" *ngFor=\"let obj of remainingImageArray\">\n <div class=\"position-relative\">\n <input *ngIf=\"!revopsTypeValue && selectedRadioType === 'duplicate'\" type=\"checkbox\"\n [checked]=\"obj.selected\"\n class=\"position-absolute absolute form-check-input cursor-pointer\"\n (change)=\"onImageCheckboxChange($event, obj, 'duplicate')\"\n [disabled]=\"obj.duplicateImagePath?.length > 0\" />\n\n <img class=\"img-src\"\n [ngClass]=\"selectedRadioType !== 'duplicate' ? 'cursor-pointer' : 'cursor-pointer'\"\n [src]=\"imageUrl + obj?.filePath\" (error)=\"obj.filePath = null\" alt=\"\"\n (click)=\"handleImageClick($event, obj)\" />\n\n <div *ngIf=\"!obj?.filePath\" class=\"no-preview\">\n <span class=\"mb-5\">\n <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"Group\">\n <path id=\"Vector\"\n d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n <path id=\"Vector_2\"\n d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n </svg>\n\n </span>\n <span class=\"header mb-5 text-center\">Preview not available</span>\n <span class=\"description mb-5 text-center\">The selected camera is not available at\n the\n moment.</span>\n </div>\n <div class=\"row px-2 mb-2\">\n <div class=\"col-md-7\">\n <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd ? obj?.templd :\n obj?.tempId}}\n <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n fill=\"#12B76A\" />\n </svg></span>\n <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n <g clip-path=\"url(#clip0_1428_59484)\">\n <path\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n fill=\"#FEE4E2\" />\n <path\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n stroke=\"#D92D20\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_1428_59484\">\n <rect width=\"12\" height=\"12\" fill=\"white\"\n transform=\"translate(0.599609 0.5)\" />\n </clipPath>\n </defs>\n </svg></span>\n </div>\n <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme ? obj?.entryTme\n :obj?.entryTime}}</div>\n </div>\n <div class=\"col-md-5 text-end py-3\">\n <span *ngIf=\"obj?.revopsType ==='non-tagging'\"\n ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\n viewBox=\"0 0 19 18\" fill=\"none\">\n <path\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='duplicate'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='employee'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\n viewBox=\"0 0 21 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='junk'\">\n\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\n viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n </div>\n </section>\n </div>\n </section>\n</div>\n\n\n<ng-template #zoomPopup let-model>\n <div class=\"p-4 m-4\">\n <div class=\"modal-header border-0 p-0 w-100 flex-column align-items-start\">\n <span *ngIf=\"popupType === 'non-tagging'\" class=\"my-3\">\n\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\n <rect width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\n <g clip-path=\"url(#clip0_2088_98337)\">\n <path\n d=\"M29.1693 13.3333V18.3333M29.1693 18.3333H24.1693M29.1693 18.3333L25.3026 14.7C24.407 13.8039 23.299 13.1493 22.0819 12.7973C20.8649 12.4453 19.5785 12.4073 18.3428 12.6869C17.1072 12.9665 15.9624 13.5545 15.0155 14.3962C14.0685 15.2378 13.3502 16.3056 12.9276 17.5M10.8359 26.6666V21.6666M10.8359 21.6666H15.8359M10.8359 21.6666L14.7026 25.3C15.5982 26.1961 16.7062 26.8506 17.9233 27.2027C19.1403 27.5547 20.4267 27.5927 21.6624 27.3131C22.898 27.0335 24.0428 26.4455 24.9897 25.6038C25.9367 24.7621 26.655 23.6943 27.0776 22.5\"\n stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2088_98337\">\n <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(10 10)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <!-- Heading -->\n <h5 class=\"modal-title mb-2\">\n <span *ngIf=\"popupType === 'employee'\">Tagging as employee/staff </span>\n <span *ngIf=\"popupType === 'duplicate'\">Tagging as duplicates </span>\n <span *ngIf=\"popupType === 'house-keeping'\">Tagging as house keeping </span>\n <span *ngIf=\"popupType === 'non-tagging'\">Clear duplicates</span>\n <span *ngIf=\"popupType ==='junk'\">Tagging as junk</span>\n\n </h5>\n <p class=\"mb-3\">\n <span *ngIf=\"popupType === 'employee'\">Are you sure you want to tag this as employee/staff?</span>\n <span *ngIf=\"popupType === 'duplicate'\">Are you sure you want to tag this as duplicates? </span>\n <span *ngIf=\"popupType === 'house-keeping'\">Are you sure you want to tag this as house keeping? </span>\n <span *ngIf=\"popupType === 'non-tagging'\">This will remove tagged duplicates and move them to\n 'Non-tag'.</span>\n <span *ngIf=\"popupType ==='junk'\">Are you sure you want to tag this as junk?</span>\n\n </p>\n </div>\n\n <div class=\"w-100 mt-5 d-flex justify-content-end\">\n <button class=\"btn btn-outline me-2\" (click)=\"cancelSubmit()\">Cancel</button>\n <button *ngIf=\"popupType !== 'non-tagging'\" class=\"btn btn-primary\" (click)=\"submitValue(popupType)\">\n Yes, Tag\n </button>\n <button *ngIf=\"popupType === 'non-tagging'\" class=\"btn btn-primary\" (click)=\"submitValue(popupType)\">\n Yes, clear\n </button>\n </div>\n </div>\n</ng-template>\n\n\n<ng-template #raisedPopup let-model>\n <div class=\"p-4 m-4\">\n <div class=\"modal-header border-0 p-0 w-100 flex-column align-items-start\">\n <span class=\"my-3\">\n\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\n <rect width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\n <path\n d=\"M21.251 11.0806C21.7405 11.0699 22.2153 11.2487 22.5762 11.5796L23.4922 12.4204C23.8089 12.7097 23.893 13.1017 23.8652 13.4263V13.4272C23.836 13.7478 23.6954 14.0592 23.4785 14.2944C23.3699 14.413 23.2865 14.5525 23.2314 14.7036C23.1764 14.8548 23.1512 15.0155 23.1582 15.1763C23.1652 15.337 23.2035 15.4953 23.2715 15.6411C23.3394 15.7869 23.4362 15.9172 23.5547 16.0259C23.6733 16.1346 23.8117 16.2198 23.9629 16.2749C24.1141 16.33 24.2748 16.3541 24.4355 16.3472C24.5961 16.3402 24.7537 16.3017 24.8994 16.2339C25.0089 16.1829 25.1106 16.116 25.2002 16.0356L25.3701 15.8657C25.5759 15.6748 25.8385 15.5408 26.1152 15.4907C26.2972 15.4546 26.485 15.4617 26.6641 15.5103C26.8439 15.5591 27.0103 15.649 27.1494 15.7729L27.1514 15.7749L28.2598 16.7905C28.445 16.9605 28.5948 17.1658 28.7002 17.394C28.8056 17.6223 28.8648 17.8694 28.874 18.1206C28.8832 18.372 28.8423 18.6234 28.7539 18.8589C28.6655 19.0941 28.5316 19.3096 28.3594 19.4927L20.1113 28.2583C19.937 28.4434 19.7268 28.5912 19.4941 28.6938C19.2614 28.7965 19.0102 28.8522 18.7559 28.856C18.5016 28.8597 18.2493 28.8119 18.0137 28.7163C17.7779 28.6206 17.5636 28.4784 17.3838 28.2983L16.2539 27.1685C15.7511 26.6656 15.8832 25.9552 16.1514 25.5542L16.2061 25.4644C16.3241 25.2486 16.3742 25.0008 16.3496 24.7544C16.3214 24.4731 16.197 24.2102 15.9971 24.0103C15.7971 23.8103 15.5343 23.6859 15.2529 23.6577C14.9715 23.6297 14.6887 23.6995 14.4531 23.856H14.4521C14.0494 24.1222 13.3407 24.2552 12.8379 23.7515L11.6797 22.5933C11.5034 22.4169 11.364 22.2074 11.2686 21.9771C11.1731 21.7467 11.1231 21.4999 11.123 21.2505C11.123 21.001 11.1731 20.7535 11.2686 20.5229C11.364 20.2926 11.5034 20.0831 11.6797 19.9067L19.9492 11.6362C20.2954 11.2902 20.7616 11.0912 21.251 11.0806ZM21.2783 12.3804C21.1237 12.3838 20.9765 12.4468 20.8672 12.5562L12.5967 20.8257C12.5409 20.8814 12.497 20.9482 12.4668 21.021C12.4367 21.0938 12.4209 21.1717 12.4209 21.2505C12.4209 21.3292 12.4367 21.4073 12.4668 21.48C12.497 21.5528 12.541 21.6196 12.5967 21.6753L13.7061 22.7837L13.7314 22.772C14.2169 22.4485 14.7993 22.3035 15.3799 22.3608C15.9608 22.4183 16.5042 22.6747 16.917 23.0874C17.3298 23.5002 17.587 24.0436 17.6445 24.6245C17.702 25.2055 17.5565 25.7892 17.2324 26.2749L17.2305 26.2759C17.2261 26.2822 17.2226 26.2893 17.2197 26.2964L18.3018 27.3804C18.3585 27.4372 18.4266 27.482 18.501 27.5122C18.5755 27.5425 18.6559 27.5574 18.7363 27.5562C18.8166 27.5549 18.8963 27.5378 18.9697 27.5054C19.043 27.4729 19.1091 27.4261 19.1641 27.3677L27.4131 18.6021C27.4673 18.5442 27.5093 18.4761 27.5371 18.4019C27.5649 18.3276 27.5781 18.2487 27.5752 18.1694C27.5722 18.0902 27.5538 18.0119 27.5205 17.9399C27.4872 17.8679 27.4394 17.8032 27.3809 17.7495L26.3223 16.7778C26.2925 16.7885 26.2648 16.8053 26.2432 16.8286C26.0217 17.0788 25.7529 17.2827 25.4521 17.4282C25.15 17.5743 24.8214 17.6585 24.4863 17.6763C24.1511 17.694 23.815 17.6452 23.499 17.5317C23.1832 17.4183 22.8928 17.2429 22.6455 17.0161C22.3982 16.7893 22.1988 16.5153 22.0586 16.2104C21.9183 15.9055 21.8404 15.5752 21.8291 15.2397C21.8178 14.9043 21.8737 14.57 21.9932 14.2563C22.1121 13.9442 22.2915 13.6587 22.5215 13.4165L22.5547 13.3657C22.5594 13.3552 22.5607 13.3437 22.5635 13.3325L21.6973 12.5386V12.5376C21.5833 12.4331 21.4329 12.377 21.2783 12.3804Z\"\n fill=\"#00A3FF\" stroke=\"#00A3FF\" stroke-width=\"0.3\" />\n </svg>\n </span>\n <!-- Heading -->\n <h5 class=\"modal-title mb-2\">\n <span>Raise tickets for the following</span>\n\n </h5>\n <p class=\"mb-3\">\n <span>Raising a ticket for footfall count issues. Make sure all records are identified for\n validation.</span>\n\n\n </p>\n </div>\n <div class=\"row\">\n <div class=\"col-md-3 my-4\">\n <div class=\"border border-1 rounded p-3 h-100\">\n <div class=\"fw-semibold fs-5 mb-2\">\n {{tempRaisedPayload?.duplicateCount ? tempRaisedPayload?.duplicateCount :'0'}}\n </div>\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\n Duplicates\n </div>\n </div>\n </div>\n\n <div class=\"col-md-3 my-4\">\n <div class=\"border border-1 rounded p-3 h-100\">\n <div class=\"fw-semibold fs-5 mb-2\">\n {{tempRaisedPayload?.employeeCount ? tempRaisedPayload?.employeeCount:'0' }}\n </div>\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\n Employee\n </div>\n </div>\n </div>\n\n <div class=\"col-md-3 my-4\">\n <div class=\"border border-1 rounded p-3 h-100\">\n <div class=\"fw-semibold fs-5 mb-2\">\n {{tempRaisedPayload?.houseKeepingCount ? tempRaisedPayload?.houseKeepingCount :'0'}}\n </div>\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\n House Keeping\n </div>\n </div>\n </div>\n <div class=\"col-md-3 my-4\">\n <div class=\"border border-1 rounded p-3 h-100\">\n <div class=\"fw-semibold fs-5 mb-2\">\n {{tempRaisedPayload?.junkCount ? tempRaisedPayload?.junkCount :'0'}}\n </div>\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\n Junk\n </div>\n </div>\n\n </div>\n </div>\n\n <!-- Label and Textarea -->\n <div class=\"my-3\">\n <label class=\"form-label\">Description (Optional)</label>\n <textarea rows=\"3\" [(ngModel)]=\"commentText\" class=\"form-control\"\n placeholder=\"Enter description\"></textarea>\n </div>\n <div class=\"w-100 mt-5 d-flex justify-content-end\">\n\n <button class=\"btn btn-outline w-50 me-2\" (click)=\"cancelRasied()\">Cancel</button>\n <button class=\"btn btn-primary w-50\" (click)=\"submitRaised()\">\n Raise Ticket\n </button>\n </div>\n </div>\n</ng-template>\n\n\n<ng-template #imagePopup let-model>\n <div class=\"mx-4\">\n <div class=\"row\">\n <div class=\" p-2 mb-2 mt-5\">\n <div *ngIf=\"isModalOpen\" class=\"position-relative border-gray p-2 \">\n <!-- <button *ngIf=\"canNavigateLeft\" (click)=\"navigateImage('left')\"\n class=\"btn btn-light position-absolute start-0 top-50 z-index-10\">\n \u25C0\n </button> -->\n\n <!-- Main Image -->\n <!-- <img class=\" cursor-pointer w-100 h-525px\" \n [src]=\"imageUrl + (tempModalImage?.filePath || selectImageArray?.filePath)\"\n appMagnifier alt=\"\"> -->\n <img class=\" cursor-pointer w-100 h-525px\"\n [src]=\"imageUrl + (tempModalImage?.filePath || selectImageArray?.filePath)\" alt=\"\">\n <!-- <button *ngIf=\"canNavigateRight\" (click)=\"navigateImage('right')\"\n class=\"btn btn-light position-absolute end-0 top-50 z-index-10\">\n \u25B6\n </button> -->\n\n <!-- Right arrow button -->\n <div class=\"row px-2 mb-2\">\n <div class=\"col-md-7\">\n <div class=\"py-2 img-doc-time\">Tango ID : {{(tempModalImage || selectImageArray)?.templd ||\n (tempModalImage || selectImageArray)?.tempId}}\n <span *ngIf=\"(tempModalImage || selectImageArray)?.status ==='approved'\"\n class=\"ms-2\"><svg style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n fill=\"#12B76A\" />\n </svg></span>\n <span *ngIf=\"(tempModalImage || selectImageArray)?.status ==='rejected'\"\n class=\"ms-2\"><svg style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n <g clip-path=\"url(#clip0_1428_59484)\">\n <path\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n fill=\"#FEE4E2\" />\n <path\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n stroke=\"#D92D20\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_1428_59484\">\n <rect width=\"12\" height=\"12\" fill=\"white\"\n transform=\"translate(0.599609 0.5)\" />\n </clipPath>\n </defs>\n </svg></span>\n </div>\n <div class=\"img-doc-value\">Entry Time : {{(tempModalImage || selectImageArray)?.entryTme ||\n (tempModalImage || selectImageArray)?.entryTime}}</div>\n </div>\n <div class=\"col-md-5 text-end py-3\">\n <span *ngIf=\"(tempModalImage || selectImageArray)?.revopsType ==='non-tagging'\"\n ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\" viewBox=\"0 0 19 18\"\n fill=\"none\">\n <path\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n <span *ngIf=\"selectImageArray?.revopsType ==='duplicate'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\"\n fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"(tempModalImage || selectImageArray)?.revopsType ==='employee'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\"\n fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"(tempModalImage || selectImageArray)?.revopsType ==='house-keeping'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\" viewBox=\"0 0 21 21\"\n fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- <div class=\"modal-footer py-2 px-0\"> -->\n\n <div class=\"w-100 py-2 mb-2 px-0 d-flex justify-content-end\">\n\n <button class=\"btn btn-outline\" (click)=\"closeImage()\">Close</button>\n\n </div>\n <!-- </div> -->\n </div>\n</ng-template>\n\n<!-- Footfall Trends Template -->\n<ng-template #footfallTrendsTemplate>\n <div class=\"row w-100 mb-3\">\n <!-- Total Footfall Card -->\n <div class=\"col-md-4 mb-3 mb-md-0\">\n <div class=\"metric-card\">\n <div class=\"metric-header\">\n <div class=\"d-flex align-items-center gap-2\">\n <span class=\"metric-title\">Total Footfall</span>\n <svg placement=\"top\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\n viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n d=\"M4 18H9.5V19.25C9.5 19.9793 9.21027 20.6788 8.69454 21.1945C8.17882 21.7103 7.47935 22 6.75 22C6.02065 22 5.32118 21.7103 4.80546 21.1945C4.28973 20.6788 4 19.9793 4 19.25V18ZM8 6.11999C10 6.11999 11 8.99999 11 11C11 12 10.5 13 10 14.5L9.5 16H4C4 15 3.5 13.5 3.5 11C3.5 8.49999 5.498 6.11999 8 6.11999ZM20.054 14.098L19.837 15.329C19.7023 16.0396 19.2931 16.6686 18.698 17.0796C18.1029 17.4907 17.3698 17.6508 16.6576 17.5252C15.9453 17.3996 15.3111 16.9984 14.8925 16.4086C14.4739 15.8188 14.3045 15.0878 14.421 14.374L14.637 13.144L20.054 14.098ZM18.178 1.70499C20.642 2.13899 22.196 4.82999 21.762 7.29199C21.328 9.75399 20.575 11.144 20.402 12.129L14.985 11.174L14.753 9.60999C14.521 8.04599 14.203 6.97399 14.376 5.98999C14.723 4.01999 16.208 1.35799 18.178 1.70499Z\"\n fill=\"#00A3FF\" />\n </svg>\n </div>\n </div>\n <div class=\"metric-value\">{{ getCurrentFootfall() || 0 }}</div>\n <div class=\"metric-trend\" [ngClass]=\"getFootfallPercentageChange() >= 0 ? 'up' : 'down'\">\n <svg *ngIf=\"getFootfallPercentageChange() >= 0\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M6 2L10 6H7V10H5V6H2L6 2Z\" fill=\"#10B981\" />\n </svg>\n <svg *ngIf=\"getFootfallPercentageChange() < 0\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M6 10L2 6H5V2H7V6H10L6 10Z\" fill=\"#F04438\" />\n </svg>\n <span>{{ getFootfallPercentageChange() >= 0 ? '+' : '' }}{{\n getFootfallPercentageChange() }}% vs Yesterday</span>\n </div>\n </div>\n </div>\n <!-- Total Downtime Card -->\n <div class=\"col-md-4 mb-3 mb-md-0\">\n <div class=\"metric-card\">\n <div class=\"metric-header\">\n <div class=\"d-flex align-items-center gap-2\">\n <span class=\"metric-title\">Total Downtime</span>\n <div class=\"downtime-icons\">\n <svg width=\"40\" height=\"41\" viewBox=\"0 0 40 41\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <rect y=\"0.5\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\n <path\n d=\"M21.9004 12.1675C22.9958 12.1675 24.0423 12.3918 24.9977 12.7987C25.9889 13.2207 26.8809 13.8402 27.6279 14.6087C28.3734 15.3756 28.9756 16.2931 29.3857 17.3162C29.7813 18.299 29.9993 19.3756 29.9993 20.5008C29.9993 21.6277 29.7813 22.7043 29.3857 23.6871C28.9756 24.7068 28.3734 25.6244 27.6263 26.3929C26.8809 27.1598 25.9889 27.7793 24.9945 28.2012C24.0391 28.6081 22.9925 28.8325 21.8988 28.8325C20.8034 28.8325 19.7568 28.6081 18.8014 28.2012C17.8102 27.7793 16.9183 27.1598 16.1729 26.3929L16.1712 26.3912C15.4242 25.6227 14.8236 24.7052 14.4134 23.6871C14.2865 23.3707 14.1774 23.0459 14.0879 22.7127C14.2572 22.7294 14.4297 22.7378 14.6038 22.7378C14.9342 22.7378 15.2565 22.7076 15.5706 22.649C15.6227 22.8098 15.6797 22.9688 15.7415 23.1246C16.0785 23.9617 16.5732 24.7152 17.1885 25.3481C17.8037 25.981 18.5378 26.49 19.3499 26.8366C20.1328 27.1698 20.9938 27.3557 21.8988 27.3557C22.8037 27.3557 23.6631 27.1715 24.4476 26.8366C25.2614 26.49 25.9938 25.981 26.6091 25.3481C27.2243 24.7152 27.7191 23.9601 28.056 23.1246C28.3799 22.3192 28.5605 21.4334 28.5605 20.5025C28.5605 19.5715 28.3815 18.6875 28.056 17.8804C27.7191 17.0432 27.2243 16.2898 26.6091 15.6569C25.9938 15.024 25.2598 14.5149 24.4476 14.1684C23.6647 13.8352 22.8037 13.6493 21.8988 13.6493C20.9938 13.6493 20.1344 13.8335 19.3499 14.1684C19.2799 14.1985 19.21 14.2303 19.1416 14.2621C18.8747 13.8301 18.5524 13.4383 18.1829 13.0984C18.3848 12.9913 18.5915 12.8925 18.8014 12.8021C19.7601 12.3918 20.805 12.1675 21.9004 12.1675ZM20.971 16.5393C20.971 16.335 21.0524 16.1508 21.181 16.0169C21.3112 15.8829 21.4902 15.8009 21.6888 15.8009C21.8874 15.8009 22.0664 15.8829 22.1966 16.0169C22.3268 16.1508 22.4066 16.335 22.4066 16.5393V20.4271L25.2305 22.1501C25.3997 22.2539 25.5137 22.4196 25.5592 22.6021C25.6048 22.7847 25.5837 22.9856 25.4827 23.1597V23.1614C25.3818 23.3355 25.2207 23.4527 25.0433 23.4996C24.8659 23.5465 24.6706 23.5247 24.5013 23.4209H24.4997L21.3405 21.4937C21.2314 21.4318 21.1419 21.3413 21.0768 21.2342C21.0101 21.122 20.971 20.9897 20.971 20.8491V16.5393Z\"\n fill=\"#667085\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M14.3913 12.6095C16.8164 12.6095 18.7826 14.6321 18.7826 17.1269C18.7826 19.6218 16.8164 21.6444 14.3913 21.6444C11.9661 21.6444 10 19.6218 10 17.1269C10 14.6321 11.9661 12.6095 14.3913 12.6095ZM14.3913 19.7172L16.748 16.7201H15.2848V15.1261H13.4977V16.7201H12.0345L14.3913 19.7172Z\"\n fill=\"#F04438\" />\n </svg>\n </div>\n </div>\n </div>\n <div class=\"metric-value\">{{ getFormattedDowntime() || '-' }}</div>\n <!-- <div class=\"metric-tag success\" *ngIf=\"hasDowntime()\"> -->\n <!-- <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M11.6667 3.5L5.25 9.91667L2.33334 7\" stroke=\"#10B981\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg> -->\n <!-- <span>Issue submitted</span>\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M4.5 2.5L7.5 5.5L10.5 2.5\" stroke=\"#10B981\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg> -->\n <!-- </div> -->\n </div>\n </div>\n\n <!-- Ticket Status Card -->\n <div class=\"col-md-4\">\n <div class=\"metric-card\">\n <div class=\"metric-header\">\n <span class=\"metric-title\">Ticket status</span>\n </div>\n <div class=\"metric-value\">{{ getTicketStatus() === '-' ? '-' : (getTicketStatus() |\n titlecase) }}</div>\n </div>\n </div>\n </div>\n</ng-template>\n\n<ng-template #resetRequestPopup let-model>\n <div class=\"p-4\">\n <div class=\"modal-header border-0 p-0 w-100\">\n <h5 class=\"modal-title mb-3 fw-bold\">\n Reset request.\n </h5>\n </div>\n <div class=\"modal-body p-0\">\n <p class=\"text-muted mb-3\">\n You're requesting to re-enable footfall tickets, disabled after three instances of exceeding 95%\n accuracy.\n </p>\n <p class=\"text-muted mb-0\">\n Please ensure future accuracy stays on or within 95%.\n </p>\n </div>\n <div class=\"modal-footer border-0 p-0 mt-4 d-flex justify-content-end gap-2\">\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"cancelResetRequest()\">\n Cancel\n </button>\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"submitResetRequest()\">\n Send Request\n </button>\n </div>\n </div>\n</ng-template>\n\n<ng-template #ticketStatusTemplate let-model>\n <!-- Ticket Review Card (shown when ticket status is raised) -->\n <div class=\"col-12 mb-3\" *ngIf=\"(isTicketRaised() || isTicketClosed()) && getTaggingData('tagging')\">\n <div class=\"ticket-review-card\">\n <!-- Actual Footfall Header -->\n <div class=\"actual-footfall-header\">\n <span class=\"actual-footfall-number\">{{ getTaggingData('tagging')?.footfall || 0 }}</span>\n <span class=\"actual-footfall-label\">Actual Footfall</span>\n </div>\n <!-- Ticket Created By Section -->\n <div class=\"ticket-creator-section\"\n *ngIf=\"getTaggingData('tagging')?.createdByEmail || getTaggingData('tagging')?.createdAt\">\n <div class=\"d-flex align-items-center gap-2\">\n <!-- <div class=\"creator-avatar\" *ngIf=\"getTaggingData()?.createdByEmail?.profilePicture\">\n <img [src]=\"getTaggingData()?.createdByEmail?.profilePicture\" alt=\"Profile\" />\n </div> -->\n <div class=\"creator-avatar-placeholder\"\n *ngIf=\"!getTaggingData('tagging')?.createdByEmail?.profilePicture\">\n <svg width=\"32\" height=\"32\" viewBox=\"0 0 32 32\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect width=\"32\" height=\"32\" rx=\"16\" fill=\"#EAF8FF\" />\n <path\n d=\"M16 10C17.6569 10 19 11.3431 19 13C19 14.6569 17.6569 16 16 16C14.3431 16 13 14.6569 13 13C13 11.3431 14.3431 10 16 10Z\"\n fill=\"#00A3FF\" />\n <path d=\"M11 22C11 19.2386 13.2386 17 16 17C18.7614 17 21 19.2386 21 22V23H11V22Z\"\n fill=\"#00A3FF\" />\n </svg>\n </div>\n <div class=\"creator-info\">\n <div class=\"creator-label\">Ticket created by</div>\n <div class=\"creator-details\">\n <span class=\"creator-email\">{{ getTaggingData('tagging')?.createdByEmail ||\n getTaggingData('tagging')?.createdByEmail || 'N/A' }}</span>\n <span class=\"creator-separator\" *ngIf=\"getTaggingData('tagging')?.createdAt\">\u2022</span>\n <span class=\"creator-time\" *ngIf=\"getTaggingData('tagging')?.createdAt\">{{\n getTaggingData('tagging')?.createdAt | date:'h:mm:ss a - d MMM yyyy' }}</span>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Ticket Revised Footfall and Metrics -->\n <div class=\"revised-footfall-section\">\n <div class=\"metrics-row\">\n <div class=\"metric-item\">\n <div class=\"metric-number blue-text\">\n {{ getTaggingData('tagging')?.revicedFootfall || 0 }}\n <span class=\"metric-percentage\">\n ({{ getTaggingData('tagging')?.revicedPerc || 0 }}%)\n </span>\n <span class=\"metric-arrow\">\u2193</span>\n </div>\n <div class=\"metric-label\">Revised footfall</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">({{ getRevisionCalculation('tagging')}}%)</div>\n <div class=\"metric-label\">Ticket%</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'duplicate') }}</div>\n <div class=\"metric-label\">Duplicates</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'employee') }}</div>\n <div class=\"metric-label\">Employee/Staff</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'junk') }}</div>\n <div class=\"metric-label\">Junk</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'houseKeeping') }}</div>\n <div class=\"metric-label\">House Keeping</div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Ticket Final revision Card (shown when ticket status is closed) -->\n <div class=\"col-12 mb-3\" *ngIf=\"isTicketClosed() && getTaggingData('finalreview')\">\n <div class=\"ticket-review-card\">\n <!-- Ticket card section in revision start -->\n\n <!-- Actual Footfall Header -->\n <div class=\"actual-footfall-header\">\n <span class=\"actual-footfall-number\">{{ getTaggingData('tagging')?.footfall || 0 }}</span>\n <span class=\"actual-footfall-label\">Actual Footfall</span>\n </div>\n <!-- Ticket Created By Section -->\n <div class=\"ticket-creator-section\"\n *ngIf=\"getTaggingData('tagging')?.createdByEmail || getTaggingData('tagging')?.createdAt\">\n <div class=\"d-flex align-items-center gap-2\">\n <!-- <div class=\"creator-avatar\" *ngIf=\"getTaggingData()?.createdByEmail?.profilePicture\">\n <img [src]=\"getTaggingData()?.createdByEmail?.profilePicture\" alt=\"Profile\" />\n </div> -->\n <div class=\"creator-avatar-placeholder\"\n *ngIf=\"!getTaggingData('tagging')?.createdByEmail?.profilePicture\">\n <svg width=\"32\" height=\"32\" viewBox=\"0 0 32 32\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect width=\"32\" height=\"32\" rx=\"16\" fill=\"#EAF8FF\" />\n <path\n d=\"M16 10C17.6569 10 19 11.3431 19 13C19 14.6569 17.6569 16 16 16C14.3431 16 13 14.6569 13 13C13 11.3431 14.3431 10 16 10Z\"\n fill=\"#00A3FF\" />\n <path d=\"M11 22C11 19.2386 13.2386 17 16 17C18.7614 17 21 19.2386 21 22V23H11V22Z\"\n fill=\"#00A3FF\" />\n </svg>\n </div>\n <div class=\"creator-info\">\n <div class=\"creator-label\">Ticket created by</div>\n <div class=\"creator-details\">\n <span class=\"creator-email\">{{ getTaggingData('tagging')?.createdByEmail ||\n getTaggingData('tagging')?.createdByEmail || 'N/A' }}</span>\n <span class=\"creator-separator\" *ngIf=\"getTaggingData('tagging')?.createdAt\">\u2022</span>\n <span class=\"creator-time\" *ngIf=\"getTaggingData('tagging')?.createdAt\">{{\n getTaggingData('tagging')?.createdAt | date:'h:mm:ss a - d MMM yyyy' }}</span>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Ticket Revised Footfall and Metrics -->\n <div class=\"revised-footfall-section\">\n <div class=\"metrics-row\">\n <div class=\"metric-item\">\n <div class=\"metric-number blue-text\">\n {{ getTaggingData('tagging')?.revicedFootfall || 0 }}\n <span class=\"metric-percentage\">\n ({{ getTaggingData('tagging')?.revicedPerc || 0 }}%)\n </span>\n <span class=\"metric-arrow\">\u2193</span>\n </div>\n <div class=\"metric-label\">Revised footfall</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">({{ getRevisionCalculation('tagging')}}%)</div>\n <div class=\"metric-label\">Ticket%</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'duplicate') }}</div>\n <div class=\"metric-label\">Duplicates</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'employee') }}</div>\n <div class=\"metric-label\">Employee/Staff</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'junk') }}</div>\n <div class=\"metric-label\">Junk</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'houseKeeping') }}</div>\n <div class=\"metric-label\">House Keeping</div>\n </div>\n </div>\n </div>\n <!-- Ticket card section in revision end -->\n\n <!-- Final Revision Section -->\n <div class=\"revision-section\">\n <div class=\"revision-title\">Final revision</div>\n <div class=\"final-revision-note\">\n Please reach centraloperations@lenskart.in for any further discrepancies\n </div>\n <div class=\"revised-footfall-section\">\n <div class=\"metrics-row\">\n <div class=\"metric-item\">\n <div class=\"metric-number blue-text\">\n {{ getTaggingData('finalreview')?.revicedFootfall || 0 }}\n <span class=\"metric-percentage\">\n ({{ getTaggingData('finalreview')?.revicedPerc || 0}}%)\n </span>\n <span class=\"metric-arrow\">\u2191</span>\n </div>\n <div class=\"metric-label\">Revised footfall</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">({{ getRevisionCalculation('finalreview')}}%)</div>\n <div class=\"metric-label\">Ticket%</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('finalreview'), 'duplicate') }}\n </div>\n <div class=\"metric-label\">Duplicates</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('finalreview'), 'employee') }}\n </div>\n <div class=\"metric-label\">Employee/Staff</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('finalreview'), 'junk') }}</div>\n <div class=\"metric-label\">Junk</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('finalreview'), 'houseKeeping')\n }}</div>\n <div class=\"metric-label\">House Keeping</div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n</ng-template>", styles: ["@charset \"UTF-8\";.switch-form-card{padding:8px 16px;border-radius:4px;border-left:2px solid var(--Primary-600, #00A3FF);background:var(--Primary-25, #F6FCFF);display:flex;align-items:center;justify-content:space-between}.switch-form-card .txt-one{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:140%}.nav-item .nav-link.active{border:none;border-radius:6px;background:var(--Primary-50, #EAF8FF);padding:8px 12px}.nav-item .nav-link:hover{border:none}.badge-num-primary{border-radius:16px!important;background:var(--Primary-50, #EAF8FF)!important;color:var(--Primary-700, #009BF3)!important;text-align:center;font-size:14px!important;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}.badge-num-muted{border-radius:16px!important;background:var(--Primary-50, #F2F4F7)!important;color:var(--Gray-700, #344054)!important;text-align:center;font-size:14px;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}.img-src{width:100%;height:195px;border-radius:.625rem}.img-traffic .col-md-3{width:24%!important}.border-gray{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF)}.img-doc-directory{color:var(--Gray-900, #101828)!important;font-size:14px!important;font-weight:600;line-height:20px;text-decoration-line:underline}.img-doc-time{color:var(--Gray-800, #1D2939);font-size:14px;font-weight:500;line-height:20px}.img-doc-value{color:var(--Gray-600, #667085);font-size:14px;font-weight:500;line-height:20px}.overflow-x{overflow-x:auto}.no-preview{border:1px solid #F04438;background:#fee4e2;border-radius:8px;stroke-width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:41px 16px}.no-preview .header{color:#f04438;font-size:20px;font-weight:700;line-height:20px}.no-preview .description{color:#f04438;font-size:12px;font-weight:500;line-height:18px}.img-nodata{width:25%;height:15%}.img-nodata1{width:15%;height:15%}.nodata-title{font-size:14px!important;font-weight:600}.img-direc{color:var(--Gray-900, #101828)!important;font-size:18px!important;font-weight:500;line-height:28px}.custom-accordion{border-radius:5px}.custom-accordion-item{margin-bottom:10px}.custom-accordion-header{background-color:#fff;border:none;cursor:pointer;padding:10px;text-align:left;width:100%;display:flex;justify-content:space-between;align-items:center}.custom-accordion{width:100%}.mainheading{width:100%;display:flex;justify-content:space-between;align-items:center;padding:19px;border:none;background:none;cursor:pointer}.mainheading-1{width:77%;display:flex;justify-content:space-between;align-items:center;padding:19px;border:none;background:none;cursor:pointer}.header-row{display:flex;align-items:center;width:100%;justify-content:space-between}.img-dire{font-size:16px;font-weight:700}.divider{flex-grow:1;height:1px;background-color:#ddd;margin:0 10px}.accordion-arrow{display:flex;align-items:center}.scroll-container{max-height:400px;overflow-y:auto;overflow-x:hidden}.view-toggle .btn{border-radius:6px}.view-toggle .btn.active{background:var(--Primary-50, #EAF8FF);border-color:var(--Primary-200, #99DAFF)}.date-list-container{padding:4px 23px;width:100%}.date-list-scroll{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px;max-height:287px;overflow-y:auto;overflow-x:hidden;padding-bottom:8px}.date-card{min-width:0;max-width:none;padding:16px;background:#fff;border:1px solid #D0D5DD;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;gap:8px}.date-card:hover{box-shadow:0 2px 8px #0000001a;border-color:#00a3ff}.date-card .date-card-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.date-card .date-card-header .calendar-icon{flex-shrink:0}.date-card .date-card-header .date-text{color:var(--Gray-900, #101828);font-size:14px;font-weight:500;line-height:20px;flex:1}.date-card .footfall-count{color:var(--Gray-900, #101828);font-size:32px;font-weight:400;line-height:40px;margin-top:4px}.date-card .footfall-label{color:var(--Gray-600, #667085);font-size:14px;font-weight:400;line-height:20px}.date-card-active{background:var(--Primary-50, #EAF8FF);border-color:var(--Primary-600, #00A3FF);border-width:2px}.date-card-active .date-text{color:var(--Primary-700, #009BF3);font-weight:600}.date-card-active .footfall-count{color:var(--Primary-700, #009BF3)}.list-view-wrapper{padding:0 8px 16px;max-height:480px;overflow-y:auto}.list-group{border:1px solid var(--Gray-200, #EAECF0);border-radius:12px;background:#fff;padding:16px 20px}.list-group-header{border-bottom:1px solid var(--Gray-200, #EAECF0);padding-bottom:12px;margin-bottom:16px!important}.list-group-header .group-title{color:var(--Gray-900, #101828);font-size:16px;font-weight:600;line-height:24px}.list-group-header .group-count{color:var(--Gray-600, #667085);font-weight:500}.high-400px{min-height:auto!important;max-height:800px!important}.scroll-y{overflow-y:auto}.absolute{top:5px;right:5px;z-index:2}.slider{position:relative}.slider .previous{position:absolute;top:30%;left:2%;width:32px;height:32px;background-color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.slider .next{position:absolute;top:30%;right:2%;width:32px;height:32px;background-color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.img-src1{border-radius:12px;border:1px solid var(--Gray-400, #98A2B3);background:var(--Gray-50, #F9FAFB);width:100%;height:375px;object-fit:contain}.zoom-icon-button{position:absolute;top:10px;right:10px;z-index:10;cursor:pointer;background:#fffffff2;border-radius:50%;padding:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000026;transition:all .2s ease}.zoom-icon-button:hover{background:#fff;box-shadow:0 4px 12px #0003;transform:scale(1.05)}.zoom-icon-button svg{width:20px;height:20px}.border-gray{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);padding:0 4px}.border-gray-active{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--Primary-50, #EAF8FF);padding:0 4px}.zone-header{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:20px}.last-visit{color:var(--Gray-500, #667085);font-size:14px;font-weight:400;line-height:20px}.toggle-label{color:var(--Gray-900, #101828);font-size:16px;font-weight:600;line-height:24px}.nav-dev{border-radius:8px!important;border:1px solid var(--Primary-200, #99DAFF)!important;background:var(--Primary-25, #F6FCFF)!important}.tab-active{border-radius:6px;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3)!important;font-size:14px;font-weight:500;line-height:20px}.tab-text-default{color:var(--Gray-500, #667085);font-size:14px;font-weight:500;line-height:20px}.border-gray-active1{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--Primary-50, #ffffff);padding:12px!important}.nav-item1 .nav-link1.active{border:none;border-radius:0;background:var(--Primary-50, #EAF8FF);border-bottom:2px solid #009BF3!important;padding:12px;color:var(--Primary-700, #009BF3);font-size:14px;font-style:normal;font-weight:500;line-height:20px}.active-normal{padding:12px;color:var(--Gray-500, #667085);font-size:14px;font-style:normal;font-weight:500;line-height:20px}.nav-item1 .nav-link1:hover{border:none}.tag-class{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:20px}.spent-title{color:var(--Gray-600, #475467);font-size:14px;font-weight:600;line-height:20px}.spent-value{color:var(--Gray-500, #667085);font-size:14px;font-weight:400;line-height:20px}.spent-value1{color:var(--Primary-500, #33B5FF);font-size:14px;font-weight:500;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font}.w-33{width:30%}.w-45{width:45%}.view-tetory{color:var(--Primary-700, #009BF3);font-size:14px;font-weight:600;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font;text-transform:capitalize}.border-gray-tagged{border-radius:4px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--Primary-50, #ffffff);padding:8px!important}.desc-id{color:var(--Gray-900, #101828);font-size:12px;font-style:normal;font-weight:400;line-height:20px}.active-tab{border-bottom:2px solid #0d6efd;font-weight:600;color:#0d6efd}.badge-selected{background-color:#e0f3ff;color:#0d6efd;border:1px solid #0d6efd;border-radius:20px;padding:6px 12px}.badge-unselected{background-color:#f0f0f0;color:#333;border-radius:20px;padding:6px 12px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;appearance:textfield}.cursor-not-allowed{cursor:not-allowed!important}.title-type{color:var(--Gray-800, #1D2939);font-size:16px;font-weight:600;line-height:24px}.top-50{top:35%!important}.activePlanBtn{border-radius:6px;background:var(--Primary-50, #EAF8FF);color:var(--Gray-700, #344054);font-size:14px!important;font-weight:500!important;line-height:20px}.inactivePlanBtn{color:var(--Gray-500, #344054)!important;font-size:14px;font-weight:500!important;line-height:20px}.badge-active{border-radius:16px;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3);text-align:center;font-size:12px;font-style:normal;font-weight:500;line-height:20px;mix-blend-mode:multiply}input[type=checkbox]{width:18px!important;height:18px!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}::ng-deep .modal-backdrop{pointer-events:none}.meta-change.up{color:#10b981}.meta-change.down{color:#ef4444}.meta-change.neutral{color:#64748b}.split-screen-container{display:flex;height:calc(100vh - 300px);min-height:600px;gap:16px;margin-top:16px}.split-screen-container .left-panel{flex:0 0 35%;max-width:35%;overflow-y:auto;overflow-x:hidden;padding-right:8px;border-right:1px solid var(--Gray-200, #EAECF0)}.split-screen-container .right-panel{flex:1;overflow-y:auto;padding-left:16px}.thumbnail-list-section{margin-bottom:24px}.thumbnail-list-section .time-range-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--Gray-200, #EAECF0)}.thumbnail-list-section .time-range-header .time-range-title{color:var(--Gray-900, #101828);font-size:16px;font-weight:600;line-height:24px}.thumbnail-list-section .time-range-header .time-range-count{color:var(--Gray-600, #667085);font-size:14px;font-weight:500;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3);padding:2px 10px;border-radius:16px}.thumbnail-list-section .thumbnail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.thumbnail-list-section .thumbnail-item{cursor:pointer;border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);padding:8px;transition:all .2s ease}.thumbnail-list-section .thumbnail-item:hover{border-color:var(--Primary-600, #00A3FF);box-shadow:0 2px 8px #00a3ff1a}.thumbnail-list-section .thumbnail-item.selected{border-color:var(--Primary-600, #00A3FF);border-width:2px;background:var(--Primary-50, #EAF8FF)}.thumbnail-list-section .thumbnail-item .thumbnail-image{width:100%;height:120px;object-fit:cover;border-radius:4px;margin-bottom:8px}.thumbnail-list-section .thumbnail-item .thumbnail-info .tango-id{color:var(--Gray-900, #101828);font-size:12px;font-weight:600;line-height:16px;margin-bottom:4px}.thumbnail-list-section .thumbnail-item .thumbnail-info .entry-time{color:var(--Gray-600, #667085);font-size:11px;font-weight:400;line-height:16px}.metric-card{background:var(--White, #FFF);border-radius:8px;padding:16px;height:100%;display:flex;flex-direction:column;gap:2px}.metric-card .metric-header{display:flex;justify-content:space-between;align-items:center}.metric-card .metric-header .metric-title{color:var(--Gray-700, #344054);font-size:14px;font-weight:500;line-height:20px}.metric-card .metric-header .metric-icon,.metric-card .metric-header .footfall-icon-header{flex-shrink:0}.metric-card .metric-header .downtime-icons{position:relative;display:inline-flex;align-items:center;width:31px;height:24px}.metric-card .metric-header .downtime-icons .clock-icon{position:absolute;left:0;top:2px;z-index:1}.metric-card .metric-header .downtime-icons .alert-icon{position:absolute;right:-2px;top:-2px;z-index:2}.metric-card .metric-value{color:var(--Gray-900, #101828);font-size:32px;font-weight:400;line-height:40px}.metric-card .metric-trend{display:flex;align-items:center;gap:4px;font-size:14px;font-weight:500;line-height:20px}.metric-card .metric-trend.up{color:#10b981}.metric-card .metric-trend.down{color:#f04438}.metric-card .metric-trend svg{flex-shrink:0}.metric-card .metric-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;line-height:16px;width:fit-content}.metric-card .metric-tag.success{background:#d1fadf;color:#10b981}.metric-card .metric-tag svg{flex-shrink:0}.ticket-review-card{background:var(--White, #FFF);border-radius:12px;border:1px solid var(--Gray-200, #EAECF0);padding:20px;box-shadow:0 1px 3px #0000001a}.ticket-review-card .actual-footfall-header{background:var(--Primary-50, #EAF8FF);border-radius:8px;padding:16px 20px;margin-bottom:20px;display:flex;align-items:center;gap:12px}.ticket-review-card .actual-footfall-header .actual-footfall-number{color:var(--Gray-900, #101828);font-size:32px;font-weight:600;line-height:40px}.ticket-review-card .actual-footfall-header .actual-footfall-label{color:var(--Gray-700, #344054);font-size:16px;font-weight:500;line-height:24px}.ticket-review-card .ticket-creator-section{padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid var(--Gray-200, #EAECF0)}.ticket-review-card .ticket-creator-section .creator-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0}.ticket-review-card .ticket-creator-section .creator-avatar img{width:100%;height:100%;object-fit:cover}.ticket-review-card .ticket-creator-section .creator-avatar-placeholder{width:40px;height:40px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.ticket-review-card .ticket-creator-section .creator-info{flex:1}.ticket-review-card .ticket-creator-section .creator-info .creator-label{color:var(--Gray-600, #667085);font-size:12px;font-weight:400;line-height:18px;margin-bottom:4px}.ticket-review-card .ticket-creator-section .creator-info .creator-details{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ticket-review-card .ticket-creator-section .creator-info .creator-details .creator-email{color:var(--Gray-900, #101828);font-size:14px;font-weight:500;line-height:20px}.ticket-review-card .ticket-creator-section .creator-info .creator-details .creator-separator{color:var(--Gray-400, #98A2B3);font-size:14px}.ticket-review-card .ticket-creator-section .creator-info .creator-details .creator-time{color:var(--Gray-600, #667085);font-size:14px;font-weight:400;line-height:20px}.ticket-review-card .revised-footfall-section .metrics-row{display:flex;flex-wrap:wrap;gap:24px;align-items:flex-start}.ticket-review-card .revised-footfall-section .metrics-row .metric-item{flex:1;min-width:120px;display:flex;flex-direction:column;gap:4px}.ticket-review-card .revised-footfall-section .metrics-row .metric-item .metric-number{color:var(--Gray-900, #101828);font-size:24px;font-weight:600;line-height:32px}.ticket-review-card .revised-footfall-section .metrics-row .metric-item .metric-number.blue-text{color:var(--Primary-700, #009BF3)}.ticket-review-card .revised-footfall-section .metrics-row .metric-item .metric-number.blue-text .metric-percentage{font-size:16px;font-weight:500;margin-left:4px}.ticket-review-card .revised-footfall-section .metrics-row .metric-item .metric-number.blue-text .metric-arrow{color:var(--Primary-700, #009BF3);font-size:16px;margin-left:4px}.ticket-review-card .revised-footfall-section .metrics-row .metric-item .metric-label{color:var(--Gray-600, #667085);font-size:14px;font-weight:400;line-height:20px}.ticket-review-card .revision-section{margin-top:24px;padding-top:24px;border-top:1px solid var(--Gray-200, #EAECF0)}.ticket-review-card .revision-section .revision-title{color:var(--Gray-900, #101828);font-size:16px;font-weight:600;line-height:24px;margin-bottom:16px}.ticket-review-card .revision-section .final-revision-note{color:var(--Gray-600, #667085);font-size:14px;font-weight:400;line-height:20px;margin-bottom:16px;font-style:italic}.ticket-block-alert{border-radius:8px;border:2px dashed #F04438;background:#fee4e2;padding:16px;margin-bottom:16px}.ticket-block-alert .ticket-block-alert-content{display:flex;align-items:flex-start;gap:12px}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-icon svg{width:24px;height:24px}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-text{flex:1;display:flex;flex-direction:column;gap:8px}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-text .ticket-block-alert-title{color:#f04438;font-size:16px;font-weight:700;line-height:24px}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-text .ticket-block-alert-description,.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-text .ticket-block-alert-action{color:#f04438;font-size:14px;font-weight:400;line-height:20px}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-text .ticket-block-alert-action .ticket-block-alert-link{color:#f04438;text-decoration:underline;cursor:pointer;font-weight:500}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-text .ticket-block-alert-action .ticket-block-alert-link:hover{color:#d92d20;text-decoration:underline}.ticket-request-alert{border-radius:8px;border:2px dashed #10B981;background:#d1fae5;padding:16px;margin-bottom:16px}.ticket-request-alert .ticket-request-alert-content{display:flex;align-items:flex-start;gap:12px}.ticket-request-alert .ticket-request-alert-content .ticket-request-alert-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.ticket-request-alert .ticket-request-alert-content .ticket-request-alert-icon svg{width:24px;height:24px}.ticket-request-alert .ticket-request-alert-content .ticket-request-alert-text{flex:1;display:flex;flex-direction:column;gap:8px}.ticket-request-alert .ticket-request-alert-content .ticket-request-alert-text .ticket-request-alert-title{color:#10b981;font-size:16px;font-weight:700;line-height:24px}.ticket-request-alert .ticket-request-alert-content .ticket-request-alert-text .ticket-request-alert-description{color:#10b981;font-size:14px;font-weight:400;line-height:20px}\n"], dependencies: [{ kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i7.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: i7.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "popperOptions", "triggers", "positionTarget", "container", "disableTooltip", "tooltipClass", "tooltipContext", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "pipe", type: i6.TitleCasePipe, name: "titlecase" }, { kind: "pipe", type: i6.DatePipe, name: "date" }] });
|
|
871
1313
|
}
|
|
872
1314
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ImgRvpsComponent, decorators: [{
|
|
873
1315
|
type: Component,
|
|
874
|
-
args: [{ selector: "lib-img-rvps", template: "<div class=\"card mt-3\">\r\n <div class=\"card-header mt-3 px-0 border-bottom-0\">\r\n <div class=\"custom-accordion\">\r\n <div class=\"custom-accordion-item\">\r\n <button class=\"mainheading pb-0 custom-accordion-header\" (click)=\"toggleAccordion()\">\r\n <div class=\"header-row\">\r\n <span class=\"img-direc\">Image Directory</span>\r\n\r\n <span class=\"divider\"></span>\r\n <span class=\"accordion-arrow\">\r\n <!-- Down arrow for collapsed state, up arrow for expanded state -->\r\n <svg *ngIf=\"!isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\r\n viewBox=\"0 0 16 6\" fill=\"none\">\r\n <path d=\"M1 1L5 5L9 1\" stroke=\"#071437\" stroke-width=\"1\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n <svg *ngIf=\"isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\r\n viewBox=\"0 0 16 6\" fill=\"none\">\r\n <path d=\"M1 5L5 1L9 5\" stroke=\"#1b84ff\" stroke-width=\"1\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n </div>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n\r\n </div>\r\n <section *ngIf=\"isAccordionExpanded\">\r\n\r\n <div *ngIf=\"folderView\" class=\"card-body px-0\">\r\n <div class=\"scroll-container\">\r\n <div class=\"row\">\r\n <div class=\"col-md-1 mt-5 text-center\" *ngFor=\"let obj of dateArray;let i = index\">\r\n <div (click)=\"getimages(i,obj)\">\r\n <div *ngIf=\"i === selectIndex;\">\r\n <span class=\"cursor-pointer\"><svg width=\"57\" height=\"56\" viewBox=\"0 0 57 56\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"0.154297\" width=\"56\" height=\"56\" rx=\"12\" fill=\"#33B5FF\" />\r\n <path\r\n d=\"M39.8216 36.1667C39.8216 36.7855 39.5758 37.379 39.1382 37.8166C38.7006 38.2542 38.1071 38.5 37.4883 38.5H18.8216C18.2028 38.5 17.6093 38.2542 17.1717 37.8166C16.7341 37.379 16.4883 36.7855 16.4883 36.1667V19.8333C16.4883 19.2145 16.7341 18.621 17.1717 18.1834C17.6093 17.7458 18.2028 17.5 18.8216 17.5H24.6549L26.9883 21H37.4883C38.1071 21 38.7006 21.2458 39.1382 21.6834C39.5758 22.121 39.8216 22.7145 39.8216 23.3333V36.1667Z\"\r\n stroke=\"white\" stroke-width=\"2.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></span>\r\n <div class=\"text-center mt-2\">{{obj | date:'dd MMM'}}</div>\r\n </div>\r\n <div *ngIf=\"i !== selectIndex;\">\r\n <span class=\"cursor-pointer\"><svg width=\"57\" height=\"56\" viewBox=\"0 0 57 56\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"0.462891\" width=\"56\" height=\"56\" rx=\"12\" fill=\"#EAF8FF\" />\r\n <path\r\n d=\"M40.1302 36.1667C40.1302 36.7855 39.8844 37.379 39.4468 37.8166C39.0092 38.2542 38.4157 38.5 37.7969 38.5H19.1302C18.5114 38.5 17.9179 38.2542 17.4803 37.8166C17.0427 37.379 16.7969 36.7855 16.7969 36.1667V19.8333C16.7969 19.2145 17.0427 18.621 17.4803 18.1834C17.9179 17.7458 18.5114 17.5 19.1302 17.5H24.9635L27.2969 21H37.7969C38.4157 21 39.0092 21.2458 39.4468 21.6834C39.8844 22.121 40.1302 22.7145 40.1302 23.3333V36.1667Z\"\r\n stroke=\"#00A3FF\" stroke-width=\"2.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></span>\r\n <div class=\"text-center mt-2\">{{obj | date:'dd MMM'}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n\r\n <div *ngIf=\"!folderView\" class=\"card-body\">\r\n <section *ngIf=\"!imageFlow\">\r\n\r\n\r\n <div class=\"row\">\r\n <div class=\"d-flex flex-shrink-0 mt-3 justify-content-start align-items-center px-0\">\r\n <span *ngIf=\"backnav\" class=\"cursor-pointer\" (click)=\"backToFootfall()\">\r\n <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <g filter=\"url(#filter0_d_2585_7036)\">\r\n <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\r\n <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\r\n <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\r\n filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\r\n <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\r\n values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\r\n <feOffset dy=\"1\" />\r\n <feGaussianBlur stdDeviation=\"1\" />\r\n <feColorMatrix type=\"matrix\"\r\n values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\r\n <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\r\n result=\"effect1_dropShadow_2585_7036\" />\r\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\r\n result=\"shape\" />\r\n </filter>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span class=\"img-direc ms-2 mt-1\">{{folderDate | date:'dd MMM, yyyy'}} \r\n <span class=\"badge badge-light-warning mx-2\" *ngIf=\"!getTicketStatuses().includes('closed') && getTicketStatuses().includes('open')\">\r\n Ticket Raised\r\n</span>\r\n<span class=\"badge badge-light-success mx-2\" *ngIf=\"getTicketStatuses().includes('closed')\">Ticket Closed</span>\r\n\r\n </span>\r\n <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\" class=\"ms-auto text-end\">\r\n \r\n<button \r\n [disabled]=\"!canEnableButton()\" \r\n class=\"btn btn-primary\" \r\n type=\"button\" \r\n (click)=\"Raised()\">\r\n Raise ticket for footfall\r\n</button>\r\n</div>\r\n </div>\r\n <div *ngIf=\"!folderView\" class=\"nav-group bg-white border-1 btn-group w-auto my-2\">\r\n<ng-container *ngIf=\"!(countData?.length > 0)\">\r\n\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n [ngClass]=\"type === 'footfall' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n (click)=\"selectPlanTrends('footfall')\">\r\n Total Footfall\r\n <span\r\n [ngClass]=\"type === 'footfall' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\r\n {{ countData?.footfallCount || 0 }}\r\n </span>\r\n </button>\r\n\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n (click)=\"selectPlanTrends('non-tagging')\">\r\n Non-tags\r\n <span\r\n [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\r\n {{ countData?.nonTags || 0 }}\r\n </span>\r\n </button>\r\n\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n [ngClass]=\"type === 'duplicate' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n (click)=\"selectPlanTrends('duplicate')\">\r\n Duplicated\r\n <span\r\n [ngClass]=\"type === 'duplicate' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\r\n {{ countData?.duplicate || 0 }}\r\n </span>\r\n </button>\r\n\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n [ngClass]=\"type === 'employee' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n (click)=\"selectPlanTrends('employee')\">\r\n Employee/Staff\r\n <span\r\n [ngClass]=\"type === 'employee' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\r\n {{ countData?.employee || 0 }}\r\n </span>\r\n </button>\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n [ngClass]=\"type === 'junk' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n (click)=\"selectPlanTrends('junk')\">\r\n Junk\r\n <span\r\n [ngClass]=\"type === 'junk' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\r\n {{ countData?.junk || 0 }}\r\n </span>\r\n </button>\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n [ngClass]=\"type === 'house-keeping' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n (click)=\"selectPlanTrends('house-keeping')\">\r\n House Keeping\r\n <span\r\n [ngClass]=\"type === 'house-keeping' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\r\n {{ countData?.housekeeping || 0 }}\r\n </span>\r\n </button>\r\n \r\n\r\n</ng-container>\r\n\r\n </div>\r\n<ng-container *ngIf=\"!imageFlow\">\r\n\r\n <div *ngIf=\"type === 'footfall'\" class=\"d-flex mt-2 mb-2 w-100 overflow-x px-0\">\r\n\r\n <div class=\"col text-nowrap\" *ngFor=\"let obj of objectsArray\">\r\n <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\r\n <li class=\"nav-item cursor-pointer\">\r\n <a (click)=\"selectedTimes(obj.timeRange)\"\r\n [ngClass]=\"selectedTime === obj?.timeRange ? 'active' : ''\"\r\n class=\"nav-link cursor-pointer no-border mx-3 mb-2\">\r\n {{obj?.timeRange}}<span class=\"mx-2\"\r\n [ngClass]=\"selectedTime === obj?.timeRange ? 'badge-num-primary' :'badge-num-muted'\">\r\n {{ obj?.count ? obj?.count : 0 }}\r\n </span>\r\n </a>\r\n </li>\r\n </ul>\r\n </div>\r\n\r\n\r\n </div>\r\n</ng-container>\r\n <div *ngIf=\"loading\" class=\"row loader d-flex justify-content-center align-items-center\">\r\n <div class=\"shimmer\">\r\n <div class=\"wrapper\">\r\n <div class=\"stroke animate title\"></div>\r\n <div class=\"stroke animate link\"></div>\r\n <div class=\"stroke animate description\"></div>\r\n </div>\r\n </div>\r\n <div class=\"shimmer\">\r\n <div class=\"wrapper\">\r\n <div class=\"stroke animate title\"></div>\r\n <div class=\"stroke animate link\"></div>\r\n <div class=\"stroke animate description\"></div>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"noData\" class=\"row\">\r\n\r\n <div class=\"col-lg-12 mb-3\">\r\n\r\n <div class=\"card-body d-flex justify-content-center align-items-center flex-column \" style=\"margin: 64px;border-radius: 8px;\r\nbackground: var(--Gray-50, #F9FAFB);\">\r\n <svg width=\"94\" height=\"94\" viewBox=\"0 0 94 94\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"7\" y=\"7\" width=\"80\" height=\"80\" rx=\"40\" fill=\"#DAF1FF\" />\r\n <rect x=\"7\" y=\"7\" width=\"80\" height=\"80\" rx=\"40\" stroke=\"#EAF8FF\"\r\n stroke-width=\"13.3333\" />\r\n <path\r\n d=\"M35.332 51.9999H33.6654C32.7813 51.9999 31.9335 51.6487 31.3083 51.0236C30.6832 50.3985 30.332 49.5506 30.332 48.6666V33.6666C30.332 32.7825 30.6832 31.9347 31.3083 31.3096C31.9335 30.6844 32.7813 30.3333 33.6654 30.3333H48.6654C49.5494 30.3333 50.3973 30.6844 51.0224 31.3096C51.6475 31.9347 51.9987 32.7825 51.9987 33.6666V35.3333M45.332 41.9999H60.332C62.173 41.9999 63.6654 43.4923 63.6654 45.3333V60.3333C63.6654 62.1742 62.173 63.6666 60.332 63.6666H45.332C43.4911 63.6666 41.9987 62.1742 41.9987 60.3333V45.3333C41.9987 43.4923 43.4911 41.9999 45.332 41.9999Z\"\r\n stroke=\"#00A3FF\" stroke-width=\"4\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n <div class=\"nodata-title my-3\">\r\n {{ noDataMessages[type?.toLowerCase()] || 'No data found' }}\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n <div class=\"row px-0 img-traffic contain high-400px scroll-y\" *ngIf=\"!noData && !loading\">\r\n <ng-container\r\n\r\n*ngFor=\"let obj of imagesArrayData\"\r\n>\r\n<div *ngIf=\"type !== 'duplicate' || (type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\" class=\"col-md-3 border-gray mx-2 p-2 mt-5\">\r\n<!-- Condition: Only show if not duplicate OR duplicate with non-empty duplicateImagePath -->\r\n<ng-container >\r\n<img\r\nclass=\"img-src cursor-pointer\"\r\n[src]=\"imageUrl + obj?.filePath\"\r\n(error)=\"obj.filePath = null\"\r\nalt=\"\"\r\n(click)=\"imgFullView(obj)\"\r\n/>\r\n</ng-container>\r\n\r\n <div *ngIf=\"!obj?.filePath\" class=\"no-preview\">\r\n <span class=\"mb-5\">\r\n <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <g id=\"Group\">\r\n <path id=\"Vector\"\r\n d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\r\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n <path id=\"Vector_2\"\r\n d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\r\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n </svg>\r\n\r\n </span>\r\n <span class=\"header mb-5 text-center\">Preview not available</span>\r\n <span class=\"description mb-5 text-center\">The selected camera is not available at the\r\n moment.</span>\r\n </div>\r\n <div *ngIf=\"type !== 'duplicate' || (type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\" class=\"row px-2 mb-2\">\r\n <div class=\"col-md-7\">\r\n <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd}} <span *ngIf=\"(type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\" class=\"mx-2 badge badge-light-primary\">{{obj.duplicateImagePath?.length}}</span>\r\n <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\r\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\r\n fill=\"#12B76A\" />\r\n </svg></span>\r\n <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_1428_59484)\">\r\n <path\r\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n fill=\"#FEE4E2\" />\r\n <path\r\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n stroke=\"#D92D20\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_1428_59484\">\r\n <rect width=\"12\" height=\"12\" fill=\"white\"\r\n transform=\"translate(0.599609 0.5)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n </div>\r\n <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme}}</div>\r\n </div>\r\n <div class=\"col-md-5 text-end py-3\">\r\n <span *ngIf=\"obj?.revopsType ==='non-tagging'\" ngbTooltip=\"Yet to tag the customer\"\r\n placement=\"top\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\r\n viewBox=\"0 0 19 18\" fill=\"none\">\r\n <path\r\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='duplicate'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94635)\">\r\n <path\r\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94635\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='employee'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94639)\">\r\n <path\r\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94639\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\r\n viewBox=\"0 0 21 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94643)\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n fill=\"#475467\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94643\">\r\n <rect width=\"21\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='junk'\">\r\n\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n<path d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg>\r\n </span>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n </div>\r\n </section>\r\n\r\n <!-- full image View -->\r\n <section *ngIf=\"imageFlow\">\r\n <div class=\"row\">\r\n <div class=\"d-flex flex-shrink-0 mt-3 justify-content-start align-items-center px-0\">\r\n <span class=\"cursor-pointer\" (click)=\"backToFootfall1()\">\r\n <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <g filter=\"url(#filter0_d_2585_7036)\">\r\n <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\r\n <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\r\n <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\r\n filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\r\n <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\r\n values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\r\n <feOffset dy=\"1\" />\r\n <feGaussianBlur stdDeviation=\"1\" />\r\n <feColorMatrix type=\"matrix\"\r\n values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\r\n <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\r\n result=\"effect1_dropShadow_2585_7036\" />\r\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\r\n result=\"shape\" />\r\n </filter>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span class=\"img-direc ms-2 mt-1\">{{folderDate | date:'dd MMM, yyyy'}}</span>\r\n </div>\r\n <div class=\"d-flex mt-2 mb-2 w-100 overflow-x px-0\">\r\n\r\n <!-- <div class=\"col text-nowrap\" *ngFor=\"let obj of objectsArray\">\r\n <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\r\n <li class=\"nav-item cursor-pointer\">\r\n <a (click)=\"selectedTimes(obj.timeRange)\"\r\n [ngClass]=\"selectedTime === obj?.timeRange ? 'active' : ''\"\r\n class=\"nav-link cursor-pointer no-border mx-3 mb-2\">\r\n {{obj?.timeRange}}<span class=\"mx-2\"\r\n [ngClass]=\"selectedTime === obj?.timeRange ? 'badge-num-primary' :'badge-num-muted'\">\r\n {{ obj?.count ? obj?.count : 0 }}\r\n </span>\r\n </a>\r\n </li>\r\n </ul>\r\n </div> -->\r\n\r\n\r\n </div>\r\n\r\n <div class=\"row mx-0 border-gray img-traffic\" *ngIf=\"!noData && !loading\">\r\n <div class=\"col-md-6 p-2 mb-2 mt-5\">\r\n <div class=\"position-relative border-gray p-2 \">\r\n <!-- <button *ngIf=\"canNavigateLeft\" (click)=\"navigateImage('left')\"\r\n class=\"btn btn-light position-absolute start-0 top-50 z-index-10\">\r\n \u25C0\r\n </button> -->\r\n\r\n <!-- Main Image -->\r\n <img class=\"img-src cursor-pointer h-450px\" (click)=\"selectedImageArray(imageUrl, selectImageArray)\"\r\n [src]=\"imageUrl + selectImageArray?.filePath\" appMagnifier alt=\"\">\r\n <!-- <button *ngIf=\"canNavigateRight\" (click)=\"navigateImage('right')\"\r\n class=\"btn btn-light position-absolute end-0 top-50 z-index-10\">\r\n \u25B6\r\n </button> -->\r\n\r\n <!-- Right arrow button -->\r\n <div class=\"row px-2 mb-2\">\r\n <div class=\"col-md-7\">\r\n <div class=\"py-2 img-doc-time\">Tango ID : {{selectImageArray?.templd}}\r\n <span *ngIf=\"selectImageArray?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\r\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\r\n fill=\"#12B76A\" />\r\n </svg></span>\r\n <span *ngIf=\"selectImageArray?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_1428_59484)\">\r\n <path\r\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n fill=\"#FEE4E2\" />\r\n <path\r\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n stroke=\"#D92D20\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_1428_59484\">\r\n <rect width=\"12\" height=\"12\" fill=\"white\"\r\n transform=\"translate(0.599609 0.5)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n </div>\r\n <div class=\"img-doc-value\">Entry Time : {{selectImageArray?.entryTme}}</div>\r\n </div>\r\n <div class=\"col-md-5 text-end py-3\">\r\n <span *ngIf=\"selectImageArray?.revopsType ==='non-tagging'\"\r\n ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\r\n viewBox=\"0 0 19 18\" fill=\"none\">\r\n <path\r\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span *ngIf=\"selectImageArray?.revopsType ==='duplicate'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94635)\">\r\n <path\r\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94635\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"selectImageArray?.revopsType ==='employee'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94639)\">\r\n <path\r\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94639\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"selectImageArray?.revopsType ==='house-keeping'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\r\n viewBox=\"0 0 21 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94643)\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n fill=\"#475467\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94643\">\r\n <rect width=\"21\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"col-md-6 p-2 mb-2 mt-5\">\r\n <div class=\"mx-2 \">\r\n <div class=\"row\">\r\n <div class=\"col-md-6 title-type\">\r\n Select non-shopper type\r\n </div>\r\n \r\n\r\n <section class=\"col-md-6 text-end\" *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\r\n \r\n <div *ngIf=\"!revopsTypeValue\" class=\"mb-5 text-end\" role=\"group\">\r\n <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\">\r\n \r\n <button [disabled]=\"\r\n (selectedRadioType === undefined || selectedRadioType === '') ||\r\n (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\r\n \"\r\n class=\"btn btn-default\" type=\"button\" (click)=\"clearValue()\">Clear</button>\r\n <button class=\"btn btn-outline me-2\" (click)=\"cancel()\">Cancel</button>\r\n <button\r\n class=\"btn btn-primary\"\r\n id=\"alert-toast\"\r\n (click)=\"save(selectedType)\"\r\n [disabled]=\"\r\n (selectedRadioType === undefined || selectedRadioType === '') ||\r\n (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\r\n \"\r\n >\r\n Save\r\n </button>\r\n </div>\r\n </div>\r\n \r\n <div *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\r\n <ng-container *ngIf=\"editBtnShow\">\r\n <div *ngIf=\"revopsTypeValue\" class=\"mb-5 text-end\" role=\"group\">\r\n <button *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\" class=\"btn btn-outline me-2\" (click)=\"editValue()\"><span\r\n class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\"\r\n height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M14.6554 1.71047C14.8927 1.47315 15.1745 1.2849 15.4845 1.15646C15.7946 1.02802 16.1269 0.961914 16.4626 0.961914C16.7982 0.961914 17.1305 1.02802 17.4406 1.15646C17.7507 1.2849 18.0324 1.47315 18.2697 1.71047C18.5071 1.94779 18.6953 2.22953 18.8238 2.53961C18.9522 2.84969 19.0183 3.18202 19.0183 3.51765C19.0183 3.85327 18.9522 4.18561 18.8238 4.49568C18.6953 4.80576 18.5071 5.0875 18.2697 5.32482L6.0713 17.5233L1.10156 18.8786L2.45695 13.9089L14.6554 1.71047Z\"\r\n stroke=\"#344054\" stroke-width=\"1.81079\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></span>Edit</button>\r\n \r\n </div>\r\n </ng-container>\r\n </div>\r\n </section>\r\n \r\n </div>\r\n\r\n <div class=\"form-check my-15\">\r\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"duplicate\"\r\n id=\"duplicate\" [(ngModel)]=\"selectedType\" [value]=\"'duplicate'\"\r\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\r\n <label class=\"form-check-label\" for=\"duplicate\">\r\n <span class=\"ms-5\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94635)\">\r\n <path\r\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94635\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span class=\"ms-5 tag-class\">Duplicate</span>\r\n </label>\r\n </div>\r\n <div class=\"form-check my-15\">\r\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"employee\"\r\n id=\"employee\" [(ngModel)]=\"selectedType\" [value]=\"'employee'\"\r\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\r\n <label class=\"form-check-label\" for=\"employee\">\r\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\"\r\n height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94639)\">\r\n <path\r\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94639\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n <span class=\"ms-5 tag-class\">Employee/Staff</span>\r\n </label>\r\n </div>\r\n <div class=\"form-check my-15\">\r\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"house-keeping\"\r\n id=\"house-keeping\" [(ngModel)]=\"selectedType\" [value]=\"'house-keeping'\"\r\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\r\n <label class=\"form-check-label\" for=\"house-keeping\">\r\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\"\r\n height=\"21\" viewBox=\"0 0 21 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94643)\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n fill=\"#475467\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94643\">\r\n <rect width=\"21\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n <span class=\"ms-5 tag-class\"> House Keeping</span>\r\n </label>\r\n </div>\r\n <div class=\"form-check my-15\">\r\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"junk\"\r\n id=\"junk\" [(ngModel)]=\"selectedType\" [value]=\"'junk'\"\r\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"users?.role ==='user' && this.users?.userType ==='client' || revopsTypeValue\">\r\n <label class=\"form-check-label\" for=\"junk\">\r\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n <path d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg></span>\r\n <span class=\"ms-5 tag-class\"> Junk</span>\r\n </label>\r\n </div>\r\n </div>\r\n\r\n\r\n </div>\r\n </div>\r\n\r\n \r\n <div class=\"row px-0 img-traffic mt-3 high-400px scroll-y\">\r\n <div class=\"col-md-3 border-gray mx-2 p-2 mt-5\" *ngFor=\"let obj of remainingImageArray\">\r\n <div class=\"position-relative\">\r\n <!-- <input *ngIf=\"selectedRadioType === 'duplicate'\" type=\"checkbox\" \r\n [(ngModel)]=\"obj.selected\" class=\"position-absolute absolute form-check-input\"\r\n (change)=\"onImageCheckboxChange(obj, 'duplicate')\" /> -->\r\n <input \r\n *ngIf=\"!revopsTypeValue && selectedRadioType === 'duplicate'\"\r\n type=\"checkbox\"\r\n [checked]=\"obj.selected\"\r\n class=\"position-absolute absolute form-check-input cursor-pointer\"\r\n (change)=\"onImageCheckboxChange($event, obj, 'duplicate')\"\r\n [disabled]=\"obj.duplicateImagePath?.length > 0\"\r\n/>\r\n\r\n<img\r\n class=\"img-src\"\r\n [ngClass]=\"selectedRadioType !== 'duplicate' ? 'cursor-pointer' : 'cursor-pointer'\"\r\n [src]=\"imageUrl + obj?.filePath\"\r\n (error)=\"obj.filePath = null\"\r\n alt=\"\"\r\n (click)=\"handleImageClick($event, obj)\"\r\n/>\r\n\r\n <div *ngIf=\"!obj?.filePath\" class=\"no-preview\">\r\n <span class=\"mb-5\">\r\n <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <g id=\"Group\">\r\n <path id=\"Vector\"\r\n d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\r\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n <path id=\"Vector_2\"\r\n d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\r\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n </svg>\r\n\r\n </span>\r\n <span class=\"header mb-5 text-center\">Preview not available</span>\r\n <span class=\"description mb-5 text-center\">The selected camera is not available at\r\n the\r\n moment.</span>\r\n </div>\r\n <div class=\"row px-2 mb-2\">\r\n <div class=\"col-md-7\">\r\n <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd ? obj?.templd : obj?.tempId}} \r\n <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\r\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\r\n fill=\"#12B76A\" />\r\n </svg></span>\r\n <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_1428_59484)\">\r\n <path\r\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n fill=\"#FEE4E2\" />\r\n <path\r\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n stroke=\"#D92D20\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_1428_59484\">\r\n <rect width=\"12\" height=\"12\" fill=\"white\"\r\n transform=\"translate(0.599609 0.5)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n </div>\r\n <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme ? obj?.entryTme :obj?.entryTime}}</div>\r\n </div>\r\n <div class=\"col-md-5 text-end py-3\">\r\n <span *ngIf=\"obj?.revopsType ==='non-tagging'\"\r\n ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\r\n viewBox=\"0 0 19 18\" fill=\"none\">\r\n <path\r\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='duplicate'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94635)\">\r\n <path\r\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94635\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='employee'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94639)\">\r\n <path\r\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94639\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\r\n viewBox=\"0 0 21 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94643)\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n fill=\"#475467\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94643\">\r\n <rect width=\"21\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"obj?.revopsType ==='junk'\">\r\n\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n<path d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg>\r\n </span>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </section>\r\n </div>\r\n </section>\r\n</div>\r\n\r\n\r\n<ng-template #zoomPopup let-model>\r\n <div class=\"p-4 m-4\">\r\n <div class=\"modal-header border-0 p-0 w-100 flex-column align-items-start\">\r\n <span *ngIf=\"popupType === 'non-tagging'\" class=\"my-3\">\r\n\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\r\n <rect width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\r\n <g clip-path=\"url(#clip0_2088_98337)\">\r\n <path\r\n d=\"M29.1693 13.3333V18.3333M29.1693 18.3333H24.1693M29.1693 18.3333L25.3026 14.7C24.407 13.8039 23.299 13.1493 22.0819 12.7973C20.8649 12.4453 19.5785 12.4073 18.3428 12.6869C17.1072 12.9665 15.9624 13.5545 15.0155 14.3962C14.0685 15.2378 13.3502 16.3056 12.9276 17.5M10.8359 26.6666V21.6666M10.8359 21.6666H15.8359M10.8359 21.6666L14.7026 25.3C15.5982 26.1961 16.7062 26.8506 17.9233 27.2027C19.1403 27.5547 20.4267 27.5927 21.6624 27.3131C22.898 27.0335 24.0428 26.4455 24.9897 25.6038C25.9367 24.7621 26.655 23.6943 27.0776 22.5\"\r\n stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2088_98337\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(10 10)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <!-- Heading -->\r\n <h5 class=\"modal-title mb-2\">\r\n <span *ngIf=\"popupType === 'employee'\">Tagging as employee/staff </span>\r\n <span *ngIf=\"popupType === 'duplicate'\">Tagging as duplicates </span>\r\n <span *ngIf=\"popupType === 'house-keeping'\">Tagging as house keeping </span>\r\n <span *ngIf=\"popupType === 'non-tagging'\">Clear duplicates</span>\r\n <span *ngIf=\"popupType ==='junk'\">Tagging as junk</span>\r\n \r\n </h5>\r\n <p class=\"mb-3\">\r\n <span *ngIf=\"popupType === 'employee'\">Are you sure you want to tag this as employee/staff?</span>\r\n <span *ngIf=\"popupType === 'duplicate'\">Are you sure you want to tag this as duplicates? </span>\r\n <span *ngIf=\"popupType === 'house-keeping'\">Are you sure you want to tag this as house keeping? </span>\r\n <span *ngIf=\"popupType === 'non-tagging'\">This will remove tagged duplicates and move them to\r\n 'Non-tag'.</span>\r\n <span *ngIf=\"popupType ==='junk'\">Are you sure you want to tag this as junk?</span>\r\n\r\n </p>\r\n </div>\r\n\r\n <div class=\"w-100 mt-5 d-flex justify-content-end\">\r\n <button class=\"btn btn-outline me-2\" (click)=\"cancelSubmit()\">Cancel</button>\r\n <button *ngIf=\"popupType !== 'non-tagging'\" class=\"btn btn-primary\" (click)=\"submitValue(popupType)\">\r\n Yes, Tag\r\n </button>\r\n <button *ngIf=\"popupType === 'non-tagging'\" class=\"btn btn-primary\" (click)=\"submitValue(popupType)\">\r\n Yes, clear\r\n </button>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n\r\n<ng-template #raisedPopup let-model>\r\n <div class=\"p-4 m-4\">\r\n <div class=\"modal-header border-0 p-0 w-100 flex-column align-items-start\">\r\n <span class=\"my-3\">\r\n\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\r\n <rect width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\r\n <path\r\n d=\"M21.251 11.0806C21.7405 11.0699 22.2153 11.2487 22.5762 11.5796L23.4922 12.4204C23.8089 12.7097 23.893 13.1017 23.8652 13.4263V13.4272C23.836 13.7478 23.6954 14.0592 23.4785 14.2944C23.3699 14.413 23.2865 14.5525 23.2314 14.7036C23.1764 14.8548 23.1512 15.0155 23.1582 15.1763C23.1652 15.337 23.2035 15.4953 23.2715 15.6411C23.3394 15.7869 23.4362 15.9172 23.5547 16.0259C23.6733 16.1346 23.8117 16.2198 23.9629 16.2749C24.1141 16.33 24.2748 16.3541 24.4355 16.3472C24.5961 16.3402 24.7537 16.3017 24.8994 16.2339C25.0089 16.1829 25.1106 16.116 25.2002 16.0356L25.3701 15.8657C25.5759 15.6748 25.8385 15.5408 26.1152 15.4907C26.2972 15.4546 26.485 15.4617 26.6641 15.5103C26.8439 15.5591 27.0103 15.649 27.1494 15.7729L27.1514 15.7749L28.2598 16.7905C28.445 16.9605 28.5948 17.1658 28.7002 17.394C28.8056 17.6223 28.8648 17.8694 28.874 18.1206C28.8832 18.372 28.8423 18.6234 28.7539 18.8589C28.6655 19.0941 28.5316 19.3096 28.3594 19.4927L20.1113 28.2583C19.937 28.4434 19.7268 28.5912 19.4941 28.6938C19.2614 28.7965 19.0102 28.8522 18.7559 28.856C18.5016 28.8597 18.2493 28.8119 18.0137 28.7163C17.7779 28.6206 17.5636 28.4784 17.3838 28.2983L16.2539 27.1685C15.7511 26.6656 15.8832 25.9552 16.1514 25.5542L16.2061 25.4644C16.3241 25.2486 16.3742 25.0008 16.3496 24.7544C16.3214 24.4731 16.197 24.2102 15.9971 24.0103C15.7971 23.8103 15.5343 23.6859 15.2529 23.6577C14.9715 23.6297 14.6887 23.6995 14.4531 23.856H14.4521C14.0494 24.1222 13.3407 24.2552 12.8379 23.7515L11.6797 22.5933C11.5034 22.4169 11.364 22.2074 11.2686 21.9771C11.1731 21.7467 11.1231 21.4999 11.123 21.2505C11.123 21.001 11.1731 20.7535 11.2686 20.5229C11.364 20.2926 11.5034 20.0831 11.6797 19.9067L19.9492 11.6362C20.2954 11.2902 20.7616 11.0912 21.251 11.0806ZM21.2783 12.3804C21.1237 12.3838 20.9765 12.4468 20.8672 12.5562L12.5967 20.8257C12.5409 20.8814 12.497 20.9482 12.4668 21.021C12.4367 21.0938 12.4209 21.1717 12.4209 21.2505C12.4209 21.3292 12.4367 21.4073 12.4668 21.48C12.497 21.5528 12.541 21.6196 12.5967 21.6753L13.7061 22.7837L13.7314 22.772C14.2169 22.4485 14.7993 22.3035 15.3799 22.3608C15.9608 22.4183 16.5042 22.6747 16.917 23.0874C17.3298 23.5002 17.587 24.0436 17.6445 24.6245C17.702 25.2055 17.5565 25.7892 17.2324 26.2749L17.2305 26.2759C17.2261 26.2822 17.2226 26.2893 17.2197 26.2964L18.3018 27.3804C18.3585 27.4372 18.4266 27.482 18.501 27.5122C18.5755 27.5425 18.6559 27.5574 18.7363 27.5562C18.8166 27.5549 18.8963 27.5378 18.9697 27.5054C19.043 27.4729 19.1091 27.4261 19.1641 27.3677L27.4131 18.6021C27.4673 18.5442 27.5093 18.4761 27.5371 18.4019C27.5649 18.3276 27.5781 18.2487 27.5752 18.1694C27.5722 18.0902 27.5538 18.0119 27.5205 17.9399C27.4872 17.8679 27.4394 17.8032 27.3809 17.7495L26.3223 16.7778C26.2925 16.7885 26.2648 16.8053 26.2432 16.8286C26.0217 17.0788 25.7529 17.2827 25.4521 17.4282C25.15 17.5743 24.8214 17.6585 24.4863 17.6763C24.1511 17.694 23.815 17.6452 23.499 17.5317C23.1832 17.4183 22.8928 17.2429 22.6455 17.0161C22.3982 16.7893 22.1988 16.5153 22.0586 16.2104C21.9183 15.9055 21.8404 15.5752 21.8291 15.2397C21.8178 14.9043 21.8737 14.57 21.9932 14.2563C22.1121 13.9442 22.2915 13.6587 22.5215 13.4165L22.5547 13.3657C22.5594 13.3552 22.5607 13.3437 22.5635 13.3325L21.6973 12.5386V12.5376C21.5833 12.4331 21.4329 12.377 21.2783 12.3804Z\"\r\n fill=\"#00A3FF\" stroke=\"#00A3FF\" stroke-width=\"0.3\" />\r\n </svg>\r\n </span>\r\n <!-- Heading -->\r\n <h5 class=\"modal-title mb-2\">\r\n <span>Raise tickets for the following</span>\r\n\r\n </h5>\r\n <p class=\"mb-3\">\r\n <span>Raising a ticket for footfall count issues. Make sure all records are identified for\r\n validation.</span>\r\n\r\n\r\n </p>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-3 my-4\">\r\n <div class=\"border border-1 rounded p-3 h-100\">\r\n <div class=\"fw-semibold fs-5 mb-2\">\r\n {{tempRaisedPayload?.duplicateCount ? tempRaisedPayload?.duplicateCount :'0'}}\r\n </div>\r\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n Duplicates\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"col-md-3 my-4\">\r\n <div class=\"border border-1 rounded p-3 h-100\">\r\n <div class=\"fw-semibold fs-5 mb-2\">\r\n {{tempRaisedPayload?.employeeCount ? tempRaisedPayload?.employeeCount:'0' }}\r\n </div>\r\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n Employee\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"col-md-3 my-4\">\r\n <div class=\"border border-1 rounded p-3 h-100\">\r\n <div class=\"fw-semibold fs-5 mb-2\">\r\n {{tempRaisedPayload?.houseKeepingCount ? tempRaisedPayload?.houseKeepingCount :'0'}}\r\n </div>\r\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n House Keeping\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-md-3 my-4\">\r\n <div class=\"border border-1 rounded p-3 h-100\">\r\n <div class=\"fw-semibold fs-5 mb-2\">\r\n {{tempRaisedPayload?.junkCount ? tempRaisedPayload?.junkCount :'0'}}\r\n </div>\r\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n Junk\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n <!-- Label and Textarea -->\r\n <div class=\"my-3\">\r\n <label class=\"form-label\">Description (Optional)</label>\r\n <textarea rows=\"3\" [(ngModel)]=\"commentText\" class=\"form-control\"\r\n placeholder=\"Enter description\"></textarea>\r\n </div>\r\n <div class=\"w-100 mt-5 d-flex justify-content-end\">\r\n\r\n <button class=\"btn btn-outline w-50 me-2\" (click)=\"cancelRasied()\">Cancel</button>\r\n <button class=\"btn btn-primary w-50\" (click)=\"submitRaised()\">\r\n Raise Ticket\r\n </button>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n\r\n<ng-template #imagePopup let-model>\r\n <div class=\"mx-4\">\r\n <div class=\"row\">\r\n <div class=\" p-2 mb-2 mt-5\">\r\n <div *ngIf=\"isModalOpen\" class=\"position-relative border-gray p-2 \">\r\n <!-- <button *ngIf=\"canNavigateLeft\" (click)=\"navigateImage('left')\"\r\n class=\"btn btn-light position-absolute start-0 top-50 z-index-10\">\r\n \u25C0\r\n </button> -->\r\n\r\n <!-- Main Image -->\r\n <img class=\" cursor-pointer w-100 h-525px\"\r\n [src]=\"imageUrl + selectImageArray?.filePath\" appMagnifier alt=\"\">\r\n <!-- <button *ngIf=\"canNavigateRight\" (click)=\"navigateImage('right')\"\r\n class=\"btn btn-light position-absolute end-0 top-50 z-index-10\">\r\n \u25B6\r\n </button> -->\r\n\r\n <!-- Right arrow button -->\r\n <div class=\"row px-2 mb-2\">\r\n <div class=\"col-md-7\">\r\n <div class=\"py-2 img-doc-time\">Tango ID : {{selectImageArray?.templd}}\r\n <span *ngIf=\"selectImageArray?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\r\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\r\n fill=\"#12B76A\" />\r\n </svg></span>\r\n <span *ngIf=\"selectImageArray?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_1428_59484)\">\r\n <path\r\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n fill=\"#FEE4E2\" />\r\n <path\r\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n stroke=\"#D92D20\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_1428_59484\">\r\n <rect width=\"12\" height=\"12\" fill=\"white\"\r\n transform=\"translate(0.599609 0.5)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n </div>\r\n <div class=\"img-doc-value\">Entry Time : {{selectImageArray?.entryTme}}</div>\r\n </div>\r\n <div class=\"col-md-5 text-end py-3\">\r\n <span *ngIf=\"selectImageArray?.revopsType ==='non-tagging'\"\r\n ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\r\n viewBox=\"0 0 19 18\" fill=\"none\">\r\n <path\r\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span *ngIf=\"selectImageArray?.revopsType ==='duplicate'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94635)\">\r\n <path\r\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94635\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"selectImageArray?.revopsType ==='employee'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n viewBox=\"0 0 20 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94639)\">\r\n <path\r\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94639\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n <span *ngIf=\"selectImageArray?.revopsType ==='house-keeping'\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\r\n viewBox=\"0 0 21 21\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_2012_94643)\">\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n fill=\"#475467\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_2012_94643\">\r\n <rect width=\"21\" height=\"20\" fill=\"white\"\r\n transform=\"translate(0 0.686035)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </span>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- <div class=\"modal-footer py-2 px-0\"> -->\r\n\r\n <div class=\"w-100 py-2 mb-2 px-0 d-flex justify-content-end\">\r\n \r\n <button class=\"btn btn-outline\" (click)=\"closeImage()\">Close</button>\r\n \r\n </div>\r\n <!-- </div> -->\r\n </div>\r\n</ng-template>", styles: [".switch-form-card{padding:8px 16px;border-radius:4px;border-left:2px solid var(--Primary-600, #00A3FF);background:var(--Primary-25, #F6FCFF);display:flex;align-items:center;justify-content:space-between}.switch-form-card .txt-one{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:140%}.nav-item .nav-link.active{border:none;border-radius:6px;background:var(--Primary-50, #EAF8FF);padding:8px 12px}.nav-item .nav-link:hover{border:none}.badge-num-primary{border-radius:16px!important;background:var(--Primary-50, #EAF8FF)!important;color:var(--Primary-700, #009BF3)!important;text-align:center;font-size:14px!important;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}.badge-num-muted{border-radius:16px!important;background:var(--Primary-50, #F2F4F7)!important;color:var(--Gray-700, #344054)!important;text-align:center;font-size:14px;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}.img-src{width:100%;height:195px;border-radius:.625rem}.img-traffic .col-md-3{width:24%!important}.border-gray{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF)}.img-doc-directory{color:var(--Gray-900, #101828)!important;font-size:14px!important;font-weight:600;line-height:20px;text-decoration-line:underline}.img-doc-time{color:var(--Gray-800, #1D2939);font-size:14px;font-weight:500;line-height:20px}.img-doc-value{color:var(--Gray-600, #667085);font-size:14px;font-weight:500;line-height:20px}.overflow-x{overflow-x:auto}.no-preview{border:1px solid #F04438;background:#fee4e2;border-radius:8px;stroke-width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:41px 16px}.no-preview .header{color:#f04438;font-size:20px;font-weight:700;line-height:20px}.no-preview .description{color:#f04438;font-size:12px;font-weight:500;line-height:18px}.img-nodata{width:25%;height:15%}.img-nodata1{width:15%;height:15%}.nodata-title{font-size:14px!important;font-weight:600}.img-direc{color:var(--Gray-900, #101828)!important;font-size:18px!important;font-weight:500;line-height:28px}.custom-accordion{border-radius:5px}.custom-accordion-item{margin-bottom:10px}.custom-accordion-header{background-color:#fff;border:none;cursor:pointer;padding:10px;text-align:left;width:100%;display:flex;justify-content:space-between;align-items:center}.custom-accordion{width:100%}.mainheading{width:100%;display:flex;justify-content:space-between;align-items:center;padding:19px;border:none;background:none;cursor:pointer}.header-row{display:flex;align-items:center;width:100%;justify-content:space-between}.img-dire{font-size:16px;font-weight:700}.divider{flex-grow:1;height:1px;background-color:#ddd;margin:0 10px}.accordion-arrow{display:flex;align-items:center}.scroll-container{max-height:400px;overflow-y:auto;overflow-x:hidden}.high-400px{min-height:auto!important;max-height:800px!important}.scroll-y{overflow-y:auto}.absolute{top:5px;right:5px;z-index:2}.slider{position:relative}.slider .previous{position:absolute;top:30%;left:2%;width:32px;height:32px;background-color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.slider .next{position:absolute;top:30%;right:2%;width:32px;height:32px;background-color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.img-src1{border-radius:12px;border:1px solid var(--Gray-400, #98A2B3);background:var(--Gray-50, #F9FAFB);width:100%;height:375px}.border-gray{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);padding:0 4px}.border-gray-active{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--Primary-50, #EAF8FF);padding:0 4px}.zone-header{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:20px}.last-visit{color:var(--Gray-500, #667085);font-size:14px;font-weight:400;line-height:20px}.toggle-label{color:var(--Gray-900, #101828);font-size:16px;font-weight:600;line-height:24px}.nav-dev{border-radius:8px!important;border:1px solid var(--Primary-200, #99DAFF)!important;background:var(--Primary-25, #F6FCFF)!important}.tab-active{border-radius:6px;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3)!important;font-size:14px;font-weight:500;line-height:20px}.tab-text-default{color:var(--Gray-500, #667085);font-size:14px;font-weight:500;line-height:20px}.border-gray-active1{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--Primary-50, #ffffff);padding:12px!important}.nav-item1 .nav-link1.active{border:none;border-radius:0;background:var(--Primary-50, #EAF8FF);border-bottom:2px solid #009BF3!important;padding:12px;color:var(--Primary-700, #009BF3);font-size:14px;font-style:normal;font-weight:500;line-height:20px}.active-normal{padding:12px;color:var(--Gray-500, #667085);font-size:14px;font-style:normal;font-weight:500;line-height:20px}.nav-item1 .nav-link1:hover{border:none}.tag-class{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:20px}.spent-title{color:var(--Gray-600, #475467);font-size:14px;font-weight:600;line-height:20px}.spent-value{color:var(--Gray-500, #667085);font-size:14px;font-weight:400;line-height:20px}.spent-value1{color:var(--Primary-500, #33B5FF);font-size:14px;font-weight:500;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font}.w-33{width:30%}.w-45{width:45%}.view-tetory{color:var(--Primary-700, #009BF3);font-size:14px;font-weight:600;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font;text-transform:capitalize}.border-gray-tagged{border-radius:4px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--Primary-50, #ffffff);padding:8px!important}.desc-id{color:var(--Gray-900, #101828);font-size:12px;font-style:normal;font-weight:400;line-height:20px}.active-tab{border-bottom:2px solid #0d6efd;font-weight:600;color:#0d6efd}.badge-selected{background-color:#e0f3ff;color:#0d6efd;border:1px solid #0d6efd;border-radius:20px;padding:6px 12px}.badge-unselected{background-color:#f0f0f0;color:#333;border-radius:20px;padding:6px 12px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.cursor-not-allowed{cursor:not-allowed!important}.title-type{color:var(--Gray-800, #1D2939);font-size:16px;font-weight:600;line-height:24px}.top-50{top:35%!important}.activePlanBtn{border-radius:6px;background:var(--Primary-50, #EAF8FF);color:var(--Gray-700, #344054);font-size:14px!important;font-weight:500!important;line-height:20px}.inactivePlanBtn{color:var(--Gray-500, #344054)!important;font-size:14px;font-weight:500!important;line-height:20px}.badge-active{border-radius:16px;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3);text-align:center;font-size:12px;font-style:normal;font-weight:500;line-height:20px;mix-blend-mode:multiply}input[type=checkbox]{width:18px!important;height:18px!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}::ng-deep .modal-backdrop{pointer-events:none}\n"] }]
|
|
1316
|
+
args: [{ selector: "lib-img-rvps", template: "<div class=\"card mt-3\">\n <div class=\"card-header mt-3 px-0 border-bottom-0\">\n <div class=\"custom-accordion\">\n <div class=\"custom-accordion-item\">\n <!-- for new navigation changes -->\n <!-- old view while folder view -->\n <button *ngIf=\"folderView\" class=\"mainheading pb-0 custom-accordion-header\" (click)=\"toggleAccordion()\">\n <div class=\"header-row\">\n <span class=\"img-direc\">Image Directory</span>\n\n <span class=\"divider\"></span>\n <span class=\"accordion-arrow\">\n <!-- Down arrow for collapsed state, up arrow for expanded state -->\n <svg *ngIf=\"!isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\n viewBox=\"0 0 16 6\" fill=\"none\">\n <path d=\"M1 1L5 5L9 1\" stroke=\"#071437\" stroke-width=\"1\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <svg *ngIf=\"isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\n viewBox=\"0 0 16 6\" fill=\"none\">\n <path d=\"M1 5L5 1L9 5\" stroke=\"#1b84ff\" stroke-width=\"1\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n </div>\n </button>\n <!-- new view while not in folder view view -->\n <div *ngIf=\"!folderView\" class=\"header-row\">\n <span *ngIf=\"backnav && !imageFlow\" class=\"cursor-pointer\" (click)=\"backToFootfall()\">\n <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g filter=\"url(#filter0_d_2585_7036)\">\n <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\n <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\n <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\n filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\n <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\n values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\n <feOffset dy=\"1\" />\n <feGaussianBlur stdDeviation=\"1\" />\n <feColorMatrix type=\"matrix\"\n values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\n <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\n result=\"effect1_dropShadow_2585_7036\" />\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\n result=\"shape\" />\n </filter>\n </defs>\n </svg>\n </span>\n <!-- back from image flow -->\n <span *ngIf=\"imageFlow\" class=\"cursor-pointer\" (click)=\"backToFootfall1()\">\n <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g filter=\"url(#filter0_d_2585_7036)\">\n <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\n <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\n <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\n filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\n <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\n values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\n <feOffset dy=\"1\" />\n <feGaussianBlur stdDeviation=\"1\" />\n <feColorMatrix type=\"matrix\"\n values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\n <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\n result=\"effect1_dropShadow_2585_7036\" />\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\n result=\"shape\" />\n </filter>\n </defs>\n </svg>\n </span>\n <span class=\"img-direc\">Image Directory | {{folderDate | date:'dd MMM, yyyy'}}</span>\n <button *ngIf=\"!folderView\" class=\"mainheading-1 pb-0 custom-accordion-header\"\n (click)=\"toggleAccordion()\">\n <span class=\"divider\"></span>\n <span class=\"accordion-arrow\">\n <!-- Down arrow for collapsed state, up arrow for expanded state -->\n <svg *ngIf=\"!isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\n viewBox=\"0 0 16 6\" fill=\"none\">\n <path d=\"M1 1L5 5L9 1\" stroke=\"#071437\" stroke-width=\"1\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <svg *ngIf=\"isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\n viewBox=\"0 0 16 6\" fill=\"none\">\n <path d=\"M1 5L5 1L9 5\" stroke=\"#1b84ff\" stroke-width=\"1\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n </button>\n </div>\n </div>\n </div>\n </div>\n\n <section *ngIf=\"isAccordionExpanded\">\n\n <div *ngIf=\"folderView\" class=\"card-body px-0\">\n <div class=\"date-list-container\">\n <div class=\"date-list-scroll\">\n <div class=\"date-card\" *ngFor=\"let obj of dateArray; let i = index\"\n [ngClass]=\"{'date-card-active': i === selectIndex}\" (click)=\"getimages(i, obj)\">\n <div class=\"date-card-header\">\n <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\" class=\"calendar-icon\">\n <path\n d=\"M12.6667 2.66667H12V2C12 1.63181 11.7015 1.33333 11.3333 1.33333C10.9651 1.33333 10.6667 1.63181 10.6667 2V2.66667H5.33333V2C5.33333 1.63181 5.03486 1.33333 4.66667 1.33333C4.29848 1.33333 4 1.63181 4 2V2.66667H3.33333C2.59695 2.66667 2 3.26362 2 4V13.3333C2 14.0697 2.59695 14.6667 3.33333 14.6667H12.6667C13.403 14.6667 14 14.0697 14 13.3333V4C14 3.26362 13.403 2.66667 12.6667 2.66667ZM12.6667 13.3333H3.33333V6H12.6667V13.3333Z\"\n fill=\"#667085\" />\n </svg>\n <span class=\"date-text\">{{obj | date:'dd MMM'}}</span>\n <span *ngIf=\"cardDataMap[obj]?.ticketStatusLower as status\" class=\"badge ms-2\" [ngClass]=\"{\n 'badge-light-success': status === 'closed',\n 'badge-light-warning': status === 'raised',\n 'badge-light-default': status !== 'closed' && status !== 'raised'\n }\">\n {{ status === 'closed' ? 'Ticket closed' : (status === 'raised' ? 'Ticket raised' :\n (cardDataMap[obj]?.ticketStatus || '')) }}\n </span>\n </div>\n <div class=\"footfall-count\">{{ cardDataMap[obj]?.footfallCount || 0 }}</div>\n <div class=\"footfall-label\">Total footfall</div>\n </div>\n </div>\n </div>\n </div>\n\n\n\n <div *ngIf=\"!folderView\" class=\"card-body\">\n <section *ngIf=\"!imageFlow\">\n <div class=\"row\">\n <!-- Ticket Block Alert -->\n <div *ngIf=\"getSelectedDateCardData()?.raisedStatusEnabled === 'block'\" class=\"col-12 mb-3\">\n <div class=\"ticket-block-alert\">\n <div class=\"ticket-block-alert-content\">\n <div class=\"ticket-block-alert-icon\">\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <circle cx=\"12\" cy=\"12\" r=\"12\" fill=\"#F04438\" />\n <path d=\"M12 8V13\" stroke=\"white\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n </svg>\n </div>\n <div class=\"ticket-block-alert-text\">\n <div class=\"ticket-block-alert-title\">\n You cannot raise ticket for next {{ getSelectedDateCardData()?.noOfBlockedDays\n || '0' }} days\n </div>\n <div class=\"ticket-block-alert-description\">\n It looks like you have achieved 95% accuracy for the three tickets raised this\n month. This limits you from raising more tickets to avoid redundancy.\n </div>\n <div class=\"ticket-block-alert-action\">\n If you still want to raise tickets, <span class=\"ticket-block-alert-link\"\n (click)=\"requestReset()\">send request</span> to reset.\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- Ticket Request Success Alert -->\n <div *ngIf=\"getSelectedDateCardData()?.raisedStatusEnabled === 'request'\" class=\"col-12 mb-3\">\n <div class=\"ticket-request-alert\">\n <div class=\"ticket-request-alert-content\">\n <div class=\"ticket-request-alert-icon\">\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M2 21L23 12L2 3V10L17 12L2 14V21Z\" fill=\"#10B981\" />\n </svg>\n </div>\n <div class=\"ticket-request-alert-text\">\n <div class=\"ticket-request-alert-title\">\n Reset Request Sent\n </div>\n <div class=\"ticket-request-alert-description\">\n Your request to enable ticket raising has been submitted. You'll be notified\n once it's approved. Please ensure future ticket accuracy remains within the 95%\n threshold.\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- footfall trends feature -->\n <ng-container *ngTemplateOutlet=\"footfallTrendsTemplate\"></ng-container>\n <ng-container *ngTemplateOutlet=\"ticketStatusTemplate\"></ng-container>\n <span class=\"divider\"></span>\n <!-- footfall trends feature end -->\n <div class=\"d-flex flex-shrink-0 mt-3 justify-content-start align-items-center px-0\">\n <!-- <span *ngIf=\"backnav\" class=\"cursor-pointer\" (click)=\"backToFootfall()\">\n <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <g filter=\"url(#filter0_d_2585_7036)\">\n <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\n <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\n <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\n filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\n <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\n values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\n <feOffset dy=\"1\" />\n <feGaussianBlur stdDeviation=\"1\" />\n <feColorMatrix type=\"matrix\"\n values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\n <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\n result=\"effect1_dropShadow_2585_7036\" />\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\n result=\"shape\" />\n </filter>\n </defs>\n </svg>\n </span> -->\n <!-- <span class=\"img-direc ms-2 mt-1\">{{folderDate | date:'dd MMM, yyyy'}}\n <span class=\"badge badge-light-warning mx-2\"\n *ngIf=\"!getTicketStatuses().includes('closed') && getTicketStatuses().includes('open')\">\n Ticket Raised\n </span>\n <span class=\"badge badge-light-success mx-2\"\n *ngIf=\"getTicketStatuses().includes('closed')\">Ticket Closed</span>\n\n </span> -->\n <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\"\n class=\"ms-auto text-end\">\n <button [disabled]=\"!canEnableButton()\" class=\"btn btn-primary\" type=\"button\"\n (click)=\"Raised()\">\n Raise ticket\n </button>\n </div>\n </div>\n <div *ngIf=\"!folderView\" class=\"d-flex flex-wrap align-items-center justify-content-between w-100 my-2 gap-3\">\n <div class=\"nav-group bg-white border-1 btn-group w-auto\">\n <ng-container *ngIf=\"!(countData?.length > 0)\">\n \n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'footfall' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('footfall')\">\n Total Footfall\n <span\n [ngClass]=\"type === 'footfall' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.footfallCount || 0 }}\n </span>\n </button>\n \n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('non-tagging')\">\n Non-tags\n <span\n [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.nonTags || 0 }}\n </span>\n </button>\n \n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'duplicate' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('duplicate')\">\n Duplicated\n <span\n [ngClass]=\"type === 'duplicate' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.duplicate || 0 }}\n </span>\n </button>\n \n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'employee' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('employee')\">\n Employee/Staff\n <span\n [ngClass]=\"type === 'employee' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.employee || 0 }}\n </span>\n </button>\n <button class=\"btn btn-outline px-6 py-3\" [ngClass]=\"type === 'junk' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('junk')\">\n Junk\n <span\n [ngClass]=\"type === 'junk' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\n {{ countData?.junk || 0 }}\n </span>\n </button>\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'house-keeping' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('house-keeping')\">\n House Keeping\n <span\n [ngClass]=\"type === 'house-keeping' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\n {{ countData?.housekeeping || 0 }}\n </span>\n </button>\n \n \n </ng-container>\n \n </div>\n \n <div class=\"btn-group view-toggle ms-auto\" role=\"group\" aria-label=\"Toggle view\">\n <button type=\"button\" class=\"btn btn-outline px-3 py-2\" [ngClass]=\"{'active': viewMode === 'grid'}\"\n (click)=\"setViewMode('grid')\" aria-label=\"Grid view\">\n <svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"3\" y=\"3\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n [attr.fill]=\"viewMode === 'grid' ? '#EAF8FF' : 'none'\"></rect>\n <rect x=\"11\" y=\"3\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n [attr.fill]=\"viewMode === 'grid' ? '#EAF8FF' : 'none'\"></rect>\n <rect x=\"3\" y=\"11\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n [attr.fill]=\"viewMode === 'grid' ? '#EAF8FF' : 'none'\"></rect>\n <rect x=\"11\" y=\"11\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n [attr.fill]=\"viewMode === 'grid' ? '#EAF8FF' : 'none'\"></rect>\n </svg>\n </button>\n <button type=\"button\" class=\"btn btn-outline px-3 py-2\" [ngClass]=\"{'active': viewMode === 'list'}\"\n (click)=\"setViewMode('list')\" aria-label=\"List view\">\n <svg width=\"20\" height=\"18\" viewBox=\"0 0 20 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"2\" y=\"3\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n [attr.fill]=\"viewMode === 'list' ? '#EAF8FF' : 'none'\"></rect>\n <rect x=\"8\" y=\"4.5\" width=\"10\" height=\"1.5\" rx=\"0.75\" fill=\"#475467\"></rect>\n <rect x=\"8\" y=\"12.5\" width=\"10\" height=\"1.5\" rx=\"0.75\" fill=\"#475467\"></rect>\n <rect x=\"2\" y=\"11\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n [attr.fill]=\"viewMode === 'list' ? '#EAF8FF' : 'none'\"></rect>\n </svg>\n </button>\n </div>\n </div>\n <ng-container *ngIf=\"!imageFlow\">\n <div *ngIf=\"type === 'footfall' && viewMode === 'grid'\" class=\"d-flex mt-2 mb-2 w-100 overflow-x px-0\">\n <div class=\"col text-nowrap\" *ngFor=\"let obj of objectsArray\">\n <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\n <li class=\"nav-item cursor-pointer\">\n <a (click)=\"selectedTimes(obj.timeRange)\"\n [ngClass]=\"selectedTime === obj?.timeRange ? 'active' : ''\"\n class=\"nav-link cursor-pointer no-border mx-3 mb-2\">\n {{obj?.timeRange}}<span class=\"mx-2\"\n [ngClass]=\"selectedTime === obj?.timeRange ? 'badge-num-primary' :'badge-num-muted'\">\n {{ obj?.count ? obj?.count : 0 }}\n </span>\n </a>\n </li>\n </ul>\n </div>\n </div>\n </ng-container>\n\n <div *ngIf=\"loading\" class=\"row loader d-flex justify-content-center align-items-center\">\n <div class=\"shimmer\">\n <div class=\"wrapper\">\n <div class=\"stroke animate title\"></div>\n <div class=\"stroke animate link\"></div>\n <div class=\"stroke animate description\"></div>\n </div>\n </div>\n <div class=\"shimmer\">\n <div class=\"wrapper\">\n <div class=\"stroke animate title\"></div>\n <div class=\"stroke animate link\"></div>\n <div class=\"stroke animate description\"></div>\n </div>\n </div>\n </div>\n <div *ngIf=\"noData\" class=\"row\">\n\n <div class=\"col-lg-12 mb-3\">\n\n <div class=\"card-body d-flex justify-content-center align-items-center flex-column \" style=\"margin: 64px;border-radius: 8px;\nbackground: var(--Gray-50, #F9FAFB);\">\n <svg width=\"94\" height=\"94\" viewBox=\"0 0 94 94\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <rect x=\"7\" y=\"7\" width=\"80\" height=\"80\" rx=\"40\" fill=\"#DAF1FF\" />\n <rect x=\"7\" y=\"7\" width=\"80\" height=\"80\" rx=\"40\" stroke=\"#EAF8FF\"\n stroke-width=\"13.3333\" />\n <path\n d=\"M35.332 51.9999H33.6654C32.7813 51.9999 31.9335 51.6487 31.3083 51.0236C30.6832 50.3985 30.332 49.5506 30.332 48.6666V33.6666C30.332 32.7825 30.6832 31.9347 31.3083 31.3096C31.9335 30.6844 32.7813 30.3333 33.6654 30.3333H48.6654C49.5494 30.3333 50.3973 30.6844 51.0224 31.3096C51.6475 31.9347 51.9987 32.7825 51.9987 33.6666V35.3333M45.332 41.9999H60.332C62.173 41.9999 63.6654 43.4923 63.6654 45.3333V60.3333C63.6654 62.1742 62.173 63.6666 60.332 63.6666H45.332C43.4911 63.6666 41.9987 62.1742 41.9987 60.3333V45.3333C41.9987 43.4923 43.4911 41.9999 45.332 41.9999Z\"\n stroke=\"#00A3FF\" stroke-width=\"4\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <div class=\"nodata-title my-3\">\n {{ noDataMessages[type?.toLowerCase()] || 'No data found' }}\n </div>\n\n </div>\n </div>\n\n </div>\n\n\n <!-- Split-screen layout (only shown after clicking an image) -->\n <div class=\"split-screen-container\" *ngIf=\"splitScreenEnabled && !noData && !loading\">\n <!-- Left Panel: Thumbnail List + Related Images -->\n <div class=\"left-panel\">\n <!-- Main Images List (hidden when duplicate is selected) -->\n <ng-container *ngIf=\"selectedRadioType !== 'duplicate'\">\n <div class=\"thumbnail-list-section\" *ngFor=\"let group of listViewGroups\">\n <div class=\"time-range-header\">\n <span class=\"time-range-title\">{{ group?.timeRange }}</span>\n <span class=\"time-range-count\">#{{ group?.data?.length || 0 }}</span>\n </div>\n <div class=\"thumbnail-grid\">\n <div class=\"thumbnail-item\" *ngFor=\"let obj of group?.data\"\n [ngClass]=\"{'selected': selectImageArray?.templd === obj?.templd}\"\n (click)=\"selectImageForSplitView(obj)\">\n <img class=\"thumbnail-image\" [src]=\"imageUrl + obj?.filePath\"\n (error)=\"obj.filePath = null\" alt=\"\" *ngIf=\"obj?.filePath\" />\n <div *ngIf=\"!obj?.filePath\" class=\"no-preview\"\n style=\"height: 120px; padding: 20px;\">\n <span style=\"color: #667085; font-size: 11px;\">No preview</span>\n </div>\n <div class=\"thumbnail-info\">\n <div class=\"tango-id\">Tango ID: {{ obj?.templd }}</div>\n <div class=\"entry-time\">Entry Time: {{ obj?.entryTme || obj?.entryTime\n }}</div>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n\n <!-- Related Images Section (ONLY shown when duplicate is selected) -->\n <div class=\"thumbnail-list-section\"\n *ngIf=\"selectedRadioType === 'duplicate' && remainingImagesGroups && remainingImagesGroups.length > 0\">\n <!-- <div class=\"time-range-header\">\n <span class=\"time-range-title\">Select related images</span>\n </div> -->\n <div class=\"thumbnail-list-section\" *ngFor=\"let group of remainingImagesGroups\">\n <div class=\"time-range-header\" style=\"margin-top: 16px;\">\n <span class=\"time-range-title\">{{ group?.timeRange }}</span>\n <span class=\"time-range-count\">#{{ group?.data?.length || 0 }}</span>\n </div>\n <div class=\"thumbnail-grid\">\n <div class=\"thumbnail-item\" *ngFor=\"let obj of group?.data\"\n [ngClass]=\"{'selected': obj.selected}\">\n <div class=\"position-relative\">\n <input *ngIf=\"!revopsTypeValue && selectedRadioType === 'duplicate'\"\n type=\"checkbox\" [checked]=\"obj.selected\"\n class=\"position-absolute absolute form-check-input cursor-pointer\"\n style=\"top: 5px; right: 5px; z-index: 2;\"\n (change)=\"onImageCheckboxChange($event, obj, 'duplicate')\"\n (click)=\"$event.stopPropagation()\"\n [disabled]=\"obj.duplicateImagePath?.length > 0\" />\n <img class=\"thumbnail-image cursor-pointer\"\n [src]=\"imageUrl + obj?.filePath\" (error)=\"obj.filePath = null\"\n alt=\"\" *ngIf=\"obj?.filePath\"\n (click)=\"handleImageClick($event, obj)\" />\n <div *ngIf=\"!obj?.filePath\" class=\"no-preview cursor-pointer\"\n style=\"height: 120px; padding: 20px;\"\n (click)=\"handleImageClick($event, obj)\">\n <span style=\"color: #667085; font-size: 11px;\">No preview</span>\n </div>\n <div class=\"thumbnail-info\">\n <div class=\"tango-id\">Tango ID: {{ obj?.templd || obj?.tempId }}\n </div>\n <div class=\"entry-time\">Entry Time: {{ obj?.entryTme ||\n obj?.entryTime }}</div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Right Panel: Selected Image Details -->\n <div class=\"right-panel\" *ngIf=\"selectImageArray\">\n <ng-container\n *ngTemplateOutlet=\"imageDetailView; context: { $implicit: selectImageArray }\"></ng-container>\n </div>\n <div class=\"right-panel\" *ngIf=\"!selectImageArray\"\n style=\"display: flex; align-items: center; justify-content: center; color: var(--Gray-500, #667085);\">\n <div style=\"text-align: center;\">\n <p style=\"font-size: 16px; font-weight: 500;\">Select an image to view details</p>\n </div>\n </div>\n </div>\n\n <!-- Image Detail View Template for Split-Screen Right Panel -->\n <ng-template #imageDetailView let-obj>\n <div class=\"border-gray p-3 mb-3\">\n <div class=\"position-relative\">\n <img class=\"img-src1\" [src]=\"imageUrl + obj?.filePath\" alt=\"\" *ngIf=\"obj?.filePath\" />\n <!-- Zoom Icon -->\n <div class=\"zoom-icon-button\" (click)=\"openImageZoomModal(imageUrl, obj)\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\"\n fill=\"none\">\n <path\n d=\"M18.3333 18.3333L15 15M16.6667 9.16667C16.6667 13.3067 13.3067 16.6667 9.16667 16.6667C5.02667 16.6667 1.66667 13.3067 1.66667 9.16667C1.66667 5.02667 5.02667 1.66667 9.16667 1.66667C13.3067 1.66667 16.6667 5.02667 16.6667 9.16667Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n <path d=\"M9.16667 6.66667V11.6667M6.66667 9.16667H11.6667\" stroke=\"#475467\"\n stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </div>\n <div *ngIf=\"!obj?.filePath\" class=\"no-preview\" style=\"height: 375px;\">\n <span class=\"mb-5\">\n <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"Group\">\n <path id=\"Vector\"\n d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n <path id=\"Vector_2\"\n d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n </svg>\n </span>\n <span class=\"header mb-5 text-center\">Preview not available</span>\n <span class=\"description mb-5 text-center\">The selected camera is not available at\n the moment.</span>\n </div>\n </div>\n <div class=\"row px-2 mb-2 mt-3\">\n <div class=\"col-md-7\">\n <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd}}\n <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\">\n <svg style=\"width: 20px; height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\"\n width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n fill=\"#12B76A\" />\n </svg>\n </span>\n <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\">\n <svg style=\"width: 20px; height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\"\n width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n <g clip-path=\"url(#clip0_1428_59484)\">\n <path\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n fill=\"#FEE4E2\" />\n <path\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n stroke=\"#D92D20\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_1428_59484\">\n <rect width=\"12\" height=\"12\" fill=\"white\"\n transform=\"translate(0.599609 0.5)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n </div>\n <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme || obj?.entryTime}}</div>\n </div>\n <div class=\"col-md-5 text-end py-3\">\n <span *ngIf=\"obj?.revopsType ==='non-tagging'\" ngbTooltip=\"Yet to tag the customer\"\n placement=\"top\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\n viewBox=\"0 0 19 18\" fill=\"none\">\n <path\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='duplicate'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='employee'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\n viewBox=\"0 0 21 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='junk'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\n viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n </div>\n </div>\n </div>\n <div class=\"border-gray p-3\">\n <div class=\"row mb-3\">\n <div class=\"col-md-6 title-type\">Select non-shopper type</div>\n <div class=\"col-md-6 text-end\"\n *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\n <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\" class=\"mb-3 text-end d-inline-flex align-items-center gap-2\">\n <!-- Clear Tag Button (visible when Edit button OR Save/Cancel buttons are visible) -->\n <button\n *ngIf=\"!revopsTypeValue || (revopsTypeValue && editBtnShow)\"\n [disabled]=\"(selectedRadioType === undefined || selectedRadioType === '') || (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\"\n class=\"btn btn-clear-tag d-inline-flex align-items-center justify-content-center\" type=\"button\"\n (click)=\"clearValue()\">\n <svg width=\"49\" height=\"49\" viewBox=\"0 0 49 49\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g filter=\"url(#filter0_d_516_96841)\">\n <rect x=\"2.16797\" y=\"1.08447\" width=\"44.0342\" height=\"44.0284\" rx=\"8.67445\" fill=\"#FEF3F2\" />\n <rect x=\"2.71012\" y=\"1.62663\" width=\"42.9499\" height=\"42.9441\" rx=\"8.13229\" stroke=\"#FEF3F2\"\n stroke-width=\"1.08431\" />\n <path\n d=\"M33.4893 21.3613L33.4912 21.3643C34.0533 21.9297 34.369 22.6949 34.3691 23.4922C34.3691 24.2895 34.0533 25.0546 33.4912 25.6201L26.7256 32.3857C26.4454 32.6661 26.1122 32.8882 25.7461 33.04C25.3798 33.1919 24.9873 33.2705 24.5908 33.2705C24.1942 33.2705 23.801 33.1919 23.4346 33.04C23.0686 32.8883 22.7361 32.6659 22.4561 32.3857L20.7676 30.6992L22.3682 29.0986L24.0557 30.7842L24.0566 30.7852C24.1267 30.8553 24.2102 30.9112 24.3018 30.9492C24.3933 30.9872 24.4917 31.0068 24.5908 31.0068C24.6899 31.0068 24.7883 30.9872 24.8799 30.9492C24.9713 30.9113 25.0541 30.8552 25.124 30.7852H25.125L31.8877 24.0215C32.0267 23.8804 32.1055 23.6903 32.1055 23.4922C32.1054 23.2941 32.0267 23.1039 31.8877 22.9629L30.1963 21.2715L31.7979 19.6699L33.4893 21.3613ZM24.6982 12.9336C24.9571 12.9594 25.2011 13.0733 25.3867 13.2588L30.1973 18.0693L28.5957 19.6709L24.1162 15.1914H16.2852V23.0225L20.7666 27.499L19.166 29.0996L14.3535 24.293C14.1411 24.0807 14.0215 23.7925 14.0215 23.4922V14.0596C14.0217 13.4346 14.5283 12.9277 15.1533 12.9277H24.5859L24.6982 12.9336ZM19.8789 17.6436C20.5038 17.6436 21.0103 18.1506 21.0107 18.7754C21.0107 19.4005 20.504 19.9082 19.8789 19.9082H19.8691C19.2442 19.908 18.7373 19.4004 18.7373 18.7754C18.7378 18.1508 19.2445 17.6438 19.8691 17.6436H19.8789Z\"\n fill=\"#B42318\" />\n <path d=\"M33.1699 14.0845L15.1699 32.0845\" stroke=\"#B42318\" stroke-width=\"2\" stroke-linecap=\"round\" />\n </g>\n <defs>\n <filter id=\"filter0_d_516_96841\" x=\"-0.000643253\" y=\"0.000166655\" width=\"48.3724\" height=\"48.3655\"\n filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\n <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\"\n result=\"hardAlpha\" />\n <feOffset dy=\"1.08431\" />\n <feGaussianBlur stdDeviation=\"1.08431\" />\n <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\n <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_516_96841\" />\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_516_96841\" result=\"shape\" />\n </filter>\n </defs>\n </svg>\n </button>\n <!-- Cancel and Save Buttons (when !revopsTypeValue) -->\n <div *ngIf=\"!revopsTypeValue\">\n <button class=\"btn btn-outline me-2\" (click)=\"cancel()\">Cancel</button>\n <button class=\"btn btn-primary\" id=\"alert-toast\"\n (click)=\"save(selectedType)\"\n [disabled]=\"(selectedRadioType === undefined || selectedRadioType === '') || (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\">Save</button>\n </div>\n <!-- Edit Button (when revopsTypeValue && editBtnShow) -->\n <div *ngIf=\"revopsTypeValue && editBtnShow\">\n <button\n class=\"btn btn-outline me-2\" (click)=\"editValue()\">\n <span class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\"\n height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M14.6554 1.71047C14.8927 1.47315 15.1745 1.2849 15.4845 1.15646C15.7946 1.02802 16.1269 0.961914 16.4626 0.961914C16.7982 0.961914 17.1305 1.02802 17.4406 1.15646C17.7507 1.2849 18.0324 1.47315 18.2697 1.71047C18.5071 1.94779 18.6953 2.22953 18.8238 2.53961C18.9522 2.84969 19.0183 3.18202 19.0183 3.51765C19.0183 3.85327 18.9522 4.18561 18.8238 4.49568C18.6953 4.80576 18.5071 5.0875 18.2697 5.32482L6.0713 17.5233L1.10156 18.8786L2.45695 13.9089L14.6554 1.71047Z\"\n stroke=\"#344054\" stroke-width=\"1.81079\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg></span>Edit\n </button>\n </div>\n </div>\n </div>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"duplicate\"\n id=\"duplicate-split\" [(ngModel)]=\"selectedType\" [value]=\"'duplicate'\"\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n <label class=\"form-check-label\" for=\"duplicate-split\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg></span>\n <span class=\"ms-5 tag-class\">Duplicate</span>\n </label>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"employee\"\n id=\"employee-split\" [(ngModel)]=\"selectedType\" [value]=\"'employee'\"\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n <label class=\"form-check-label\" for=\"employee-split\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg></span>\n <span class=\"ms-5 tag-class\">Employee/Staff</span>\n </label>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"house-keeping\"\n id=\"house-keeping-split\" [(ngModel)]=\"selectedType\" [value]=\"'house-keeping'\"\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n <label class=\"form-check-label\" for=\"house-keeping-split\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\n viewBox=\"0 0 21 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg></span>\n <span class=\"ms-5 tag-class\">House Keeping</span>\n </label>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"junk\" id=\"junk-split\"\n [(ngModel)]=\"selectedType\" [value]=\"'junk'\" (change)=\"onRadioChange(selectedType)\"\n [disabled]=\"users?.role ==='user' && users?.userType ==='client' || revopsTypeValue\">\n <label class=\"form-check-label\" for=\"junk-split\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\n viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg></span>\n <span class=\"ms-5 tag-class\">Junk</span>\n </label>\n </div>\n <div class=\"mt-3\">\n <label class=\"form-label\">Remarks (Optional)</label>\n <textarea class=\"form-control\" rows=\"3\" placeholder=\"Comment here\"\n [(ngModel)]=\"userComment\"></textarea>\n </div>\n </div>\n </ng-template>\n\n <!-- Grid/List View (shown when split-screen is not enabled) -->\n <div class=\"row px-0 img-traffic contain high-400px scroll-y\"\n *ngIf=\"viewMode === 'grid' && !noData && !loading && !splitScreenEnabled\">\n <ng-container *ngFor=\"let obj of imagesArrayData\">\n <ng-container *ngTemplateOutlet=\"imageCard; context: { $implicit: obj }\"></ng-container>\n </ng-container>\n </div>\n\n <div class=\"list-view-wrapper\"\n *ngIf=\"viewMode === 'list' && !noData && !loading && !splitScreenEnabled\">\n <div class=\"list-group mb-5\" *ngFor=\"let group of listViewGroups\">\n <div class=\"list-group-header d-flex align-items-center mb-3\">\n <div class=\"group-title\">{{ group?.timeRange }}</div>\n <span class=\"group-count badge badge-light-default ms-2\">\n #{{ group?.data?.length || 0 }}\n </span>\n </div>\n <div class=\"row gx-4 list-group-row\">\n <ng-container *ngFor=\"let obj of group?.data\">\n <ng-container\n *ngTemplateOutlet=\"imageCard; context: { $implicit: obj }\"></ng-container>\n </ng-container>\n </div>\n </div>\n </div>\n\n <ng-template #imageCard let-obj>\n <div *ngIf=\"type !== 'duplicate' || (type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\"\n class=\"col-md-3 border-gray mx-2 p-2 mt-5\">\n <!-- Condition: Only show if not duplicate OR duplicate with non-empty duplicateImagePath -->\n <ng-container>\n <img class=\"img-src cursor-pointer\" [src]=\"imageUrl + obj?.filePath\" (error)=\"obj.filePath = null\" alt=\"\"\n (click)=\"selectImageForSplitView(obj)\" />\n </ng-container>\n \n <div *ngIf=\"!obj?.filePath\" class=\"no-preview\">\n <span class=\"mb-5\">\n <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"Group\">\n <path id=\"Vector\" d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path id=\"Vector_2\"\n d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n </svg>\n \n </span>\n <span class=\"header mb-5 text-center\">Preview not available</span>\n <span class=\"description mb-5 text-center\">The selected camera is not available at\n the\n moment.</span>\n </div>\n <div *ngIf=\"type !== 'duplicate' || (type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\"\n class=\"row px-2 mb-2\">\n <div class=\"col-md-7\">\n <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd}} <span\n *ngIf=\"(type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\"\n class=\"mx-2 badge badge-light-primary\">{{obj.duplicateImagePath?.length}}\n </span>\n <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\">\n <svg style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\"\n height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n fill=\"#12B76A\" />\n </svg>\n </span>\n <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\">\n <svg style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\"\n height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n <g clip-path=\"url(#clip0_1428_59484)\">\n <path\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n fill=\"#FEE4E2\" />\n <path\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n stroke=\"#D92D20\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_1428_59484\">\n <rect width=\"12\" height=\"12\" fill=\"white\" transform=\"translate(0.599609 0.5)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n </div>\n <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme}}</div>\n </div>\n <div class=\"col-md-5 text-end py-3\">\n <span *ngIf=\"obj?.revopsType ==='non-tagging'\" ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 19 18\" fill=\"none\">\n <path\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='duplicate'\">\n <svg *ngIf=\"obj?.isParent\" width=\"20\" height=\"21\" viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g clip-path=\"url(#clip0_568_103657)\">\n <path\n d=\"M2.08398 6.25001H1.66732C1.4463 6.25001 1.23434 6.16221 1.07806 6.00593C0.921782 5.84965 0.833984 5.63769 0.833984 5.41668V1.66668C0.833984 1.44566 0.921782 1.2337 1.07806 1.07742C1.23434 0.921141 1.4463 0.833344 1.66732 0.833344H5.41732C5.63833 0.833344 5.85029 0.921141 6.00657 1.07742C6.16285 1.2337 6.25065 1.44566 6.25065 1.66668V2.08334M4.58398 3.75001H8.33398C8.79422 3.75001 9.16732 4.12311 9.16732 4.58334V8.33334C9.16732 8.79358 8.79422 9.16668 8.33398 9.16668H4.58398C4.12375 9.16668 3.75065 8.79358 3.75065 8.33334V4.58334C3.75065 4.12311 4.12375 3.75001 4.58398 3.75001Z\"\n stroke=\"#475467\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n <rect x=\"4\" y=\"4\" width=\"5\" height=\"5\" fill=\"#475467\" />\n <defs>\n <clipPath id=\"clip0_568_103657\">\n <rect width=\"10\" height=\"10\" fill=\"white\" />\n </clipPath>\n </defs>\n </svg>\n <svg *ngIf=\"!obj?.isParent\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='employee'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 21 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\" transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='junk'\">\n \n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </span>\n </div>\n </div>\n </div>\n </ng-template>\n\n </div>\n </section>\n\n <!-- full image View -->\n <section *ngIf=\"imageFlow\">\n <div class=\"row\">\n <!-- Ticket Block Alert -->\n <div *ngIf=\"getSelectedDateCardData()?.raisedStatusEnabled === 'block'\" class=\"col-12 mb-3\">\n <div class=\"ticket-block-alert\">\n <div class=\"ticket-block-alert-content\">\n <div class=\"ticket-block-alert-icon\">\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <circle cx=\"12\" cy=\"12\" r=\"12\" fill=\"#F04438\" />\n <path d=\"M12 8V13\" stroke=\"white\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n </svg>\n </div>\n <div class=\"ticket-block-alert-text\">\n <div class=\"ticket-block-alert-title\">\n You cannot raise ticket for next {{ getSelectedDateCardData()?.noOfBlockedDays\n || '0' }} days\n </div>\n <div class=\"ticket-block-alert-description\">\n It looks like you have achieved 95% accuracy for the three tickets raised this\n month. This limits you from raising more tickets to avoid redundancy.\n </div>\n <div class=\"ticket-block-alert-action\">\n If you still want to raise tickets, <span class=\"ticket-block-alert-link\"\n (click)=\"requestReset()\">send request</span> to reset.\n </div>\n </div>\n </div>\n </div>\n </div>\n <!-- Ticket Request Success Alert -->\n <div *ngIf=\"getSelectedDateCardData()?.raisedStatusEnabled === 'request'\" class=\"col-12 mb-3\">\n <div class=\"ticket-request-alert\">\n <div class=\"ticket-request-alert-content\">\n <div class=\"ticket-request-alert-icon\">\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M2 21L23 12L2 3V10L17 12L2 14V21Z\" fill=\"#10B981\" />\n </svg>\n </div>\n <div class=\"ticket-request-alert-text\">\n <div class=\"ticket-request-alert-title\">\n Reset Request Sent\n </div>\n <div class=\"ticket-request-alert-description\">\n Your request to enable ticket raising has been submitted. You'll be notified\n once it's approved. Please ensure future ticket accuracy remains within the 95%\n threshold.\n </div>\n </div>\n </div>\n </div>\n </div>\n <div class=\"d-flex mt-2 mb-2 w-100 overflow-x px-0\">\n <ng-container *ngTemplateOutlet=\"footfallTrendsTemplate\"></ng-container>\n </div>\n <ng-container *ngTemplateOutlet=\"ticketStatusTemplate\"></ng-container>\n <span class=\"divider\"></span>\n <div class=\"d-flex flex-shrink-0 mt-3 justify-content-start align-items-center px-0\">\n <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\"\n class=\"ms-auto text-end\">\n\n <button [disabled]=\"!canEnableButton()\" class=\"btn btn-primary\" type=\"button\"\n (click)=\"Raised()\">\n Raise ticket\n </button>\n </div>\n </div>\n <div class=\"nav-group bg-white border-1 btn-group w-auto\">\n <ng-container *ngIf=\"!(countData?.length > 0)\">\n\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'footfall' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('footfall')\">\n Total Footfall\n <span\n [ngClass]=\"type === 'footfall' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.footfallCount || 0 }}\n </span>\n </button>\n\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('non-tagging')\">\n Non-tags\n <span\n [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.nonTags || 0 }}\n </span>\n </button>\n\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'duplicate' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('duplicate')\">\n Duplicated\n <span\n [ngClass]=\"type === 'duplicate' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.duplicate || 0 }}\n </span>\n </button>\n\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'employee' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('employee')\">\n Employee/Staff\n <span\n [ngClass]=\"type === 'employee' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n {{ countData?.employee || 0 }}\n </span>\n </button>\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'junk' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('junk')\">\n Junk\n <span\n [ngClass]=\"type === 'junk' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\n {{ countData?.junk || 0 }}\n </span>\n </button>\n <button class=\"btn btn-outline px-6 py-3\"\n [ngClass]=\"type === 'house-keeping' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n (click)=\"selectPlanTrends('house-keeping')\">\n House Keeping\n <span\n [ngClass]=\"type === 'house-keeping' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\n {{ countData?.housekeeping || 0 }}\n </span>\n </button>\n\n </ng-container>\n\n </div>\n\n <div class=\"row mx-0 border-gray img-traffic\" *ngIf=\"!noData && !loading\">\n <div class=\"col-md-6 p-2 mb-2 mt-5\">\n <div class=\"position-relative border-gray p-2 \">\n <!-- Main Image -->\n <!-- <img class=\"img-src cursor-pointer h-450px\"\n (click)=\"selectedImageArray(imageUrl, selectImageArray)\"\n [src]=\"imageUrl + selectImageArray?.filePath\" appMagnifier alt=\"\"> -->\n <img class=\"img-src cursor-pointer h-450px\"\n (click)=\"selectedImageArray(imageUrl, selectImageArray)\"\n [src]=\"imageUrl + selectImageArray?.filePath\" alt=\"\">\n\n <!-- Right arrow button -->\n <div class=\"row px-2 mb-2\">\n <div class=\"col-md-7\">\n <div class=\"py-2 img-doc-time\">Tango ID : {{selectImageArray?.templd}}\n <span *ngIf=\"selectImageArray?.status ==='approved'\" class=\"ms-2\"><svg\n style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n fill=\"#12B76A\" />\n </svg></span>\n <span *ngIf=\"selectImageArray?.status ==='rejected'\" class=\"ms-2\"><svg\n style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n <g clip-path=\"url(#clip0_1428_59484)\">\n <path\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n fill=\"#FEE4E2\" />\n <path\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n stroke=\"#D92D20\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_1428_59484\">\n <rect width=\"12\" height=\"12\" fill=\"white\"\n transform=\"translate(0.599609 0.5)\" />\n </clipPath>\n </defs>\n </svg></span>\n </div>\n <div class=\"img-doc-value\">Entry Time : {{(tempModalImage ||\n selectImageArray)?.entryTme || (tempModalImage ||\n selectImageArray)?.entryTime}}</div>\n </div>\n <div class=\"col-md-5 text-end py-3\">\n <span *ngIf=\"(tempModalImage || selectImageArray)?.revopsType ==='non-tagging'\"\n ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\n viewBox=\"0 0 19 18\" fill=\"none\">\n <path\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n <span *ngIf=\"selectImageArray?.revopsType ==='duplicate'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"selectImageArray?.revopsType ==='employee'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"selectImageArray?.revopsType ==='house-keeping'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\n viewBox=\"0 0 21 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"col-md-6 p-2 mb-2 mt-5\">\n <div class=\"mx-2 \">\n <div class=\"row\">\n <div class=\"col-md-6 title-type\">\n Select non-shopper type\n </div>\n\n\n <section class=\"col-md-6 text-end\"\n *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\n\n <div *ngIf=\"!revopsTypeValue\" class=\"mb-5 text-end\" role=\"group\">\n <div\n *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\">\n\n <button [disabled]=\"\n (selectedRadioType === undefined || selectedRadioType === '') ||\n (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\n \" class=\"btn btn-default\" type=\"button\" (click)=\"clearValue()\">Clear</button>\n <button class=\"btn btn-outline me-2\" (click)=\"cancel()\">Cancel</button>\n <button class=\"btn btn-primary\" id=\"alert-toast\"\n (click)=\"save(selectedType)\" [disabled]=\"\n (selectedRadioType === undefined || selectedRadioType === '') ||\n (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\n \">\n Save\n </button>\n </div>\n </div>\n\n <div\n *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\n <ng-container *ngIf=\"editBtnShow\">\n <div *ngIf=\"revopsTypeValue\" class=\"mb-5 text-end\" role=\"group\">\n <button\n *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\"\n class=\"btn btn-outline me-2\" (click)=\"editValue()\"><span\n class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\"\n width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M14.6554 1.71047C14.8927 1.47315 15.1745 1.2849 15.4845 1.15646C15.7946 1.02802 16.1269 0.961914 16.4626 0.961914C16.7982 0.961914 17.1305 1.02802 17.4406 1.15646C17.7507 1.2849 18.0324 1.47315 18.2697 1.71047C18.5071 1.94779 18.6953 2.22953 18.8238 2.53961C18.9522 2.84969 19.0183 3.18202 19.0183 3.51765C19.0183 3.85327 18.9522 4.18561 18.8238 4.49568C18.6953 4.80576 18.5071 5.0875 18.2697 5.32482L6.0713 17.5233L1.10156 18.8786L2.45695 13.9089L14.6554 1.71047Z\"\n stroke=\"#344054\" stroke-width=\"1.81079\"\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg></span>Edit</button>\n\n </div>\n </ng-container>\n </div>\n </section>\n\n </div>\n\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"duplicate\"\n id=\"duplicate\" [(ngModel)]=\"selectedType\" [value]=\"'duplicate'\"\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n <label class=\"form-check-label\" for=\"duplicate\">\n <span class=\"ms-5\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span class=\"ms-5 tag-class\">Duplicate</span>\n </label>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"employee\"\n id=\"employee\" [(ngModel)]=\"selectedType\" [value]=\"'employee'\"\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n <label class=\"form-check-label\" for=\"employee\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\"\n height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg></span>\n <span class=\"ms-5 tag-class\">Employee/Staff</span>\n </label>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"house-keeping\"\n id=\"house-keeping\" [(ngModel)]=\"selectedType\" [value]=\"'house-keeping'\"\n (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n <label class=\"form-check-label\" for=\"house-keeping\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\"\n height=\"21\" viewBox=\"0 0 21 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg></span>\n <span class=\"ms-5 tag-class\"> House Keeping</span>\n </label>\n </div>\n <div class=\"form-check my-15\">\n <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"junk\" id=\"junk\"\n [(ngModel)]=\"selectedType\" [value]=\"'junk'\"\n (change)=\"onRadioChange(selectedType)\"\n [disabled]=\"users?.role ==='user' && this.users?.userType ==='client' || revopsTypeValue\">\n <label class=\"form-check-label\" for=\"junk\">\n <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\"\n height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg></span>\n <span class=\"ms-5 tag-class\"> Junk</span>\n </label>\n </div>\n </div>\n\n\n </div>\n </div>\n\n\n <div class=\"row px-0 img-traffic mt-3 high-400px scroll-y\">\n <div class=\"col-md-3 border-gray mx-2 p-2 mt-5\" *ngFor=\"let obj of remainingImageArray\">\n <div class=\"position-relative\">\n <input *ngIf=\"!revopsTypeValue && selectedRadioType === 'duplicate'\" type=\"checkbox\"\n [checked]=\"obj.selected\"\n class=\"position-absolute absolute form-check-input cursor-pointer\"\n (change)=\"onImageCheckboxChange($event, obj, 'duplicate')\"\n [disabled]=\"obj.duplicateImagePath?.length > 0\" />\n\n <img class=\"img-src\"\n [ngClass]=\"selectedRadioType !== 'duplicate' ? 'cursor-pointer' : 'cursor-pointer'\"\n [src]=\"imageUrl + obj?.filePath\" (error)=\"obj.filePath = null\" alt=\"\"\n (click)=\"handleImageClick($event, obj)\" />\n\n <div *ngIf=\"!obj?.filePath\" class=\"no-preview\">\n <span class=\"mb-5\">\n <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"Group\">\n <path id=\"Vector\"\n d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n <path id=\"Vector_2\"\n d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n </svg>\n\n </span>\n <span class=\"header mb-5 text-center\">Preview not available</span>\n <span class=\"description mb-5 text-center\">The selected camera is not available at\n the\n moment.</span>\n </div>\n <div class=\"row px-2 mb-2\">\n <div class=\"col-md-7\">\n <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd ? obj?.templd :\n obj?.tempId}}\n <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n fill=\"#12B76A\" />\n </svg></span>\n <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n <g clip-path=\"url(#clip0_1428_59484)\">\n <path\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n fill=\"#FEE4E2\" />\n <path\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n stroke=\"#D92D20\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_1428_59484\">\n <rect width=\"12\" height=\"12\" fill=\"white\"\n transform=\"translate(0.599609 0.5)\" />\n </clipPath>\n </defs>\n </svg></span>\n </div>\n <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme ? obj?.entryTme\n :obj?.entryTime}}</div>\n </div>\n <div class=\"col-md-5 text-end py-3\">\n <span *ngIf=\"obj?.revopsType ==='non-tagging'\"\n ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\n viewBox=\"0 0 19 18\" fill=\"none\">\n <path\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='duplicate'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='employee'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n viewBox=\"0 0 20 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\n viewBox=\"0 0 21 21\" fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"obj?.revopsType ==='junk'\">\n\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\n viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n </div>\n </section>\n </div>\n </section>\n</div>\n\n\n<ng-template #zoomPopup let-model>\n <div class=\"p-4 m-4\">\n <div class=\"modal-header border-0 p-0 w-100 flex-column align-items-start\">\n <span *ngIf=\"popupType === 'non-tagging'\" class=\"my-3\">\n\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\n <rect width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\n <g clip-path=\"url(#clip0_2088_98337)\">\n <path\n d=\"M29.1693 13.3333V18.3333M29.1693 18.3333H24.1693M29.1693 18.3333L25.3026 14.7C24.407 13.8039 23.299 13.1493 22.0819 12.7973C20.8649 12.4453 19.5785 12.4073 18.3428 12.6869C17.1072 12.9665 15.9624 13.5545 15.0155 14.3962C14.0685 15.2378 13.3502 16.3056 12.9276 17.5M10.8359 26.6666V21.6666M10.8359 21.6666H15.8359M10.8359 21.6666L14.7026 25.3C15.5982 26.1961 16.7062 26.8506 17.9233 27.2027C19.1403 27.5547 20.4267 27.5927 21.6624 27.3131C22.898 27.0335 24.0428 26.4455 24.9897 25.6038C25.9367 24.7621 26.655 23.6943 27.0776 22.5\"\n stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2088_98337\">\n <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(10 10)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <!-- Heading -->\n <h5 class=\"modal-title mb-2\">\n <span *ngIf=\"popupType === 'employee'\">Tagging as employee/staff </span>\n <span *ngIf=\"popupType === 'duplicate'\">Tagging as duplicates </span>\n <span *ngIf=\"popupType === 'house-keeping'\">Tagging as house keeping </span>\n <span *ngIf=\"popupType === 'non-tagging'\">Clear duplicates</span>\n <span *ngIf=\"popupType ==='junk'\">Tagging as junk</span>\n\n </h5>\n <p class=\"mb-3\">\n <span *ngIf=\"popupType === 'employee'\">Are you sure you want to tag this as employee/staff?</span>\n <span *ngIf=\"popupType === 'duplicate'\">Are you sure you want to tag this as duplicates? </span>\n <span *ngIf=\"popupType === 'house-keeping'\">Are you sure you want to tag this as house keeping? </span>\n <span *ngIf=\"popupType === 'non-tagging'\">This will remove tagged duplicates and move them to\n 'Non-tag'.</span>\n <span *ngIf=\"popupType ==='junk'\">Are you sure you want to tag this as junk?</span>\n\n </p>\n </div>\n\n <div class=\"w-100 mt-5 d-flex justify-content-end\">\n <button class=\"btn btn-outline me-2\" (click)=\"cancelSubmit()\">Cancel</button>\n <button *ngIf=\"popupType !== 'non-tagging'\" class=\"btn btn-primary\" (click)=\"submitValue(popupType)\">\n Yes, Tag\n </button>\n <button *ngIf=\"popupType === 'non-tagging'\" class=\"btn btn-primary\" (click)=\"submitValue(popupType)\">\n Yes, clear\n </button>\n </div>\n </div>\n</ng-template>\n\n\n<ng-template #raisedPopup let-model>\n <div class=\"p-4 m-4\">\n <div class=\"modal-header border-0 p-0 w-100 flex-column align-items-start\">\n <span class=\"my-3\">\n\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\n <rect width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\n <path\n d=\"M21.251 11.0806C21.7405 11.0699 22.2153 11.2487 22.5762 11.5796L23.4922 12.4204C23.8089 12.7097 23.893 13.1017 23.8652 13.4263V13.4272C23.836 13.7478 23.6954 14.0592 23.4785 14.2944C23.3699 14.413 23.2865 14.5525 23.2314 14.7036C23.1764 14.8548 23.1512 15.0155 23.1582 15.1763C23.1652 15.337 23.2035 15.4953 23.2715 15.6411C23.3394 15.7869 23.4362 15.9172 23.5547 16.0259C23.6733 16.1346 23.8117 16.2198 23.9629 16.2749C24.1141 16.33 24.2748 16.3541 24.4355 16.3472C24.5961 16.3402 24.7537 16.3017 24.8994 16.2339C25.0089 16.1829 25.1106 16.116 25.2002 16.0356L25.3701 15.8657C25.5759 15.6748 25.8385 15.5408 26.1152 15.4907C26.2972 15.4546 26.485 15.4617 26.6641 15.5103C26.8439 15.5591 27.0103 15.649 27.1494 15.7729L27.1514 15.7749L28.2598 16.7905C28.445 16.9605 28.5948 17.1658 28.7002 17.394C28.8056 17.6223 28.8648 17.8694 28.874 18.1206C28.8832 18.372 28.8423 18.6234 28.7539 18.8589C28.6655 19.0941 28.5316 19.3096 28.3594 19.4927L20.1113 28.2583C19.937 28.4434 19.7268 28.5912 19.4941 28.6938C19.2614 28.7965 19.0102 28.8522 18.7559 28.856C18.5016 28.8597 18.2493 28.8119 18.0137 28.7163C17.7779 28.6206 17.5636 28.4784 17.3838 28.2983L16.2539 27.1685C15.7511 26.6656 15.8832 25.9552 16.1514 25.5542L16.2061 25.4644C16.3241 25.2486 16.3742 25.0008 16.3496 24.7544C16.3214 24.4731 16.197 24.2102 15.9971 24.0103C15.7971 23.8103 15.5343 23.6859 15.2529 23.6577C14.9715 23.6297 14.6887 23.6995 14.4531 23.856H14.4521C14.0494 24.1222 13.3407 24.2552 12.8379 23.7515L11.6797 22.5933C11.5034 22.4169 11.364 22.2074 11.2686 21.9771C11.1731 21.7467 11.1231 21.4999 11.123 21.2505C11.123 21.001 11.1731 20.7535 11.2686 20.5229C11.364 20.2926 11.5034 20.0831 11.6797 19.9067L19.9492 11.6362C20.2954 11.2902 20.7616 11.0912 21.251 11.0806ZM21.2783 12.3804C21.1237 12.3838 20.9765 12.4468 20.8672 12.5562L12.5967 20.8257C12.5409 20.8814 12.497 20.9482 12.4668 21.021C12.4367 21.0938 12.4209 21.1717 12.4209 21.2505C12.4209 21.3292 12.4367 21.4073 12.4668 21.48C12.497 21.5528 12.541 21.6196 12.5967 21.6753L13.7061 22.7837L13.7314 22.772C14.2169 22.4485 14.7993 22.3035 15.3799 22.3608C15.9608 22.4183 16.5042 22.6747 16.917 23.0874C17.3298 23.5002 17.587 24.0436 17.6445 24.6245C17.702 25.2055 17.5565 25.7892 17.2324 26.2749L17.2305 26.2759C17.2261 26.2822 17.2226 26.2893 17.2197 26.2964L18.3018 27.3804C18.3585 27.4372 18.4266 27.482 18.501 27.5122C18.5755 27.5425 18.6559 27.5574 18.7363 27.5562C18.8166 27.5549 18.8963 27.5378 18.9697 27.5054C19.043 27.4729 19.1091 27.4261 19.1641 27.3677L27.4131 18.6021C27.4673 18.5442 27.5093 18.4761 27.5371 18.4019C27.5649 18.3276 27.5781 18.2487 27.5752 18.1694C27.5722 18.0902 27.5538 18.0119 27.5205 17.9399C27.4872 17.8679 27.4394 17.8032 27.3809 17.7495L26.3223 16.7778C26.2925 16.7885 26.2648 16.8053 26.2432 16.8286C26.0217 17.0788 25.7529 17.2827 25.4521 17.4282C25.15 17.5743 24.8214 17.6585 24.4863 17.6763C24.1511 17.694 23.815 17.6452 23.499 17.5317C23.1832 17.4183 22.8928 17.2429 22.6455 17.0161C22.3982 16.7893 22.1988 16.5153 22.0586 16.2104C21.9183 15.9055 21.8404 15.5752 21.8291 15.2397C21.8178 14.9043 21.8737 14.57 21.9932 14.2563C22.1121 13.9442 22.2915 13.6587 22.5215 13.4165L22.5547 13.3657C22.5594 13.3552 22.5607 13.3437 22.5635 13.3325L21.6973 12.5386V12.5376C21.5833 12.4331 21.4329 12.377 21.2783 12.3804Z\"\n fill=\"#00A3FF\" stroke=\"#00A3FF\" stroke-width=\"0.3\" />\n </svg>\n </span>\n <!-- Heading -->\n <h5 class=\"modal-title mb-2\">\n <span>Raise tickets for the following</span>\n\n </h5>\n <p class=\"mb-3\">\n <span>Raising a ticket for footfall count issues. Make sure all records are identified for\n validation.</span>\n\n\n </p>\n </div>\n <div class=\"row\">\n <div class=\"col-md-3 my-4\">\n <div class=\"border border-1 rounded p-3 h-100\">\n <div class=\"fw-semibold fs-5 mb-2\">\n {{tempRaisedPayload?.duplicateCount ? tempRaisedPayload?.duplicateCount :'0'}}\n </div>\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\n Duplicates\n </div>\n </div>\n </div>\n\n <div class=\"col-md-3 my-4\">\n <div class=\"border border-1 rounded p-3 h-100\">\n <div class=\"fw-semibold fs-5 mb-2\">\n {{tempRaisedPayload?.employeeCount ? tempRaisedPayload?.employeeCount:'0' }}\n </div>\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\n Employee\n </div>\n </div>\n </div>\n\n <div class=\"col-md-3 my-4\">\n <div class=\"border border-1 rounded p-3 h-100\">\n <div class=\"fw-semibold fs-5 mb-2\">\n {{tempRaisedPayload?.houseKeepingCount ? tempRaisedPayload?.houseKeepingCount :'0'}}\n </div>\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\n House Keeping\n </div>\n </div>\n </div>\n <div class=\"col-md-3 my-4\">\n <div class=\"border border-1 rounded p-3 h-100\">\n <div class=\"fw-semibold fs-5 mb-2\">\n {{tempRaisedPayload?.junkCount ? tempRaisedPayload?.junkCount :'0'}}\n </div>\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\n Junk\n </div>\n </div>\n\n </div>\n </div>\n\n <!-- Label and Textarea -->\n <div class=\"my-3\">\n <label class=\"form-label\">Description (Optional)</label>\n <textarea rows=\"3\" [(ngModel)]=\"commentText\" class=\"form-control\"\n placeholder=\"Enter description\"></textarea>\n </div>\n <div class=\"w-100 mt-5 d-flex justify-content-end\">\n\n <button class=\"btn btn-outline w-50 me-2\" (click)=\"cancelRasied()\">Cancel</button>\n <button class=\"btn btn-primary w-50\" (click)=\"submitRaised()\">\n Raise Ticket\n </button>\n </div>\n </div>\n</ng-template>\n\n\n<ng-template #imagePopup let-model>\n <div class=\"mx-4\">\n <div class=\"row\">\n <div class=\" p-2 mb-2 mt-5\">\n <div *ngIf=\"isModalOpen\" class=\"position-relative border-gray p-2 \">\n <!-- <button *ngIf=\"canNavigateLeft\" (click)=\"navigateImage('left')\"\n class=\"btn btn-light position-absolute start-0 top-50 z-index-10\">\n \u25C0\n </button> -->\n\n <!-- Main Image -->\n <!-- <img class=\" cursor-pointer w-100 h-525px\" \n [src]=\"imageUrl + (tempModalImage?.filePath || selectImageArray?.filePath)\"\n appMagnifier alt=\"\"> -->\n <img class=\" cursor-pointer w-100 h-525px\"\n [src]=\"imageUrl + (tempModalImage?.filePath || selectImageArray?.filePath)\" alt=\"\">\n <!-- <button *ngIf=\"canNavigateRight\" (click)=\"navigateImage('right')\"\n class=\"btn btn-light position-absolute end-0 top-50 z-index-10\">\n \u25B6\n </button> -->\n\n <!-- Right arrow button -->\n <div class=\"row px-2 mb-2\">\n <div class=\"col-md-7\">\n <div class=\"py-2 img-doc-time\">Tango ID : {{(tempModalImage || selectImageArray)?.templd ||\n (tempModalImage || selectImageArray)?.tempId}}\n <span *ngIf=\"(tempModalImage || selectImageArray)?.status ==='approved'\"\n class=\"ms-2\"><svg style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n fill=\"#12B76A\" />\n </svg></span>\n <span *ngIf=\"(tempModalImage || selectImageArray)?.status ==='rejected'\"\n class=\"ms-2\"><svg style=\"width: 20px;\n height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n <g clip-path=\"url(#clip0_1428_59484)\">\n <path\n d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n fill=\"#FEE4E2\" />\n <path\n d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n stroke=\"#D92D20\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_1428_59484\">\n <rect width=\"12\" height=\"12\" fill=\"white\"\n transform=\"translate(0.599609 0.5)\" />\n </clipPath>\n </defs>\n </svg></span>\n </div>\n <div class=\"img-doc-value\">Entry Time : {{(tempModalImage || selectImageArray)?.entryTme ||\n (tempModalImage || selectImageArray)?.entryTime}}</div>\n </div>\n <div class=\"col-md-5 text-end py-3\">\n <span *ngIf=\"(tempModalImage || selectImageArray)?.revopsType ==='non-tagging'\"\n ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\" viewBox=\"0 0 19 18\"\n fill=\"none\">\n <path\n d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </span>\n <span *ngIf=\"selectImageArray?.revopsType ==='duplicate'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\"\n fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94635)\">\n <path\n d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94635\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"(tempModalImage || selectImageArray)?.revopsType ==='employee'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\"\n fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94639)\">\n <path\n d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94639\">\n <rect width=\"20\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n <span *ngIf=\"(tempModalImage || selectImageArray)?.revopsType ==='house-keeping'\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\" viewBox=\"0 0 21 21\"\n fill=\"none\">\n <g clip-path=\"url(#clip0_2012_94643)\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n fill=\"#475467\" />\n </g>\n <defs>\n <clipPath id=\"clip0_2012_94643\">\n <rect width=\"21\" height=\"20\" fill=\"white\"\n transform=\"translate(0 0.686035)\" />\n </clipPath>\n </defs>\n </svg>\n </span>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- <div class=\"modal-footer py-2 px-0\"> -->\n\n <div class=\"w-100 py-2 mb-2 px-0 d-flex justify-content-end\">\n\n <button class=\"btn btn-outline\" (click)=\"closeImage()\">Close</button>\n\n </div>\n <!-- </div> -->\n </div>\n</ng-template>\n\n<!-- Footfall Trends Template -->\n<ng-template #footfallTrendsTemplate>\n <div class=\"row w-100 mb-3\">\n <!-- Total Footfall Card -->\n <div class=\"col-md-4 mb-3 mb-md-0\">\n <div class=\"metric-card\">\n <div class=\"metric-header\">\n <div class=\"d-flex align-items-center gap-2\">\n <span class=\"metric-title\">Total Footfall</span>\n <svg placement=\"top\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\n viewBox=\"0 0 24 24\" fill=\"none\">\n <path\n d=\"M4 18H9.5V19.25C9.5 19.9793 9.21027 20.6788 8.69454 21.1945C8.17882 21.7103 7.47935 22 6.75 22C6.02065 22 5.32118 21.7103 4.80546 21.1945C4.28973 20.6788 4 19.9793 4 19.25V18ZM8 6.11999C10 6.11999 11 8.99999 11 11C11 12 10.5 13 10 14.5L9.5 16H4C4 15 3.5 13.5 3.5 11C3.5 8.49999 5.498 6.11999 8 6.11999ZM20.054 14.098L19.837 15.329C19.7023 16.0396 19.2931 16.6686 18.698 17.0796C18.1029 17.4907 17.3698 17.6508 16.6576 17.5252C15.9453 17.3996 15.3111 16.9984 14.8925 16.4086C14.4739 15.8188 14.3045 15.0878 14.421 14.374L14.637 13.144L20.054 14.098ZM18.178 1.70499C20.642 2.13899 22.196 4.82999 21.762 7.29199C21.328 9.75399 20.575 11.144 20.402 12.129L14.985 11.174L14.753 9.60999C14.521 8.04599 14.203 6.97399 14.376 5.98999C14.723 4.01999 16.208 1.35799 18.178 1.70499Z\"\n fill=\"#00A3FF\" />\n </svg>\n </div>\n </div>\n <div class=\"metric-value\">{{ getCurrentFootfall() || 0 }}</div>\n <div class=\"metric-trend\" [ngClass]=\"getFootfallPercentageChange() >= 0 ? 'up' : 'down'\">\n <svg *ngIf=\"getFootfallPercentageChange() >= 0\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M6 2L10 6H7V10H5V6H2L6 2Z\" fill=\"#10B981\" />\n </svg>\n <svg *ngIf=\"getFootfallPercentageChange() < 0\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M6 10L2 6H5V2H7V6H10L6 10Z\" fill=\"#F04438\" />\n </svg>\n <span>{{ getFootfallPercentageChange() >= 0 ? '+' : '' }}{{\n getFootfallPercentageChange() }}% vs Yesterday</span>\n </div>\n </div>\n </div>\n <!-- Total Downtime Card -->\n <div class=\"col-md-4 mb-3 mb-md-0\">\n <div class=\"metric-card\">\n <div class=\"metric-header\">\n <div class=\"d-flex align-items-center gap-2\">\n <span class=\"metric-title\">Total Downtime</span>\n <div class=\"downtime-icons\">\n <svg width=\"40\" height=\"41\" viewBox=\"0 0 40 41\" fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <rect y=\"0.5\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\n <path\n d=\"M21.9004 12.1675C22.9958 12.1675 24.0423 12.3918 24.9977 12.7987C25.9889 13.2207 26.8809 13.8402 27.6279 14.6087C28.3734 15.3756 28.9756 16.2931 29.3857 17.3162C29.7813 18.299 29.9993 19.3756 29.9993 20.5008C29.9993 21.6277 29.7813 22.7043 29.3857 23.6871C28.9756 24.7068 28.3734 25.6244 27.6263 26.3929C26.8809 27.1598 25.9889 27.7793 24.9945 28.2012C24.0391 28.6081 22.9925 28.8325 21.8988 28.8325C20.8034 28.8325 19.7568 28.6081 18.8014 28.2012C17.8102 27.7793 16.9183 27.1598 16.1729 26.3929L16.1712 26.3912C15.4242 25.6227 14.8236 24.7052 14.4134 23.6871C14.2865 23.3707 14.1774 23.0459 14.0879 22.7127C14.2572 22.7294 14.4297 22.7378 14.6038 22.7378C14.9342 22.7378 15.2565 22.7076 15.5706 22.649C15.6227 22.8098 15.6797 22.9688 15.7415 23.1246C16.0785 23.9617 16.5732 24.7152 17.1885 25.3481C17.8037 25.981 18.5378 26.49 19.3499 26.8366C20.1328 27.1698 20.9938 27.3557 21.8988 27.3557C22.8037 27.3557 23.6631 27.1715 24.4476 26.8366C25.2614 26.49 25.9938 25.981 26.6091 25.3481C27.2243 24.7152 27.7191 23.9601 28.056 23.1246C28.3799 22.3192 28.5605 21.4334 28.5605 20.5025C28.5605 19.5715 28.3815 18.6875 28.056 17.8804C27.7191 17.0432 27.2243 16.2898 26.6091 15.6569C25.9938 15.024 25.2598 14.5149 24.4476 14.1684C23.6647 13.8352 22.8037 13.6493 21.8988 13.6493C20.9938 13.6493 20.1344 13.8335 19.3499 14.1684C19.2799 14.1985 19.21 14.2303 19.1416 14.2621C18.8747 13.8301 18.5524 13.4383 18.1829 13.0984C18.3848 12.9913 18.5915 12.8925 18.8014 12.8021C19.7601 12.3918 20.805 12.1675 21.9004 12.1675ZM20.971 16.5393C20.971 16.335 21.0524 16.1508 21.181 16.0169C21.3112 15.8829 21.4902 15.8009 21.6888 15.8009C21.8874 15.8009 22.0664 15.8829 22.1966 16.0169C22.3268 16.1508 22.4066 16.335 22.4066 16.5393V20.4271L25.2305 22.1501C25.3997 22.2539 25.5137 22.4196 25.5592 22.6021C25.6048 22.7847 25.5837 22.9856 25.4827 23.1597V23.1614C25.3818 23.3355 25.2207 23.4527 25.0433 23.4996C24.8659 23.5465 24.6706 23.5247 24.5013 23.4209H24.4997L21.3405 21.4937C21.2314 21.4318 21.1419 21.3413 21.0768 21.2342C21.0101 21.122 20.971 20.9897 20.971 20.8491V16.5393Z\"\n fill=\"#667085\" />\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n d=\"M14.3913 12.6095C16.8164 12.6095 18.7826 14.6321 18.7826 17.1269C18.7826 19.6218 16.8164 21.6444 14.3913 21.6444C11.9661 21.6444 10 19.6218 10 17.1269C10 14.6321 11.9661 12.6095 14.3913 12.6095ZM14.3913 19.7172L16.748 16.7201H15.2848V15.1261H13.4977V16.7201H12.0345L14.3913 19.7172Z\"\n fill=\"#F04438\" />\n </svg>\n </div>\n </div>\n </div>\n <div class=\"metric-value\">{{ getFormattedDowntime() || '-' }}</div>\n <!-- <div class=\"metric-tag success\" *ngIf=\"hasDowntime()\"> -->\n <!-- <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M11.6667 3.5L5.25 9.91667L2.33334 7\" stroke=\"#10B981\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg> -->\n <!-- <span>Issue submitted</span>\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M4.5 2.5L7.5 5.5L10.5 2.5\" stroke=\"#10B981\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n </svg> -->\n <!-- </div> -->\n </div>\n </div>\n\n <!-- Ticket Status Card -->\n <div class=\"col-md-4\">\n <div class=\"metric-card\">\n <div class=\"metric-header\">\n <span class=\"metric-title\">Ticket status</span>\n </div>\n <div class=\"metric-value\">{{ getTicketStatus() === '-' ? '-' : (getTicketStatus() |\n titlecase) }}</div>\n </div>\n </div>\n </div>\n</ng-template>\n\n<ng-template #resetRequestPopup let-model>\n <div class=\"p-4\">\n <div class=\"modal-header border-0 p-0 w-100\">\n <h5 class=\"modal-title mb-3 fw-bold\">\n Reset request.\n </h5>\n </div>\n <div class=\"modal-body p-0\">\n <p class=\"text-muted mb-3\">\n You're requesting to re-enable footfall tickets, disabled after three instances of exceeding 95%\n accuracy.\n </p>\n <p class=\"text-muted mb-0\">\n Please ensure future accuracy stays on or within 95%.\n </p>\n </div>\n <div class=\"modal-footer border-0 p-0 mt-4 d-flex justify-content-end gap-2\">\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"cancelResetRequest()\">\n Cancel\n </button>\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"submitResetRequest()\">\n Send Request\n </button>\n </div>\n </div>\n</ng-template>\n\n<ng-template #ticketStatusTemplate let-model>\n <!-- Ticket Review Card (shown when ticket status is raised) -->\n <div class=\"col-12 mb-3\" *ngIf=\"(isTicketRaised() || isTicketClosed()) && getTaggingData('tagging')\">\n <div class=\"ticket-review-card\">\n <!-- Actual Footfall Header -->\n <div class=\"actual-footfall-header\">\n <span class=\"actual-footfall-number\">{{ getTaggingData('tagging')?.footfall || 0 }}</span>\n <span class=\"actual-footfall-label\">Actual Footfall</span>\n </div>\n <!-- Ticket Created By Section -->\n <div class=\"ticket-creator-section\"\n *ngIf=\"getTaggingData('tagging')?.createdByEmail || getTaggingData('tagging')?.createdAt\">\n <div class=\"d-flex align-items-center gap-2\">\n <!-- <div class=\"creator-avatar\" *ngIf=\"getTaggingData()?.createdByEmail?.profilePicture\">\n <img [src]=\"getTaggingData()?.createdByEmail?.profilePicture\" alt=\"Profile\" />\n </div> -->\n <div class=\"creator-avatar-placeholder\"\n *ngIf=\"!getTaggingData('tagging')?.createdByEmail?.profilePicture\">\n <svg width=\"32\" height=\"32\" viewBox=\"0 0 32 32\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect width=\"32\" height=\"32\" rx=\"16\" fill=\"#EAF8FF\" />\n <path\n d=\"M16 10C17.6569 10 19 11.3431 19 13C19 14.6569 17.6569 16 16 16C14.3431 16 13 14.6569 13 13C13 11.3431 14.3431 10 16 10Z\"\n fill=\"#00A3FF\" />\n <path d=\"M11 22C11 19.2386 13.2386 17 16 17C18.7614 17 21 19.2386 21 22V23H11V22Z\"\n fill=\"#00A3FF\" />\n </svg>\n </div>\n <div class=\"creator-info\">\n <div class=\"creator-label\">Ticket created by</div>\n <div class=\"creator-details\">\n <span class=\"creator-email\">{{ getTaggingData('tagging')?.createdByEmail ||\n getTaggingData('tagging')?.createdByEmail || 'N/A' }}</span>\n <span class=\"creator-separator\" *ngIf=\"getTaggingData('tagging')?.createdAt\">\u2022</span>\n <span class=\"creator-time\" *ngIf=\"getTaggingData('tagging')?.createdAt\">{{\n getTaggingData('tagging')?.createdAt | date:'h:mm:ss a - d MMM yyyy' }}</span>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Ticket Revised Footfall and Metrics -->\n <div class=\"revised-footfall-section\">\n <div class=\"metrics-row\">\n <div class=\"metric-item\">\n <div class=\"metric-number blue-text\">\n {{ getTaggingData('tagging')?.revicedFootfall || 0 }}\n <span class=\"metric-percentage\">\n ({{ getTaggingData('tagging')?.revicedPerc || 0 }}%)\n </span>\n <span class=\"metric-arrow\">\u2193</span>\n </div>\n <div class=\"metric-label\">Revised footfall</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">({{ getRevisionCalculation('tagging')}}%)</div>\n <div class=\"metric-label\">Ticket%</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'duplicate') }}</div>\n <div class=\"metric-label\">Duplicates</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'employee') }}</div>\n <div class=\"metric-label\">Employee/Staff</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'junk') }}</div>\n <div class=\"metric-label\">Junk</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'houseKeeping') }}</div>\n <div class=\"metric-label\">House Keeping</div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Ticket Final revision Card (shown when ticket status is closed) -->\n <div class=\"col-12 mb-3\" *ngIf=\"isTicketClosed() && getTaggingData('finalreview')\">\n <div class=\"ticket-review-card\">\n <!-- Ticket card section in revision start -->\n\n <!-- Actual Footfall Header -->\n <div class=\"actual-footfall-header\">\n <span class=\"actual-footfall-number\">{{ getTaggingData('tagging')?.footfall || 0 }}</span>\n <span class=\"actual-footfall-label\">Actual Footfall</span>\n </div>\n <!-- Ticket Created By Section -->\n <div class=\"ticket-creator-section\"\n *ngIf=\"getTaggingData('tagging')?.createdByEmail || getTaggingData('tagging')?.createdAt\">\n <div class=\"d-flex align-items-center gap-2\">\n <!-- <div class=\"creator-avatar\" *ngIf=\"getTaggingData()?.createdByEmail?.profilePicture\">\n <img [src]=\"getTaggingData()?.createdByEmail?.profilePicture\" alt=\"Profile\" />\n </div> -->\n <div class=\"creator-avatar-placeholder\"\n *ngIf=\"!getTaggingData('tagging')?.createdByEmail?.profilePicture\">\n <svg width=\"32\" height=\"32\" viewBox=\"0 0 32 32\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <rect width=\"32\" height=\"32\" rx=\"16\" fill=\"#EAF8FF\" />\n <path\n d=\"M16 10C17.6569 10 19 11.3431 19 13C19 14.6569 17.6569 16 16 16C14.3431 16 13 14.6569 13 13C13 11.3431 14.3431 10 16 10Z\"\n fill=\"#00A3FF\" />\n <path d=\"M11 22C11 19.2386 13.2386 17 16 17C18.7614 17 21 19.2386 21 22V23H11V22Z\"\n fill=\"#00A3FF\" />\n </svg>\n </div>\n <div class=\"creator-info\">\n <div class=\"creator-label\">Ticket created by</div>\n <div class=\"creator-details\">\n <span class=\"creator-email\">{{ getTaggingData('tagging')?.createdByEmail ||\n getTaggingData('tagging')?.createdByEmail || 'N/A' }}</span>\n <span class=\"creator-separator\" *ngIf=\"getTaggingData('tagging')?.createdAt\">\u2022</span>\n <span class=\"creator-time\" *ngIf=\"getTaggingData('tagging')?.createdAt\">{{\n getTaggingData('tagging')?.createdAt | date:'h:mm:ss a - d MMM yyyy' }}</span>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Ticket Revised Footfall and Metrics -->\n <div class=\"revised-footfall-section\">\n <div class=\"metrics-row\">\n <div class=\"metric-item\">\n <div class=\"metric-number blue-text\">\n {{ getTaggingData('tagging')?.revicedFootfall || 0 }}\n <span class=\"metric-percentage\">\n ({{ getTaggingData('tagging')?.revicedPerc || 0 }}%)\n </span>\n <span class=\"metric-arrow\">\u2193</span>\n </div>\n <div class=\"metric-label\">Revised footfall</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">({{ getRevisionCalculation('tagging')}}%)</div>\n <div class=\"metric-label\">Ticket%</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'duplicate') }}</div>\n <div class=\"metric-label\">Duplicates</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'employee') }}</div>\n <div class=\"metric-label\">Employee/Staff</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'junk') }}</div>\n <div class=\"metric-label\">Junk</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'houseKeeping') }}</div>\n <div class=\"metric-label\">House Keeping</div>\n </div>\n </div>\n </div>\n <!-- Ticket card section in revision end -->\n\n <!-- Final Revision Section -->\n <div class=\"revision-section\">\n <div class=\"revision-title\">Final revision</div>\n <div class=\"final-revision-note\">\n Please reach centraloperations@lenskart.in for any further discrepancies\n </div>\n <div class=\"revised-footfall-section\">\n <div class=\"metrics-row\">\n <div class=\"metric-item\">\n <div class=\"metric-number blue-text\">\n {{ getTaggingData('finalreview')?.revicedFootfall || 0 }}\n <span class=\"metric-percentage\">\n ({{ getTaggingData('finalreview')?.revicedPerc || 0}}%)\n </span>\n <span class=\"metric-arrow\">\u2191</span>\n </div>\n <div class=\"metric-label\">Revised footfall</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">({{ getRevisionCalculation('finalreview')}}%)</div>\n <div class=\"metric-label\">Ticket%</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('finalreview'), 'duplicate') }}\n </div>\n <div class=\"metric-label\">Duplicates</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('finalreview'), 'employee') }}\n </div>\n <div class=\"metric-label\">Employee/Staff</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('finalreview'), 'junk') }}</div>\n <div class=\"metric-label\">Junk</div>\n </div>\n <div class=\"metric-item\">\n <div class=\"metric-number\">{{ getCountByType(getTaggingData('finalreview'), 'houseKeeping')\n }}</div>\n <div class=\"metric-label\">House Keeping</div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n</ng-template>", styles: ["@charset \"UTF-8\";.switch-form-card{padding:8px 16px;border-radius:4px;border-left:2px solid var(--Primary-600, #00A3FF);background:var(--Primary-25, #F6FCFF);display:flex;align-items:center;justify-content:space-between}.switch-form-card .txt-one{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:140%}.nav-item .nav-link.active{border:none;border-radius:6px;background:var(--Primary-50, #EAF8FF);padding:8px 12px}.nav-item .nav-link:hover{border:none}.badge-num-primary{border-radius:16px!important;background:var(--Primary-50, #EAF8FF)!important;color:var(--Primary-700, #009BF3)!important;text-align:center;font-size:14px!important;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}.badge-num-muted{border-radius:16px!important;background:var(--Primary-50, #F2F4F7)!important;color:var(--Gray-700, #344054)!important;text-align:center;font-size:14px;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}.img-src{width:100%;height:195px;border-radius:.625rem}.img-traffic .col-md-3{width:24%!important}.border-gray{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF)}.img-doc-directory{color:var(--Gray-900, #101828)!important;font-size:14px!important;font-weight:600;line-height:20px;text-decoration-line:underline}.img-doc-time{color:var(--Gray-800, #1D2939);font-size:14px;font-weight:500;line-height:20px}.img-doc-value{color:var(--Gray-600, #667085);font-size:14px;font-weight:500;line-height:20px}.overflow-x{overflow-x:auto}.no-preview{border:1px solid #F04438;background:#fee4e2;border-radius:8px;stroke-width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:41px 16px}.no-preview .header{color:#f04438;font-size:20px;font-weight:700;line-height:20px}.no-preview .description{color:#f04438;font-size:12px;font-weight:500;line-height:18px}.img-nodata{width:25%;height:15%}.img-nodata1{width:15%;height:15%}.nodata-title{font-size:14px!important;font-weight:600}.img-direc{color:var(--Gray-900, #101828)!important;font-size:18px!important;font-weight:500;line-height:28px}.custom-accordion{border-radius:5px}.custom-accordion-item{margin-bottom:10px}.custom-accordion-header{background-color:#fff;border:none;cursor:pointer;padding:10px;text-align:left;width:100%;display:flex;justify-content:space-between;align-items:center}.custom-accordion{width:100%}.mainheading{width:100%;display:flex;justify-content:space-between;align-items:center;padding:19px;border:none;background:none;cursor:pointer}.mainheading-1{width:77%;display:flex;justify-content:space-between;align-items:center;padding:19px;border:none;background:none;cursor:pointer}.header-row{display:flex;align-items:center;width:100%;justify-content:space-between}.img-dire{font-size:16px;font-weight:700}.divider{flex-grow:1;height:1px;background-color:#ddd;margin:0 10px}.accordion-arrow{display:flex;align-items:center}.scroll-container{max-height:400px;overflow-y:auto;overflow-x:hidden}.view-toggle .btn{border-radius:6px}.view-toggle .btn.active{background:var(--Primary-50, #EAF8FF);border-color:var(--Primary-200, #99DAFF)}.date-list-container{padding:4px 23px;width:100%}.date-list-scroll{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px;max-height:287px;overflow-y:auto;overflow-x:hidden;padding-bottom:8px}.date-card{min-width:0;max-width:none;padding:16px;background:#fff;border:1px solid #D0D5DD;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;gap:8px}.date-card:hover{box-shadow:0 2px 8px #0000001a;border-color:#00a3ff}.date-card .date-card-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.date-card .date-card-header .calendar-icon{flex-shrink:0}.date-card .date-card-header .date-text{color:var(--Gray-900, #101828);font-size:14px;font-weight:500;line-height:20px;flex:1}.date-card .footfall-count{color:var(--Gray-900, #101828);font-size:32px;font-weight:400;line-height:40px;margin-top:4px}.date-card .footfall-label{color:var(--Gray-600, #667085);font-size:14px;font-weight:400;line-height:20px}.date-card-active{background:var(--Primary-50, #EAF8FF);border-color:var(--Primary-600, #00A3FF);border-width:2px}.date-card-active .date-text{color:var(--Primary-700, #009BF3);font-weight:600}.date-card-active .footfall-count{color:var(--Primary-700, #009BF3)}.list-view-wrapper{padding:0 8px 16px;max-height:480px;overflow-y:auto}.list-group{border:1px solid var(--Gray-200, #EAECF0);border-radius:12px;background:#fff;padding:16px 20px}.list-group-header{border-bottom:1px solid var(--Gray-200, #EAECF0);padding-bottom:12px;margin-bottom:16px!important}.list-group-header .group-title{color:var(--Gray-900, #101828);font-size:16px;font-weight:600;line-height:24px}.list-group-header .group-count{color:var(--Gray-600, #667085);font-weight:500}.high-400px{min-height:auto!important;max-height:800px!important}.scroll-y{overflow-y:auto}.absolute{top:5px;right:5px;z-index:2}.slider{position:relative}.slider .previous{position:absolute;top:30%;left:2%;width:32px;height:32px;background-color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.slider .next{position:absolute;top:30%;right:2%;width:32px;height:32px;background-color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.img-src1{border-radius:12px;border:1px solid var(--Gray-400, #98A2B3);background:var(--Gray-50, #F9FAFB);width:100%;height:375px;object-fit:contain}.zoom-icon-button{position:absolute;top:10px;right:10px;z-index:10;cursor:pointer;background:#fffffff2;border-radius:50%;padding:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000026;transition:all .2s ease}.zoom-icon-button:hover{background:#fff;box-shadow:0 4px 12px #0003;transform:scale(1.05)}.zoom-icon-button svg{width:20px;height:20px}.border-gray{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);padding:0 4px}.border-gray-active{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--Primary-50, #EAF8FF);padding:0 4px}.zone-header{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:20px}.last-visit{color:var(--Gray-500, #667085);font-size:14px;font-weight:400;line-height:20px}.toggle-label{color:var(--Gray-900, #101828);font-size:16px;font-weight:600;line-height:24px}.nav-dev{border-radius:8px!important;border:1px solid var(--Primary-200, #99DAFF)!important;background:var(--Primary-25, #F6FCFF)!important}.tab-active{border-radius:6px;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3)!important;font-size:14px;font-weight:500;line-height:20px}.tab-text-default{color:var(--Gray-500, #667085);font-size:14px;font-weight:500;line-height:20px}.border-gray-active1{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--Primary-50, #ffffff);padding:12px!important}.nav-item1 .nav-link1.active{border:none;border-radius:0;background:var(--Primary-50, #EAF8FF);border-bottom:2px solid #009BF3!important;padding:12px;color:var(--Primary-700, #009BF3);font-size:14px;font-style:normal;font-weight:500;line-height:20px}.active-normal{padding:12px;color:var(--Gray-500, #667085);font-size:14px;font-style:normal;font-weight:500;line-height:20px}.nav-item1 .nav-link1:hover{border:none}.tag-class{color:var(--Gray-900, #101828);font-size:14px;font-weight:600;line-height:20px}.spent-title{color:var(--Gray-600, #475467);font-size:14px;font-weight:600;line-height:20px}.spent-value{color:var(--Gray-500, #667085);font-size:14px;font-weight:400;line-height:20px}.spent-value1{color:var(--Primary-500, #33B5FF);font-size:14px;font-weight:500;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font}.w-33{width:30%}.w-45{width:45%}.view-tetory{color:var(--Primary-700, #009BF3);font-size:14px;font-weight:600;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font;text-transform:capitalize}.border-gray-tagged{border-radius:4px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--Primary-50, #ffffff);padding:8px!important}.desc-id{color:var(--Gray-900, #101828);font-size:12px;font-style:normal;font-weight:400;line-height:20px}.active-tab{border-bottom:2px solid #0d6efd;font-weight:600;color:#0d6efd}.badge-selected{background-color:#e0f3ff;color:#0d6efd;border:1px solid #0d6efd;border-radius:20px;padding:6px 12px}.badge-unselected{background-color:#f0f0f0;color:#333;border-radius:20px;padding:6px 12px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;appearance:textfield}.cursor-not-allowed{cursor:not-allowed!important}.title-type{color:var(--Gray-800, #1D2939);font-size:16px;font-weight:600;line-height:24px}.top-50{top:35%!important}.activePlanBtn{border-radius:6px;background:var(--Primary-50, #EAF8FF);color:var(--Gray-700, #344054);font-size:14px!important;font-weight:500!important;line-height:20px}.inactivePlanBtn{color:var(--Gray-500, #344054)!important;font-size:14px;font-weight:500!important;line-height:20px}.badge-active{border-radius:16px;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3);text-align:center;font-size:12px;font-style:normal;font-weight:500;line-height:20px;mix-blend-mode:multiply}input[type=checkbox]{width:18px!important;height:18px!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}::ng-deep .modal-backdrop{pointer-events:none}.meta-change.up{color:#10b981}.meta-change.down{color:#ef4444}.meta-change.neutral{color:#64748b}.split-screen-container{display:flex;height:calc(100vh - 300px);min-height:600px;gap:16px;margin-top:16px}.split-screen-container .left-panel{flex:0 0 35%;max-width:35%;overflow-y:auto;overflow-x:hidden;padding-right:8px;border-right:1px solid var(--Gray-200, #EAECF0)}.split-screen-container .right-panel{flex:1;overflow-y:auto;padding-left:16px}.thumbnail-list-section{margin-bottom:24px}.thumbnail-list-section .time-range-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--Gray-200, #EAECF0)}.thumbnail-list-section .time-range-header .time-range-title{color:var(--Gray-900, #101828);font-size:16px;font-weight:600;line-height:24px}.thumbnail-list-section .time-range-header .time-range-count{color:var(--Gray-600, #667085);font-size:14px;font-weight:500;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3);padding:2px 10px;border-radius:16px}.thumbnail-list-section .thumbnail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.thumbnail-list-section .thumbnail-item{cursor:pointer;border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);padding:8px;transition:all .2s ease}.thumbnail-list-section .thumbnail-item:hover{border-color:var(--Primary-600, #00A3FF);box-shadow:0 2px 8px #00a3ff1a}.thumbnail-list-section .thumbnail-item.selected{border-color:var(--Primary-600, #00A3FF);border-width:2px;background:var(--Primary-50, #EAF8FF)}.thumbnail-list-section .thumbnail-item .thumbnail-image{width:100%;height:120px;object-fit:cover;border-radius:4px;margin-bottom:8px}.thumbnail-list-section .thumbnail-item .thumbnail-info .tango-id{color:var(--Gray-900, #101828);font-size:12px;font-weight:600;line-height:16px;margin-bottom:4px}.thumbnail-list-section .thumbnail-item .thumbnail-info .entry-time{color:var(--Gray-600, #667085);font-size:11px;font-weight:400;line-height:16px}.metric-card{background:var(--White, #FFF);border-radius:8px;padding:16px;height:100%;display:flex;flex-direction:column;gap:2px}.metric-card .metric-header{display:flex;justify-content:space-between;align-items:center}.metric-card .metric-header .metric-title{color:var(--Gray-700, #344054);font-size:14px;font-weight:500;line-height:20px}.metric-card .metric-header .metric-icon,.metric-card .metric-header .footfall-icon-header{flex-shrink:0}.metric-card .metric-header .downtime-icons{position:relative;display:inline-flex;align-items:center;width:31px;height:24px}.metric-card .metric-header .downtime-icons .clock-icon{position:absolute;left:0;top:2px;z-index:1}.metric-card .metric-header .downtime-icons .alert-icon{position:absolute;right:-2px;top:-2px;z-index:2}.metric-card .metric-value{color:var(--Gray-900, #101828);font-size:32px;font-weight:400;line-height:40px}.metric-card .metric-trend{display:flex;align-items:center;gap:4px;font-size:14px;font-weight:500;line-height:20px}.metric-card .metric-trend.up{color:#10b981}.metric-card .metric-trend.down{color:#f04438}.metric-card .metric-trend svg{flex-shrink:0}.metric-card .metric-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;line-height:16px;width:fit-content}.metric-card .metric-tag.success{background:#d1fadf;color:#10b981}.metric-card .metric-tag svg{flex-shrink:0}.ticket-review-card{background:var(--White, #FFF);border-radius:12px;border:1px solid var(--Gray-200, #EAECF0);padding:20px;box-shadow:0 1px 3px #0000001a}.ticket-review-card .actual-footfall-header{background:var(--Primary-50, #EAF8FF);border-radius:8px;padding:16px 20px;margin-bottom:20px;display:flex;align-items:center;gap:12px}.ticket-review-card .actual-footfall-header .actual-footfall-number{color:var(--Gray-900, #101828);font-size:32px;font-weight:600;line-height:40px}.ticket-review-card .actual-footfall-header .actual-footfall-label{color:var(--Gray-700, #344054);font-size:16px;font-weight:500;line-height:24px}.ticket-review-card .ticket-creator-section{padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid var(--Gray-200, #EAECF0)}.ticket-review-card .ticket-creator-section .creator-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0}.ticket-review-card .ticket-creator-section .creator-avatar img{width:100%;height:100%;object-fit:cover}.ticket-review-card .ticket-creator-section .creator-avatar-placeholder{width:40px;height:40px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.ticket-review-card .ticket-creator-section .creator-info{flex:1}.ticket-review-card .ticket-creator-section .creator-info .creator-label{color:var(--Gray-600, #667085);font-size:12px;font-weight:400;line-height:18px;margin-bottom:4px}.ticket-review-card .ticket-creator-section .creator-info .creator-details{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ticket-review-card .ticket-creator-section .creator-info .creator-details .creator-email{color:var(--Gray-900, #101828);font-size:14px;font-weight:500;line-height:20px}.ticket-review-card .ticket-creator-section .creator-info .creator-details .creator-separator{color:var(--Gray-400, #98A2B3);font-size:14px}.ticket-review-card .ticket-creator-section .creator-info .creator-details .creator-time{color:var(--Gray-600, #667085);font-size:14px;font-weight:400;line-height:20px}.ticket-review-card .revised-footfall-section .metrics-row{display:flex;flex-wrap:wrap;gap:24px;align-items:flex-start}.ticket-review-card .revised-footfall-section .metrics-row .metric-item{flex:1;min-width:120px;display:flex;flex-direction:column;gap:4px}.ticket-review-card .revised-footfall-section .metrics-row .metric-item .metric-number{color:var(--Gray-900, #101828);font-size:24px;font-weight:600;line-height:32px}.ticket-review-card .revised-footfall-section .metrics-row .metric-item .metric-number.blue-text{color:var(--Primary-700, #009BF3)}.ticket-review-card .revised-footfall-section .metrics-row .metric-item .metric-number.blue-text .metric-percentage{font-size:16px;font-weight:500;margin-left:4px}.ticket-review-card .revised-footfall-section .metrics-row .metric-item .metric-number.blue-text .metric-arrow{color:var(--Primary-700, #009BF3);font-size:16px;margin-left:4px}.ticket-review-card .revised-footfall-section .metrics-row .metric-item .metric-label{color:var(--Gray-600, #667085);font-size:14px;font-weight:400;line-height:20px}.ticket-review-card .revision-section{margin-top:24px;padding-top:24px;border-top:1px solid var(--Gray-200, #EAECF0)}.ticket-review-card .revision-section .revision-title{color:var(--Gray-900, #101828);font-size:16px;font-weight:600;line-height:24px;margin-bottom:16px}.ticket-review-card .revision-section .final-revision-note{color:var(--Gray-600, #667085);font-size:14px;font-weight:400;line-height:20px;margin-bottom:16px;font-style:italic}.ticket-block-alert{border-radius:8px;border:2px dashed #F04438;background:#fee4e2;padding:16px;margin-bottom:16px}.ticket-block-alert .ticket-block-alert-content{display:flex;align-items:flex-start;gap:12px}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-icon svg{width:24px;height:24px}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-text{flex:1;display:flex;flex-direction:column;gap:8px}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-text .ticket-block-alert-title{color:#f04438;font-size:16px;font-weight:700;line-height:24px}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-text .ticket-block-alert-description,.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-text .ticket-block-alert-action{color:#f04438;font-size:14px;font-weight:400;line-height:20px}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-text .ticket-block-alert-action .ticket-block-alert-link{color:#f04438;text-decoration:underline;cursor:pointer;font-weight:500}.ticket-block-alert .ticket-block-alert-content .ticket-block-alert-text .ticket-block-alert-action .ticket-block-alert-link:hover{color:#d92d20;text-decoration:underline}.ticket-request-alert{border-radius:8px;border:2px dashed #10B981;background:#d1fae5;padding:16px;margin-bottom:16px}.ticket-request-alert .ticket-request-alert-content{display:flex;align-items:flex-start;gap:12px}.ticket-request-alert .ticket-request-alert-content .ticket-request-alert-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.ticket-request-alert .ticket-request-alert-content .ticket-request-alert-icon svg{width:24px;height:24px}.ticket-request-alert .ticket-request-alert-content .ticket-request-alert-text{flex:1;display:flex;flex-direction:column;gap:8px}.ticket-request-alert .ticket-request-alert-content .ticket-request-alert-text .ticket-request-alert-title{color:#10b981;font-size:16px;font-weight:700;line-height:24px}.ticket-request-alert .ticket-request-alert-content .ticket-request-alert-text .ticket-request-alert-description{color:#10b981;font-size:14px;font-weight:400;line-height:20px}\n"] }]
|
|
875
1317
|
}], ctorParameters: () => [{ type: i1.TrafficService }, { type: i2.GlobalStateService }, { type: i0.ChangeDetectorRef }, { type: i3.NgbModal }, { type: i4.ToastService }, { type: i5.TrafficRvpsService }], propDecorators: { zoomPopup: [{
|
|
876
1318
|
type: ViewChild,
|
|
877
1319
|
args: ["zoomPopup"]
|
|
878
1320
|
}], raisedPopup: [{
|
|
879
1321
|
type: ViewChild,
|
|
880
1322
|
args: ["raisedPopup"]
|
|
1323
|
+
}], resetRequestPopup: [{
|
|
1324
|
+
type: ViewChild,
|
|
1325
|
+
args: ["resetRequestPopup"]
|
|
881
1326
|
}], imagePopup: [{
|
|
882
1327
|
type: ViewChild,
|
|
883
1328
|
args: ["imagePopup"]
|
|
884
1329
|
}] } });
|
|
885
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"img-rvps.component.js","sourceRoot":"","sources":["../../../../../../projects/tango-analyse-traffic/src/lib/components/img-rvps/img-rvps.component.ts","../../../../../../projects/tango-analyse-traffic/src/lib/components/img-rvps/img-rvps.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,ElementRef,ViewChild\r\n} from \"@angular/core\";\r\nimport { TrafficRvpsService } from \"../../services/traffic-rvps.service\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\nimport { TrafficService } from \"../../services/traffic.service\";\r\nimport { ToastService } from \"tango-app-ui-shared\";\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport { NgbModal } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport { debounceTime } from \"rxjs/operators\";\r\n\r\n@Component({\r\n  selector: \"lib-img-rvps\",\r\n  templateUrl: \"./img-rvps.component.html\",\r\n  styleUrl: \"./img-rvps.component.scss\",\r\n})\r\nexport class ImgRvpsComponent implements OnInit, OnDestroy {\r\n  headerData: any;\r\n  storeIdarray: any;\r\n  loading: boolean = true;\r\n  noData = false;\r\n  normalize: any;\r\n  constructor(\r\n    private service: TrafficService,\r\n    public gs: GlobalStateService,\r\n    private cd: ChangeDetectorRef,\r\n    private modalService: NgbModal,\r\n    private toast: ToastService,\r\n    private rvpsService: TrafficRvpsService\r\n  ) {}\r\n  private readonly destroy$ = new Subject();\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next(true);\r\n    this.destroy$.complete();\r\n  }\r\n  isAccordionExpanded = true;\r\n  toggleAccordion() {\r\n    this.isAccordionExpanded = !this.isAccordionExpanded;\r\n  }\r\n  users:any;\r\n  ngOnInit(): void {\r\n    this.getInital();\r\n    const userData: any = JSON.parse(localStorage.getItem(\"user-info\") || \"{}\");\r\n    this.users = userData;\r\n  }\r\n  getInital() {\r\n    this.gs.dataRangeValue\r\n      .pipe(takeUntil(this.destroy$), debounceTime(100))\r\n      .subscribe((data: any) => {\r\n        if (data !== null || data?.client !== null) {\r\n          this.headerData = data;\r\n          this.storeIdarray = this.headerData?.stores\r\n            .filter((store: any) => store.checked)\r\n            .map((store: any) => store.storeId);\r\n          this.backToFootfall();\r\n          this.displayDateRange();\r\n          if (\r\n            this.headerData?.date?.startDate === this.headerData?.date?.endDate\r\n          ) {\r\n            this.backnav = false;\r\n            this.displayDateRange();\r\n            this.getimages(0, this.headerData.date.endDate);\r\n          } else {\r\n            this.folderView = true;\r\n            this.backnav = true;\r\n          }\r\n        }\r\n      });\r\n  }\r\n\r\n  backToFootfall() {\r\n    this.folderView = true;\r\n    this.getRvpsList = [];\r\n    this.getRvpsImageList = [];\r\n    this.objectsArray = [];\r\n    this.noData = false;\r\n    this.type = \"footfall\";\r\n    this.selectedTime = \"\";\r\n  }\r\n  folderView: boolean;\r\n  backnav: boolean;\r\n  dateArray: any;\r\n  displayDateRange() {\r\n    const dates = this.getDateRangeArray(\r\n      this.headerData.date.startDate,\r\n      this.headerData.date.endDate\r\n    );\r\n    this.dateArray = dates;\r\n  }\r\n\r\n  getDateRangeArray(fromDate: string, toDate: string): string[] {\r\n    const start = new Date(fromDate); // Convert string to Date object\r\n    const end = new Date(toDate); // Convert string to Date object\r\n    const dateArray: string[] = [];\r\n\r\n    // Check if the dates are valid\r\n    if (isNaN(start.getTime()) || isNaN(end.getTime())) {\r\n      return dateArray;\r\n    }\r\n\r\n    // Loop from start date to end date\r\n    let currentDate = start;\r\n    while (currentDate <= end) {\r\n      dateArray.push(currentDate.toISOString().split(\"T\")[0]); // Format YYYY-MM-DD\r\n      currentDate.setDate(currentDate.getDate() + 1); // Increment the date by 1 day\r\n    }\r\n\r\n    return dateArray;\r\n  }\r\n  selectedTime: any;\r\n  folderName: any;\r\n  selectedTimes(val: any) {\r\n    this.selectedTime = val;\r\n    this.folderName = val;\r\n    this.folderView = false;\r\n    this.type = this.type;\r\n    this.getRevops();\r\n  }\r\n  folderDate: any;\r\n  imageFlow = false;\r\n  // get Revops Api\r\n  getRvpsList: any;\r\n  getRvpsImageList: any;\r\n  objectsArray: any;\r\n  imagesArrayData: any;\r\n  selectIndex: any = 0;\r\n  footfallDate: any;\r\n  lengthValue: boolean;\r\n  getimages(index: any, obj: any) {\r\n    this.objectsArray = [];\r\n    this.selectIndex = index;\r\n    this.folderDate = obj;\r\n    (this.footfallDate = obj), (this.folderView = false);\r\n    this.service?.isnormalizeSource\r\n      ?.pipe(takeUntil(this.destroy$), debounceTime(300))\r\n      ?.subscribe((normalize: any) => {\r\n        this.normalize = normalize;\r\n        if (!normalize) {\r\n          this.getRvpsList = [];\r\n          this.getRvpsImageList = [];\r\n          this.objectsArray = [];\r\n          this.getRevops();\r\n          this.getTotal();\r\n        } else {\r\n          this.lengthValue = false;\r\n          this.objectsArray = [];\r\n        }\r\n      });\r\n  }\r\n  countData: any = [];\r\n  getTotal() {\r\n    this.countData = [];\r\n    const storeId =\r\n      this.storeIdarray && this.storeIdarray.length > 0\r\n        ? this.storeIdarray[0]\r\n        : null;\r\n    const dateString = this.folderDate || \"\";\r\n    this.rvpsService\r\n      .getTotalVal(storeId, dateString)\r\n      .pipe(takeUntil(this.destroy$))\r\n      ?.subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            if (this.getRvpsList?.length) this.countData = res.data;\r\n            // console.log(this.countData)\r\n          } else {\r\n            this.countData = [];\r\n          }\r\n        },\r\n        error: (err) => {},\r\n      });\r\n  }\r\n  imageUrl: any;\r\n  revopsTypeCount: any;\r\n  currentTimeRangeData: any = [];\r\n  overallArrayData: any = [];\r\n  allFootfallData: any = [];\r\n  getTicketStatuses(): string[] {\r\n    const statusList = this.getRvpsList?.ticketStatus;\r\n    if (Array.isArray(statusList)) {\r\n      return statusList.map((s) => s?.status?.toLowerCase()).filter(Boolean); // Removes null/undefined\r\n    }\r\n    return [];\r\n  }\r\n  getRevops() {\r\n    this.loading = true;\r\n    this.noData = false;\r\n    // this.objectsArray =[];\r\n    // this.overallArrayData =[];\r\n    // this.getRvpsList =[];\r\n    // this.getRvpsImageList=[];\r\n    // this.allFootfallData =[]\r\n    const storeId =\r\n      this.storeIdarray && this.storeIdarray.length > 0\r\n        ? this.storeIdarray[0]\r\n        : null;\r\n    const dateString = this.folderDate || \"\";\r\n    const groupByKey = \"time\";\r\n    const type = this.type === \"footfall\" ? \"\" : this.type || \"\";\r\n    const processType = \"footfall\";\r\n\r\n    this.rvpsService\r\n      .getRvpsListApi(storeId, dateString, groupByKey, type, processType)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.getRvpsList = res?.data;\r\n            this.imageUrl = this.rvpsService?.footfallCDN;\r\n            this.getRvpsImageList = res?.data?.result;\r\n\r\n            // Save the full footfall data (grouped by timeRange)\r\n            this.allFootfallData = res?.data?.result?.footfallData || [];\r\n\r\n            // Create timeRange + count object\r\n            const timeRanges = this.allFootfallData.map(\r\n              (item: any) => item.timeRange\r\n            );\r\n            this.objectsArray = timeRanges.map((timeRange: any) => ({\r\n              timeRange,\r\n              count:\r\n                this.allFootfallData.find((d: any) => d.timeRange === timeRange)\r\n                  ?.data?.length || 0,\r\n            }));\r\n            // Only reset if previous selected time is NOT in the new list\r\n            if (!timeRanges.includes(this.selectedTime)) {\r\n              this.selectedTimes(this.objectsArray[0].timeRange);\r\n            }\r\n\r\n            // Get data for the selected timeRange\r\n            this.currentTimeRangeData =\r\n              this.allFootfallData.find(\r\n                (item: any) => item.timeRange === this.selectedTime\r\n              )?.data || [];\r\n\r\n            // Count revopsTypes\r\n            const revopsTypeCount: { [key: string]: number } = {\r\n              \"non-tagging\": 0,\r\n              duplicate: 0,\r\n              employee: 0,\r\n              \"house-keeping\": 0,\r\n              junk: 0,\r\n            };\r\n\r\n            let totalCount = 0;\r\n            this.overallArrayData = [];\r\n\r\n            this.allFootfallData.forEach((item: any) => {\r\n              item.data?.forEach((image: any) => {\r\n                this.overallArrayData.push(image);\r\n                totalCount++;\r\n\r\n                const type =\r\n                  image.revopsType?.trim().toLowerCase() || \"unknown\";\r\n\r\n                if (type === \"non-tagging\") {\r\n                  revopsTypeCount[\"non-tagging\"]++;\r\n                } else if (type === \"employee\") {\r\n                  revopsTypeCount[\"employee\"]++;\r\n                } else if (type === \"house-keeping\") {\r\n                  revopsTypeCount[\"house-keeping\"]++;\r\n                } else if(type === \"junk\") {\r\n                  revopsTypeCount[\"junk\"]++;\r\n                }\r\n\r\n                // ✅ Count duplicates only from duplicateImagePath\r\n                if (Array.isArray(image.duplicateImagePath)) {\r\n                  revopsTypeCount[\"duplicate\"] +=\r\n                    image.duplicateImagePath.length;\r\n                }\r\n              });\r\n            });\r\n\r\n            this.countData = {\r\n              footfallCount: totalCount,\r\n              nonTags: revopsTypeCount[\"non-tagging\"],\r\n              duplicate: revopsTypeCount[\"duplicate\"],\r\n              employee: revopsTypeCount[\"employee\"],\r\n              housekeeping: revopsTypeCount[\"house-keeping\"],\r\n              junk: revopsTypeCount[\"junk\"]\r\n            };\r\n\r\n            // Apply type filter after loading timeRange data\r\n            this.applyFilters();\r\n            this.cd.detectChanges();\r\n            this.loading = false;\r\n            // this.noData = false;\r\n          } else {\r\n            // In case of failure\r\n            this.getRvpsList = [];\r\n            this.getRvpsImageList = [];\r\n            this.objectsArray = [];\r\n            this.imagesArrayData = [];\r\n            this.overallArrayData = [];\r\n            this.countData = [];\r\n            this.loading = false;\r\n            this.noData = true;\r\n          }\r\n        },\r\n        error: (err) => {\r\n          const msg =\r\n            err.error.error ||\r\n            err.error ||\r\n            err?.error?.message ||\r\n            err.message ||\r\n            \"Unknown error\";\r\n          this.toast.getErrorToast(msg);\r\n          this.loading = false;\r\n          this.noData = true;\r\n          this.getRvpsList = [];\r\n          this.getRvpsImageList = [];\r\n          this.objectsArray = [];\r\n          this.imagesArrayData = [];\r\n          this.overallArrayData = [];\r\n          this.countData = [];\r\n        },\r\n      });\r\n  }\r\n\r\n  originalCheckedDuplicateIds: any;\r\n  editValue() {\r\n    const type = (this.selectedType || \"\").toLowerCase();\r\n    this.revopsTypeValue = false;\r\n\r\n    const selectedImage = this.selectImageArray;\r\n    const selectedTempld = selectedImage?.templd;\r\n\r\n    if (\r\n      type === \"duplicate\" &&\r\n      Array.isArray(selectedImage.duplicateImagePath)\r\n    ) {\r\n      // 1. Convert duplicate children into consistent objects with parent reference\r\n      const duplicateChildren = selectedImage.duplicateImagePath.map(\r\n        (child: any) => ({\r\n          ...child,\r\n          parent: selectedTempld,\r\n          selected: true,\r\n        })\r\n      );\r\n\r\n      // 2. Collect the templd values of duplicate children\r\n      const duplicateChildIds = duplicateChildren.map(\r\n        (child: any) => child.tempId\r\n      );\r\n\r\n      // 3. Filter out non-tagging images except the selected parent & its children\r\n      const nonTaggingImages = this.overallArrayData.filter((img: any) => {\r\n        const isNonTagging =\r\n          (img.revopsType || \"\").toLowerCase() === \"non-tagging\";\r\n        const isNotSelected =\r\n          img.templd !== selectedTempld &&\r\n          !duplicateChildIds.includes(img.templd);\r\n        return isNonTagging && isNotSelected;\r\n      });\r\n\r\n      // 4. Merge duplicate children + other non-tagging images\r\n      this.remainingImageArray = [...duplicateChildren, ...nonTaggingImages];\r\n\r\n      // 5. Mark selected: only duplicate images that were marked isChecked\r\n      this.remainingImageArray.forEach((img: any) => {\r\n        const isDuplicate =\r\n          (img.revopsType || \"\").toLowerCase() === \"duplicate\";\r\n        img.selected = isDuplicate && img.isChecked === true;\r\n      });\r\n\r\n      // 6. Store original checked IDs to compare later during submit\r\n      this.originalCheckedDuplicateIds = this.remainingImageArray\r\n        .filter((img: any) => img.isChecked === true)\r\n        .map((img: any) => img.templd);\r\n\r\n      // ✅ 7. Fill selectedDuplicateImagesList with pre-selected duplicates\r\n      this.selectedDuplicateImagesList = this.remainingImageArray\r\n        .filter(\r\n          (img: any) =>\r\n            (img.revopsType || \"\").toLowerCase() === \"duplicate\" &&\r\n            img.isChecked === true\r\n        )\r\n        .map((img: any) => ({\r\n          ...img,\r\n          parent: img.parent || selectedTempld,\r\n          isChecked: true,\r\n        }));\r\n    } else {\r\n      // Not duplicate type → show only selected type (excluding the current selected image)\r\n      this.remainingImageArray = this.overallArrayData.filter((img: any) => {\r\n        const imgType = (img.revopsType || \"\").toLowerCase();\r\n        return imgType === type && img.templd !== selectedTempld;\r\n      });\r\n    }\r\n  }\r\n\r\n  backToFootfall1() {\r\n    this.selectedRadioType = undefined;\r\n    this.imageFlow = false;\r\n  }\r\n  selectImageArray: any;\r\n  remainingImageArray: any;\r\n  revopsTypeValue = false;\r\n\r\n  editBtnShow = false;\r\nimgFullView(obj: any) {\r\n  this.selectImageArray = obj;\r\n  this.imageFlow = true;\r\n  this.revopsTypeValue = false;\r\n  this.selectedType = \"\";\r\n  this.selectedRadioType = undefined;\r\n  let filteredByType: any[] = [];\r\n  const selectedType = obj.revopsType?.toLowerCase();\r\n\r\n  if (selectedType === \"duplicate\" && Array.isArray(obj.duplicateImagePath)) {\r\n    // 🔹 Case 1: Duplicate parent → show only parent + its children\r\n    const children = obj.duplicateImagePath.map((child: any) => {\r\n      const matched = this.overallArrayData.find(\r\n        (img: any) => img.templd === child.tempId\r\n      );\r\n      return {\r\n        ...child,\r\n        ...(matched || {}),\r\n        parent: obj.templd,\r\n      };\r\n    });\r\n\r\n    filteredByType = [obj, ...children];\r\n\r\n    // current index always 0 (parent first)\r\n    this.currentImageIndex = 0;\r\n\r\n    // remaining = children only\r\n    this.remainingImageArray = children;\r\n  } else {\r\n    // 🔹 Case 2: Normal → filter by same type\r\n    filteredByType = this.overallArrayData.filter(\r\n      (img: any) => img.revopsType?.toLowerCase() === selectedType\r\n    );\r\n\r\n    this.currentImageIndex = filteredByType.findIndex(\r\n      (img: any) => img.templd === obj.templd\r\n    );\r\n\r\n    this.remainingImageArray = filteredByType.filter(\r\n      (_: any, i: number) => i !== this.currentImageIndex\r\n    );\r\n  }\r\n\r\n  // ✅ Handle edit button / radio logic\r\n  if (\r\n    obj?.revopsType === \"duplicate\" ||\r\n    obj?.revopsType === \"employee\" ||\r\n    obj?.revopsType === \"house-keeping\" || obj?.revopsType ===\"junk\"\r\n  ) {\r\n    if (\r\n      obj?.revopsType === \"duplicate\" &&\r\n      obj?.duplicateImagePath?.length > 0\r\n    ) {\r\n      this.editBtnShow = true;\r\n    } else if (\r\n      obj?.revopsType === \"employee\" ||\r\n      obj?.revopsType === \"house-keeping\" || obj?.revopsType ===\"junk\"\r\n    ) {\r\n      this.editBtnShow = true;\r\n    } else {\r\n      this.editBtnShow = false;\r\n    }\r\n\r\n    this.revopsTypeValue = true;\r\n    this.selectedType = obj?.revopsType;\r\n    this.onRadioChange(obj?.revopsType);\r\n  }\r\n}\r\n\r\n\r\n  imgSwap(obj: any) {\r\n    if (this.selectImageArray) {\r\n      // Find where the new selected image is in the list\r\n      const index = this.remainingImageArray.findIndex(\r\n        (img: any) => img.templd === obj.templd\r\n      );\r\n\r\n      // Replace selectedImageArray back into its original position\r\n      if (index !== -1) {\r\n        this.remainingImageArray[index] = this.selectImageArray;\r\n      } else {\r\n        // fallback if not found\r\n        this.remainingImageArray.push(this.selectImageArray);\r\n      }\r\n    }\r\n\r\n    // Update selected image\r\n    this.selectImageArray = obj;\r\n\r\n    // Remove selected from remaining list\r\n    this.remainingImageArray = this.remainingImageArray.filter(\r\n      (img: any) => img.templd !== obj.templd\r\n    );\r\n\r\n    this.imageFlow = true;\r\n  }\r\n\r\n  selectedType: any = \"\"; // default selected\r\n  selectedRadioType: any;\r\nonRadioChange(val: any) {\r\n  this.selectedRadioType = val;\r\n  this.selectedDuplicateImagesList = [];\r\n\r\n  const type = (val || \"\").toLowerCase();\r\n\r\n  if (type === \"duplicate\") {\r\n    if (\r\n      this.selectImageArray?.revopsType?.toLowerCase() === \"duplicate\" &&\r\n      Array.isArray(this.selectImageArray?.duplicateImagePath) &&\r\n      this.selectImageArray.duplicateImagePath.length > 0\r\n    ) {\r\n      // 🔹 Case 1: Already in duplicate flow → keep children set by imgFullView\r\n      this.remainingImageArray = this.remainingImageArray.map((child: any) => {\r\n        return { ...child, selected: false, isChecked: false };\r\n      });\r\n    } else {\r\n      // 🔹 Case 2: Radio duplicate for non-duplicate parent → show non-tagging images\r\n      const selectedTempld = this.selectImageArray?.templd;\r\n\r\n      this.remainingImageArray = this.overallArrayData.filter((img: any) => {\r\n        const imgType = (img.revopsType || \"\").toLowerCase();\r\n        return imgType === \"non-tagging\" && img.templd !== selectedTempld;\r\n      });\r\n\r\n      this.remainingImageArray.forEach((img: any) => {\r\n        img.selected = false;\r\n        img.isChecked = false;\r\n      });\r\n    }\r\n  }\r\n}\r\n\r\n\r\n  type: any = \"footfall\";\r\n  selectPlanTrends(type: any) {\r\n    this.type = type;\r\n\r\n    this.applyFilters();\r\n  }\r\n  applyFilters() {\r\n    this.imageFlow = false;\r\n\r\n    // Convert type to lowercase safely\r\n    const selectedType = this.type?.toLowerCase();\r\n\r\n    if (selectedType === \"footfall\") {\r\n      // Footfall shows all currentTimeRangeData (time range based)\r\n      this.imagesArrayData = [...this.currentTimeRangeData];\r\n    } else {\r\n      // For tagged types like 'duplicate', 'employee', 'housekeeping'\r\n      this.imagesArrayData = this.overallArrayData.filter(\r\n        (item: any) => item.revopsType?.toLowerCase() === selectedType\r\n      );\r\n    }\r\n    // else {\r\n    //   // Non-tagging means no revopsType - show all unmatched (no tag)\r\n    //   this.imagesArrayData = this.currentTimeRangeData.filter((item: any) =>\r\n    //     !item.revopsType\r\n    //   );\r\n    // }\r\n\r\n    // Set noData based on result\r\n    this.noData = !this.imagesArrayData?.length;\r\n\r\n    this.cd.detectChanges();\r\n  }\r\n  handleImageClick(evt: any, obj: any) {\r\n    // Only toggle checkbox if radio is 'duplicate' and image is not already tagged\r\n    if (\r\n      this.selectedRadioType === \"duplicate\" &&\r\n      !(obj.duplicateImagePath?.length > 0)\r\n    ) {\r\n      this.onImageCheckboxChange(evt, obj, \"duplicate\");\r\n    } else if (this.selectedRadioType !== \"duplicate\") {\r\n      this.imgSwap(obj); // existing non-duplicate click behavior\r\n    }\r\n  }\r\n  selectedDuplicateImagesList: any = [];\r\n\r\n  onImageCheckboxChange(evt: any, img: any, type: string) {\r\n    if (type === \"duplicate\") {\r\n      const totalImages = this.overallArrayData.length;\r\n      const alreadyTaggedCount = this.countData?.duplicate || 0;\r\n      // console.log(totalImages)\r\n      // console.log(alreadyTaggedCount)\r\n      // Total taggable count = already tagged + selected now\r\n      const maxSelectable = Math.round(totalImages * 0.2);\r\n      // console.log(maxSelectable)\r\n      // Count selected now (in UI)\r\n      const currentlySelectedCount = this.overallArrayData.filter(\r\n        (item: any) => item.selected\r\n      ).length;\r\n\r\n      const willSelect = !img.selected;\r\n\r\n      // ⛔ Block selection if trying to go beyond 10% cap\r\n      if (\r\n        willSelect &&\r\n        currentlySelectedCount + alreadyTaggedCount >= maxSelectable\r\n      ) {\r\n        this.toast.getWarningToast(\r\n          `You can select only ${maxSelectable} images (${\r\n            this.getRvpsList?.data?.config?.duplicate ?? \"20%\"\r\n          } of total footfall)`\r\n        );\r\n        evt.target.checked = false;\r\n        this.cd.detectChanges();\r\n        return;\r\n      }\r\n\r\n      // ✅ Proceed with selection toggle\r\n      img.selected = !img.selected;\r\n      img.isChecked = img.selected;\r\n\r\n      // ✅ Always rebuild the selected list\r\n      this.selectedDuplicateImagesList = this.remainingImageArray\r\n        .filter((item: any) => item.selected)\r\n        .map((item: any) => ({\r\n          ...item,\r\n          parent: item.parent || this.selectImageArray?.templd,\r\n          isChecked: true,\r\n        }));\r\n\r\n      // console.log('✅ selectedDuplicateImagesList:', this.selectedDuplicateImagesList);\r\n    }\r\n  }\r\n\r\n  clearValue() {\r\n    this.save(\"non-tagging\");\r\n    // this.submitValue('non-tagging')\r\n  }\r\n  cancel() {\r\n    // 1. Clear selected duplicate images list\r\n    this.selectedDuplicateImagesList = [];\r\n\r\n    // 2. Reset all checkboxes and radio buttons in overall image list\r\n    this.overallArrayData = this.overallArrayData.map((img: any) => ({\r\n      ...img,\r\n      isChecked: false,\r\n      selected: false, // assuming 'selected' is checkbox bind\r\n      parent: null, // reset parent if used\r\n      // Add other flags here if needed\r\n    }));\r\n\r\n    // 3. Close image flow/full-view if open\r\n    this.imageFlow = false;\r\n\r\n    // 4. Reset currently selected image\r\n    this.selectImageArray = null;\r\n    this.currentImageIndex = 0;\r\n    this.remainingImageArray = [];\r\n\r\n    // 5. (Optional) Reset radio buttons — if you have any specific flag\r\n    this.selectedRadioType = undefined;\r\n  }\r\n  popupType: any;\r\n  @ViewChild(\"zoomPopup\") zoomPopup: ElementRef;\r\n  save(category: any) {\r\n    const modalRef = this.modalService.open(this.zoomPopup, {\r\n      centered: true,\r\n      size: \"md\",\r\n      backdrop: \"static\", // Prevent closing on outside click\r\n      keyboard: false, // Prevent closing on ESC key\r\n    });\r\n    this.popupType = category;\r\n  }\r\n\r\n  cancelSubmit() {\r\n    this.modalService.dismissAll();\r\n\r\n    this.selectedDuplicateImagesList = [];\r\n  }\r\n  submitValue(category: any) {\r\n    let duplicateImages = [];\r\n\r\n    if (category === \"duplicate\") {\r\n      duplicateImages = this.remainingImageArray\r\n        .filter((img: any) => img.selected === true)\r\n        .map((img: any) => ({\r\n          tempId: img.templd || img.tempId || \"\",\r\n          timeRange: img.timeRange || \"\",\r\n          entryTime: img.entryTime || img.entryTme || \"\",\r\n          exitTime: img.exitTime || \"\",\r\n          filePath: img.filePath,\r\n          revopsType: \"duplicate\",\r\n          isChecked: true,\r\n        }));\r\n    }\r\n\r\n    const img = this.selectImageArray;\r\n\r\n    const obj = {\r\n      storeId:\r\n        this.storeIdarray && this.storeIdarray.length > 0\r\n          ? this.storeIdarray[0]\r\n          : null,\r\n      dateString: this.folderDate || \"\",\r\n      tempId: img?.templd || 0,\r\n      revopsType: category,\r\n      timeRange: img?.timeRange || \"\",\r\n      isChecked: true,\r\n      duplicateImage: duplicateImages,\r\n      processType: img?.processType || \"footfall\",\r\n      entryTime: img?.entryTime || img?.entryTme || \"\",\r\n      exitTime: img?.exitTime || \"\",\r\n      filePath: img?.filePath || \"\",\r\n    };\r\n\r\n    this.rvpsService\r\n      .getRvpsTag(obj)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.toast.getSuccessToast(\r\n              res?.message || \"Ticket updated successfully\"\r\n            );\r\n            this.imageFlow = false;\r\n            this.getRevops();\r\n            this.cancelSubmit();\r\n            this.selectedRadioType = undefined;\r\n            this.selectedType = \"\";\r\n          } else {\r\n            this.toast.getErrorToast(\"Failed to update\");\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          const msg =\r\n            err.error?.error || err.error || err?.message || \"Unknown error\";\r\n          this.toast.getErrorToast(msg);\r\n        },\r\n      });\r\n  }\r\n\r\n  noDataMessages: { [key: string]: string } = {\r\n    duplicate: \"No duplicates found\",\r\n    employee: \"No employee/staff found\",\r\n    \"house-keeping\": \"No house keeping found\",\r\n    \"non-tagging\": \"No non-tagging found\",\r\n    junk: \"No junk found\"\r\n  };\r\n\r\n  tempRaisedPayload: any = null; // class-level variable for preview\r\n\r\n  prepareRaisedPayload(showOnly = false): any {}\r\n\r\n  @ViewChild(\"raisedPopup\") raisedPopup: ElementRef;\r\n  Raised() {\r\n    const payload: any = {\r\n      dateString: this.folderDate,\r\n      storeId: this.storeIdarray?.length > 0 ? this.storeIdarray[0] : null,\r\n      ticketName: \"footfall-directory\",\r\n      footfallCount: 0,\r\n      duplicateCount: 0,\r\n      employeeCount: 0,\r\n      houseKeepingCount: 0,\r\n      junkCount:0,\r\n      comments: this.commentText || \"\",\r\n      duplicateImages: [],\r\n      houseKeeping: [],\r\n      employee: [],\r\n      junk: [],\r\n    };\r\n\r\n    let totalCheckedCount = 0;\r\n\r\n    this.overallArrayData.forEach((item: any) => {\r\n      const type = item.revopsType?.toLowerCase()?.trim();\r\n      const isChecked = item.isChecked === true;\r\n\r\n      // ✅ Count only if item is checked AND revopsType is 'non-tagging'\r\n      // const isNotTagged = type === 'non-tagging';\r\n\r\n      // if (isNotTagged) {\r\n      //   totalCheckedCount++;\r\n      // }\r\n\r\n      // DUPLICATE TYPE\r\n      if (type === \"duplicate\" && Array.isArray(item.duplicateImagePath)) {\r\n        const nestedData = item.duplicateImagePath\r\n          .filter((dup: any) => dup.isChecked)\r\n          .map((dup: any) => ({\r\n            tempId: dup.tempId || dup.templd || \"\",\r\n            filePath: dup.filePath,\r\n            entryTime: dup?.entryTime || dup?.entryTme || \"\",\r\n            exitTime: dup.exitTime,\r\n            timeRange: dup.timeRange,\r\n            isChecked: dup.isChecked,\r\n          }));\r\n\r\n        if (nestedData.length > 0) {\r\n          payload.duplicateImages.push({\r\n            tempId: item.templd,\r\n            filePath: item.filePath,\r\n            entryTime: item?.entryTime || item?.entryTme || \"\",\r\n            exitTime: item.exitTime,\r\n            timeRange: item.timeRange,\r\n            isChecked: item.isChecked,\r\n            data: nestedData,\r\n          });\r\n\r\n          payload.duplicateCount += nestedData.length;\r\n        }\r\n      }\r\n\r\n      // EMPLOYEE\r\n      else if (type === \"employee\" && isChecked) {\r\n        payload.employee.push({\r\n          tempId: item.templd,\r\n          filePath: item.filePath,\r\n          entryTime: item?.entryTime || item?.entryTme || \"\",\r\n          exitTime: item.exitTime,\r\n          timeRange: item.timeRange,\r\n          isChecked: item.isChecked,\r\n        });\r\n\r\n        payload.employeeCount++;\r\n      }\r\n\r\n      // HOUSEKEEPING\r\n      else if (type === \"house-keeping\" && isChecked) {\r\n        payload.houseKeeping.push({\r\n          tempId: item.templd,\r\n          filePath: item.filePath,\r\n          entryTime: item?.entryTime || item?.entryTme || \"\",\r\n          exitTime: item.exitTime,\r\n          timeRange: item.timeRange,\r\n          isChecked: item.isChecked,\r\n        });\r\n\r\n        payload.houseKeepingCount++;\r\n      } \r\n      else if (type === \"junk\" && isChecked) {\r\n        payload.junk.push({\r\n          tempId: item.templd,\r\n          filePath: item.filePath,\r\n          entryTime : item?.entryTime || item?.entryTme || \"\",\r\n          exitTime : item.exitTime,\r\n          timeRange : item.timeRange,\r\n          isChecked : item.isChecked,\r\n        });\r\n\r\n        payload.junkCount++;\r\n      }\r\n    });\r\n\r\n    payload.footfallCount = this.countData?.footfallCount;\r\n\r\n    // 👇 Return or assign\r\n\r\n    this.tempRaisedPayload = payload;\r\n    this.cd.detectChanges();\r\n    const modalRef = this.modalService.open(this.raisedPopup, {\r\n      centered: true,\r\n      size: \"md\",\r\n      backdrop: \"static\",\r\n      keyboard: false,\r\n    });\r\n  }\r\n\r\n  cancelRasied() {\r\n    this.modalService.dismissAll();\r\n    this.selectedDuplicateImagesList = [];\r\n  }\r\n\r\n  commentText: any;\r\n  getRaisedData: any;\r\n  submitRaised() {\r\n    const payload = this.tempRaisedPayload; // fresh data for API\r\n\r\n    this.getRaisedData = payload;\r\n\r\n    this.rvpsService\r\n      .getCreateRaisedTag(payload)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res && res.code === 200) {\r\n            this.toast.getSuccessToast(\r\n              res?.message || \"Ticket updated successfully\"\r\n            );\r\n            this.imageFlow = false;\r\n            this.getRevops();\r\n            this.cancelRasied();\r\n            this.selectedRadioType = undefined;\r\n            this.selectedType = \"\";\r\n          } else {\r\n            this.toast.getErrorToast(\"Failed to update\");\r\n          }\r\n        },\r\n        error: (err: any) => {\r\n          const msg =\r\n            err.error?.error ||\r\n            err.error ||\r\n            err?.error?.message ||\r\n            err.message ||\r\n            \"Unknown error\";\r\n          this.toast.getErrorToast(msg);\r\n        },\r\n      });\r\n  }\r\n\r\n  // onImageCheckboxChange(img: any, type: string) {\r\n  //   if (type === 'duplicate') {\r\n  //     // Count only valid duplicate images where `duplicateImagePath.length === 0`\r\n  //     const totalValidDuplicateImages = this.overallArrayData.filter(\r\n  //       (item: any) =>\r\n  //         item.revopsType === 'duplicate' && (!item.duplicateImagePath || item.duplicateImagePath.length === 0)\r\n  //     ).length;\r\n\r\n  //     const maxAllowed = Math.floor(totalValidDuplicateImages * 0.1); // 10% limit\r\n\r\n  //     const alreadyExists = this.selectedDuplicateImagesList.some(\r\n  //       (item: any) => item.templd === img.templd\r\n  //     );\r\n\r\n  //     if (img.selected) {\r\n  //       // ❌ Reached max allowed — block it\r\n  //       if (this.selectedDuplicateImagesList.length >= maxAllowed) {\r\n  //         this.toast.getErrorToast(\r\n  //           `Only ${maxAllowed} images can be selected as duplicate (10% of untagged duplicates).`\r\n  //         );\r\n\r\n  //         img.selected = false;\r\n  //         const index = this.overallArrayData.findIndex((item: any) => item.templd === img.templd);\r\n  //         if (index !== -1) {\r\n  //           this.overallArrayData[index].selected = false;\r\n  //         }\r\n\r\n  //         setTimeout(() => {\r\n  //           img.selected = false;\r\n  //         });\r\n\r\n  //         return;\r\n  //       }\r\n\r\n  //       // ✅ Add if not already in list\r\n  //       if (!alreadyExists) {\r\n  //         this.selectedDuplicateImagesList.push({\r\n  //           ...img,\r\n  //           isChecked: true,\r\n  //           parent: img.parent || null\r\n  //         });\r\n  //       }\r\n  //     } else {\r\n  //       // ❌ Removal case\r\n  //       this.selectedDuplicateImagesList = this.selectedDuplicateImagesList.filter(\r\n  //         (item: any) => item.templd !== img.templd\r\n  //       );\r\n  //     }\r\n  //   }\r\n\r\n  //   // ⚠️ Call this to update button enable state\r\n  //   this.checkDuplicateSaveEnable();\r\n  // }\r\n\r\n  // duplicateSaveEnabled = false;\r\n\r\n  // checkDuplicateSaveEnable() {\r\n  //   this.duplicateSaveEnabled =\r\n  //     this.selectedRadioType === 'duplicate' && this.selectedDuplicateImagesList.length > 0;\r\n  // }\r\n\r\n  isModalOpen = false;\r\n  @ViewChild(\"imagePopup\") imagePopup: ElementRef;\r\n  selectedImageArray(url: any, data: any) {\r\n    this.isModalOpen = true;\r\n    const modalRef = this.modalService.open(this.imagePopup, {\r\n      centered: true,\r\n      size: \"lg\",\r\n      backdrop: \"static\",\r\n      keyboard: false,\r\n    });\r\n  }\r\n\r\n  closeImage() {\r\n    this.isModalOpen = false;\r\n    this.modalService.dismissAll();\r\n  }\r\n\r\n  canEnableButton(): boolean {\r\n    if (!this.countData || !this.folderDate) {\r\n      return false;\r\n    }\r\n\r\n    const { duplicate, housekeeping, employee, junk } = this.countData;\r\n\r\n    // Check count condition\r\n    const hasCount = duplicate > 0 || housekeeping > 0 || employee > 0 || junk > 0;\r\n\r\n    // Convert folderDate to Date\r\n    const folder = new Date(this.folderDate);\r\n    const today = new Date();\r\n\r\n    // Normalize times (remove hours for proper day comparison)\r\n    folder.setHours(0, 0, 0, 0);\r\n    today.setHours(0, 0, 0, 0);\r\n\r\n    // Calculate difference in days\r\n    const diffInTime = today.getTime() - folder.getTime();\r\n    const diffInDays = diffInTime / (1000 * 3600 * 24);\r\n\r\n    // Within last 7 days → diff between 0 and 7\r\n    const isWithinLast7 = diffInDays >= 0 && diffInDays <= 7;\r\n\r\n    return hasCount && isWithinLast7;\r\n  }\r\n\r\n  currentImageIndex: number = 0;\r\n  get canNavigateLeft(): boolean {\r\n    return this.currentImageIndex > 0;\r\n  }\r\n\r\n  get canNavigateRight(): boolean {\r\n    return this.currentImageIndex < this.imagesArrayData.length - 1;\r\n  }\r\n\r\n  navigateImage(direction: \"left\" | \"right\") {\r\n    const length = this.imagesArrayData.length;\r\n\r\n    if (direction === \"left\" && this.canNavigateLeft) {\r\n      this.currentImageIndex--;\r\n    } else if (direction === \"right\" && this.canNavigateRight) {\r\n      this.currentImageIndex++;\r\n    }\r\n\r\n    // Update selected image\r\n    this.selectImageArray = this.imagesArrayData[this.currentImageIndex];\r\n\r\n    // Update remaining images\r\n    this.remainingImageArray = this.imagesArrayData.filter(\r\n      (_: any, i: any) => i !== this.currentImageIndex\r\n    );\r\n  }\r\n}","<div class=\"card mt-3\">\r\n    <div class=\"card-header mt-3 px-0 border-bottom-0\">\r\n        <div class=\"custom-accordion\">\r\n            <div class=\"custom-accordion-item\">\r\n                <button class=\"mainheading pb-0 custom-accordion-header\" (click)=\"toggleAccordion()\">\r\n                    <div class=\"header-row\">\r\n                        <span class=\"img-direc\">Image Directory</span>\r\n\r\n                        <span class=\"divider\"></span>\r\n                        <span class=\"accordion-arrow\">\r\n                            <!-- Down arrow for collapsed state, up arrow for expanded state -->\r\n                            <svg *ngIf=\"!isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\r\n                                viewBox=\"0 0 16 6\" fill=\"none\">\r\n                                <path d=\"M1 1L5 5L9 1\" stroke=\"#071437\" stroke-width=\"1\" stroke-linecap=\"round\"\r\n                                    stroke-linejoin=\"round\" />\r\n                            </svg>\r\n                            <svg *ngIf=\"isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\r\n                                viewBox=\"0 0 16 6\" fill=\"none\">\r\n                                <path d=\"M1 5L5 1L9 5\" stroke=\"#1b84ff\" stroke-width=\"1\" stroke-linecap=\"round\"\r\n                                    stroke-linejoin=\"round\" />\r\n                            </svg>\r\n                        </span>\r\n                    </div>\r\n                </button>\r\n            </div>\r\n        </div>\r\n\r\n\r\n    </div>\r\n    <section *ngIf=\"isAccordionExpanded\">\r\n\r\n        <div *ngIf=\"folderView\" class=\"card-body px-0\">\r\n            <div class=\"scroll-container\">\r\n                <div class=\"row\">\r\n                    <div class=\"col-md-1 mt-5 text-center\" *ngFor=\"let obj of dateArray;let i = index\">\r\n                        <div (click)=\"getimages(i,obj)\">\r\n                            <div *ngIf=\"i === selectIndex;\">\r\n                                <span class=\"cursor-pointer\"><svg width=\"57\" height=\"56\" viewBox=\"0 0 57 56\" fill=\"none\"\r\n                                        xmlns=\"http://www.w3.org/2000/svg\">\r\n                                        <rect x=\"0.154297\" width=\"56\" height=\"56\" rx=\"12\" fill=\"#33B5FF\" />\r\n                                        <path\r\n                                            d=\"M39.8216 36.1667C39.8216 36.7855 39.5758 37.379 39.1382 37.8166C38.7006 38.2542 38.1071 38.5 37.4883 38.5H18.8216C18.2028 38.5 17.6093 38.2542 17.1717 37.8166C16.7341 37.379 16.4883 36.7855 16.4883 36.1667V19.8333C16.4883 19.2145 16.7341 18.621 17.1717 18.1834C17.6093 17.7458 18.2028 17.5 18.8216 17.5H24.6549L26.9883 21H37.4883C38.1071 21 38.7006 21.2458 39.1382 21.6834C39.5758 22.121 39.8216 22.7145 39.8216 23.3333V36.1667Z\"\r\n                                            stroke=\"white\" stroke-width=\"2.33333\" stroke-linecap=\"round\"\r\n                                            stroke-linejoin=\"round\" />\r\n                                    </svg></span>\r\n                                <div class=\"text-center mt-2\">{{obj | date:'dd MMM'}}</div>\r\n                            </div>\r\n                            <div *ngIf=\"i !== selectIndex;\">\r\n                                <span class=\"cursor-pointer\"><svg width=\"57\" height=\"56\" viewBox=\"0 0 57 56\" fill=\"none\"\r\n                                        xmlns=\"http://www.w3.org/2000/svg\">\r\n                                        <rect x=\"0.462891\" width=\"56\" height=\"56\" rx=\"12\" fill=\"#EAF8FF\" />\r\n                                        <path\r\n                                            d=\"M40.1302 36.1667C40.1302 36.7855 39.8844 37.379 39.4468 37.8166C39.0092 38.2542 38.4157 38.5 37.7969 38.5H19.1302C18.5114 38.5 17.9179 38.2542 17.4803 37.8166C17.0427 37.379 16.7969 36.7855 16.7969 36.1667V19.8333C16.7969 19.2145 17.0427 18.621 17.4803 18.1834C17.9179 17.7458 18.5114 17.5 19.1302 17.5H24.9635L27.2969 21H37.7969C38.4157 21 39.0092 21.2458 39.4468 21.6834C39.8844 22.121 40.1302 22.7145 40.1302 23.3333V36.1667Z\"\r\n                                            stroke=\"#00A3FF\" stroke-width=\"2.33333\" stroke-linecap=\"round\"\r\n                                            stroke-linejoin=\"round\" />\r\n                                    </svg></span>\r\n                                <div class=\"text-center mt-2\">{{obj | date:'dd MMM'}}</div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n\r\n\r\n        <div *ngIf=\"!folderView\" class=\"card-body\">\r\n            <section *ngIf=\"!imageFlow\">\r\n\r\n\r\n                <div class=\"row\">\r\n                    <div class=\"d-flex flex-shrink-0 mt-3 justify-content-start align-items-center px-0\">\r\n                        <span *ngIf=\"backnav\" class=\"cursor-pointer\" (click)=\"backToFootfall()\">\r\n                            <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\"\r\n                                xmlns=\"http://www.w3.org/2000/svg\">\r\n                                <g filter=\"url(#filter0_d_2585_7036)\">\r\n                                    <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\r\n                                    <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\r\n                                    <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\r\n                                        stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                        stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\r\n                                        filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n                                        <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\r\n                                        <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\r\n                                            values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\r\n                                        <feOffset dy=\"1\" />\r\n                                        <feGaussianBlur stdDeviation=\"1\" />\r\n                                        <feColorMatrix type=\"matrix\"\r\n                                            values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\r\n                                        <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\r\n                                            result=\"effect1_dropShadow_2585_7036\" />\r\n                                        <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\r\n                                            result=\"shape\" />\r\n                                    </filter>\r\n                                </defs>\r\n                            </svg>\r\n                        </span>\r\n                        <span class=\"img-direc ms-2 mt-1\">{{folderDate | date:'dd MMM, yyyy'}}  \r\n           <span class=\"badge badge-light-warning mx-2\" *ngIf=\"!getTicketStatuses().includes('closed') && getTicketStatuses().includes('open')\">\r\n  Ticket Raised\r\n</span>\r\n<span class=\"badge badge-light-success mx-2\" *ngIf=\"getTicketStatuses().includes('closed')\">Ticket Closed</span>\r\n\r\n                            </span>\r\n                      <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\"  class=\"ms-auto text-end\">\r\n                     \r\n<button \r\n  [disabled]=\"!canEnableButton()\" \r\n  class=\"btn btn-primary\" \r\n  type=\"button\" \r\n  (click)=\"Raised()\">\r\n  Raise ticket for footfall\r\n</button>\r\n</div>\r\n                    </div>\r\n                    <div *ngIf=\"!folderView\" class=\"nav-group bg-white border-1 btn-group w-auto my-2\">\r\n<ng-container *ngIf=\"!(countData?.length > 0)\">\r\n\r\n    <button class=\"btn btn-outline px-6 py-3\"\r\n        [ngClass]=\"type === 'footfall' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n        (click)=\"selectPlanTrends('footfall')\">\r\n        Total Footfall\r\n        <span\r\n            [ngClass]=\"type === 'footfall' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\r\n            {{ countData?.footfallCount || 0 }}\r\n        </span>\r\n    </button>\r\n\r\n    <button class=\"btn btn-outline px-6 py-3\"\r\n        [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n        (click)=\"selectPlanTrends('non-tagging')\">\r\n        Non-tags\r\n        <span\r\n            [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\r\n            {{ countData?.nonTags || 0 }}\r\n        </span>\r\n    </button>\r\n\r\n    <button class=\"btn btn-outline px-6 py-3\"\r\n        [ngClass]=\"type === 'duplicate' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n        (click)=\"selectPlanTrends('duplicate')\">\r\n        Duplicated\r\n        <span\r\n            [ngClass]=\"type === 'duplicate' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\r\n            {{ countData?.duplicate || 0 }}\r\n        </span>\r\n    </button>\r\n\r\n    <button class=\"btn btn-outline px-6 py-3\"\r\n        [ngClass]=\"type === 'employee' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n        (click)=\"selectPlanTrends('employee')\">\r\n        Employee/Staff\r\n        <span\r\n            [ngClass]=\"type === 'employee' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\r\n            {{ countData?.employee || 0 }}\r\n        </span>\r\n    </button>\r\n <button class=\"btn btn-outline px-6 py-3\"\r\n        [ngClass]=\"type === 'junk' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n        (click)=\"selectPlanTrends('junk')\">\r\n    Junk\r\n        <span\r\n            [ngClass]=\"type === 'junk' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\r\n            {{ countData?.junk || 0 }}\r\n        </span>\r\n    </button>\r\n    <button class=\"btn btn-outline px-6 py-3\"\r\n        [ngClass]=\"type === 'house-keeping' ? 'activePlanBtn' : 'inactivePlanBtn'\"\r\n        (click)=\"selectPlanTrends('house-keeping')\">\r\n    House Keeping\r\n        <span\r\n            [ngClass]=\"type === 'house-keeping' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\r\n            {{ countData?.housekeeping || 0 }}\r\n        </span>\r\n    </button>\r\n   \r\n\r\n</ng-container>\r\n\r\n                    </div>\r\n<ng-container *ngIf=\"!imageFlow\">\r\n\r\n    <div *ngIf=\"type === 'footfall'\" class=\"d-flex mt-2 mb-2 w-100 overflow-x px-0\">\r\n\r\n            <div class=\"col text-nowrap\" *ngFor=\"let obj of objectsArray\">\r\n                <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\r\n                    <li class=\"nav-item cursor-pointer\">\r\n                        <a (click)=\"selectedTimes(obj.timeRange)\"\r\n                            [ngClass]=\"selectedTime === obj?.timeRange ? 'active' : ''\"\r\n                            class=\"nav-link cursor-pointer no-border mx-3 mb-2\">\r\n                            {{obj?.timeRange}}<span class=\"mx-2\"\r\n                                [ngClass]=\"selectedTime === obj?.timeRange ? 'badge-num-primary' :'badge-num-muted'\">\r\n                                {{ obj?.count ? obj?.count : 0 }}\r\n                            </span>\r\n                        </a>\r\n                    </li>\r\n                </ul>\r\n            </div>\r\n\r\n\r\n    </div>\r\n</ng-container>\r\n                    <div *ngIf=\"loading\" class=\"row loader  d-flex justify-content-center align-items-center\">\r\n                        <div class=\"shimmer\">\r\n                            <div class=\"wrapper\">\r\n                                <div class=\"stroke animate title\"></div>\r\n                                <div class=\"stroke animate link\"></div>\r\n                                <div class=\"stroke animate description\"></div>\r\n                            </div>\r\n                        </div>\r\n                        <div class=\"shimmer\">\r\n                            <div class=\"wrapper\">\r\n                                <div class=\"stroke animate title\"></div>\r\n                                <div class=\"stroke animate link\"></div>\r\n                                <div class=\"stroke animate description\"></div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                    <div *ngIf=\"noData\" class=\"row\">\r\n\r\n                        <div class=\"col-lg-12 mb-3\">\r\n\r\n                            <div class=\"card-body d-flex justify-content-center align-items-center flex-column \" style=\"margin: 64px;border-radius: 8px;\r\nbackground: var(--Gray-50, #F9FAFB);\">\r\n                                <svg width=\"94\" height=\"94\" viewBox=\"0 0 94 94\" fill=\"none\"\r\n                                    xmlns=\"http://www.w3.org/2000/svg\">\r\n                                    <rect x=\"7\" y=\"7\" width=\"80\" height=\"80\" rx=\"40\" fill=\"#DAF1FF\" />\r\n                                    <rect x=\"7\" y=\"7\" width=\"80\" height=\"80\" rx=\"40\" stroke=\"#EAF8FF\"\r\n                                        stroke-width=\"13.3333\" />\r\n                                    <path\r\n                                        d=\"M35.332 51.9999H33.6654C32.7813 51.9999 31.9335 51.6487 31.3083 51.0236C30.6832 50.3985 30.332 49.5506 30.332 48.6666V33.6666C30.332 32.7825 30.6832 31.9347 31.3083 31.3096C31.9335 30.6844 32.7813 30.3333 33.6654 30.3333H48.6654C49.5494 30.3333 50.3973 30.6844 51.0224 31.3096C51.6475 31.9347 51.9987 32.7825 51.9987 33.6666V35.3333M45.332 41.9999H60.332C62.173 41.9999 63.6654 43.4923 63.6654 45.3333V60.3333C63.6654 62.1742 62.173 63.6666 60.332 63.6666H45.332C43.4911 63.6666 41.9987 62.1742 41.9987 60.3333V45.3333C41.9987 43.4923 43.4911 41.9999 45.332 41.9999Z\"\r\n                                        stroke=\"#00A3FF\" stroke-width=\"4\" stroke-linecap=\"round\"\r\n                                        stroke-linejoin=\"round\" />\r\n                                </svg>\r\n                                <div class=\"nodata-title my-3\">\r\n                                    {{ noDataMessages[type?.toLowerCase()] || 'No data found' }}\r\n                                </div>\r\n\r\n                            </div>\r\n                        </div>\r\n\r\n                    </div>\r\n\r\n\r\n    <div class=\"row px-0 img-traffic contain high-400px scroll-y\" *ngIf=\"!noData && !loading\">\r\n       <ng-container\r\n\r\n*ngFor=\"let obj of imagesArrayData\"\r\n>\r\n<div  *ngIf=\"type !== 'duplicate' || (type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\"  class=\"col-md-3 border-gray mx-2 p-2 mt-5\">\r\n<!-- Condition: Only show if not duplicate OR duplicate with non-empty duplicateImagePath -->\r\n<ng-container >\r\n<img\r\nclass=\"img-src cursor-pointer\"\r\n[src]=\"imageUrl + obj?.filePath\"\r\n(error)=\"obj.filePath = null\"\r\nalt=\"\"\r\n(click)=\"imgFullView(obj)\"\r\n/>\r\n</ng-container>\r\n\r\n            <div *ngIf=\"!obj?.filePath\" class=\"no-preview\">\r\n                <span class=\"mb-5\">\r\n                    <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\"\r\n                        xmlns=\"http://www.w3.org/2000/svg\">\r\n                        <g id=\"Group\">\r\n                            <path id=\"Vector\"\r\n                                d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\r\n                                stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                stroke-linejoin=\"round\" />\r\n                            <path id=\"Vector_2\"\r\n                                d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\r\n                                stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                stroke-linejoin=\"round\" />\r\n                        </g>\r\n                    </svg>\r\n\r\n                </span>\r\n                <span class=\"header mb-5 text-center\">Preview not available</span>\r\n                <span class=\"description mb-5 text-center\">The selected camera is not available at the\r\n                    moment.</span>\r\n            </div>\r\n            <div *ngIf=\"type !== 'duplicate' || (type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\" class=\"row px-2 mb-2\">\r\n                <div class=\"col-md-7\">\r\n                    <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd}} <span *ngIf=\"(type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\" class=\"mx-2 badge badge-light-primary\">{{obj.duplicateImagePath?.length}}</span>\r\n                     <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\r\n                                                        <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\r\n                                                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                                                            d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\r\n                                                            fill=\"#12B76A\" />\r\n                                                    </svg></span>\r\n                                        <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n                                                        <g clip-path=\"url(#clip0_1428_59484)\">\r\n                                                            <path\r\n                                                                d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n                                                                fill=\"#FEE4E2\" />\r\n                                                            <path\r\n                                                                d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n                                                                stroke=\"#D92D20\" stroke-linecap=\"round\"\r\n                                                                stroke-linejoin=\"round\" />\r\n                                                        </g>\r\n                                                        <defs>\r\n                                                            <clipPath id=\"clip0_1428_59484\">\r\n                                                                <rect width=\"12\" height=\"12\" fill=\"white\"\r\n                                                                    transform=\"translate(0.599609 0.5)\" />\r\n                                                            </clipPath>\r\n                                                        </defs>\r\n                                                    </svg></span>\r\n                                                </div>\r\n                    <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme}}</div>\r\n                </div>\r\n                <div class=\"col-md-5 text-end py-3\">\r\n                    <span *ngIf=\"obj?.revopsType ==='non-tagging'\" ngbTooltip=\"Yet to tag the customer\"\r\n                        placement=\"top\">\r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\r\n                            viewBox=\"0 0 19 18\" fill=\"none\">\r\n                            <path\r\n                                d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\r\n                                stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                stroke-linejoin=\"round\" />\r\n                        </svg>\r\n                    </span>\r\n                    <span *ngIf=\"obj?.revopsType ==='duplicate'\">\r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n                            viewBox=\"0 0 20 21\" fill=\"none\">\r\n                            <g clip-path=\"url(#clip0_2012_94635)\">\r\n                                <path\r\n                                    d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                    stroke-linejoin=\"round\" />\r\n                            </g>\r\n                            <defs>\r\n                                <clipPath id=\"clip0_2012_94635\">\r\n                                    <rect width=\"20\" height=\"20\" fill=\"white\"\r\n                                        transform=\"translate(0 0.686035)\" />\r\n                                </clipPath>\r\n                            </defs>\r\n                        </svg>\r\n                    </span>\r\n                    <span *ngIf=\"obj?.revopsType ==='employee'\">\r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n                            viewBox=\"0 0 20 21\" fill=\"none\">\r\n                            <g clip-path=\"url(#clip0_2012_94639)\">\r\n                                <path\r\n                                    d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                    stroke-linejoin=\"round\" />\r\n                            </g>\r\n                            <defs>\r\n                                <clipPath id=\"clip0_2012_94639\">\r\n                                    <rect width=\"20\" height=\"20\" fill=\"white\"\r\n                                        transform=\"translate(0 0.686035)\" />\r\n                                </clipPath>\r\n                            </defs>\r\n                        </svg>\r\n                    </span>\r\n                    <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\r\n                            viewBox=\"0 0 21 21\" fill=\"none\">\r\n                            <g clip-path=\"url(#clip0_2012_94643)\">\r\n                                <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                                    d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n                                    fill=\"#475467\" />\r\n                            </g>\r\n                            <defs>\r\n                                <clipPath id=\"clip0_2012_94643\">\r\n                                    <rect width=\"21\" height=\"20\" fill=\"white\"\r\n                                        transform=\"translate(0 0.686035)\" />\r\n                                </clipPath>\r\n                            </defs>\r\n                        </svg>\r\n                    </span>\r\n   <span *ngIf=\"obj?.revopsType ==='junk'\">\r\n\r\n       <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n<path d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg>\r\n   </span>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </ng-container>\r\n</div>\r\n\r\n                </div>\r\n            </section>\r\n\r\n            <!-- full image View -->\r\n            <section *ngIf=\"imageFlow\">\r\n                <div class=\"row\">\r\n                    <div class=\"d-flex flex-shrink-0 mt-3 justify-content-start align-items-center px-0\">\r\n                        <span class=\"cursor-pointer\" (click)=\"backToFootfall1()\">\r\n                            <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\"\r\n                                xmlns=\"http://www.w3.org/2000/svg\">\r\n                                <g filter=\"url(#filter0_d_2585_7036)\">\r\n                                    <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\r\n                                    <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\r\n                                    <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\r\n                                        stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\r\n                                        stroke-linejoin=\"round\" />\r\n                                </g>\r\n                                <defs>\r\n                                    <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\r\n                                        filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n                                        <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\r\n                                        <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\r\n                                            values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\r\n                                        <feOffset dy=\"1\" />\r\n                                        <feGaussianBlur stdDeviation=\"1\" />\r\n                                        <feColorMatrix type=\"matrix\"\r\n                                            values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\r\n                                        <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\r\n                                            result=\"effect1_dropShadow_2585_7036\" />\r\n                                        <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\r\n                                            result=\"shape\" />\r\n                                    </filter>\r\n                                </defs>\r\n                            </svg>\r\n                        </span>\r\n                        <span class=\"img-direc ms-2 mt-1\">{{folderDate | date:'dd MMM, yyyy'}}</span>\r\n                    </div>\r\n                    <div class=\"d-flex mt-2 mb-2 w-100 overflow-x px-0\">\r\n\r\n                        <!-- <div class=\"col text-nowrap\" *ngFor=\"let obj of objectsArray\">\r\n                            <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\r\n                                <li class=\"nav-item cursor-pointer\">\r\n                                    <a (click)=\"selectedTimes(obj.timeRange)\"\r\n                                        [ngClass]=\"selectedTime === obj?.timeRange ? 'active' : ''\"\r\n                                        class=\"nav-link cursor-pointer no-border mx-3 mb-2\">\r\n                                        {{obj?.timeRange}}<span class=\"mx-2\"\r\n                                            [ngClass]=\"selectedTime === obj?.timeRange ? 'badge-num-primary' :'badge-num-muted'\">\r\n                                            {{ obj?.count ? obj?.count : 0 }}\r\n                                        </span>\r\n                                    </a>\r\n                                </li>\r\n                            </ul>\r\n                        </div> -->\r\n\r\n\r\n                    </div>\r\n\r\n                    <div class=\"row mx-0 border-gray img-traffic\" *ngIf=\"!noData && !loading\">\r\n                        <div class=\"col-md-6 p-2  mb-2 mt-5\">\r\n                            <div class=\"position-relative border-gray p-2 \">\r\n                                <!-- <button *ngIf=\"canNavigateLeft\" (click)=\"navigateImage('left')\"\r\n                                    class=\"btn btn-light position-absolute start-0 top-50 z-index-10\">\r\n                                    ◀\r\n                                </button> -->\r\n\r\n                                <!-- Main Image -->\r\n                                <img class=\"img-src cursor-pointer h-450px\" (click)=\"selectedImageArray(imageUrl, selectImageArray)\"\r\n                                    [src]=\"imageUrl + selectImageArray?.filePath\" appMagnifier alt=\"\">\r\n                                <!-- <button *ngIf=\"canNavigateRight\" (click)=\"navigateImage('right')\"\r\n                                    class=\"btn btn-light position-absolute end-0 top-50 z-index-10\">\r\n                                    ▶\r\n                                </button> -->\r\n\r\n                                <!-- Right arrow button -->\r\n                                <div class=\"row px-2 mb-2\">\r\n                                    <div class=\"col-md-7\">\r\n                                        <div class=\"py-2 img-doc-time\">Tango ID : {{selectImageArray?.templd}}\r\n                                            <span *ngIf=\"selectImageArray?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\r\n                                                        <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\r\n                                                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                                                            d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\r\n                                                            fill=\"#12B76A\" />\r\n                                                    </svg></span>\r\n                                        <span *ngIf=\"selectImageArray?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n                                                        <g clip-path=\"url(#clip0_1428_59484)\">\r\n                                                            <path\r\n                                                                d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n                                                                fill=\"#FEE4E2\" />\r\n                                                            <path\r\n                                                                d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n                                                                stroke=\"#D92D20\" stroke-linecap=\"round\"\r\n                                                                stroke-linejoin=\"round\" />\r\n                                                        </g>\r\n                                                        <defs>\r\n                                                            <clipPath id=\"clip0_1428_59484\">\r\n                                                                <rect width=\"12\" height=\"12\" fill=\"white\"\r\n                                                                    transform=\"translate(0.599609 0.5)\" />\r\n                                                            </clipPath>\r\n                                                        </defs>\r\n                                                    </svg></span>\r\n                                        </div>\r\n                                        <div class=\"img-doc-value\">Entry Time : {{selectImageArray?.entryTme}}</div>\r\n                                    </div>\r\n                                    <div class=\"col-md-5 text-end py-3\">\r\n                                        <span *ngIf=\"selectImageArray?.revopsType ==='non-tagging'\"\r\n                                            ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\r\n                                                viewBox=\"0 0 19 18\" fill=\"none\">\r\n                                                <path\r\n                                                    d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\r\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                    stroke-linejoin=\"round\" />\r\n                                            </svg>\r\n                                        </span>\r\n                                        <span *ngIf=\"selectImageArray?.revopsType ==='duplicate'\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n                                                viewBox=\"0 0 20 21\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2012_94635)\">\r\n                                                    <path\r\n                                                        d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2012_94635\">\r\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\r\n                                                            transform=\"translate(0 0.686035)\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                        </span>\r\n                                        <span *ngIf=\"selectImageArray?.revopsType ==='employee'\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n                                                viewBox=\"0 0 20 21\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2012_94639)\">\r\n                                                    <path\r\n                                                        d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2012_94639\">\r\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\r\n                                                            transform=\"translate(0 0.686035)\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                        </span>\r\n                                        <span *ngIf=\"selectImageArray?.revopsType ==='house-keeping'\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\r\n                                                viewBox=\"0 0 21 21\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2012_94643)\">\r\n                                                    <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                                                        d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n                                                        fill=\"#475467\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2012_94643\">\r\n                                                        <rect width=\"21\" height=\"20\" fill=\"white\"\r\n                                                            transform=\"translate(0 0.686035)\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                        </span>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"col-md-6 p-2 mb-2  mt-5\">\r\n                            <div class=\"mx-2 \">\r\n                                <div class=\"row\">\r\n                                    <div class=\"col-md-6 title-type\">\r\n                                        Select non-shopper type\r\n                                    </div>\r\n                                  \r\n\r\n                                        <section  class=\"col-md-6 text-end\" *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\r\n                                        \r\n                                            <div *ngIf=\"!revopsTypeValue\" class=\"mb-5 text-end\" role=\"group\">\r\n                                                <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\">\r\n                                        \r\n                                                    <button [disabled]=\"\r\n                                        (selectedRadioType === undefined || selectedRadioType === '') ||\r\n                                        (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\r\n                                        \"\r\n                                                        class=\"btn btn-default\" type=\"button\" (click)=\"clearValue()\">Clear</button>\r\n                                                    <button class=\"btn btn-outline me-2\" (click)=\"cancel()\">Cancel</button>\r\n                                                   <button\r\n                                        class=\"btn btn-primary\"\r\n                                        id=\"alert-toast\"\r\n                                        (click)=\"save(selectedType)\"\r\n                                        [disabled]=\"\r\n                                        (selectedRadioType === undefined || selectedRadioType === '') ||\r\n                                        (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\r\n                                        \"\r\n                                        >\r\n                                        Save\r\n                                        </button>\r\n                                                </div>\r\n                                            </div>\r\n                                      \r\n                                        <div *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\r\n                                                                            <ng-container *ngIf=\"editBtnShow\">\r\n                                                                                <div *ngIf=\"revopsTypeValue\" class=\"mb-5 text-end\" role=\"group\">\r\n                                                                                    <button *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\" class=\"btn btn-outline me-2\" (click)=\"editValue()\"><span\r\n                                                                                            class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\"\r\n                                                                                                height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                                                                                                <path\r\n                                                                                                    d=\"M14.6554 1.71047C14.8927 1.47315 15.1745 1.2849 15.4845 1.15646C15.7946 1.02802 16.1269 0.961914 16.4626 0.961914C16.7982 0.961914 17.1305 1.02802 17.4406 1.15646C17.7507 1.2849 18.0324 1.47315 18.2697 1.71047C18.5071 1.94779 18.6953 2.22953 18.8238 2.53961C18.9522 2.84969 19.0183 3.18202 19.0183 3.51765C19.0183 3.85327 18.9522 4.18561 18.8238 4.49568C18.6953 4.80576 18.5071 5.0875 18.2697 5.32482L6.0713 17.5233L1.10156 18.8786L2.45695 13.9089L14.6554 1.71047Z\"\r\n                                                                                                    stroke=\"#344054\" stroke-width=\"1.81079\" stroke-linecap=\"round\"\r\n                                                                                                    stroke-linejoin=\"round\" />\r\n                                                                                            </svg></span>Edit</button>\r\n                                            \r\n                                                                                </div>\r\n                                                                            </ng-container>\r\n                                                                        </div>\r\n                                                                          </section>\r\n                                   \r\n                                </div>\r\n\r\n                                <div  class=\"form-check my-15\">\r\n                                    <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"duplicate\"\r\n                                        id=\"duplicate\" [(ngModel)]=\"selectedType\" [value]=\"'duplicate'\"\r\n                                        (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\r\n                                    <label class=\"form-check-label\" for=\"duplicate\">\r\n                                        <span class=\"ms-5\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n                                                viewBox=\"0 0 20 21\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2012_94635)\">\r\n                                                    <path\r\n                                                        d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2012_94635\">\r\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\r\n                                                            transform=\"translate(0 0.686035)\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                        </span>\r\n                                        <span class=\"ms-5 tag-class\">Duplicate</span>\r\n                                    </label>\r\n                                </div>\r\n                                <div class=\"form-check my-15\">\r\n                                    <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"employee\"\r\n                                        id=\"employee\" [(ngModel)]=\"selectedType\" [value]=\"'employee'\"\r\n                                        (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\r\n                                    <label class=\"form-check-label\" for=\"employee\">\r\n                                        <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\"\r\n                                                height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2012_94639)\">\r\n                                                    <path\r\n                                                        d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2012_94639\">\r\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\r\n                                                            transform=\"translate(0 0.686035)\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg></span>\r\n                                        <span class=\"ms-5 tag-class\">Employee/Staff</span>\r\n                                    </label>\r\n                                </div>\r\n                                <div class=\"form-check my-15\">\r\n                                    <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"house-keeping\"\r\n                                        id=\"house-keeping\" [(ngModel)]=\"selectedType\" [value]=\"'house-keeping'\"\r\n                                        (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\r\n                                    <label class=\"form-check-label\" for=\"house-keeping\">\r\n                                        <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\"\r\n                                                height=\"21\" viewBox=\"0 0 21 21\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2012_94643)\">\r\n                                                    <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                                                        d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n                                                        fill=\"#475467\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2012_94643\">\r\n                                                        <rect width=\"21\" height=\"20\" fill=\"white\"\r\n                                                            transform=\"translate(0 0.686035)\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg></span>\r\n                                        <span class=\"ms-5 tag-class\"> House Keeping</span>\r\n                                    </label>\r\n                                </div>\r\n                                <div class=\"form-check my-15\">\r\n                                    <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"junk\"\r\n                                        id=\"junk\" [(ngModel)]=\"selectedType\" [value]=\"'junk'\"\r\n                                        (change)=\"onRadioChange(selectedType)\" [disabled]=\"users?.role ==='user' && this.users?.userType ==='client' || revopsTypeValue\">\r\n                                    <label class=\"form-check-label\" for=\"junk\">\r\n                                        <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n  <path d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg></span>\r\n                                        <span class=\"ms-5 tag-class\"> Junk</span>\r\n                                        </label>\r\n                                </div>\r\n                            </div>\r\n\r\n\r\n                        </div>\r\n                    </div>\r\n\r\n    \r\n                    <div class=\"row px-0 img-traffic mt-3 high-400px scroll-y\">\r\n                        <div class=\"col-md-3 border-gray mx-2 p-2 mt-5\" *ngFor=\"let obj of remainingImageArray\">\r\n                            <div class=\"position-relative\">\r\n                                <!-- <input *ngIf=\"selectedRadioType === 'duplicate'\" type=\"checkbox\" \r\n                                    [(ngModel)]=\"obj.selected\" class=\"position-absolute absolute form-check-input\"\r\n                                    (change)=\"onImageCheckboxChange(obj, 'duplicate')\" /> -->\r\n                            <input \r\n  *ngIf=\"!revopsTypeValue && selectedRadioType === 'duplicate'\"\r\n  type=\"checkbox\"\r\n  [checked]=\"obj.selected\"\r\n  class=\"position-absolute absolute form-check-input cursor-pointer\"\r\n  (change)=\"onImageCheckboxChange($event, obj, 'duplicate')\"\r\n  [disabled]=\"obj.duplicateImagePath?.length > 0\"\r\n/>\r\n\r\n<img\r\n  class=\"img-src\"\r\n  [ngClass]=\"selectedRadioType !== 'duplicate' ? 'cursor-pointer' : 'cursor-pointer'\"\r\n  [src]=\"imageUrl + obj?.filePath\"\r\n  (error)=\"obj.filePath = null\"\r\n  alt=\"\"\r\n  (click)=\"handleImageClick($event, obj)\"\r\n/>\r\n\r\n                                <div *ngIf=\"!obj?.filePath\" class=\"no-preview\">\r\n                                    <span class=\"mb-5\">\r\n                                        <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\"\r\n                                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                                            <g id=\"Group\">\r\n                                                <path id=\"Vector\"\r\n                                                    d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\r\n                                                    stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                    stroke-linejoin=\"round\" />\r\n                                                <path id=\"Vector_2\"\r\n                                                    d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\r\n                                                    stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                    stroke-linejoin=\"round\" />\r\n                                            </g>\r\n                                        </svg>\r\n\r\n                                    </span>\r\n                                    <span class=\"header mb-5 text-center\">Preview not available</span>\r\n                                    <span class=\"description mb-5 text-center\">The selected camera is not available at\r\n                                        the\r\n                                        moment.</span>\r\n                                </div>\r\n                                <div class=\"row px-2 mb-2\">\r\n                                    <div class=\"col-md-7\">\r\n                                        <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd ? obj?.templd : obj?.tempId}} \r\n                                            <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\r\n                                                        <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\r\n                                                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                                                            d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\r\n                                                            fill=\"#12B76A\" />\r\n                                                    </svg></span>\r\n                                        <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n                                                        <g clip-path=\"url(#clip0_1428_59484)\">\r\n                                                            <path\r\n                                                                d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n                                                                fill=\"#FEE4E2\" />\r\n                                                            <path\r\n                                                                d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n                                                                stroke=\"#D92D20\" stroke-linecap=\"round\"\r\n                                                                stroke-linejoin=\"round\" />\r\n                                                        </g>\r\n                                                        <defs>\r\n                                                            <clipPath id=\"clip0_1428_59484\">\r\n                                                                <rect width=\"12\" height=\"12\" fill=\"white\"\r\n                                                                    transform=\"translate(0.599609 0.5)\" />\r\n                                                            </clipPath>\r\n                                                        </defs>\r\n                                                    </svg></span>\r\n                                    </div>\r\n                                        <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme ? obj?.entryTme :obj?.entryTime}}</div>\r\n                                    </div>\r\n                                    <div class=\"col-md-5 text-end py-3\">\r\n                                        <span *ngIf=\"obj?.revopsType ==='non-tagging'\"\r\n                                            ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\r\n                                                viewBox=\"0 0 19 18\" fill=\"none\">\r\n                                                <path\r\n                                                    d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\r\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                    stroke-linejoin=\"round\" />\r\n                                            </svg>\r\n                                        </span>\r\n                                        <span *ngIf=\"obj?.revopsType ==='duplicate'\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n                                                viewBox=\"0 0 20 21\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2012_94635)\">\r\n                                                    <path\r\n                                                        d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2012_94635\">\r\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\r\n                                                            transform=\"translate(0 0.686035)\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                        </span>\r\n                                        <span *ngIf=\"obj?.revopsType ==='employee'\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n                                                viewBox=\"0 0 20 21\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2012_94639)\">\r\n                                                    <path\r\n                                                        d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2012_94639\">\r\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\r\n                                                            transform=\"translate(0 0.686035)\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                        </span>\r\n                                        <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\r\n                                                viewBox=\"0 0 21 21\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2012_94643)\">\r\n                                                    <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                                                        d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n                                                        fill=\"#475467\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2012_94643\">\r\n                                                        <rect width=\"21\" height=\"20\" fill=\"white\"\r\n                                                            transform=\"translate(0 0.686035)\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                        </span>\r\n                                         <span *ngIf=\"obj?.revopsType ==='junk'\">\r\n\r\n       <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n<path d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg>\r\n   </span>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n\r\n                </div>\r\n            </section>\r\n        </div>\r\n    </section>\r\n</div>\r\n\r\n\r\n<ng-template #zoomPopup let-model>\r\n    <div class=\"p-4 m-4\">\r\n        <div class=\"modal-header border-0 p-0 w-100 flex-column align-items-start\">\r\n            <span *ngIf=\"popupType === 'non-tagging'\" class=\"my-3\">\r\n\r\n                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\r\n                    <rect width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\r\n                    <g clip-path=\"url(#clip0_2088_98337)\">\r\n                        <path\r\n                            d=\"M29.1693 13.3333V18.3333M29.1693 18.3333H24.1693M29.1693 18.3333L25.3026 14.7C24.407 13.8039 23.299 13.1493 22.0819 12.7973C20.8649 12.4453 19.5785 12.4073 18.3428 12.6869C17.1072 12.9665 15.9624 13.5545 15.0155 14.3962C14.0685 15.2378 13.3502 16.3056 12.9276 17.5M10.8359 26.6666V21.6666M10.8359 21.6666H15.8359M10.8359 21.6666L14.7026 25.3C15.5982 26.1961 16.7062 26.8506 17.9233 27.2027C19.1403 27.5547 20.4267 27.5927 21.6624 27.3131C22.898 27.0335 24.0428 26.4455 24.9897 25.6038C25.9367 24.7621 26.655 23.6943 27.0776 22.5\"\r\n                            stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                    </g>\r\n                    <defs>\r\n                        <clipPath id=\"clip0_2088_98337\">\r\n                            <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(10 10)\" />\r\n                        </clipPath>\r\n                    </defs>\r\n                </svg>\r\n            </span>\r\n            <!-- Heading -->\r\n            <h5 class=\"modal-title mb-2\">\r\n                <span *ngIf=\"popupType === 'employee'\">Tagging as employee/staff </span>\r\n                <span *ngIf=\"popupType === 'duplicate'\">Tagging as duplicates </span>\r\n                <span *ngIf=\"popupType === 'house-keeping'\">Tagging as house keeping </span>\r\n                <span *ngIf=\"popupType === 'non-tagging'\">Clear duplicates</span>\r\n                <span *ngIf=\"popupType ==='junk'\">Tagging as junk</span>\r\n            \r\n            </h5>\r\n            <p class=\"mb-3\">\r\n                <span *ngIf=\"popupType === 'employee'\">Are you sure you want to tag this as employee/staff?</span>\r\n                <span *ngIf=\"popupType === 'duplicate'\">Are you sure you want to tag this as duplicates? </span>\r\n                <span *ngIf=\"popupType === 'house-keeping'\">Are you sure you want to tag this as house keeping? </span>\r\n                <span *ngIf=\"popupType === 'non-tagging'\">This will remove tagged duplicates and move them to\r\n                    'Non-tag'.</span>\r\n                    <span *ngIf=\"popupType ==='junk'\">Are you sure you want to tag this as junk?</span>\r\n\r\n            </p>\r\n        </div>\r\n\r\n        <div class=\"w-100 mt-5 d-flex justify-content-end\">\r\n            <button class=\"btn btn-outline me-2\" (click)=\"cancelSubmit()\">Cancel</button>\r\n            <button *ngIf=\"popupType !== 'non-tagging'\" class=\"btn btn-primary\" (click)=\"submitValue(popupType)\">\r\n                Yes, Tag\r\n            </button>\r\n            <button *ngIf=\"popupType === 'non-tagging'\" class=\"btn btn-primary\" (click)=\"submitValue(popupType)\">\r\n                Yes, clear\r\n            </button>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n\r\n\r\n<ng-template #raisedPopup let-model>\r\n    <div class=\"p-4 m-4\">\r\n        <div class=\"modal-header border-0 p-0 w-100 flex-column align-items-start\">\r\n            <span class=\"my-3\">\r\n\r\n                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\r\n                    <rect width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\r\n                    <path\r\n                        d=\"M21.251 11.0806C21.7405 11.0699 22.2153 11.2487 22.5762 11.5796L23.4922 12.4204C23.8089 12.7097 23.893 13.1017 23.8652 13.4263V13.4272C23.836 13.7478 23.6954 14.0592 23.4785 14.2944C23.3699 14.413 23.2865 14.5525 23.2314 14.7036C23.1764 14.8548 23.1512 15.0155 23.1582 15.1763C23.1652 15.337 23.2035 15.4953 23.2715 15.6411C23.3394 15.7869 23.4362 15.9172 23.5547 16.0259C23.6733 16.1346 23.8117 16.2198 23.9629 16.2749C24.1141 16.33 24.2748 16.3541 24.4355 16.3472C24.5961 16.3402 24.7537 16.3017 24.8994 16.2339C25.0089 16.1829 25.1106 16.116 25.2002 16.0356L25.3701 15.8657C25.5759 15.6748 25.8385 15.5408 26.1152 15.4907C26.2972 15.4546 26.485 15.4617 26.6641 15.5103C26.8439 15.5591 27.0103 15.649 27.1494 15.7729L27.1514 15.7749L28.2598 16.7905C28.445 16.9605 28.5948 17.1658 28.7002 17.394C28.8056 17.6223 28.8648 17.8694 28.874 18.1206C28.8832 18.372 28.8423 18.6234 28.7539 18.8589C28.6655 19.0941 28.5316 19.3096 28.3594 19.4927L20.1113 28.2583C19.937 28.4434 19.7268 28.5912 19.4941 28.6938C19.2614 28.7965 19.0102 28.8522 18.7559 28.856C18.5016 28.8597 18.2493 28.8119 18.0137 28.7163C17.7779 28.6206 17.5636 28.4784 17.3838 28.2983L16.2539 27.1685C15.7511 26.6656 15.8832 25.9552 16.1514 25.5542L16.2061 25.4644C16.3241 25.2486 16.3742 25.0008 16.3496 24.7544C16.3214 24.4731 16.197 24.2102 15.9971 24.0103C15.7971 23.8103 15.5343 23.6859 15.2529 23.6577C14.9715 23.6297 14.6887 23.6995 14.4531 23.856H14.4521C14.0494 24.1222 13.3407 24.2552 12.8379 23.7515L11.6797 22.5933C11.5034 22.4169 11.364 22.2074 11.2686 21.9771C11.1731 21.7467 11.1231 21.4999 11.123 21.2505C11.123 21.001 11.1731 20.7535 11.2686 20.5229C11.364 20.2926 11.5034 20.0831 11.6797 19.9067L19.9492 11.6362C20.2954 11.2902 20.7616 11.0912 21.251 11.0806ZM21.2783 12.3804C21.1237 12.3838 20.9765 12.4468 20.8672 12.5562L12.5967 20.8257C12.5409 20.8814 12.497 20.9482 12.4668 21.021C12.4367 21.0938 12.4209 21.1717 12.4209 21.2505C12.4209 21.3292 12.4367 21.4073 12.4668 21.48C12.497 21.5528 12.541 21.6196 12.5967 21.6753L13.7061 22.7837L13.7314 22.772C14.2169 22.4485 14.7993 22.3035 15.3799 22.3608C15.9608 22.4183 16.5042 22.6747 16.917 23.0874C17.3298 23.5002 17.587 24.0436 17.6445 24.6245C17.702 25.2055 17.5565 25.7892 17.2324 26.2749L17.2305 26.2759C17.2261 26.2822 17.2226 26.2893 17.2197 26.2964L18.3018 27.3804C18.3585 27.4372 18.4266 27.482 18.501 27.5122C18.5755 27.5425 18.6559 27.5574 18.7363 27.5562C18.8166 27.5549 18.8963 27.5378 18.9697 27.5054C19.043 27.4729 19.1091 27.4261 19.1641 27.3677L27.4131 18.6021C27.4673 18.5442 27.5093 18.4761 27.5371 18.4019C27.5649 18.3276 27.5781 18.2487 27.5752 18.1694C27.5722 18.0902 27.5538 18.0119 27.5205 17.9399C27.4872 17.8679 27.4394 17.8032 27.3809 17.7495L26.3223 16.7778C26.2925 16.7885 26.2648 16.8053 26.2432 16.8286C26.0217 17.0788 25.7529 17.2827 25.4521 17.4282C25.15 17.5743 24.8214 17.6585 24.4863 17.6763C24.1511 17.694 23.815 17.6452 23.499 17.5317C23.1832 17.4183 22.8928 17.2429 22.6455 17.0161C22.3982 16.7893 22.1988 16.5153 22.0586 16.2104C21.9183 15.9055 21.8404 15.5752 21.8291 15.2397C21.8178 14.9043 21.8737 14.57 21.9932 14.2563C22.1121 13.9442 22.2915 13.6587 22.5215 13.4165L22.5547 13.3657C22.5594 13.3552 22.5607 13.3437 22.5635 13.3325L21.6973 12.5386V12.5376C21.5833 12.4331 21.4329 12.377 21.2783 12.3804Z\"\r\n                        fill=\"#00A3FF\" stroke=\"#00A3FF\" stroke-width=\"0.3\" />\r\n                </svg>\r\n            </span>\r\n            <!-- Heading -->\r\n            <h5 class=\"modal-title mb-2\">\r\n                <span>Raise tickets for the following</span>\r\n\r\n            </h5>\r\n            <p class=\"mb-3\">\r\n                <span>Raising a ticket for footfall count issues. Make sure all records are identified for\r\n                    validation.</span>\r\n\r\n\r\n            </p>\r\n        </div>\r\n        <div class=\"row\">\r\n            <div class=\"col-md-3 my-4\">\r\n                <div class=\"border border-1 rounded p-3 h-100\">\r\n                    <div class=\"fw-semibold fs-5 mb-2\">\r\n                        {{tempRaisedPayload?.duplicateCount ? tempRaisedPayload?.duplicateCount :'0'}}\r\n                    </div>\r\n                    <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n                        Duplicates\r\n                    </div>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"col-md-3 my-4\">\r\n                <div class=\"border border-1 rounded p-3 h-100\">\r\n                    <div class=\"fw-semibold fs-5 mb-2\">\r\n                        {{tempRaisedPayload?.employeeCount ? tempRaisedPayload?.employeeCount:'0' }}\r\n                    </div>\r\n                    <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n                        Employee\r\n                    </div>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"col-md-3 my-4\">\r\n                <div class=\"border border-1 rounded p-3 h-100\">\r\n                    <div class=\"fw-semibold fs-5 mb-2\">\r\n                        {{tempRaisedPayload?.houseKeepingCount ? tempRaisedPayload?.houseKeepingCount :'0'}}\r\n                    </div>\r\n                    <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n                        House Keeping\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"col-md-3 my-4\">\r\n                <div class=\"border border-1 rounded p-3 h-100\">\r\n                    <div class=\"fw-semibold fs-5 mb-2\">\r\n                        {{tempRaisedPayload?.junkCount ? tempRaisedPayload?.junkCount :'0'}}\r\n                    </div>\r\n                    <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n                        Junk\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Label and Textarea -->\r\n        <div class=\"my-3\">\r\n            <label class=\"form-label\">Description (Optional)</label>\r\n            <textarea rows=\"3\" [(ngModel)]=\"commentText\" class=\"form-control\"\r\n                placeholder=\"Enter description\"></textarea>\r\n        </div>\r\n        <div class=\"w-100 mt-5 d-flex justify-content-end\">\r\n\r\n            <button class=\"btn btn-outline w-50 me-2\" (click)=\"cancelRasied()\">Cancel</button>\r\n            <button class=\"btn btn-primary w-50\" (click)=\"submitRaised()\">\r\n                Raise Ticket\r\n            </button>\r\n        </div>\r\n    </div>\r\n</ng-template>\r\n\r\n\r\n<ng-template #imagePopup let-model>\r\n    <div class=\"mx-4\">\r\n        <div class=\"row\">\r\n            <div class=\" p-2  mb-2 mt-5\">\r\n                            <div *ngIf=\"isModalOpen\" class=\"position-relative border-gray p-2 \">\r\n                                <!-- <button *ngIf=\"canNavigateLeft\" (click)=\"navigateImage('left')\"\r\n                                    class=\"btn btn-light position-absolute start-0 top-50 z-index-10\">\r\n                                    ◀\r\n                                </button> -->\r\n\r\n                                <!-- Main Image -->\r\n                                <img class=\" cursor-pointer w-100 h-525px\"\r\n                                    [src]=\"imageUrl + selectImageArray?.filePath\" appMagnifier alt=\"\">\r\n                                <!-- <button *ngIf=\"canNavigateRight\" (click)=\"navigateImage('right')\"\r\n                                    class=\"btn btn-light position-absolute end-0 top-50 z-index-10\">\r\n                                    ▶\r\n                                </button> -->\r\n\r\n                                <!-- Right arrow button -->\r\n                                <div class=\"row px-2 mb-2\">\r\n                                    <div class=\"col-md-7\">\r\n                                        <div class=\"py-2 img-doc-time\">Tango ID : {{selectImageArray?.templd}}\r\n                                              <span *ngIf=\"selectImageArray?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\r\n                                                        <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\r\n                                                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                                                            d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\r\n                                                            fill=\"#12B76A\" />\r\n                                                    </svg></span>\r\n                                        <span *ngIf=\"selectImageArray?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\r\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\r\n                                                        <g clip-path=\"url(#clip0_1428_59484)\">\r\n                                                            <path\r\n                                                                d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n                                                                fill=\"#FEE4E2\" />\r\n                                                            <path\r\n                                                                d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\r\n                                                                stroke=\"#D92D20\" stroke-linecap=\"round\"\r\n                                                                stroke-linejoin=\"round\" />\r\n                                                        </g>\r\n                                                        <defs>\r\n                                                            <clipPath id=\"clip0_1428_59484\">\r\n                                                                <rect width=\"12\" height=\"12\" fill=\"white\"\r\n                                                                    transform=\"translate(0.599609 0.5)\" />\r\n                                                            </clipPath>\r\n                                                        </defs>\r\n                                                    </svg></span>\r\n                                        </div>\r\n                                        <div class=\"img-doc-value\">Entry Time : {{selectImageArray?.entryTme}}</div>\r\n                                    </div>\r\n                                    <div class=\"col-md-5 text-end py-3\">\r\n                                        <span *ngIf=\"selectImageArray?.revopsType ==='non-tagging'\"\r\n                                            ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\r\n                                                viewBox=\"0 0 19 18\" fill=\"none\">\r\n                                                <path\r\n                                                    d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\r\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                    stroke-linejoin=\"round\" />\r\n                                            </svg>\r\n                                        </span>\r\n                                        <span *ngIf=\"selectImageArray?.revopsType ==='duplicate'\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n                                                viewBox=\"0 0 20 21\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2012_94635)\">\r\n                                                    <path\r\n                                                        d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\r\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2012_94635\">\r\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\r\n                                                            transform=\"translate(0 0.686035)\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                        </span>\r\n                                        <span *ngIf=\"selectImageArray?.revopsType ==='employee'\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\r\n                                                viewBox=\"0 0 20 21\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2012_94639)\">\r\n                                                    <path\r\n                                                        d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\r\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                                                        stroke-linejoin=\"round\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2012_94639\">\r\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\r\n                                                            transform=\"translate(0 0.686035)\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                        </span>\r\n                                        <span *ngIf=\"selectImageArray?.revopsType ==='house-keeping'\">\r\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\r\n                                                viewBox=\"0 0 21 21\" fill=\"none\">\r\n                                                <g clip-path=\"url(#clip0_2012_94643)\">\r\n                                                    <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                                                        d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\r\n                                                        fill=\"#475467\" />\r\n                                                </g>\r\n                                                <defs>\r\n                                                    <clipPath id=\"clip0_2012_94643\">\r\n                                                        <rect width=\"21\" height=\"20\" fill=\"white\"\r\n                                                            transform=\"translate(0 0.686035)\" />\r\n                                                    </clipPath>\r\n                                                </defs>\r\n                                            </svg>\r\n                                        </span>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n        </div>\r\n\r\n        <!-- <div class=\"modal-footer py-2 px-0\"> -->\r\n\r\n            <div class=\"w-100 py-2 mb-2 px-0 d-flex justify-content-end\">\r\n    \r\n                <button class=\"btn btn-outline\" (click)=\"closeImage()\">Close</button>\r\n               \r\n            </div>\r\n        <!-- </div> -->\r\n    </div>\r\n</ng-template>"]}
|
|
1330
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"img-rvps.component.js","sourceRoot":"","sources":["../../../../../../projects/tango-analyse-traffic/src/lib/components/img-rvps/img-rvps.component.ts","../../../../../../projects/tango-analyse-traffic/src/lib/components/img-rvps/img-rvps.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAGS,SAAS,EAC5B,MAAM,eAAe,CAAC;AAKvB,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAE1C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;AAO9C,MAAM,OAAO,gBAAgB;IAWjB;IACD;IACC;IACA;IACA;IACA;IAfV,UAAU,CAAM;IAChB,YAAY,CAAM;IAClB,OAAO,GAAY,IAAI,CAAC;IACxB,MAAM,GAAG,KAAK,CAAC;IACf,SAAS,CAAM;IACf,eAAe,GAAQ,EAAE,CAAC;IAC1B,WAAW,GAA4B,EAAE,CAAC;IAC1C,kBAAkB,GAAQ,EAAE,CAAC;IAC7B,WAAW,CAAM;IACjB,YACU,OAAuB,EACxB,EAAsB,EACrB,EAAqB,EACrB,YAAsB,EACtB,KAAmB,EACnB,WAA+B;QAL/B,YAAO,GAAP,OAAO,CAAgB;QACxB,OAAE,GAAF,EAAE,CAAoB;QACrB,OAAE,GAAF,EAAE,CAAmB;QACrB,iBAAY,GAAZ,YAAY,CAAU;QACtB,UAAK,GAAL,KAAK,CAAc;QACnB,gBAAW,GAAX,WAAW,CAAoB;IACtC,CAAC;IACa,QAAQ,GAAG,IAAI,OAAO,EAAE,CAAC;IAC1C,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IACD,mBAAmB,GAAG,IAAI,CAAC;IAC3B,eAAe;QACb,IAAI,CAAC,mBAAmB,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC;IACvD,CAAC;IACD,KAAK,CAAK;IACV,QAAQ;QACN,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,MAAM,QAAQ,GAAQ,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,CAAC;QAC5E,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;IACxB,CAAC;IACD,SAAS;QACP,IAAI,CAAC,EAAE,CAAC,cAAc;aACnB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC;aACjD,SAAS,CAAC,CAAC,IAAS,EAAE,EAAE;YACvB,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;YAC5B,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI,EAAE,MAAM,KAAK,IAAI,EAAE;gBAC1C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,EAAE,MAAM;qBACxC,MAAM,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC;qBACrC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;gBACtC,IAAI,CAAC,cAAc,EAAE,CAAC;gBACtB,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACxB,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpB,IACE,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,SAAS,KAAK,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,OAAO,EACnE;oBACA,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;oBACrB,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBACxB,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;iBACjD;qBAAM;oBACL,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;oBACvB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;iBACrB;aACF;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;QAC3B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC;QACvB,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;QAC7B,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC;QAC9B,IAAI,CAAC,qBAAqB,GAAG,EAAE,CAAC;IAClC,CAAC;IACD,UAAU,CAAU;IACpB,OAAO,CAAU;IACjB,SAAS,CAAM;IACf,gBAAgB;QACd,MAAM,KAAK,GAAG,IAAI,CAAC,iBAAiB,CAClC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,EAC9B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAC7B,CAAC;QACF,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAED,iBAAiB,CAAC,QAAgB,EAAE,MAAc;QAChD,MAAM,KAAK,GAAG,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,gCAAgC;QAClE,MAAM,GAAG,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,gCAAgC;QAC9D,MAAM,SAAS,GAAa,EAAE,CAAC;QAE/B,+BAA+B;QAC/B,IAAI,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,EAAE;YAClD,OAAO,SAAS,CAAC;SAClB;QAED,mCAAmC;QACnC,IAAI,WAAW,GAAG,KAAK,CAAC;QACxB,OAAO,WAAW,IAAI,GAAG,EAAE;YACzB,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,oBAAoB;YAC7E,WAAW,CAAC,OAAO,CAAC,WAAW,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,8BAA8B;SAC/E;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,iBAAiB;IACjB,YAAY;QACV,MAAM,OAAO,GACb,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAChF,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE;YACtC,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;YAC1B,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;YACtB,OAAO;SACR;QAED,IAAI,CAAC,WAAW;aACb,yBAAyB,CACxB,OAAO,EACP,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,EAC9B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAC7B;aACA,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC/B,EAAE,SAAS,CAAC;YACV,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,IAAI,GAAG,CAAC,IAAI,KAAK,GAAG,EAAE;oBAC3B,IAAI,CAAC,eAAe,GAAG,GAAG,EAAE,IAAI,IAAI,EAAE,CAAC;oBACvC,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC,MAAM,CACpD,CAAC,GAA2B,EAAE,IAAS,EAAE,EAAE;wBACzC,MAAM,cAAc,GAAG,IAAI,EAAE,IAAI;4BAC/B,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;4BACjD,CAAC,CAAC,IAAI,CAAC;wBACT,IAAI,cAAc,EAAE;4BAClB,GAAG,CAAC,cAAc,CAAC,GAAG;gCACpB,GAAG,IAAI;gCACP,iBAAiB,EAAE,IAAI,EAAE,YAAY;oCACnC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,WAAW,EAAE;oCACzC,CAAC,CAAC,EAAE;6BACP,CAAC;yBACH;wBACD,OAAO,GAAG,CAAC;oBACb,CAAC,EACD,EAAE,CACH,CAAC;iBACH;qBAAM;oBACL,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;oBAC1B,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;iBACvB;YACH,CAAC;YACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE;gBACb,OAAO,CAAC,KAAK,CAAC,8BAA8B,EAAE,GAAG,CAAC,CAAC;gBACnD,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;gBAC1B,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;YACxB,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAGD,YAAY,CAAM;IAClB,UAAU,CAAM;IAChB,aAAa,CAAC,GAAQ;QACpB,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC;QACxB,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;QACtB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACtB,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IACD,UAAU,CAAM;IAChB,SAAS,GAAG,KAAK,CAAC;IAClB,kBAAkB,GAAG,KAAK,CAAC,CAAC,mCAAmC;IAC/D,iBAAiB;IACjB,WAAW,CAAM;IACjB,gBAAgB,CAAM;IACtB,YAAY,CAAM;IAClB,eAAe,CAAM;IACrB,cAAc,GAA8C,EAAE,CAAC;IAC/D,WAAW,GAAQ,CAAC,CAAC;IACrB,YAAY,CAAM;IAClB,WAAW,CAAU;IACrB,QAAQ,GAAoB,MAAM,CAAC;IACnC,SAAS,CAAC,KAAU,EAAE,GAAQ;QAC5B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;QACtB,CAAC,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,CAAC;QACrD,IAAI,CAAC,OAAO,EAAE,iBAAiB;YAC7B,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,YAAY,CAAC,GAAG,CAAC,CAAC;YACnD,EAAE,SAAS,CAAC,CAAC,SAAc,EAAE,EAAE;YAC7B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;YAC3B,IAAI,CAAC,SAAS,EAAE;gBACd,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;gBACtB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;gBAC3B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;gBACvB,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjB,mBAAmB;aACpB;iBAAM;gBACL,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;gBACzB,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;aACxB;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IACD,SAAS,GAAQ,EAAE,CAAC;IACpB,QAAQ;QACN,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,MAAM,OAAO,GACX,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC;YAC/C,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;YACtB,CAAC,CAAC,IAAI,CAAC;QACX,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,EAAE,CAAC;QACzC,IAAI,CAAC,WAAW;aACb,WAAW,CAAC,OAAO,EAAE,UAAU,CAAC;aAChC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC/B,EAAE,SAAS,CAAC;YACV,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,IAAI,GAAG,CAAC,IAAI,KAAK,GAAG,EAAE;oBAE3B,IAAI,IAAI,CAAC,WAAW,EAAE,MAAM;wBAAE,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC,IAAI,CAAC;iBACzD;qBAAM;oBACL,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;iBACrB;YACH,CAAC;YACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE,GAAE,CAAC;SACnB,CAAC,CAAC;IACP,CAAC;IACD,QAAQ,CAAM;IACd,eAAe,CAAM;IACrB,oBAAoB,GAAQ,EAAE,CAAC;IAC/B,gBAAgB,GAAQ,EAAE,CAAC;IAC3B,eAAe,GAAQ,EAAE,CAAC;IAC1B,iBAAiB;QACf,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,EAAE,YAAY,CAAC;QAClD,IAAI,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;YAC7B,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,yBAAyB;SAClG;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,SAAS;QACP,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,yBAAyB;QACzB,6BAA6B;QAC7B,wBAAwB;QACxB,4BAA4B;QAC5B,2BAA2B;QAC3B,MAAM,OAAO,GACX,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC;YAC/C,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;YACtB,CAAC,CAAC,IAAI,CAAC;QACX,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,EAAE,CAAC;QACzC,MAAM,UAAU,GAAG,MAAM,CAAC;QAC1B,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;QAC7D,MAAM,WAAW,GAAG,UAAU,CAAC;QAE/B,IAAI,CAAC,WAAW;aACb,cAAc,CAAC,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,CAAC;aAClE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,IAAI,GAAG,CAAC,IAAI,KAAK,GAAG,EAAE;oBAC3B,IAAI,CAAC,WAAW,GAAG,GAAG,EAAE,IAAI,CAAC;oBAC7B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,WAAW,CAAC;oBAC9C,IAAI,CAAC,gBAAgB,GAAG,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC;oBAC1C,IAAI,CAAC,kBAAkB,GAAG,GAAG,EAAE,IAAI,EAAE,YAAY,CAAC;oBAClD,OAAO,CAAC,GAAG,CAAC,yBAAyB,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;oBAClD,OAAO,CAAC,GAAG,CAAC,6BAA6B,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;oBACpE,qDAAqD;oBACrD,IAAI,CAAC,eAAe,GAAG,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,YAAY,IAAI,EAAE,CAAC;oBAE7D,kCAAkC;oBAClC,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CACzC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAC9B,CAAC;oBACF,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,SAAc,EAAE,EAAE,CAAC,CAAC;wBACtD,SAAS;wBACT,KAAK,EACH,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,SAAS,CAAC;4BAC9D,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;qBACxB,CAAC,CAAC,CAAC;oBACJ,8DAA8D;oBAC9D,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;wBAC3C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;qBACpD;oBAED,sCAAsC;oBACtC,IAAI,CAAC,oBAAoB;wBACvB,IAAI,CAAC,eAAe,CAAC,IAAI,CACvB,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,YAAY,CACpD,EAAE,IAAI,IAAI,EAAE,CAAC;oBAEhB,oBAAoB;oBACpB,MAAM,eAAe,GAA8B;wBACjD,aAAa,EAAE,CAAC;wBAChB,SAAS,EAAE,CAAC;wBACZ,QAAQ,EAAE,CAAC;wBACX,eAAe,EAAE,CAAC;wBAClB,IAAI,EAAE,CAAC;qBACR,CAAC;oBAEF,IAAI,UAAU,GAAG,CAAC,CAAC;oBACnB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;oBAE3B,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;wBACzC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;4BAChC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;4BAClC,UAAU,EAAE,CAAC;4BAEb,MAAM,IAAI,GACR,KAAK,CAAC,UAAU,EAAE,IAAI,EAAE,CAAC,WAAW,EAAE,IAAI,SAAS,CAAC;4BAEtD,IAAI,IAAI,KAAK,aAAa,EAAE;gCAC1B,eAAe,CAAC,aAAa,CAAC,EAAE,CAAC;6BAClC;iCAAM,IAAI,IAAI,KAAK,UAAU,EAAE;gCAC9B,eAAe,CAAC,UAAU,CAAC,EAAE,CAAC;6BAC/B;iCAAM,IAAI,IAAI,KAAK,eAAe,EAAE;gCACnC,eAAe,CAAC,eAAe,CAAC,EAAE,CAAC;6BACpC;iCAAM,IAAG,IAAI,KAAK,MAAM,EAAE;gCACzB,eAAe,CAAC,MAAM,CAAC,EAAE,CAAC;6BAC3B;4BAED,kDAAkD;4BAClD,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,kBAAkB,CAAC,EAAE;gCAC3C,eAAe,CAAC,WAAW,CAAC;oCAC1B,KAAK,CAAC,kBAAkB,CAAC,MAAM,CAAC;6BACnC;wBACH,CAAC,CAAC,CAAC;oBACL,CAAC,CAAC,CAAC;oBAEH,IAAI,CAAC,SAAS,GAAG;wBACf,aAAa,EAAE,UAAU;wBACzB,OAAO,EAAE,eAAe,CAAC,aAAa,CAAC;wBACvC,SAAS,EAAE,eAAe,CAAC,WAAW,CAAC;wBACvC,QAAQ,EAAE,eAAe,CAAC,UAAU,CAAC;wBACrC,YAAY,EAAE,eAAe,CAAC,eAAe,CAAC;wBAC9C,IAAI,EAAE,eAAe,CAAC,MAAM,CAAC;qBAC9B,CAAC;oBAEF,iDAAiD;oBACjD,IAAI,CAAC,YAAY,EAAE,CAAC;oBAEpB,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;oBACxB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;oBACrB,uBAAuB;iBACxB;qBAAM;oBACL,qBAAqB;oBACrB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;oBACtB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;oBAC3B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;oBACvB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;oBAC1B,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;oBAC3B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;oBACpB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;oBACrB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;iBACpB;YACH,CAAC;YACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE;gBACb,MAAM,GAAG,GACP,GAAG,CAAC,KAAK,CAAC,KAAK;oBACf,GAAG,CAAC,KAAK;oBACT,GAAG,EAAE,KAAK,EAAE,OAAO;oBACnB,GAAG,CAAC,OAAO;oBACX,eAAe,CAAC;gBAClB,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;gBAC9B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;gBACnB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;gBACtB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;gBAC3B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;gBACvB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;gBAC1B,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;gBAC3B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;YACtB,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAED,2BAA2B,CAAM;IACjC,SAAS;QACP,MAAM,IAAI,GAAG,CAAC,IAAI,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;QACrD,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAE7B,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC;QAC5C,MAAM,cAAc,GAAG,aAAa,EAAE,MAAM,CAAC;QAE7C,IACE,IAAI,KAAK,WAAW;YACpB,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC,kBAAkB,CAAC,EAC/C;YACA,8EAA8E;YAC9E,MAAM,iBAAiB,GAAG,aAAa,CAAC,kBAAkB,CAAC,GAAG,CAC5D,CAAC,KAAU,EAAE,EAAE,CAAC,CAAC;gBACf,GAAG,KAAK;gBACR,MAAM,EAAE,cAAc;gBACtB,QAAQ,EAAE,IAAI;aACf,CAAC,CACH,CAAC;YAEF,qDAAqD;YACrD,MAAM,iBAAiB,GAAG,iBAAiB,CAAC,GAAG,CAC7C,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAC7B,CAAC;YAEF,6EAA6E;YAC7E,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE;gBACjE,MAAM,YAAY,GAChB,CAAC,GAAG,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE,KAAK,aAAa,CAAC;gBACzD,MAAM,aAAa,GACjB,GAAG,CAAC,MAAM,KAAK,cAAc;oBAC7B,CAAC,iBAAiB,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;gBAC1C,OAAO,YAAY,IAAI,aAAa,CAAC;YACvC,CAAC,CAAC,CAAC;YAEH,yDAAyD;YACzD,IAAI,CAAC,mBAAmB,GAAG,CAAC,GAAG,iBAAiB,EAAE,GAAG,gBAAgB,CAAC,CAAC;YAEvE,qEAAqE;YACrE,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC,GAAQ,EAAE,EAAE;gBAC5C,MAAM,WAAW,GACf,CAAC,GAAG,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE,KAAK,WAAW,CAAC;gBACvD,GAAG,CAAC,QAAQ,GAAG,WAAW,IAAI,GAAG,CAAC,SAAS,KAAK,IAAI,CAAC;YACvD,CAAC,CAAC,CAAC;YAEH,+DAA+D;YAC/D,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC,mBAAmB;iBACxD,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,SAAS,KAAK,IAAI,CAAC;iBAC5C,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YAEjC,qEAAqE;YACrE,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC,mBAAmB;iBACxD,MAAM,CACL,CAAC,GAAQ,EAAE,EAAE,CACX,CAAC,GAAG,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE,KAAK,WAAW;gBACpD,GAAG,CAAC,SAAS,KAAK,IAAI,CACzB;iBACA,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,CAAC;gBAClB,GAAG,GAAG;gBACN,MAAM,EAAE,GAAG,CAAC,MAAM,IAAI,cAAc;gBACpC,SAAS,EAAE,IAAI;aAChB,CAAC,CAAC,CAAC;SACP;aAAM;YACL,sFAAsF;YACtF,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE;gBACnE,MAAM,OAAO,GAAG,CAAC,GAAG,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;gBACrD,OAAO,OAAO,KAAK,IAAI,IAAI,GAAG,CAAC,MAAM,KAAK,cAAc,CAAC;YAC3D,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;QACnC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC,CAAC,uCAAuC;QACxE,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAC/B,CAAC;IACD,gBAAgB,CAAM;IACtB,mBAAmB,CAAM;IACzB,eAAe,GAAG,KAAK,CAAC;IAExB,WAAW,GAAG,KAAK,CAAC;IACpB,uBAAuB,CAAC,GAAQ;QAC9B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,CAAC,4CAA4C;QAC5E,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC;QAE5B,mEAAmE;QACnE,MAAM,eAAe,GAAG,IAAI,CAAC,iBAAiB,KAAK,WAAW,CAAC;QAE/D,IAAI,CAAC,eAAe,EAAE;YACpB,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;YAC7B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;YACvB,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;YACnC,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC,CAAC,mCAAmC;YAClE,IAAI,CAAC,qBAAqB,GAAG,EAAE,CAAC,CAAC,eAAe;SACjD;QAED,IAAI,cAAc,GAAU,EAAE,CAAC;QAC/B,MAAM,YAAY,GAAG,GAAG,CAAC,UAAU,EAAE,WAAW,EAAE,CAAC;QAEnD,2FAA2F;QAC3F,IAAI,eAAe,EAAE;YACnB,mEAAmE;YACnE,8CAA8C;YAC9C,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC,CAAC,2BAA2B;YACzD,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC,CAAC,+BAA+B;YACvD,4DAA4D;SAC7D;aAAM,IAAI,YAAY,KAAK,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,EAAE;YAChF,MAAM,QAAQ,GAAG,GAAG,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;gBACzD,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CACxC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM,CAC1C,CAAC;gBACF,OAAO;oBACL,GAAG,KAAK;oBACR,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC;oBAClB,MAAM,EAAE,GAAG,CAAC,MAAM;iBACnB,CAAC;YACJ,CAAC,CAAC,CAAC;YACH,cAAc,GAAG,CAAC,GAAG,EAAE,GAAG,QAAQ,CAAC,CAAC;YACpC,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;YAC3B,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC;SACrC;aAAM;YACL,yEAAyE;YACzE,wDAAwD;YACxD,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAC3C,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,EAAE,WAAW,EAAE,KAAK,YAAY,CAC7D,CAAC;YACF,IAAI,CAAC,iBAAiB,GAAG,cAAc,CAAC,SAAS,CAC/C,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,GAAG,CAAC,MAAM,CACxC,CAAC;YACF,0EAA0E;YAC1E,mEAAmE;YACnE,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC7B,IAAI,CAAC,mBAAmB,GAAG,cAAc,CAAC,MAAM,CAC9C,CAAC,CAAM,EAAE,CAAS,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,iBAAiB,CACpD,CAAC;aACH;SACF;QAED,yDAAyD;QACzD,IAAI,CAAC,eAAe,EAAE;YACpB,IACE,GAAG,EAAE,UAAU,KAAK,WAAW;gBAC/B,GAAG,EAAE,UAAU,KAAK,UAAU;gBAC9B,GAAG,EAAE,UAAU,KAAK,eAAe,IAAI,GAAG,EAAE,UAAU,KAAI,MAAM,EAChE;gBACA,IACE,GAAG,EAAE,UAAU,KAAK,WAAW;oBAC/B,GAAG,EAAE,kBAAkB,EAAE,MAAM,GAAG,CAAC,EACnC;oBACA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;iBACzB;qBAAM,IACL,GAAG,EAAE,UAAU,KAAK,UAAU;oBAC9B,GAAG,EAAE,UAAU,KAAK,eAAe,IAAI,GAAG,EAAE,UAAU,KAAI,MAAM,EAChE;oBACA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;iBACzB;qBAAM;oBACL,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;iBAC1B;gBACD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;gBAC5B,IAAI,CAAC,YAAY,GAAG,GAAG,EAAE,UAAU,CAAC;gBACpC,IAAI,CAAC,aAAa,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;aACrC;SACF;aAAM;YACL,sDAAsD;YACtD,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;YAC7B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;SAC1B;QAED,8CAA8C;QAC9C,IAAI,CAAC,0BAA0B,EAAE,CAAC;IACpC,CAAC;IAED,WAAW,CAAC,GAAQ;QACpB,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;QACnC,IAAI,cAAc,GAAU,EAAE,CAAC;QAC/B,MAAM,YAAY,GAAG,GAAG,CAAC,UAAU,EAAE,WAAW,EAAE,CAAC;QAEnD,IAAI,YAAY,KAAK,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,EAAE;YACzE,gEAAgE;YAChE,MAAM,QAAQ,GAAG,GAAG,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;gBACzD,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CACxC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM,CAC1C,CAAC;gBACF,OAAO;oBACL,GAAG,KAAK;oBACR,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC;oBAClB,MAAM,EAAE,GAAG,CAAC,MAAM;iBACnB,CAAC;YACJ,CAAC,CAAC,CAAC;YAEH,cAAc,GAAG,CAAC,GAAG,EAAE,GAAG,QAAQ,CAAC,CAAC;YAEpC,wCAAwC;YACxC,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;YAE3B,4BAA4B;YAC5B,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC;SACrC;aAAM;YACL,0CAA0C;YAC1C,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAC3C,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,EAAE,WAAW,EAAE,KAAK,YAAY,CAC7D,CAAC;YAEF,IAAI,CAAC,iBAAiB,GAAG,cAAc,CAAC,SAAS,CAC/C,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,GAAG,CAAC,MAAM,CACxC,CAAC;YAEF,IAAI,CAAC,mBAAmB,GAAG,cAAc,CAAC,MAAM,CAC9C,CAAC,CAAM,EAAE,CAAS,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,iBAAiB,CACpD,CAAC;SACH;QAGD,qCAAqC;QACrC,IACE,GAAG,EAAE,UAAU,KAAK,WAAW;YAC/B,GAAG,EAAE,UAAU,KAAK,UAAU;YAC9B,GAAG,EAAE,UAAU,KAAK,eAAe,IAAI,GAAG,EAAE,UAAU,KAAI,MAAM,EAChE;YACA,IACE,GAAG,EAAE,UAAU,KAAK,WAAW;gBAC/B,GAAG,EAAE,kBAAkB,EAAE,MAAM,GAAG,CAAC,EACnC;gBACA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;aACzB;iBAAM,IACL,GAAG,EAAE,UAAU,KAAK,UAAU;gBAC9B,GAAG,EAAE,UAAU,KAAK,eAAe,IAAI,GAAG,EAAE,UAAU,KAAI,MAAM,EAChE;gBACA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;aACzB;iBAAM;gBACL,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;aAC1B;YAED,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;YAC5B,IAAI,CAAC,YAAY,GAAG,GAAG,EAAE,UAAU,CAAC;YACpC,IAAI,CAAC,aAAa,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;SACrC;IACH,CAAC;IAGC,OAAO,CAAC,GAAQ;QACd,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACzB,mDAAmD;YACnD,MAAM,KAAK,GAAG,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAC9C,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,GAAG,CAAC,MAAM,CACxC,CAAC;YAEF,6DAA6D;YAC7D,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;gBAChB,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC;aACzD;iBAAM;gBACL,wBAAwB;gBACxB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;aACtD;SACF;QAED,wBAAwB;QACxB,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC;QAE5B,sCAAsC;QACtC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CACxD,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,GAAG,CAAC,MAAM,CACxC,CAAC;QAEF,kCAAkC;QAClC,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAElC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IACxB,CAAC;IAED,YAAY,GAAQ,EAAE,CAAC,CAAC,mBAAmB;IAC3C,iBAAiB,CAAM;IACvB,aAAa,CAAC,GAAQ;QACtB,IAAI,CAAC,iBAAiB,GAAG,GAAG,CAAC;QAC7B,IAAI,CAAC,2BAA2B,GAAG,EAAE,CAAC;QAEtC,MAAM,IAAI,GAAG,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;QAEvC,IAAI,IAAI,KAAK,WAAW,EAAE;YACxB,IACE,IAAI,CAAC,gBAAgB,EAAE,UAAU,EAAE,WAAW,EAAE,KAAK,WAAW;gBAChE,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,EAAE,kBAAkB,CAAC;gBACxD,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,MAAM,GAAG,CAAC,EACnD;gBACA,sFAAsF;gBACtF,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;oBACrE,OAAO,EAAE,GAAG,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;gBACzD,CAAC,CAAC,CAAC;aACJ;iBAAM;gBACL,gFAAgF;gBAChF,MAAM,cAAc,GAAG,IAAI,CAAC,gBAAgB,EAAE,MAAM,CAAC;gBAErD,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE;oBACnE,MAAM,OAAO,GAAG,CAAC,GAAG,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;oBACrD,OAAO,OAAO,KAAK,aAAa,IAAI,GAAG,CAAC,MAAM,KAAK,cAAc,CAAC;gBACpE,CAAC,CAAC,CAAC;gBAEH,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC,GAAQ,EAAE,EAAE;oBAC5C,GAAG,CAAC,QAAQ,GAAG,KAAK,CAAC;oBACrB,GAAG,CAAC,SAAS,GAAG,KAAK,CAAC;gBACxB,CAAC,CAAC,CAAC;aACJ;YACD,iDAAiD;YACjD,IAAI,CAAC,0BAA0B,EAAE,CAAC;YAClC,OAAO,CAAC,GAAG,CAAC,uBAAuB,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAA;SAC/D;aAAM;YACL,kDAAkD;YAClD,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC;YAC9B,IAAI,CAAC,qBAAqB,GAAG,EAAE,CAAC;SACjC;IACH,CAAC;IAGC,IAAI,GAAQ,UAAU,CAAC;IACvB,gBAAgB,CAAC,IAAS;QACxB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QAEjB,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,YAAY;QACV,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC,CAAC,yCAAyC;QAC1E,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;QAE7B,mCAAmC;QACnC,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,EAAE,WAAW,EAAE,CAAC;QAE9C,IAAI,YAAY,KAAK,UAAU,EAAE;YAC/B,6DAA6D;YAC7D,IAAI,CAAC,eAAe,GAAG,CAAC,GAAG,IAAI,CAAC,oBAAoB,CAAC,CAAC;SACvD;aAAM;YACL,gEAAgE;YAChE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CACjD,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,EAAE,KAAK,YAAY,CAC/D,CAAC;SACH;QACD,SAAS;QACT,qEAAqE;QACrE,2EAA2E;QAC3E,uBAAuB;QACvB,OAAO;QACP,IAAI;QAEJ,6BAA6B;QAC7B,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,MAAM,CAAC;QAE5C,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;IAC1B,CAAC;IACD,WAAW,CAAC,IAAqB;QAC/B,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE;YAC1B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACtB;IACH,CAAC;IAED,8BAA8B;IAC5B,cAAc,CAAC,YAAoB;QACjC,IAAI,CAAC,YAAY,IAAI,YAAY,KAAK,CAAC;YAAE,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC;QACtE,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,EAAE,CAAC,CAAC;QAC5C,MAAM,IAAI,GAAG,YAAY,GAAG,EAAE,CAAC;QAC/B,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;IACzB,CAAC;IAEH,qBAAqB,GAA8C,EAAE,CAAC;IAE9D,0BAA0B;QAChC,IAAI,CAAC,IAAI,CAAC,mBAAmB,IAAI,IAAI,CAAC,mBAAmB,CAAC,MAAM,KAAK,CAAC,EAAE;YACtE,IAAI,CAAC,qBAAqB,GAAG,EAAE,CAAC;YAChC,OAAO;SACR;QAED,MAAM,KAAK,GAAa,EAAE,CAAC;QAC3B,MAAM,GAAG,GAAG,IAAI,GAAG,EAAiB,CAAC;QAErC,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC,GAAQ,EAAE,EAAE;YAC5C,MAAM,GAAG,GAAG,GAAG,EAAE,SAAS,IAAI,IAAI,CAAC;YACnC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;gBACjB,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBACjB,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aACjB;YACD,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YAC/C,SAAS,EAAE,GAAG;YACd,IAAI,EAAE,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE;SACzB,CAAC,CAAC,CAAC;QAEJ,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAA;IACtD,CAAC;IAEO,mBAAmB;QACzB,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,EAAE;YAC5B,IAAI,CAAC,cAAc,GAAG,CAAC,IAAI,CAAC,eAAe,IAAI,EAAE,CAAC;iBAC/C,MAAM,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC;iBACvE,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,CAAC;gBACpB,SAAS,EAAE,KAAK,EAAE,SAAS,IAAI,IAAI;gBACnC,IAAI,EAAE,KAAK,EAAE,IAAI,IAAI,EAAE;aACxB,CAAC,CAAC,CAAC;YACN,OAAO;SACR;QAED,MAAM,KAAK,GAAa,EAAE,CAAC;QAC3B,MAAM,GAAG,GAAG,IAAI,GAAG,EAAiB,CAAC;QAErC,CAAC,IAAI,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,GAAQ,EAAE,EAAE;YAChD,MAAM,GAAG,GAAG,GAAG,EAAE,SAAS,IAAI,IAAI,CAAC;YACnC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;gBACjB,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBACjB,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aACjB;YACD,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YACxC,SAAS,EAAE,GAAG;YACd,IAAI,EAAE,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE;SACzB,CAAC,CAAC,CAAC;IACN,CAAC;IACD,gBAAgB,CAAC,GAAQ,EAAE,GAAQ;QACjC,gFAAgF;QAChF,IAAI,IAAI,CAAC,iBAAiB,KAAK,WAAW,IAAI,IAAI,CAAC,kBAAkB,EAAE;YACrE,sDAAsD;YACtD,wDAAwD;YACxD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;YAC5C,OAAO;SACR;QAED,8EAA8E;QAC9E,IAAI,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,iBAAiB,KAAK,WAAW,EAAE;YACrE,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,CAAC;SACnC;aAAM,IAAI,IAAI,CAAC,iBAAiB,KAAK,WAAW,EAAE;YACjD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,wCAAwC;SAC5D;IACH,CAAC;IAED,cAAc,GAAQ,IAAI,CAAC,CAAC,+DAA+D;IAE3F,kBAAkB,CAAC,QAAa,EAAE,SAAc;QAC9C,qDAAqD;QACrD,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;QAChC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACvD,QAAQ,EAAE,IAAI;YACd,IAAI,EAAE,IAAI;YACV,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAC;IACL,CAAC;IACD,2BAA2B,GAAQ,EAAE,CAAC;IAEtC,wBAAwB,CAAC,GAAQ;QAC/B,IAAI,CAAC,GAAG,IAAI,GAAG,CAAC,kBAAkB,EAAE,MAAM,GAAG,CAAC,EAAE;YAC9C,OAAO;SACR;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC;QACjD,MAAM,kBAAkB,GAAG,IAAI,CAAC,SAAS,EAAE,SAAS,IAAI,CAAC,CAAC;QAC1D,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,GAAG,CAAC,CAAC;QACpD,MAAM,sBAAsB,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAC5D,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAC7B,CAAC,MAAM,CAAC;QAET,MAAM,UAAU,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC;QAEjC,mDAAmD;QACnD,IACE,UAAU;YACV,sBAAsB,GAAG,kBAAkB,IAAI,aAAa,EAC5D;YACA,IAAI,CAAC,KAAK,CAAC,eAAe,CACxB,uBAAuB,aAAa,YAClC,IAAI,CAAC,WAAW,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,IAAI,KAC/C,qBAAqB,CACtB,CAAC;YACF,OAAO;SACR;QAED,kCAAkC;QAClC,GAAG,CAAC,QAAQ,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC;QAC7B,GAAG,CAAC,SAAS,GAAG,GAAG,CAAC,QAAQ,CAAC;QAE7B,qCAAqC;QACrC,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC,mBAAmB;aACxD,MAAM,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC;aACpC,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,CAAC;YACnB,GAAG,IAAI;YACP,MAAM,EAAE,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,gBAAgB,EAAE,MAAM;YACpD,SAAS,EAAE,IAAI;SAChB,CAAC,CAAC,CAAC;QAEN,wDAAwD;QACxD,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;IAC1B,CAAC;IAED,qBAAqB,CAAC,GAAQ,EAAE,GAAQ,EAAE,IAAY;QACpD,IAAI,IAAI,KAAK,WAAW,EAAE;YACxB,gDAAgD;YAChD,IAAI,CAAC,wBAAwB,CAAC,GAAG,CAAC,CAAC;YACnC,2CAA2C;YAC3C,IAAI,GAAG,IAAI,GAAG,CAAC,MAAM,EAAE;gBACrB,GAAG,CAAC,MAAM,CAAC,OAAO,GAAG,GAAG,CAAC,QAAQ,CAAC;aACnC;SACF;IACH,CAAC;IAED,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACzB,kCAAkC;IACpC,CAAC;IACD,MAAM;QACJ,0CAA0C;QAC1C,IAAI,CAAC,2BAA2B,GAAG,EAAE,CAAC;QAEtC,kEAAkE;QAClE,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,CAAC;YAC/D,GAAG,GAAG;YACN,SAAS,EAAE,KAAK;YAChB,QAAQ,EAAE,KAAK;YACf,MAAM,EAAE,IAAI,EAAE,uBAAuB;YACrC,iCAAiC;SAClC,CAAC,CAAC,CAAC;QAEJ,wCAAwC;QACxC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QAEvB,2CAA2C;QAC3C,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;QAC7B,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;QAC3B,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC;QAC9B,IAAI,CAAC,qBAAqB,GAAG,EAAE,CAAC;QAEhC,oEAAoE;QACpE,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;QACnC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC/B,CAAC;IACD,SAAS,CAAM;IACS,SAAS,CAAa;IAC9C,IAAI,CAAC,QAAa;QAChB,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACtD,QAAQ,EAAE,IAAI;YACd,IAAI,EAAE,IAAI;YACV,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,KAAK,EAAE,6BAA6B;SAC/C,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC5B,CAAC;IAED,YAAY;QACV,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;QAE/B,IAAI,CAAC,2BAA2B,GAAG,EAAE,CAAC;IACxC,CAAC;IACD,WAAW,CAAC,QAAa;QACvB,IAAI,eAAe,GAAG,EAAE,CAAC;QAEzB,IAAI,QAAQ,KAAK,WAAW,EAAE;YAC5B,eAAe,GAAG,IAAI,CAAC,mBAAmB;iBACvC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,QAAQ,KAAK,IAAI,CAAC;iBAC3C,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,CAAC;gBAClB,MAAM,EAAE,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,MAAM,IAAI,EAAE;gBACtC,SAAS,EAAE,GAAG,CAAC,SAAS,IAAI,EAAE;gBAC9B,SAAS,EAAE,GAAG,CAAC,SAAS,IAAI,GAAG,CAAC,QAAQ,IAAI,EAAE;gBAC9C,QAAQ,EAAE,GAAG,CAAC,QAAQ,IAAI,EAAE;gBAC5B,QAAQ,EAAE,GAAG,CAAC,QAAQ;gBACtB,UAAU,EAAE,WAAW;gBACvB,SAAS,EAAE,IAAI;aAChB,CAAC,CAAC,CAAC;SACP;QAED,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC;QAElC,MAAM,GAAG,GAAG;YACV,OAAO,EACL,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC;gBAC/C,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;gBACtB,CAAC,CAAC,IAAI;YACV,UAAU,EAAE,IAAI,CAAC,UAAU,IAAI,EAAE;YACjC,MAAM,EAAE,GAAG,EAAE,MAAM,IAAI,CAAC;YACxB,UAAU,EAAE,QAAQ;YACpB,SAAS,EAAE,GAAG,EAAE,SAAS,IAAI,EAAE;YAC/B,SAAS,EAAE,IAAI;YACf,cAAc,EAAE,eAAe;YAC/B,WAAW,EAAE,GAAG,EAAE,WAAW,IAAI,UAAU;YAC3C,SAAS,EAAE,GAAG,EAAE,SAAS,IAAI,GAAG,EAAE,QAAQ,IAAI,EAAE;YAChD,QAAQ,EAAE,GAAG,EAAE,QAAQ,IAAI,EAAE;YAC7B,QAAQ,EAAE,GAAG,EAAE,QAAQ,IAAI,EAAE;YAC7B,QAAQ,EAAE,IAAI,CAAC,WAAW,IAAI,EAAE;YAChC,IAAI,EAAE,KAAK;SACZ,CAAC;QAEF,IAAI,CAAC,WAAW;aACb,UAAU,CAAC,GAAG,CAAC;aACf,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,IAAI,GAAG,CAAC,IAAI,KAAK,GAAG,EAAE;oBAC3B,IAAI,CAAC,KAAK,CAAC,eAAe,CACxB,GAAG,EAAE,OAAO,IAAI,6BAA6B,CAC9C,CAAC;oBACF,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;oBACvB,IAAI,CAAC,SAAS,EAAE,CAAC;oBACjB,IAAI,CAAC,YAAY,EAAE,CAAC;oBACpB,IAAI,CAAC,YAAY,EAAE,CAAC;oBACpB,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;oBACnC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;iBACxB;qBAAM;oBACL,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC;iBAC9C;YACH,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;gBAClB,MAAM,GAAG,GACP,GAAG,CAAC,KAAK,EAAE,KAAK,IAAI,GAAG,CAAC,KAAK,IAAI,GAAG,EAAE,OAAO,IAAI,eAAe,CAAC;gBACnE,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YAChC,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAED,cAAc,GAA8B;QAC1C,SAAS,EAAE,qBAAqB;QAChC,QAAQ,EAAE,yBAAyB;QACnC,eAAe,EAAE,wBAAwB;QACzC,aAAa,EAAE,sBAAsB;QACrC,IAAI,EAAE,eAAe;KACtB,CAAC;IAEF,iBAAiB,GAAQ,IAAI,CAAC,CAAC,mCAAmC;IAElE,oBAAoB,CAAC,QAAQ,GAAG,KAAK,IAAQ,CAAC;IAEpB,WAAW,CAAa;IAClB,iBAAiB,CAAa;IAC9D,MAAM;QACJ,MAAM,OAAO,GAAQ;YACnB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,OAAO,EAAE,IAAI,CAAC,YAAY,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI;YACpE,UAAU,EAAE,oBAAoB;YAChC,aAAa,EAAE,CAAC;YAChB,cAAc,EAAE,CAAC;YACjB,aAAa,EAAE,CAAC;YAChB,iBAAiB,EAAE,CAAC;YACpB,SAAS,EAAC,CAAC;YACX,QAAQ,EAAE,IAAI,CAAC,WAAW,IAAI,EAAE;YAChC,eAAe,EAAE,EAAE;YACnB,YAAY,EAAE,EAAE;YAChB,QAAQ,EAAE,EAAE;YACZ,IAAI,EAAE,EAAE;SACT,CAAC;QAEF,IAAI,iBAAiB,GAAG,CAAC,CAAC;QAE1B,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;YAC1C,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,WAAW,EAAE,EAAE,IAAI,EAAE,CAAC;YACpD,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC;YAE1C,kEAAkE;YAClE,8CAA8C;YAE9C,qBAAqB;YACrB,yBAAyB;YACzB,IAAI;YAEJ,iBAAiB;YACjB,IAAI,IAAI,KAAK,WAAW,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,EAAE;gBAClE,MAAM,UAAU,GAAG,IAAI,CAAC,kBAAkB;qBACvC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC;qBACnC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,CAAC;oBAClB,MAAM,EAAE,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,MAAM,IAAI,EAAE;oBACtC,QAAQ,EAAE,GAAG,CAAC,QAAQ;oBACtB,SAAS,EAAE,GAAG,EAAE,SAAS,IAAI,GAAG,EAAE,QAAQ,IAAI,EAAE;oBAChD,QAAQ,EAAE,GAAG,CAAC,QAAQ;oBACtB,SAAS,EAAE,GAAG,CAAC,SAAS;oBACxB,SAAS,EAAE,GAAG,CAAC,SAAS;iBACzB,CAAC,CAAC,CAAC;gBAEN,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE;oBACzB,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC;wBAC3B,MAAM,EAAE,IAAI,CAAC,MAAM;wBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;wBACvB,SAAS,EAAE,IAAI,EAAE,SAAS,IAAI,IAAI,EAAE,QAAQ,IAAI,EAAE;wBAClD,QAAQ,EAAE,IAAI,CAAC,QAAQ;wBACvB,SAAS,EAAE,IAAI,CAAC,SAAS;wBACzB,SAAS,EAAE,IAAI,CAAC,SAAS;wBACzB,IAAI,EAAE,UAAU;qBACjB,CAAC,CAAC;oBAEH,OAAO,CAAC,cAAc,IAAI,UAAU,CAAC,MAAM,CAAC;iBAC7C;aACF;YAED,WAAW;iBACN,IAAI,IAAI,KAAK,UAAU,IAAI,SAAS,EAAE;gBACzC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;oBACpB,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,SAAS,EAAE,IAAI,EAAE,SAAS,IAAI,IAAI,EAAE,QAAQ,IAAI,EAAE;oBAClD,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,SAAS,EAAE,IAAI,CAAC,SAAS;oBACzB,SAAS,EAAE,IAAI,CAAC,SAAS;iBAC1B,CAAC,CAAC;gBAEH,OAAO,CAAC,aAAa,EAAE,CAAC;aACzB;YAED,eAAe;iBACV,IAAI,IAAI,KAAK,eAAe,IAAI,SAAS,EAAE;gBAC9C,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC;oBACxB,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,SAAS,EAAE,IAAI,EAAE,SAAS,IAAI,IAAI,EAAE,QAAQ,IAAI,EAAE;oBAClD,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,SAAS,EAAE,IAAI,CAAC,SAAS;oBACzB,SAAS,EAAE,IAAI,CAAC,SAAS;iBAC1B,CAAC,CAAC;gBAEH,OAAO,CAAC,iBAAiB,EAAE,CAAC;aAC7B;iBACI,IAAI,IAAI,KAAK,MAAM,IAAI,SAAS,EAAE;gBACrC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC;oBAChB,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,SAAS,EAAG,IAAI,EAAE,SAAS,IAAI,IAAI,EAAE,QAAQ,IAAI,EAAE;oBACnD,QAAQ,EAAG,IAAI,CAAC,QAAQ;oBACxB,SAAS,EAAG,IAAI,CAAC,SAAS;oBAC1B,SAAS,EAAG,IAAI,CAAC,SAAS;iBAC3B,CAAC,CAAC;gBAEH,OAAO,CAAC,SAAS,EAAE,CAAC;aACrB;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC;QAEtD,sBAAsB;QAEtB,IAAI,CAAC,iBAAiB,GAAG,OAAO,CAAC;QACjC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QACxB,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACxD,QAAQ,EAAE,IAAI;YACd,IAAI,EAAE,IAAI;YACV,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAC;IACL,CAAC;IAED,YAAY;QACV,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;QAC/B,IAAI,CAAC,2BAA2B,GAAG,EAAE,CAAC;IACxC,CAAC;IAED,WAAW,CAAM;IACjB,aAAa,CAAM;IACnB,YAAY;QACV,gEAAgE;QAChE,MAAM,OAAO,GAAG;YACd,UAAU,EAAE,oBAAoB;YAChC,OAAO,EAAE,IAAI,CAAC,iBAAiB,CAAC,OAAO;YACvC,UAAU,EAAE,IAAI,CAAC,iBAAiB,CAAC,UAAU;YAC7C,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,KAAK;SACZ,CAAA;QACD,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;QAC7B,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,OAAO,CAAC,CAAA;QACvC,IAAI,CAAC,WAAW;aACb,kBAAkB,CAAC,OAAO,CAAC;aAC3B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,IAAI,GAAG,CAAC,IAAI,KAAK,GAAG,EAAE;oBAC3B,IAAI,CAAC,KAAK,CAAC,eAAe,CACxB,GAAG,EAAE,OAAO,IAAI,6BAA6B,CAC9C,CAAC;oBACF,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;oBACvB,IAAI,CAAC,SAAS,EAAE,CAAC;oBACjB,IAAI,CAAC,YAAY,EAAE,CAAC;oBACpB,IAAI,CAAC,YAAY,EAAE,CAAC;oBACpB,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;oBACnC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;oBACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;iBACrB;qBAAM;oBACL,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC;oBAC7C,IAAI,CAAC,YAAY,EAAE,CAAC;iBACrB;YACH,CAAC;YACD,KAAK,EAAE,CAAC,GAAQ,EAAE,EAAE;gBAClB,MAAM,GAAG,GACP,GAAG,CAAC,KAAK,EAAE,KAAK;oBAChB,GAAG,CAAC,KAAK;oBACT,GAAG,EAAE,KAAK,EAAE,OAAO;oBACnB,GAAG,CAAC,OAAO;oBACX,eAAe,CAAC;gBAClB,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;gBAC9B,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAED,kDAAkD;IAClD,gCAAgC;IAChC,mFAAmF;IACnF,sEAAsE;IACtE,uBAAuB;IACvB,gHAAgH;IAChH,gBAAgB;IAEhB,mFAAmF;IAEnF,mEAAmE;IACnE,kDAAkD;IAClD,SAAS;IAET,0BAA0B;IAC1B,4CAA4C;IAC5C,qEAAqE;IACrE,oCAAoC;IACpC,mGAAmG;IACnG,aAAa;IAEb,gCAAgC;IAChC,oGAAoG;IACpG,8BAA8B;IAC9B,2DAA2D;IAC3D,YAAY;IAEZ,6BAA6B;IAC7B,kCAAkC;IAClC,cAAc;IAEd,kBAAkB;IAClB,UAAU;IAEV,wCAAwC;IACxC,8BAA8B;IAC9B,kDAAkD;IAClD,oBAAoB;IACpB,6BAA6B;IAC7B,uCAAuC;IACvC,cAAc;IACd,UAAU;IACV,eAAe;IACf,0BAA0B;IAC1B,oFAAoF;IACpF,oDAAoD;IACpD,WAAW;IACX,QAAQ;IACR,MAAM;IAEN,kDAAkD;IAClD,qCAAqC;IACrC,IAAI;IAEJ,gCAAgC;IAEhC,+BAA+B;IAC/B,gCAAgC;IAChC,6FAA6F;IAC7F,IAAI;IAEJ,WAAW,GAAG,KAAK,CAAC;IACK,UAAU,CAAa;IAChD,kBAAkB,CAAC,GAAQ,EAAE,IAAS;QACpC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACvD,QAAQ,EAAE,IAAI;YACd,IAAI,EAAE,IAAI;YACV,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAC;IACL,CAAC;IAED,UAAU;QACR,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,CAAC,2CAA2C;QACvE,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;IACjC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACvC,OAAO,KAAK,CAAC;SACd;QACD,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC;QAEnE,wBAAwB;QACxB,MAAM,QAAQ,GAAG,SAAS,GAAG,CAAC,IAAI,YAAY,GAAG,CAAC,IAAI,QAAQ,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,CAAC;QAE/E,6BAA6B;QAC7B,MAAM,MAAM,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACzC,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;QAEzB,2DAA2D;QAC3D,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC5B,KAAK,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAE3B,+BAA+B;QAC/B,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,EAAE,GAAG,MAAM,CAAC,OAAO,EAAE,CAAC;QACtD,MAAM,UAAU,GAAG,UAAU,GAAG,CAAC,IAAI,GAAG,IAAI,GAAG,EAAE,CAAC,CAAC;QAEnD,4CAA4C;QAC5C,MAAM,aAAa,GAAG,UAAU,IAAI,CAAC,IAAI,UAAU,IAAI,CAAC,CAAC;QAEzD,OAAO,QAAQ,IAAI,aAAa,CAAC;IACnC,CAAC;IAED,iBAAiB,GAAW,CAAC,CAAC;IAC9B,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;IACpC,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC;IAClE,CAAC;IAED,aAAa,CAAC,SAA2B;QACvC,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC;QAE3C,IAAI,SAAS,KAAK,MAAM,IAAI,IAAI,CAAC,eAAe,EAAE;YAChD,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;aAAM,IAAI,SAAS,KAAK,OAAO,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACzD,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;QAED,wBAAwB;QACxB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAErE,0BAA0B;QAC1B,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CACpD,CAAC,CAAM,EAAE,CAAM,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,iBAAiB,CACjD,CAAC;IACJ,CAAC;IAED,+CAA+C;IAC/C,kBAAkB;QAChB,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAO,CAAC,CAAC;QAC/B,MAAM,cAAc,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7E,OAAO,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,aAAa,IAAI,CAAC,CAAC;IAC9D,CAAC;IAED,gDAAgD;IAChD,2BAA2B;QACzB,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAO,CAAC,CAAC;QAC/B,MAAM,cAAc,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7E,OAAO,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,kBAAkB,IAAI,CAAC,CAAC;IACnE,CAAC;IAED,iDAAiD;IACjD,oBAAoB;QAClB,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAO,GAAG,CAAC;QACjC,MAAM,cAAc,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7E,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,QAAQ,IAAI,CAAC,CAAC;QAExE,IAAI,CAAC,eAAe,IAAI,eAAe,KAAK,CAAC;YAAE,OAAO,GAAG,CAAC;QAE1D,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC;QAC7D,IAAI,KAAK,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,EAAE;YACzB,OAAO,GAAG,KAAK,MAAM,IAAI,OAAO,CAAC;SAClC;aAAM,IAAI,KAAK,GAAG,CAAC,EAAE;YACpB,OAAO,GAAG,KAAK,IAAI,CAAC;SACrB;aAAM,IAAI,IAAI,GAAG,CAAC,EAAE;YACnB,OAAO,GAAG,IAAI,OAAO,CAAC;SACvB;QACD,OAAO,GAAG,CAAC;IACb,CAAC;IAED,oBAAoB;IACpB,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAO,GAAG,CAAC;QACjC,MAAM,cAAc,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7E,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,YAAY,CAAC;QAC9D,OAAO,MAAM,IAAI,GAAG,CAAC;IACvB,CAAC;IAED,4BAA4B;IAC5B,WAAW;QACT,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAO,KAAK,CAAC;QACnC,MAAM,cAAc,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7E,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,QAAQ,IAAI,CAAC,CAAC;QACjE,OAAO,QAAQ,GAAG,CAAC,CAAC;IACtB,CAAC;IAED,wEAAwE;IACxE,cAAc,CAAC,IAAY;QACzB,IAAI,CAAC,IAAI,CAAC,kBAAkB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,EAAE;YAChF,OAAO,IAAI,CAAC;SACb;QACD,OAAO,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,EAAE,UAAU,KAAK,IAAI,CAAC,IAAI,IAAI,CAAC;IACxF,CAAC;IAED,mCAAmC;IACnC,cAAc;QACZ,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACtC,OAAO,MAAM,KAAK,GAAG,IAAI,MAAM,EAAE,WAAW,EAAE,KAAK,QAAQ,CAAC;IAC9D,CAAC;IAED,mCAAmC;IACnC,cAAc;QACZ,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACtC,OAAO,MAAM,KAAK,GAAG,IAAI,MAAM,EAAE,WAAW,EAAE,KAAK,QAAQ,CAAC;IAC9D,CAAC;IAED,+DAA+D;IAC/D,iBAAiB;QACf,IAAI,CAAC,IAAI,CAAC,kBAAkB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,EAAE;YACvE,OAAO,EAAE,CAAC;SACX;QACD,OAAO,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,EAAE,UAAU,KAAK,SAAS,CAAC,IAAI,EAAE,CAAC;IAC7F,CAAC;IAED,iDAAiD;IACjD,sBAAsB;QACpB,MAAM,UAAU,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC5C,OAAO,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACtD,CAAC;IAED,mEAAmE;IACnE,oBAAoB;QAClB,MAAM,UAAU,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC5C,OAAO,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IACpH,CAAC;IAED,4DAA4D;IAC5D,cAAc,CAAC,IAAS,EAAE,SAAiB;QACzC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACxB,OAAO,CAAC,CAAC;SACV;QAED,0CAA0C;QAC1C,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAC7B,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,SAAS,CAAC,CAAC;YAC3E,OAAO,SAAS,EAAE,KAAK,IAAI,CAAC,CAAC;SAC9B;QAED,mCAAmC;QACnC,MAAM,MAAM,GAA8B;YACxC,WAAW,EAAE,gBAAgB;YAC7B,UAAU,EAAE,eAAe;YAC3B,MAAM,EAAE,WAAW;YACnB,cAAc,EAAE,mBAAmB;SACpC,CAAC;QAEF,MAAM,GAAG,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAC9B,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC;IAED,gFAAgF;IAChF,iCAAiC;IACjC,sBAAsB,CAAC,IAAY;QACjC,IAAI,CAAC,IAAI,CAAC,kBAAkB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,kBAAkB,IAAI,CAAC,IAAI,CAAE,EAAE;YACjF,OAAO,CAAC,CAAC;SACV;QAED,mCAAmC;QACnC,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,EAAE,UAAU,KAAK,IAAI,CAAC,CAAC;QAC9F,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE;YAC7B,OAAO,CAAC,CAAC;SACV;QAED,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,eAAe,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,eAAe,KAAK,CAAC,EAAE;YACjG,OAAO,CAAC,CAAC;SACV;QAED,MAAM,KAAK,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;QAC1C,iEAAiE;QACjE,IAAI,UAAU,GAAG,CAAC,CAAC;QAEnB,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACxB,+DAA+D;YAC/D,MAAM,UAAU,GAAG,CAAC,WAAW,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;YACrE,UAAU,GAAG,KAAK;iBACf,MAAM,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;iBACtD,MAAM,CAAC,CAAC,GAAW,EAAE,IAAS,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,IAAI,EAAE,KAAK,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;SACpE;QACD,SAAS;QACT,gDAAgD;QAChD,gDAAgD;QAChD,+CAA+C;QAC/C,2CAA2C;QAC3C,iDAAiD;QACjD,IAAI;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,UAAU,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,GAAG,GAAG,CAAC,CAAC;IAC1E,CAAC;IAED,YAAY;QACV,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;YAC9D,QAAQ,EAAE,IAAI;YACd,IAAI,EAAE,IAAI;YACV,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAC;IACL,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;IACjC,CAAC;IAED,kBAAkB;QAChB,IAAI,OAAO,GAAG;YACZ,OAAO,EAAE,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI;YACxF,UAAU,EAAE,IAAI,CAAC,UAAU,IAAI,EAAE;SAClC,CAAC;QACF,OAAO,CAAC,GAAG,CAAC,6BAA6B,EAAE,OAAO,CAAC,CAAC;QACpD,+BAA+B;QAC/B,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;QAC/B,IAAI,CAAC,OAAO;aACT,mBAAmB,CAAC,OAAO,CAAC;aAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC/B,EAAE,SAAS,CAAC;YACV,IAAI,EAAE,CAAC,GAAQ,EAAE,EAAE;gBACjB,IAAI,GAAG,IAAI,GAAG,CAAC,IAAI,KAAK,GAAG,EAAE;oBAC3B,IAAI,CAAC,YAAY,EAAE,CAAC;oBACpB,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,4BAA4B,CAAC,CAAC;iBAC1D;qBAAM;oBACL,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,yBAAyB,CAAC,CAAC;iBACrD;YACH,CAAC;YACD,KAAK,EAAE,CAAC,GAAG,EAAE,EAAE;gBACb,MAAM,GAAG,GACP,GAAG,CAAC,KAAK,EAAE,KAAK;oBAChB,GAAG,CAAC,KAAK;oBACT,GAAG,EAAE,KAAK,EAAE,OAAO;oBACnB,GAAG,CAAC,OAAO;oBACX,eAAe,CAAC;gBAClB,OAAO,CAAC,KAAK,CAAC,+BAA+B,EAAE,GAAG,CAAC,CAAC;gBACpD,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG,IAAI,wBAAwB,CAAC,CAAC;YAC5D,CAAC;SACF,CAAC,CAAC;IAEP,CAAC;IAED,6CAA6C;IAC7C,iBAAiB;QACf,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAO,IAAI,CAAC;QAClC,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/D,CAAC;IAED,gCAAgC;IAChC,uBAAuB;QACrB,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAChD,OAAO,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAClE,CAAC;wGAh/CU,gBAAgB;4FAAhB,gBAAgB,6bCpB7B,kkkLAmiEc;;4FD/gED,gBAAgB;kBAL5B,SAAS;+BACE,cAAc;uOA25BA,SAAS;sBAAhC,SAAS;uBAAC,WAAW;gBA6FI,WAAW;sBAApC,SAAS;uBAAC,aAAa;gBACQ,iBAAiB;sBAAhD,SAAS;uBAAC,mBAAmB;gBAoOL,UAAU;sBAAlC,SAAS;uBAAC,YAAY","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,ElementRef,ViewChild\n} from \"@angular/core\";\nimport { TrafficRvpsService } from \"../../services/traffic-rvps.service\";\nimport { GlobalStateService } from \"tango-app-ui-global\";\nimport { TrafficService } from \"../../services/traffic.service\";\nimport { ToastService } from \"tango-app-ui-shared\";\nimport { Subject, takeUntil } from \"rxjs\";\nimport { NgbModal } from \"@ng-bootstrap/ng-bootstrap\";\nimport { debounceTime } from \"rxjs/operators\";\n\n@Component({\n  selector: \"lib-img-rvps\",\n  templateUrl: \"./img-rvps.component.html\",\n  styleUrl: \"./img-rvps.component.scss\",\n})\nexport class ImgRvpsComponent implements OnInit, OnDestroy {\n  headerData: any;\n  storeIdarray: any;\n  loading: boolean = true;\n  noData = false;\n  normalize: any;\n  overallCardData: any = [];\n  cardDataMap: { [date: string]: any } = {};\n  ticketReviewStatus: any = [];\n  userComment: any;\n  constructor(\n    private service: TrafficService,\n    public gs: GlobalStateService,\n    private cd: ChangeDetectorRef,\n    private modalService: NgbModal,\n    private toast: ToastService,\n    private rvpsService: TrafficRvpsService\n  ) {}\n  private readonly destroy$ = new Subject();\n  ngOnDestroy(): void {\n    this.destroy$.next(true);\n    this.destroy$.complete();\n  }\n  isAccordionExpanded = true;\n  toggleAccordion() {\n    this.isAccordionExpanded = !this.isAccordionExpanded;\n  }\n  users:any;\n  ngOnInit(): void {\n    this.getInital();\n    const userData: any = JSON.parse(localStorage.getItem(\"user-info\") || \"{}\");\n    this.users = userData;\n  }\n  getInital() {\n    this.gs.dataRangeValue\n      .pipe(takeUntil(this.destroy$), debounceTime(100))\n      .subscribe((data: any) => {\n        console.log('data :', data);\n        if (data !== null || data?.client !== null) {\n          this.headerData = data;\n          this.storeIdarray = this.headerData?.stores\n            .filter((store: any) => store.checked)\n            .map((store: any) => store.storeId);\n          this.backToFootfall();\n          this.displayDateRange();\n          this.loadCardData();\n          if (\n            this.headerData?.date?.startDate === this.headerData?.date?.endDate\n          ) {\n            this.backnav = false;\n            this.displayDateRange();\n            this.getimages(0, this.headerData.date.endDate);\n          } else {\n            this.folderView = true;\n            this.backnav = true;\n          }\n        }\n      });\n  }\n\n  backToFootfall() {\n    this.folderView = true;\n    this.getRvpsList = [];\n    this.getRvpsImageList = [];\n    this.objectsArray = [];\n    this.noData = false;\n    this.type = \"footfall\";\n    this.selectedTime = \"\";\n    this.splitScreenEnabled = false;\n    this.selectImageArray = null;\n    this.remainingImageArray = [];\n    this.remainingImagesGroups = [];\n  }\n  folderView: boolean;\n  backnav: boolean;\n  dateArray: any;\n  displayDateRange() {\n    const dates = this.getDateRangeArray(\n      this.headerData.date.startDate,\n      this.headerData.date.endDate\n    );\n    this.dateArray = dates;\n  }\n\n  getDateRangeArray(fromDate: string, toDate: string): string[] {\n    const start = new Date(fromDate); // Convert string to Date object\n    const end = new Date(toDate); // Convert string to Date object\n    const dateArray: string[] = [];\n\n    // Check if the dates are valid\n    if (isNaN(start.getTime()) || isNaN(end.getTime())) {\n      return dateArray;\n    }\n\n    // Loop from start date to end date\n    let currentDate = start;\n    while (currentDate <= end) {\n      dateArray.push(currentDate.toISOString().split(\"T\")[0]); // Format YYYY-MM-DD\n      currentDate.setDate(currentDate.getDate() + 1); // Increment the date by 1 day\n    }\n\n    return dateArray;\n  }\n\n  // Load card data\n  loadCardData() {\n    const storeId =\n    this.storeIdarray && this.storeIdarray.length > 0 ? this.storeIdarray[0] : null;\n    if (!storeId || !this.headerData?.date) {\n      this.overallCardData = [];\n      this.cardDataMap = {};\n      return;\n    }\n\n    this.rvpsService\n      .getImageDirectoryCardData(\n        storeId,\n        this.headerData.date.startDate,\n        this.headerData.date.endDate\n      )\n      .pipe(takeUntil(this.destroy$))\n      ?.subscribe({\n        next: (res: any) => {\n          if (res && res.code === 200) {\n            this.overallCardData = res?.data || [];\n            this.cardDataMap = (this.overallCardData || []).reduce(\n              (acc: { [key: string]: any }, item: any) => {\n                const normalizedDate = item?.date\n                  ? new Date(item.date).toISOString().split(\"T\")[0]\n                  : null;\n                if (normalizedDate) {\n                  acc[normalizedDate] = {\n                    ...item,\n                    ticketStatusLower: item?.ticketStatus\n                      ? String(item.ticketStatus).toLowerCase()\n                      : \"\",\n                  };\n                }\n                return acc;\n              },\n              {}\n            );\n          } else {\n            this.overallCardData = [];\n            this.cardDataMap = {};\n          }\n        },\n        error: (err) => {\n          console.error(\"Error fetching loadCardData:\", err);\n          this.overallCardData = [];\n          this.cardDataMap = {};\n        },\n      });\n  }\n\n\n  selectedTime: any;\n  folderName: any;\n  selectedTimes(val: any) {\n    this.selectedTime = val;\n    this.folderName = val;\n    this.folderView = false;\n    this.type = this.type;\n    this.getRevops();\n  }\n  folderDate: any;\n  imageFlow = false;\n  splitScreenEnabled = false; // Flag to enable split-screen view\n  // get Revops Api\n  getRvpsList: any;\n  getRvpsImageList: any;\n  objectsArray: any;\n  imagesArrayData: any;\n  listViewGroups: Array<{ timeRange: string; data: any[] }> = [];\n  selectIndex: any = 0;\n  footfallDate: any;\n  lengthValue: boolean;\n  viewMode: \"grid\" | \"list\" = \"grid\";\n  getimages(index: any, obj: any) {\n    this.objectsArray = [];\n    this.selectIndex = index;\n    this.folderDate = obj;\n    (this.footfallDate = obj), (this.folderView = false);\n    this.service?.isnormalizeSource\n      ?.pipe(takeUntil(this.destroy$), debounceTime(300))\n      ?.subscribe((normalize: any) => {\n        this.normalize = normalize;\n        if (!normalize) {\n          this.getRvpsList = [];\n          this.getRvpsImageList = [];\n          this.objectsArray = [];\n          this.getRevops();\n          // this.getTotal();\n        } else {\n          this.lengthValue = false;\n          this.objectsArray = [];\n        }\n      });\n  }\n  countData: any = [];\n  getTotal() {\n    this.countData = [];\n    const storeId =\n      this.storeIdarray && this.storeIdarray.length > 0\n        ? this.storeIdarray[0]\n        : null;\n    const dateString = this.folderDate || \"\";\n    this.rvpsService\n      .getTotalVal(storeId, dateString)\n      .pipe(takeUntil(this.destroy$))\n      ?.subscribe({\n        next: (res: any) => {\n          if (res && res.code === 200) {\n\n            if (this.getRvpsList?.length) this.countData = res.data;\n          } else {\n            this.countData = [];\n          }\n        },\n        error: (err) => {},\n      });\n  }\n  imageUrl: any;\n  revopsTypeCount: any;\n  currentTimeRangeData: any = [];\n  overallArrayData: any = [];\n  allFootfallData: any = [];\n  getTicketStatuses(): string[] {\n    const statusList = this.getRvpsList?.ticketStatus;\n    if (Array.isArray(statusList)) {\n      return statusList.map((s) => s?.status?.toLowerCase()).filter(Boolean); // Removes null/undefined\n    }\n    return [];\n  }\n  getRevops() {\n    this.loading = true;\n    this.noData = false;\n    // this.objectsArray =[];\n    // this.overallArrayData =[];\n    // this.getRvpsList =[];\n    // this.getRvpsImageList=[];\n    // this.allFootfallData =[]\n    const storeId =\n      this.storeIdarray && this.storeIdarray.length > 0\n        ? this.storeIdarray[0]\n        : null;\n    const dateString = this.folderDate || \"\";\n    const groupByKey = \"time\";\n    const type = this.type === \"footfall\" ? \"\" : this.type || \"\";\n    const processType = \"footfall\";\n\n    this.rvpsService\n      .getRvpsListApi(storeId, dateString, groupByKey, type, processType)\n      .pipe(takeUntil(this.destroy$))\n      .subscribe({\n        next: (res: any) => {\n          if (res && res.code === 200) {\n            this.getRvpsList = res?.data;\n            this.imageUrl = this.rvpsService?.footfallCDN;\n            this.getRvpsImageList = res?.data?.result;\n            this.ticketReviewStatus = res?.data?.ticketStatus;\n            console.log('revops getRvpsListApi :', res?.data);\n            console.log('revops ticketReviewStatus :', this.ticketReviewStatus);\n            // Save the full footfall data (grouped by timeRange)\n            this.allFootfallData = res?.data?.result?.footfallData || [];\n\n            // Create timeRange + count object\n            const timeRanges = this.allFootfallData.map(\n              (item: any) => item.timeRange\n            );\n            this.objectsArray = timeRanges.map((timeRange: any) => ({\n              timeRange,\n              count:\n                this.allFootfallData.find((d: any) => d.timeRange === timeRange)\n                  ?.data?.length || 0,\n            }));\n            // Only reset if previous selected time is NOT in the new list\n            if (!timeRanges.includes(this.selectedTime)) {\n              this.selectedTimes(this.objectsArray[0].timeRange);\n            }\n\n            // Get data for the selected timeRange\n            this.currentTimeRangeData =\n              this.allFootfallData.find(\n                (item: any) => item.timeRange === this.selectedTime\n              )?.data || [];\n\n            // Count revopsTypes\n            const revopsTypeCount: { [key: string]: number } = {\n              \"non-tagging\": 0,\n              duplicate: 0,\n              employee: 0,\n              \"house-keeping\": 0,\n              junk: 0,\n            };\n\n            let totalCount = 0;\n            this.overallArrayData = [];\n\n            this.allFootfallData.forEach((item: any) => {\n              item.data?.forEach((image: any) => {\n                this.overallArrayData.push(image);\n                totalCount++;\n\n                const type =\n                  image.revopsType?.trim().toLowerCase() || \"unknown\";\n\n                if (type === \"non-tagging\") {\n                  revopsTypeCount[\"non-tagging\"]++;\n                } else if (type === \"employee\") {\n                  revopsTypeCount[\"employee\"]++;\n                } else if (type === \"house-keeping\") {\n                  revopsTypeCount[\"house-keeping\"]++;\n                } else if(type === \"junk\") {\n                  revopsTypeCount[\"junk\"]++;\n                }\n\n                // ✅ Count duplicates only from duplicateImagePath\n                if (Array.isArray(image.duplicateImagePath)) {\n                  revopsTypeCount[\"duplicate\"] +=\n                    image.duplicateImagePath.length;\n                }\n              });\n            });\n\n            this.countData = {\n              footfallCount: totalCount,\n              nonTags: revopsTypeCount[\"non-tagging\"],\n              duplicate: revopsTypeCount[\"duplicate\"],\n              employee: revopsTypeCount[\"employee\"],\n              housekeeping: revopsTypeCount[\"house-keeping\"],\n              junk: revopsTypeCount[\"junk\"]\n            };\n\n            // Apply type filter after loading timeRange data\n            this.applyFilters();\n            \n            this.cd.detectChanges();\n            this.loading = false;\n            // this.noData = false;\n          } else {\n            // In case of failure\n            this.getRvpsList = [];\n            this.getRvpsImageList = [];\n            this.objectsArray = [];\n            this.imagesArrayData = [];\n            this.overallArrayData = [];\n            this.countData = [];\n            this.loading = false;\n            this.noData = true;\n          }\n        },\n        error: (err) => {\n          const msg =\n            err.error.error ||\n            err.error ||\n            err?.error?.message ||\n            err.message ||\n            \"Unknown error\";\n          this.toast.getErrorToast(msg);\n          this.loading = false;\n          this.noData = true;\n          this.getRvpsList = [];\n          this.getRvpsImageList = [];\n          this.objectsArray = [];\n          this.imagesArrayData = [];\n          this.overallArrayData = [];\n          this.countData = [];\n        },\n      });\n  }\n\n  originalCheckedDuplicateIds: any;\n  editValue() {\n    const type = (this.selectedType || \"\").toLowerCase();\n    this.revopsTypeValue = false;\n\n    const selectedImage = this.selectImageArray;\n    const selectedTempld = selectedImage?.templd;\n\n    if (\n      type === \"duplicate\" &&\n      Array.isArray(selectedImage.duplicateImagePath)\n    ) {\n      // 1. Convert duplicate children into consistent objects with parent reference\n      const duplicateChildren = selectedImage.duplicateImagePath.map(\n        (child: any) => ({\n          ...child,\n          parent: selectedTempld,\n          selected: true,\n        })\n      );\n\n      // 2. Collect the templd values of duplicate children\n      const duplicateChildIds = duplicateChildren.map(\n        (child: any) => child.tempId\n      );\n\n      // 3. Filter out non-tagging images except the selected parent & its children\n      const nonTaggingImages = this.overallArrayData.filter((img: any) => {\n        const isNonTagging =\n          (img.revopsType || \"\").toLowerCase() === \"non-tagging\";\n        const isNotSelected =\n          img.templd !== selectedTempld &&\n          !duplicateChildIds.includes(img.templd);\n        return isNonTagging && isNotSelected;\n      });\n\n      // 4. Merge duplicate children + other non-tagging images\n      this.remainingImageArray = [...duplicateChildren, ...nonTaggingImages];\n\n      // 5. Mark selected: only duplicate images that were marked isChecked\n      this.remainingImageArray.forEach((img: any) => {\n        const isDuplicate =\n          (img.revopsType || \"\").toLowerCase() === \"duplicate\";\n        img.selected = isDuplicate && img.isChecked === true;\n      });\n\n      // 6. Store original checked IDs to compare later during submit\n      this.originalCheckedDuplicateIds = this.remainingImageArray\n        .filter((img: any) => img.isChecked === true)\n        .map((img: any) => img.templd);\n\n      // ✅ 7. Fill selectedDuplicateImagesList with pre-selected duplicates\n      this.selectedDuplicateImagesList = this.remainingImageArray\n        .filter(\n          (img: any) =>\n            (img.revopsType || \"\").toLowerCase() === \"duplicate\" &&\n            img.isChecked === true\n        )\n        .map((img: any) => ({\n          ...img,\n          parent: img.parent || selectedTempld,\n          isChecked: true,\n        }));\n    } else {\n      // Not duplicate type → show only selected type (excluding the current selected image)\n      this.remainingImageArray = this.overallArrayData.filter((img: any) => {\n        const imgType = (img.revopsType || \"\").toLowerCase();\n        return imgType === type && img.templd !== selectedTempld;\n      });\n    }\n  }\n\n  backToFootfall1() {\n    this.selectedRadioType = undefined;\n    this.imageFlow = false;\n    this.splitScreenEnabled = false; // Disable split-screen when going back\n    this.selectImageArray = null;\n  }\n  selectImageArray: any;\n  remainingImageArray: any;\n  revopsTypeValue = false;\n\n  editBtnShow = false;\n  selectImageForSplitView(obj: any) {\n    this.splitScreenEnabled = true; // Enable split-screen when image is clicked\n    this.selectImageArray = obj;\n    \n    // If duplicate is already selected, preserve the duplicate context\n    const isDuplicateMode = this.selectedRadioType === \"duplicate\";\n    \n    if (!isDuplicateMode) {\n      this.revopsTypeValue = false;\n      this.selectedType = \"\";\n      this.selectedRadioType = undefined;\n      this.remainingImageArray = []; // Reset remaining images initially\n      this.remainingImagesGroups = []; // Reset groups\n    }\n    \n    let filteredByType: any[] = [];\n    const selectedType = obj.revopsType?.toLowerCase();\n\n    // If we're in duplicate mode and clicking on a remaining image, keep the duplicate context\n    if (isDuplicateMode) {\n      // Keep the existing remaining images but update the selected image\n      // Don't reset the duplicate selection context\n      this.revopsTypeValue = false; // Allow editing this image\n      this.selectedType = \"\"; // Reset to allow new selection\n      // Keep selectedRadioType as 'duplicate' to maintain context\n    } else if (selectedType === \"duplicate\" && Array.isArray(obj.duplicateImagePath)) {\n      const children = obj.duplicateImagePath.map((child: any) => {\n        const matched = this.overallArrayData.find(\n          (img: any) => img.templd === child.tempId\n        );\n        return {\n          ...child,\n          ...(matched || {}),\n          parent: obj.templd,\n        };\n      });\n      filteredByType = [obj, ...children];\n      this.currentImageIndex = 0;\n      this.remainingImageArray = children;\n    } else {\n      // For non-duplicate images, don't populate remainingImageArray initially\n      // It will be populated when user selects a radio button\n      filteredByType = this.overallArrayData.filter(\n        (img: any) => img.revopsType?.toLowerCase() === selectedType\n      );\n      this.currentImageIndex = filteredByType.findIndex(\n        (img: any) => img.templd === obj.templd\n      );\n      // Only set remainingImageArray if there are other images of the same type\n      // Otherwise, leave it empty for radio button selection to populate\n      if (filteredByType.length > 1) {\n        this.remainingImageArray = filteredByType.filter(\n          (_: any, i: number) => i !== this.currentImageIndex\n        );\n      }\n    }\n\n    // Only auto-set revopsTypeValue if not in duplicate mode\n    if (!isDuplicateMode) {\n      if (\n        obj?.revopsType === \"duplicate\" ||\n        obj?.revopsType === \"employee\" ||\n        obj?.revopsType === \"house-keeping\" || obj?.revopsType ===\"junk\"\n      ) {\n        if (\n          obj?.revopsType === \"duplicate\" &&\n          obj?.duplicateImagePath?.length > 0\n        ) {\n          this.editBtnShow = true;\n        } else if (\n          obj?.revopsType === \"employee\" ||\n          obj?.revopsType === \"house-keeping\" || obj?.revopsType ===\"junk\"\n        ) {\n          this.editBtnShow = true;\n        } else {\n          this.editBtnShow = false;\n        }\n        this.revopsTypeValue = true;\n        this.selectedType = obj?.revopsType;\n        this.onRadioChange(obj?.revopsType);\n      }\n    } else {\n      // In duplicate mode, allow editing the selected image\n      this.revopsTypeValue = false;\n      this.editBtnShow = false;\n    }\n    \n    // Build remaining images groups by time range\n    this.buildRemainingImagesGroups();\n  }\n\n  imgFullView(obj: any) {\n  this.selectImageArray = obj;\n  this.imageFlow = true;\n  this.revopsTypeValue = false;\n  this.selectedType = \"\";\n  this.selectedRadioType = undefined;\n  let filteredByType: any[] = [];\n  const selectedType = obj.revopsType?.toLowerCase();\n\n  if (selectedType === \"duplicate\" && Array.isArray(obj.duplicateImagePath)) {\n    // 🔹 Case 1: Duplicate parent → show only parent + its children\n    const children = obj.duplicateImagePath.map((child: any) => {\n      const matched = this.overallArrayData.find(\n        (img: any) => img.templd === child.tempId\n      );\n      return {\n        ...child,\n        ...(matched || {}),\n        parent: obj.templd,\n      };\n    });\n\n    filteredByType = [obj, ...children];\n\n    // current index always 0 (parent first)\n    this.currentImageIndex = 0;\n\n    // remaining = children only\n    this.remainingImageArray = children;\n  } else {\n    // 🔹 Case 2: Normal → filter by same type\n    filteredByType = this.overallArrayData.filter(\n      (img: any) => img.revopsType?.toLowerCase() === selectedType\n    );\n\n    this.currentImageIndex = filteredByType.findIndex(\n      (img: any) => img.templd === obj.templd\n    );\n\n    this.remainingImageArray = filteredByType.filter(\n      (_: any, i: number) => i !== this.currentImageIndex\n    );\n  }\n\n\n  // ✅ Handle edit button / radio logic\n  if (\n    obj?.revopsType === \"duplicate\" ||\n    obj?.revopsType === \"employee\" ||\n    obj?.revopsType === \"house-keeping\" || obj?.revopsType ===\"junk\"\n  ) {\n    if (\n      obj?.revopsType === \"duplicate\" &&\n      obj?.duplicateImagePath?.length > 0\n    ) {\n      this.editBtnShow = true;\n    } else if (\n      obj?.revopsType === \"employee\" ||\n      obj?.revopsType === \"house-keeping\" || obj?.revopsType ===\"junk\"\n    ) {\n      this.editBtnShow = true;\n    } else {\n      this.editBtnShow = false;\n    }\n\n    this.revopsTypeValue = true;\n    this.selectedType = obj?.revopsType;\n    this.onRadioChange(obj?.revopsType);\n  }\n}\n\n\n  imgSwap(obj: any) {\n    if (this.selectImageArray) {\n      // Find where the new selected image is in the list\n      const index = this.remainingImageArray.findIndex(\n        (img: any) => img.templd === obj.templd\n      );\n\n      // Replace selectedImageArray back into its original position\n      if (index !== -1) {\n        this.remainingImageArray[index] = this.selectImageArray;\n      } else {\n        // fallback if not found\n        this.remainingImageArray.push(this.selectImageArray);\n      }\n    }\n\n    // Update selected image\n    this.selectImageArray = obj;\n\n    // Remove selected from remaining list\n    this.remainingImageArray = this.remainingImageArray.filter(\n      (img: any) => img.templd !== obj.templd\n    );\n\n    // Rebuild remaining images groups\n    this.buildRemainingImagesGroups();\n    \n    this.imageFlow = true;\n  }\n\n  selectedType: any = \"\"; // default selected\n  selectedRadioType: any;\n  onRadioChange(val: any) {\n  this.selectedRadioType = val;\n  this.selectedDuplicateImagesList = [];\n\n  const type = (val || \"\").toLowerCase();\n\n  if (type === \"duplicate\") {\n    if (\n      this.selectImageArray?.revopsType?.toLowerCase() === \"duplicate\" &&\n      Array.isArray(this.selectImageArray?.duplicateImagePath) &&\n      this.selectImageArray.duplicateImagePath.length > 0\n    ) {\n      // 🔹 Case 1: Already in duplicate flow → keep children set by selectImageForSplitView\n      this.remainingImageArray = this.remainingImageArray.map((child: any) => {\n        return { ...child, selected: false, isChecked: false };\n      });\n    } else {\n      // 🔹 Case 2: Radio duplicate for non-duplicate parent → show non-tagging images\n      const selectedTempld = this.selectImageArray?.templd;\n\n      this.remainingImageArray = this.overallArrayData.filter((img: any) => {\n        const imgType = (img.revopsType || \"\").toLowerCase();\n        return imgType === \"non-tagging\" && img.templd !== selectedTempld;\n      });\n\n      this.remainingImageArray.forEach((img: any) => {\n        img.selected = false;\n        img.isChecked = false;\n      });\n    }\n    // Rebuild remaining images groups after updating\n    this.buildRemainingImagesGroups();\n    console.log('remain image array ::', this.remainingImageArray)\n  } else {\n    // For non-duplicate types, clear remaining images\n    this.remainingImageArray = [];\n    this.remainingImagesGroups = [];\n  }\n}\n\n\n  type: any = \"footfall\";\n  selectPlanTrends(type: any) {\n    this.type = type;\n\n    this.applyFilters();\n  }\n\n  applyFilters() {\n    this.imageFlow = false;\n    this.splitScreenEnabled = false; // Reset split-screen when filters change\n    this.selectImageArray = null;\n\n    // Convert type to lowercase safely\n    const selectedType = this.type?.toLowerCase();\n\n    if (selectedType === \"footfall\") {\n      // Footfall shows all currentTimeRangeData (time range based)\n      this.imagesArrayData = [...this.currentTimeRangeData];\n    } else {\n      // For tagged types like 'duplicate', 'employee', 'housekeeping'\n      this.imagesArrayData = this.overallArrayData.filter(\n        (item: any) => item.revopsType?.toLowerCase() === selectedType\n      );\n    }\n    // else {\n    //   // Non-tagging means no revopsType - show all unmatched (no tag)\n    //   this.imagesArrayData = this.currentTimeRangeData.filter((item: any) =>\n    //     !item.revopsType\n    //   );\n    // }\n\n    // Set noData based on result\n    this.noData = !this.imagesArrayData?.length;\n\n    this.buildListViewGroups();\n    this.cd.detectChanges();\n  }\n  setViewMode(mode: \"grid\" | \"list\") {\n    if (this.viewMode !== mode) {\n      this.viewMode = mode;\n    }\n  }\n\n  // Convert minutes → hr + mins\n    convertMinutes(totalMinutes: number) {\n      if (!totalMinutes && totalMinutes !== 0) return { hours: 0, mins: 0 };\n      const hours = Math.floor(totalMinutes / 60);\n      const mins = totalMinutes % 60;\n      return { hours, mins };\n    }\n\n  remainingImagesGroups: Array<{ timeRange: string; data: any[] }> = [];\n\n  private buildRemainingImagesGroups() {\n    if (!this.remainingImageArray || this.remainingImageArray.length === 0) {\n      this.remainingImagesGroups = [];\n      return;\n    }\n\n    const order: string[] = [];\n    const map = new Map<string, any[]>();\n\n    this.remainingImageArray.forEach((img: any) => {\n      const key = img?.timeRange || \"NA\";\n      if (!map.has(key)) {\n        map.set(key, []);\n        order.push(key);\n      }\n      map.get(key)?.push(img);\n    });\n\n    this.remainingImagesGroups = order.map((key) => ({\n      timeRange: key,\n      data: map.get(key) || [],\n    }));\n\n    console.log('my methd =>', this.remainingImageArray)\n  }\n\n  private buildListViewGroups() {\n    if (this.type === \"footfall\") {\n      this.listViewGroups = (this.allFootfallData || [])\n        .filter((group: any) => Array.isArray(group?.data) && group.data.length)\n        .map((group: any) => ({\n          timeRange: group?.timeRange || \"NA\",\n          data: group?.data || [],\n        }));\n      return;\n    }\n\n    const order: string[] = [];\n    const map = new Map<string, any[]>();\n\n    (this.imagesArrayData || []).forEach((img: any) => {\n      const key = img?.timeRange || \"NA\";\n      if (!map.has(key)) {\n        map.set(key, []);\n        order.push(key);\n      }\n      map.get(key)?.push(img);\n    });\n\n    this.listViewGroups = order.map((key) => ({\n      timeRange: key,\n      data: map.get(key) || [],\n    }));\n  }\n  handleImageClick(evt: any, obj: any) {\n    // When duplicate is selected, clicking on images should open them in zoom modal\n    if (this.selectedRadioType === \"duplicate\" && this.splitScreenEnabled) {\n      // Open image in zoom modal when duplicate is selected\n      // Store the clicked image temporarily for modal display\n      this.openImageZoomModal(this.imageUrl, obj);\n      return;\n    }\n    \n    // For split-screen view, clicking on related images should swap to that image\n    if (this.splitScreenEnabled && this.selectedRadioType !== \"duplicate\") {\n      this.selectImageForSplitView(obj);\n    } else if (this.selectedRadioType !== \"duplicate\") {\n      this.imgSwap(obj); // existing non-duplicate click behavior\n    }\n  }\n\n  tempModalImage: any = null; // Temporary storage for modal image when duplicate is selected\n\n  openImageZoomModal(imageUrl: any, imageData: any) {\n    // Store the image data temporarily for modal display\n    this.tempModalImage = imageData;\n    this.isModalOpen = true;\n    const modalRef = this.modalService.open(this.imagePopup, {\n      centered: true,\n      size: \"lg\",\n      backdrop: \"static\",\n      keyboard: false,\n    });\n  }\n  selectedDuplicateImagesList: any = [];\n\n  toggleDuplicateSelection(img: any) {\n    if (!img || img.duplicateImagePath?.length > 0) {\n      return;\n    }\n\n    const totalImages = this.overallArrayData.length;\n    const alreadyTaggedCount = this.countData?.duplicate || 0;\n    const maxSelectable = Math.round(totalImages * 0.2);\n    const currentlySelectedCount = this.remainingImageArray.filter(\n      (item: any) => item.selected\n    ).length;\n\n    const willSelect = !img.selected;\n\n    // ⛔ Block selection if trying to go beyond 20% cap\n    if (\n      willSelect &&\n      currentlySelectedCount + alreadyTaggedCount >= maxSelectable\n    ) {\n      this.toast.getWarningToast(\n        `You can select only ${maxSelectable} images (${\n          this.getRvpsList?.data?.config?.duplicate ?? \"20%\"\n        } of total footfall)`\n      );\n      return;\n    }\n\n    // ✅ Proceed with selection toggle\n    img.selected = !img.selected;\n    img.isChecked = img.selected;\n\n    // ✅ Always rebuild the selected list\n    this.selectedDuplicateImagesList = this.remainingImageArray\n      .filter((item: any) => item.selected)\n      .map((item: any) => ({\n        ...item,\n        parent: item.parent || this.selectImageArray?.templd,\n        isChecked: true,\n      }));\n\n    // Rebuild remaining images groups after checkbox change\n    this.buildRemainingImagesGroups();\n    this.cd.detectChanges();\n  }\n\n  onImageCheckboxChange(evt: any, img: any, type: string) {\n    if (type === \"duplicate\") {\n      // Use the toggle method for duplicate selection\n      this.toggleDuplicateSelection(img);\n      // Update checkbox state to match selection\n      if (evt && evt.target) {\n        evt.target.checked = img.selected;\n      }\n    }\n  }\n\n  clearValue() {\n    this.save(\"non-tagging\");\n    // this.submitValue('non-tagging')\n  }\n  cancel() {\n    // 1. Clear selected duplicate images list\n    this.selectedDuplicateImagesList = [];\n\n    // 2. Reset all checkboxes and radio buttons in overall image list\n    this.overallArrayData = this.overallArrayData.map((img: any) => ({\n      ...img,\n      isChecked: false,\n      selected: false, // assuming 'selected' is checkbox bind\n      parent: null, // reset parent if used\n      // Add other flags here if needed\n    }));\n\n    // 3. Close image flow/full-view if open\n    this.imageFlow = false;\n\n    // 4. Reset split-screen and selected image\n    this.splitScreenEnabled = false;\n    this.selectImageArray = null;\n    this.currentImageIndex = 0;\n    this.remainingImageArray = [];\n    this.remainingImagesGroups = [];\n\n    // 5. (Optional) Reset radio buttons — if you have any specific flag\n    this.selectedRadioType = undefined;\n    this.selectedType = \"\";\n    this.revopsTypeValue = false;\n  }\n  popupType: any;\n  @ViewChild(\"zoomPopup\") zoomPopup: ElementRef;\n  save(category: any) {\n    const modalRef = this.modalService.open(this.zoomPopup, {\n      centered: true,\n      size: \"md\",\n      backdrop: \"static\", // Prevent closing on outside click\n      keyboard: false, // Prevent closing on ESC key\n    });\n    this.popupType = category;\n  }\n\n  cancelSubmit() {\n    this.modalService.dismissAll();\n\n    this.selectedDuplicateImagesList = [];\n  }\n  submitValue(category: any) {\n    let duplicateImages = [];\n\n    if (category === \"duplicate\") {\n      duplicateImages = this.remainingImageArray\n        .filter((img: any) => img.selected === true)\n        .map((img: any) => ({\n          tempId: img.templd || img.tempId || \"\",\n          timeRange: img.timeRange || \"\",\n          entryTime: img.entryTime || img.entryTme || \"\",\n          exitTime: img.exitTime || \"\",\n          filePath: img.filePath,\n          revopsType: \"duplicate\",\n          isChecked: true,\n        }));\n    }\n\n    const img = this.selectImageArray;\n\n    const obj = {\n      storeId:\n        this.storeIdarray && this.storeIdarray.length > 0\n          ? this.storeIdarray[0]\n          : null,\n      dateString: this.folderDate || \"\",\n      tempId: img?.templd || 0,\n      revopsType: category,\n      timeRange: img?.timeRange || \"\",\n      isChecked: true,\n      duplicateImage: duplicateImages,\n      processType: img?.processType || \"footfall\",\n      entryTime: img?.entryTime || img?.entryTme || \"\",\n      exitTime: img?.exitTime || \"\",\n      filePath: img?.filePath || \"\",\n      comments: this.userComment || \"\",\n      mode: 'web'\n    };\n\n    this.rvpsService\n      .getRvpsTag(obj)\n      .pipe(takeUntil(this.destroy$))\n      .subscribe({\n        next: (res: any) => {\n          if (res && res.code === 200) {\n            this.toast.getSuccessToast(\n              res?.message || \"Ticket updated successfully\"\n            );\n            this.imageFlow = false;\n            this.getRevops();\n            this.cancelSubmit();\n            this.loadCardData();\n            this.selectedRadioType = undefined;\n            this.selectedType = \"\";\n          } else {\n            this.toast.getErrorToast(\"Failed to update\");\n          }\n        },\n        error: (err: any) => {\n          const msg =\n            err.error?.error || err.error || err?.message || \"Unknown error\";\n          this.toast.getErrorToast(msg);\n        },\n      });\n  }\n\n  noDataMessages: { [key: string]: string } = {\n    duplicate: \"No duplicates found\",\n    employee: \"No employee/staff found\",\n    \"house-keeping\": \"No house keeping found\",\n    \"non-tagging\": \"No non-tagging found\",\n    junk: \"No junk found\"\n  };\n\n  tempRaisedPayload: any = null; // class-level variable for preview\n\n  prepareRaisedPayload(showOnly = false): any {}\n\n  @ViewChild(\"raisedPopup\") raisedPopup: ElementRef;\n  @ViewChild(\"resetRequestPopup\") resetRequestPopup: ElementRef;\n  Raised() {\n    const payload: any = {\n      dateString: this.folderDate,\n      storeId: this.storeIdarray?.length > 0 ? this.storeIdarray[0] : null,\n      ticketName: \"footfall-directory\",\n      footfallCount: 0,\n      duplicateCount: 0,\n      employeeCount: 0,\n      houseKeepingCount: 0,\n      junkCount:0,\n      comments: this.commentText || \"\",\n      duplicateImages: [],\n      houseKeeping: [],\n      employee: [],\n      junk: [],\n    };\n\n    let totalCheckedCount = 0;\n\n    this.overallArrayData.forEach((item: any) => {\n      const type = item.revopsType?.toLowerCase()?.trim();\n      const isChecked = item.isChecked === true;\n\n      // ✅ Count only if item is checked AND revopsType is 'non-tagging'\n      // const isNotTagged = type === 'non-tagging';\n\n      // if (isNotTagged) {\n      //   totalCheckedCount++;\n      // }\n\n      // DUPLICATE TYPE\n      if (type === \"duplicate\" && Array.isArray(item.duplicateImagePath)) {\n        const nestedData = item.duplicateImagePath\n          .filter((dup: any) => dup.isChecked)\n          .map((dup: any) => ({\n            tempId: dup.tempId || dup.templd || \"\",\n            filePath: dup.filePath,\n            entryTime: dup?.entryTime || dup?.entryTme || \"\",\n            exitTime: dup.exitTime,\n            timeRange: dup.timeRange,\n            isChecked: dup.isChecked,\n          }));\n\n        if (nestedData.length > 0) {\n          payload.duplicateImages.push({\n            tempId: item.templd,\n            filePath: item.filePath,\n            entryTime: item?.entryTime || item?.entryTme || \"\",\n            exitTime: item.exitTime,\n            timeRange: item.timeRange,\n            isChecked: item.isChecked,\n            data: nestedData,\n          });\n\n          payload.duplicateCount += nestedData.length;\n        }\n      }\n\n      // EMPLOYEE\n      else if (type === \"employee\" && isChecked) {\n        payload.employee.push({\n          tempId: item.templd,\n          filePath: item.filePath,\n          entryTime: item?.entryTime || item?.entryTme || \"\",\n          exitTime: item.exitTime,\n          timeRange: item.timeRange,\n          isChecked: item.isChecked,\n        });\n\n        payload.employeeCount++;\n      }\n\n      // HOUSEKEEPING\n      else if (type === \"house-keeping\" && isChecked) {\n        payload.houseKeeping.push({\n          tempId: item.templd,\n          filePath: item.filePath,\n          entryTime: item?.entryTime || item?.entryTme || \"\",\n          exitTime: item.exitTime,\n          timeRange: item.timeRange,\n          isChecked: item.isChecked,\n        });\n\n        payload.houseKeepingCount++;\n      } \n      else if (type === \"junk\" && isChecked) {\n        payload.junk.push({\n          tempId: item.templd,\n          filePath: item.filePath,\n          entryTime : item?.entryTime || item?.entryTme || \"\",\n          exitTime : item.exitTime,\n          timeRange : item.timeRange,\n          isChecked : item.isChecked,\n        });\n\n        payload.junkCount++;\n      }\n    });\n\n    payload.footfallCount = this.countData?.footfallCount;\n\n    // 👇 Return or assign\n\n    this.tempRaisedPayload = payload;\n    this.cd.detectChanges();\n    const modalRef = this.modalService.open(this.raisedPopup, {\n      centered: true,\n      size: \"md\",\n      backdrop: \"static\",\n      keyboard: false,\n    });\n  }\n\n  cancelRasied() {\n    this.modalService.dismissAll();\n    this.selectedDuplicateImagesList = [];\n  }\n\n  commentText: any;\n  getRaisedData: any;\n  submitRaised() {\n    // const payload = this.tempRaisedPayload; // fresh data for API\n    const payload = {\n      ticketName: \"footfall-directory\",\n      storeId: this.tempRaisedPayload.storeId,\n      dateString: this.tempRaisedPayload.dateString,\n      type: \"create\",\n      mode: \"web\"\n    }\n    this.getRaisedData = payload;\n    console.log('submit raised :', payload)\n    this.rvpsService\n      .getCreateRaisedTag(payload)\n      .pipe(takeUntil(this.destroy$))\n      .subscribe({\n        next: (res: any) => {\n          if (res && res.code === 200) {\n            this.toast.getSuccessToast(\n              res?.message || \"Ticket updated successfully\"\n            );\n            this.imageFlow = false;\n            this.getRevops();\n            this.loadCardData();\n            this.cancelRasied();\n            this.selectedRadioType = undefined;\n            this.selectedType = \"\";\n            this.countData = [];\n          } else {\n            this.toast.getErrorToast(\"Failed to update\");\n            this.cancelRasied();\n          }\n        },\n        error: (err: any) => {\n          const msg =\n            err.error?.error ||\n            err.error ||\n            err?.error?.message ||\n            err.message ||\n            \"Unknown error\";\n          this.toast.getErrorToast(msg);\n          this.cancelRasied();\n        },\n      });\n  }\n\n  // onImageCheckboxChange(img: any, type: string) {\n  //   if (type === 'duplicate') {\n  //     // Count only valid duplicate images where `duplicateImagePath.length === 0`\n  //     const totalValidDuplicateImages = this.overallArrayData.filter(\n  //       (item: any) =>\n  //         item.revopsType === 'duplicate' && (!item.duplicateImagePath || item.duplicateImagePath.length === 0)\n  //     ).length;\n\n  //     const maxAllowed = Math.floor(totalValidDuplicateImages * 0.1); // 10% limit\n\n  //     const alreadyExists = this.selectedDuplicateImagesList.some(\n  //       (item: any) => item.templd === img.templd\n  //     );\n\n  //     if (img.selected) {\n  //       // ❌ Reached max allowed — block it\n  //       if (this.selectedDuplicateImagesList.length >= maxAllowed) {\n  //         this.toast.getErrorToast(\n  //           `Only ${maxAllowed} images can be selected as duplicate (10% of untagged duplicates).`\n  //         );\n\n  //         img.selected = false;\n  //         const index = this.overallArrayData.findIndex((item: any) => item.templd === img.templd);\n  //         if (index !== -1) {\n  //           this.overallArrayData[index].selected = false;\n  //         }\n\n  //         setTimeout(() => {\n  //           img.selected = false;\n  //         });\n\n  //         return;\n  //       }\n\n  //       // ✅ Add if not already in list\n  //       if (!alreadyExists) {\n  //         this.selectedDuplicateImagesList.push({\n  //           ...img,\n  //           isChecked: true,\n  //           parent: img.parent || null\n  //         });\n  //       }\n  //     } else {\n  //       // ❌ Removal case\n  //       this.selectedDuplicateImagesList = this.selectedDuplicateImagesList.filter(\n  //         (item: any) => item.templd !== img.templd\n  //       );\n  //     }\n  //   }\n\n  //   // ⚠️ Call this to update button enable state\n  //   this.checkDuplicateSaveEnable();\n  // }\n\n  // duplicateSaveEnabled = false;\n\n  // checkDuplicateSaveEnable() {\n  //   this.duplicateSaveEnabled =\n  //     this.selectedRadioType === 'duplicate' && this.selectedDuplicateImagesList.length > 0;\n  // }\n\n  isModalOpen = false;\n  @ViewChild(\"imagePopup\") imagePopup: ElementRef;\n  selectedImageArray(url: any, data: any) {\n    this.isModalOpen = true;\n    const modalRef = this.modalService.open(this.imagePopup, {\n      centered: true,\n      size: \"lg\",\n      backdrop: \"static\",\n      keyboard: false,\n    });\n  }\n\n  closeImage() {\n    this.isModalOpen = false;\n    this.tempModalImage = null; // Clear temporary image when closing modal\n    this.modalService.dismissAll();\n  }\n\n  canEnableButton(): boolean {\n    if (!this.countData || !this.folderDate) {\n      return false;\n    }\n    const { duplicate, housekeeping, employee, junk } = this.countData;\n\n    // Check count condition\n    const hasCount = duplicate > 0 || housekeeping > 0 || employee > 0 || junk > 0;\n\n    // Convert folderDate to Date\n    const folder = new Date(this.folderDate);\n    const today = new Date();\n\n    // Normalize times (remove hours for proper day comparison)\n    folder.setHours(0, 0, 0, 0);\n    today.setHours(0, 0, 0, 0);\n\n    // Calculate difference in days\n    const diffInTime = today.getTime() - folder.getTime();\n    const diffInDays = diffInTime / (1000 * 3600 * 24);\n\n    // Within last 7 days → diff between 0 and 7\n    const isWithinLast7 = diffInDays >= 0 && diffInDays <= 7;\n\n    return hasCount && isWithinLast7;\n  }\n\n  currentImageIndex: number = 0;\n  get canNavigateLeft(): boolean {\n    return this.currentImageIndex > 0;\n  }\n\n  get canNavigateRight(): boolean {\n    return this.currentImageIndex < this.imagesArrayData.length - 1;\n  }\n\n  navigateImage(direction: \"left\" | \"right\") {\n    const length = this.imagesArrayData.length;\n\n    if (direction === \"left\" && this.canNavigateLeft) {\n      this.currentImageIndex--;\n    } else if (direction === \"right\" && this.canNavigateRight) {\n      this.currentImageIndex++;\n    }\n\n    // Update selected image\n    this.selectImageArray = this.imagesArrayData[this.currentImageIndex];\n\n    // Update remaining images\n    this.remainingImageArray = this.imagesArrayData.filter(\n      (_: any, i: any) => i !== this.currentImageIndex\n    );\n  }\n\n  // Get current footfall count for selected date\n  getCurrentFootfall(): number {\n    if (!this.folderDate) return 0;\n    const normalizedDate = new Date(this.folderDate).toISOString().split(\"T\")[0];\n    return this.cardDataMap[normalizedDate]?.footfallCount || 0;\n  }\n\n  // Get percentage change from footfallCountTrend\n  getFootfallPercentageChange(): number {\n    if (!this.folderDate) return 0;\n    const normalizedDate = new Date(this.folderDate).toISOString().split(\"T\")[0];\n    return this.cardDataMap[normalizedDate]?.footfallCountTrend || 0;\n  }\n\n  // Format downtime from downtime key (in minutes)\n  getFormattedDowntime(): string {\n    if (!this.folderDate) return '-';\n    const normalizedDate = new Date(this.folderDate).toISOString().split(\"T\")[0];\n    const downtimeMinutes = this.cardDataMap[normalizedDate]?.downtime || 0;\n    \n    if (!downtimeMinutes || downtimeMinutes === 0) return '-';\n    \n    const { hours, mins } = this.convertMinutes(downtimeMinutes);\n    if (hours > 0 && mins > 0) {\n      return `${hours}hr ${mins} mins`;\n    } else if (hours > 0) {\n      return `${hours}hr`;\n    } else if (mins > 0) {\n      return `${mins} mins`;\n    }\n    return '-';\n  }\n\n  // Get ticket status\n  getTicketStatus(): string {\n    if (!this.folderDate) return '-';\n    const normalizedDate = new Date(this.folderDate).toISOString().split(\"T\")[0];\n    const status = this.cardDataMap[normalizedDate]?.ticketStatus;\n    return status || '-';\n  }\n\n  // Check if there's downtime\n  hasDowntime(): boolean {\n    if (!this.folderDate) return false;\n    const normalizedDate = new Date(this.folderDate).toISOString().split(\"T\")[0];\n    const downtime = this.cardDataMap[normalizedDate]?.downtime || 0;\n    return downtime > 0;\n  }\n\n  // Get tagging data from ticketReviewStatus where actionType = \"tagging\"\n  getTaggingData(type: string): any {\n    if (!this.ticketReviewStatus || !Array.isArray(this.ticketReviewStatus) || !type) {\n      return null;\n    }\n    return this.ticketReviewStatus.find((item: any) => item?.actionType === type) || null;\n  }\n\n  // Check if ticket status is raised\n  isTicketRaised(): boolean {\n    const status = this.getTicketStatus();\n    return status !== '-' && status?.toLowerCase() === \"raised\";\n  }\n\n  // Check if ticket status is closed\n  isTicketClosed(): boolean {\n    const status = this.getTicketStatus();\n    return status !== '-' && status?.toLowerCase() === \"closed\";\n  }\n\n  // Get all tagging data items (for initial and final revisions)\n  getAllTaggingData(): any[] {\n    if (!this.ticketReviewStatus || !Array.isArray(this.ticketReviewStatus)) {\n      return [];\n    }\n    return this.ticketReviewStatus.filter((item: any) => item?.actionType === \"tagging\") || [];\n  }\n\n  // Get initial revision data (first tagging item)\n  getInitialRevisionData(): any {\n    const allTagging = this.getAllTaggingData();\n    return allTagging.length > 0 ? allTagging[0] : null;\n  }\n\n  // Get final revision data (last tagging item, or second if exists)\n  getFinalRevisionData(): any {\n    const allTagging = this.getAllTaggingData();\n    return allTagging.length > 1 ? allTagging[allTagging.length - 1] : (allTagging.length > 0 ? allTagging[0] : null);\n  }\n\n  // Helper method to get count value by type from count array\n  getCountByType(data: any, countType: string): number {\n    if (!data || !data.count) {\n      return 0;\n    }\n    \n    // Check if count is an array (new format)\n    if (Array.isArray(data.count)) {\n      const countItem = data.count.find((item: any) => item?.type === countType);\n      return countItem?.value || 0;\n    }\n    \n    // Fallback for old format (object)\n    const keyMap: { [key: string]: string } = {\n      'duplicate': 'duplicateCount',\n      'employee': 'employeeCount',\n      'junk': 'junkCount',\n      'houseKeeping': 'houseKeepingCount'\n    };\n    \n    const key = keyMap[countType];\n    return key ? (data.count[key] || 0) : 0;\n  }\n\n  // Calculate total percentage: (sum of all count values / revicedFootfall) * 100\n  // type: 'raised' | 'finalreview'\n  getRevisionCalculation(type: string): number {\n    if (!this.ticketReviewStatus || !Array.isArray(this.ticketReviewStatus || !type )) {\n      return 0;\n    }\n\n    // Filter items based on actionType\n    const taggingItems = this.ticketReviewStatus.filter((item: any) => item?.actionType === type);\n    if (taggingItems.length === 0) {\n      return 0;\n    }\n\n    if (!taggingItems[0] || !taggingItems[0].revicedFootfall || taggingItems[0].revicedFootfall === 0) {\n      return 0;\n    }\n    \n    const count = taggingItems[0].count || [];\n    // Check if count is an array (new format) or object (old format)\n    let totalCount = 0;\n    \n    if (Array.isArray(count)) {\n      // New format: count is an array of objects with type and value\n      const typesToSum = ['duplicate', 'employee', 'houseKeeping', 'junk'];\n      totalCount = count\n        .filter((item: any) => typesToSum.includes(item?.type))\n        .reduce((sum: number, item: any) => sum + (item?.value || 0), 0);\n    } \n    // else {\n    //   // Old format: count is an object with keys\n    //   totalCount = (count.duplicateCount || 0) + \n    //                (count.employeeCount || 0) + \n    //                (count.junkCount || 0) + \n    //                (count.houseKeepingCount || 0);\n    // }\n    return Math.round((totalCount / taggingItems[0].revicedFootfall) * 100);\n  }\n\n  requestReset(): void {\n    const modalRef = this.modalService.open(this.resetRequestPopup, {\n      centered: true,\n      size: \"md\",\n      backdrop: \"static\",\n      keyboard: false,\n    });\n  }\n\n  cancelResetRequest(): void {\n    this.modalService.dismissAll();\n  }\n\n  submitResetRequest(): void {\n    let payload = {\n      storeId: this.storeIdarray && this.storeIdarray.length > 0 ? this.storeIdarray[0] : null,\n      dateString: this.folderDate || \"\"\n    };\n    console.log('submitResetRequest Payload:', payload);\n    // Close modal after submission\n    this.modalService.dismissAll();\n    this.service\n      .sendVMSResetRequest(payload)\n      .pipe(takeUntil(this.destroy$))\n      ?.subscribe({\n        next: (res: any) => {\n          if (res && res.code === 200) {\n            this.loadCardData();\n            this.toast.getSuccessToast(\"Request reset successfully\");\n          } else {\n            this.toast.getErrorToast(\"Failed to reset request\");\n          }\n        },\n        error: (err) => {\n          const msg =\n            err.error?.error ||\n            err.error ||\n            err?.error?.message ||\n            err.message ||\n            \"Unknown error\";\n          console.error('Error in submitResetRequest :', err);\n          this.toast.getErrorToast(msg || \"Unknown error occurred\");\n        },\n      });\n    \n  }\n\n  // Get normalized date for current folderDate\n  getNormalizedDate(): string | null {\n    if (!this.folderDate) return null;\n    return new Date(this.folderDate).toISOString().split(\"T\")[0];\n  }\n\n  // Get selected date's card data\n  getSelectedDateCardData(): any {\n    const normalizedDate = this.getNormalizedDate();\n    return normalizedDate ? this.cardDataMap[normalizedDate] : null;\n  }\n}","<div class=\"card mt-3\">\n    <div class=\"card-header mt-3 px-0 border-bottom-0\">\n        <div class=\"custom-accordion\">\n            <div class=\"custom-accordion-item\">\n                <!-- for new navigation changes -->\n                <!-- old view while folder view -->\n                <button *ngIf=\"folderView\" class=\"mainheading pb-0 custom-accordion-header\" (click)=\"toggleAccordion()\">\n                    <div class=\"header-row\">\n                        <span class=\"img-direc\">Image Directory</span>\n\n                        <span class=\"divider\"></span>\n                        <span class=\"accordion-arrow\">\n                            <!-- Down arrow for collapsed state, up arrow for expanded state -->\n                            <svg *ngIf=\"!isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\n                                viewBox=\"0 0 16 6\" fill=\"none\">\n                                <path d=\"M1 1L5 5L9 1\" stroke=\"#071437\" stroke-width=\"1\" stroke-linecap=\"round\"\n                                    stroke-linejoin=\"round\" />\n                            </svg>\n                            <svg *ngIf=\"isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\n                                viewBox=\"0 0 16 6\" fill=\"none\">\n                                <path d=\"M1 5L5 1L9 5\" stroke=\"#1b84ff\" stroke-width=\"1\" stroke-linecap=\"round\"\n                                    stroke-linejoin=\"round\" />\n                            </svg>\n                        </span>\n                    </div>\n                </button>\n                <!-- new view while not in folder view view -->\n                <div *ngIf=\"!folderView\" class=\"header-row\">\n                    <span *ngIf=\"backnav && !imageFlow\" class=\"cursor-pointer\" (click)=\"backToFootfall()\">\n                        <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                            <g filter=\"url(#filter0_d_2585_7036)\">\n                                <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\n                                <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\n                                <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\n                                    stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\n                                    stroke-linejoin=\"round\" />\n                            </g>\n                            <defs>\n                                <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\n                                    filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                    <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\n                                    <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\n                                        values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\n                                    <feOffset dy=\"1\" />\n                                    <feGaussianBlur stdDeviation=\"1\" />\n                                    <feColorMatrix type=\"matrix\"\n                                        values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\n                                    <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\n                                        result=\"effect1_dropShadow_2585_7036\" />\n                                    <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\n                                        result=\"shape\" />\n                                </filter>\n                            </defs>\n                        </svg>\n                    </span>\n                    <!-- back from image flow -->\n                    <span *ngIf=\"imageFlow\" class=\"cursor-pointer\" (click)=\"backToFootfall1()\">\n                        <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                            <g filter=\"url(#filter0_d_2585_7036)\">\n                                <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\n                                <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\n                                <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\n                                    stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\n                                    stroke-linejoin=\"round\" />\n                            </g>\n                            <defs>\n                                <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\n                                    filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                    <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\n                                    <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\n                                        values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\n                                    <feOffset dy=\"1\" />\n                                    <feGaussianBlur stdDeviation=\"1\" />\n                                    <feColorMatrix type=\"matrix\"\n                                        values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\n                                    <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\n                                        result=\"effect1_dropShadow_2585_7036\" />\n                                    <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\n                                        result=\"shape\" />\n                                </filter>\n                            </defs>\n                        </svg>\n                    </span>\n                    <span class=\"img-direc\">Image Directory | {{folderDate | date:'dd MMM, yyyy'}}</span>\n                    <button *ngIf=\"!folderView\" class=\"mainheading-1 pb-0 custom-accordion-header\"\n                        (click)=\"toggleAccordion()\">\n                        <span class=\"divider\"></span>\n                        <span class=\"accordion-arrow\">\n                            <!-- Down arrow for collapsed state, up arrow for expanded state -->\n                            <svg *ngIf=\"!isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\n                                viewBox=\"0 0 16 6\" fill=\"none\">\n                                <path d=\"M1 1L5 5L9 1\" stroke=\"#071437\" stroke-width=\"1\" stroke-linecap=\"round\"\n                                    stroke-linejoin=\"round\" />\n                            </svg>\n                            <svg *ngIf=\"isAccordionExpanded\" xmlns=\"http://www.w3.org/2000/svg\" width=\"26\" height=\"6\"\n                                viewBox=\"0 0 16 6\" fill=\"none\">\n                                <path d=\"M1 5L5 1L9 5\" stroke=\"#1b84ff\" stroke-width=\"1\" stroke-linecap=\"round\"\n                                    stroke-linejoin=\"round\" />\n                            </svg>\n                        </span>\n                    </button>\n                </div>\n            </div>\n        </div>\n    </div>\n\n    <section *ngIf=\"isAccordionExpanded\">\n\n        <div *ngIf=\"folderView\" class=\"card-body px-0\">\n            <div class=\"date-list-container\">\n                <div class=\"date-list-scroll\">\n                    <div class=\"date-card\" *ngFor=\"let obj of dateArray; let i = index\"\n                        [ngClass]=\"{'date-card-active': i === selectIndex}\" (click)=\"getimages(i, obj)\">\n                        <div class=\"date-card-header\">\n                            <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\"\n                                xmlns=\"http://www.w3.org/2000/svg\" class=\"calendar-icon\">\n                                <path\n                                    d=\"M12.6667 2.66667H12V2C12 1.63181 11.7015 1.33333 11.3333 1.33333C10.9651 1.33333 10.6667 1.63181 10.6667 2V2.66667H5.33333V2C5.33333 1.63181 5.03486 1.33333 4.66667 1.33333C4.29848 1.33333 4 1.63181 4 2V2.66667H3.33333C2.59695 2.66667 2 3.26362 2 4V13.3333C2 14.0697 2.59695 14.6667 3.33333 14.6667H12.6667C13.403 14.6667 14 14.0697 14 13.3333V4C14 3.26362 13.403 2.66667 12.6667 2.66667ZM12.6667 13.3333H3.33333V6H12.6667V13.3333Z\"\n                                    fill=\"#667085\" />\n                            </svg>\n                            <span class=\"date-text\">{{obj | date:'dd MMM'}}</span>\n                            <span *ngIf=\"cardDataMap[obj]?.ticketStatusLower as status\" class=\"badge ms-2\" [ngClass]=\"{\n                                    'badge-light-success': status === 'closed',\n                                    'badge-light-warning': status === 'raised',\n                                    'badge-light-default': status !== 'closed' && status !== 'raised'\n                                  }\">\n                                {{ status === 'closed' ? 'Ticket closed' : (status === 'raised' ? 'Ticket raised' :\n                                (cardDataMap[obj]?.ticketStatus || '')) }}\n                            </span>\n                        </div>\n                        <div class=\"footfall-count\">{{ cardDataMap[obj]?.footfallCount || 0 }}</div>\n                        <div class=\"footfall-label\">Total footfall</div>\n                    </div>\n                </div>\n            </div>\n        </div>\n\n\n\n        <div *ngIf=\"!folderView\" class=\"card-body\">\n            <section *ngIf=\"!imageFlow\">\n                <div class=\"row\">\n                    <!-- Ticket Block Alert -->\n                    <div *ngIf=\"getSelectedDateCardData()?.raisedStatusEnabled === 'block'\" class=\"col-12 mb-3\">\n                        <div class=\"ticket-block-alert\">\n                            <div class=\"ticket-block-alert-content\">\n                                <div class=\"ticket-block-alert-icon\">\n                                    <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\n                                        xmlns=\"http://www.w3.org/2000/svg\">\n                                        <circle cx=\"12\" cy=\"12\" r=\"12\" fill=\"#F04438\" />\n                                        <path d=\"M12 8V13\" stroke=\"white\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                            stroke-linejoin=\"round\" />\n                                        <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n                                    </svg>\n                                </div>\n                                <div class=\"ticket-block-alert-text\">\n                                    <div class=\"ticket-block-alert-title\">\n                                        You cannot raise ticket for next {{ getSelectedDateCardData()?.noOfBlockedDays\n                                        || '0' }} days\n                                    </div>\n                                    <div class=\"ticket-block-alert-description\">\n                                        It looks like you have achieved 95% accuracy for the three tickets raised this\n                                        month. This limits you from raising more tickets to avoid redundancy.\n                                    </div>\n                                    <div class=\"ticket-block-alert-action\">\n                                        If you still want to raise tickets, <span class=\"ticket-block-alert-link\"\n                                            (click)=\"requestReset()\">send request</span> to reset.\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                    <!-- Ticket Request Success Alert -->\n                    <div *ngIf=\"getSelectedDateCardData()?.raisedStatusEnabled === 'request'\" class=\"col-12 mb-3\">\n                        <div class=\"ticket-request-alert\">\n                            <div class=\"ticket-request-alert-content\">\n                                <div class=\"ticket-request-alert-icon\">\n                                    <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\n                                        xmlns=\"http://www.w3.org/2000/svg\">\n                                        <path d=\"M2 21L23 12L2 3V10L17 12L2 14V21Z\" fill=\"#10B981\" />\n                                    </svg>\n                                </div>\n                                <div class=\"ticket-request-alert-text\">\n                                    <div class=\"ticket-request-alert-title\">\n                                        Reset Request Sent\n                                    </div>\n                                    <div class=\"ticket-request-alert-description\">\n                                        Your request to enable ticket raising has been submitted. You'll be notified\n                                        once it's approved. Please ensure future ticket accuracy remains within the 95%\n                                        threshold.\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                    <!-- footfall trends feature -->\n                    <ng-container *ngTemplateOutlet=\"footfallTrendsTemplate\"></ng-container>\n                    <ng-container *ngTemplateOutlet=\"ticketStatusTemplate\"></ng-container>\n                    <span class=\"divider\"></span>\n                    <!-- footfall trends feature end -->\n                    <div class=\"d-flex flex-shrink-0 mt-3 justify-content-start align-items-center px-0\">\n                        <!-- <span *ngIf=\"backnav\" class=\"cursor-pointer\" (click)=\"backToFootfall()\">\n                            <svg width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\"\n                                xmlns=\"http://www.w3.org/2000/svg\">\n                                <g filter=\"url(#filter0_d_2585_7036)\">\n                                    <rect x=\"2\" y=\"1\" width=\"36\" height=\"36\" rx=\"8\" fill=\"white\" />\n                                    <rect x=\"2.5\" y=\"1.5\" width=\"35\" height=\"35\" rx=\"7.5\" stroke=\"#D0D5DD\" />\n                                    <path d=\"M25.8327 19H14.166M14.166 19L19.9993 24.8334M14.166 19L19.9993 13.1667\"\n                                        stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\"\n                                        stroke-linejoin=\"round\" />\n                                </g>\n                                <defs>\n                                    <filter id=\"filter0_d_2585_7036\" x=\"0\" y=\"0\" width=\"40\" height=\"40\"\n                                        filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                        <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\n                                        <feColorMatrix in=\"SourceAlpha\" type=\"matrix\"\n                                            values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\" />\n                                        <feOffset dy=\"1\" />\n                                        <feGaussianBlur stdDeviation=\"1\" />\n                                        <feColorMatrix type=\"matrix\"\n                                            values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\n                                        <feBlend mode=\"normal\" in2=\"BackgroundImageFix\"\n                                            result=\"effect1_dropShadow_2585_7036\" />\n                                        <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2585_7036\"\n                                            result=\"shape\" />\n                                    </filter>\n                                </defs>\n                            </svg>\n                        </span> -->\n                        <!-- <span class=\"img-direc ms-2 mt-1\">{{folderDate | date:'dd MMM, yyyy'}}\n                            <span class=\"badge badge-light-warning mx-2\"\n                                *ngIf=\"!getTicketStatuses().includes('closed') && getTicketStatuses().includes('open')\">\n                                Ticket Raised\n                            </span>\n                            <span class=\"badge badge-light-success mx-2\"\n                                *ngIf=\"getTicketStatuses().includes('closed')\">Ticket Closed</span>\n\n                        </span> -->\n                        <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\"\n                            class=\"ms-auto text-end\">\n                            <button [disabled]=\"!canEnableButton()\" class=\"btn btn-primary\" type=\"button\"\n                                (click)=\"Raised()\">\n                                Raise ticket\n                            </button>\n                        </div>\n                    </div>\n                    <div *ngIf=\"!folderView\" class=\"d-flex flex-wrap align-items-center justify-content-between w-100 my-2 gap-3\">\n                        <div class=\"nav-group bg-white border-1 btn-group w-auto\">\n                            <ng-container *ngIf=\"!(countData?.length > 0)\">\n                    \n                                <button class=\"btn btn-outline px-6 py-3\"\n                                    [ngClass]=\"type === 'footfall' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n                                    (click)=\"selectPlanTrends('footfall')\">\n                                    Total Footfall\n                                    <span\n                                        [ngClass]=\"type === 'footfall' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n                                        {{ countData?.footfallCount || 0 }}\n                                    </span>\n                                </button>\n                    \n                                <button class=\"btn btn-outline px-6 py-3\"\n                                    [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n                                    (click)=\"selectPlanTrends('non-tagging')\">\n                                    Non-tags\n                                    <span\n                                        [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n                                        {{ countData?.nonTags || 0 }}\n                                    </span>\n                                </button>\n                    \n                                <button class=\"btn btn-outline px-6 py-3\"\n                                    [ngClass]=\"type === 'duplicate' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n                                    (click)=\"selectPlanTrends('duplicate')\">\n                                    Duplicated\n                                    <span\n                                        [ngClass]=\"type === 'duplicate' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n                                        {{ countData?.duplicate || 0 }}\n                                    </span>\n                                </button>\n                    \n                                <button class=\"btn btn-outline px-6 py-3\"\n                                    [ngClass]=\"type === 'employee' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n                                    (click)=\"selectPlanTrends('employee')\">\n                                    Employee/Staff\n                                    <span\n                                        [ngClass]=\"type === 'employee' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n                                        {{ countData?.employee || 0 }}\n                                    </span>\n                                </button>\n                                <button class=\"btn btn-outline px-6 py-3\" [ngClass]=\"type === 'junk' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n                                    (click)=\"selectPlanTrends('junk')\">\n                                    Junk\n                                    <span\n                                        [ngClass]=\"type === 'junk' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\n                                        {{ countData?.junk || 0 }}\n                                    </span>\n                                </button>\n                                <button class=\"btn btn-outline px-6 py-3\"\n                                    [ngClass]=\"type === 'house-keeping' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n                                    (click)=\"selectPlanTrends('house-keeping')\">\n                                    House Keeping\n                                    <span\n                                        [ngClass]=\"type === 'house-keeping' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\n                                        {{ countData?.housekeeping || 0 }}\n                                    </span>\n                                </button>\n                    \n                    \n                            </ng-container>\n                    \n                        </div>\n                    \n                        <div class=\"btn-group view-toggle ms-auto\" role=\"group\" aria-label=\"Toggle view\">\n                            <button type=\"button\" class=\"btn btn-outline px-3 py-2\" [ngClass]=\"{'active': viewMode === 'grid'}\"\n                                (click)=\"setViewMode('grid')\" aria-label=\"Grid view\">\n                                <svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                                    <rect x=\"3\" y=\"3\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n                                        [attr.fill]=\"viewMode === 'grid' ? '#EAF8FF' : 'none'\"></rect>\n                                    <rect x=\"11\" y=\"3\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n                                        [attr.fill]=\"viewMode === 'grid' ? '#EAF8FF' : 'none'\"></rect>\n                                    <rect x=\"3\" y=\"11\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n                                        [attr.fill]=\"viewMode === 'grid' ? '#EAF8FF' : 'none'\"></rect>\n                                    <rect x=\"11\" y=\"11\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n                                        [attr.fill]=\"viewMode === 'grid' ? '#EAF8FF' : 'none'\"></rect>\n                                </svg>\n                            </button>\n                            <button type=\"button\" class=\"btn btn-outline px-3 py-2\" [ngClass]=\"{'active': viewMode === 'list'}\"\n                                (click)=\"setViewMode('list')\" aria-label=\"List view\">\n                                <svg width=\"20\" height=\"18\" viewBox=\"0 0 20 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                                    <rect x=\"2\" y=\"3\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n                                        [attr.fill]=\"viewMode === 'list' ? '#EAF8FF' : 'none'\"></rect>\n                                    <rect x=\"8\" y=\"4.5\" width=\"10\" height=\"1.5\" rx=\"0.75\" fill=\"#475467\"></rect>\n                                    <rect x=\"8\" y=\"12.5\" width=\"10\" height=\"1.5\" rx=\"0.75\" fill=\"#475467\"></rect>\n                                    <rect x=\"2\" y=\"11\" width=\"4\" height=\"4\" rx=\"1\" stroke=\"#475467\"\n                                        [attr.fill]=\"viewMode === 'list' ? '#EAF8FF' : 'none'\"></rect>\n                                </svg>\n                            </button>\n                        </div>\n                    </div>\n                    <ng-container *ngIf=\"!imageFlow\">\n                        <div *ngIf=\"type === 'footfall' && viewMode === 'grid'\" class=\"d-flex mt-2 mb-2 w-100 overflow-x px-0\">\n                            <div class=\"col text-nowrap\" *ngFor=\"let obj of objectsArray\">\n                                <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\n                                    <li class=\"nav-item cursor-pointer\">\n                                        <a (click)=\"selectedTimes(obj.timeRange)\"\n                                            [ngClass]=\"selectedTime === obj?.timeRange ? 'active' : ''\"\n                                            class=\"nav-link cursor-pointer no-border mx-3 mb-2\">\n                                            {{obj?.timeRange}}<span class=\"mx-2\"\n                                                [ngClass]=\"selectedTime === obj?.timeRange ? 'badge-num-primary' :'badge-num-muted'\">\n                                                {{ obj?.count ? obj?.count : 0 }}\n                                            </span>\n                                        </a>\n                                    </li>\n                                </ul>\n                            </div>\n                        </div>\n                    </ng-container>\n\n                    <div *ngIf=\"loading\" class=\"row loader  d-flex justify-content-center align-items-center\">\n                        <div class=\"shimmer\">\n                            <div class=\"wrapper\">\n                                <div class=\"stroke animate title\"></div>\n                                <div class=\"stroke animate link\"></div>\n                                <div class=\"stroke animate description\"></div>\n                            </div>\n                        </div>\n                        <div class=\"shimmer\">\n                            <div class=\"wrapper\">\n                                <div class=\"stroke animate title\"></div>\n                                <div class=\"stroke animate link\"></div>\n                                <div class=\"stroke animate description\"></div>\n                            </div>\n                        </div>\n                    </div>\n                    <div *ngIf=\"noData\" class=\"row\">\n\n                        <div class=\"col-lg-12 mb-3\">\n\n                            <div class=\"card-body d-flex justify-content-center align-items-center flex-column \" style=\"margin: 64px;border-radius: 8px;\nbackground: var(--Gray-50, #F9FAFB);\">\n                                <svg width=\"94\" height=\"94\" viewBox=\"0 0 94 94\" fill=\"none\"\n                                    xmlns=\"http://www.w3.org/2000/svg\">\n                                    <rect x=\"7\" y=\"7\" width=\"80\" height=\"80\" rx=\"40\" fill=\"#DAF1FF\" />\n                                    <rect x=\"7\" y=\"7\" width=\"80\" height=\"80\" rx=\"40\" stroke=\"#EAF8FF\"\n                                        stroke-width=\"13.3333\" />\n                                    <path\n                                        d=\"M35.332 51.9999H33.6654C32.7813 51.9999 31.9335 51.6487 31.3083 51.0236C30.6832 50.3985 30.332 49.5506 30.332 48.6666V33.6666C30.332 32.7825 30.6832 31.9347 31.3083 31.3096C31.9335 30.6844 32.7813 30.3333 33.6654 30.3333H48.6654C49.5494 30.3333 50.3973 30.6844 51.0224 31.3096C51.6475 31.9347 51.9987 32.7825 51.9987 33.6666V35.3333M45.332 41.9999H60.332C62.173 41.9999 63.6654 43.4923 63.6654 45.3333V60.3333C63.6654 62.1742 62.173 63.6666 60.332 63.6666H45.332C43.4911 63.6666 41.9987 62.1742 41.9987 60.3333V45.3333C41.9987 43.4923 43.4911 41.9999 45.332 41.9999Z\"\n                                        stroke=\"#00A3FF\" stroke-width=\"4\" stroke-linecap=\"round\"\n                                        stroke-linejoin=\"round\" />\n                                </svg>\n                                <div class=\"nodata-title my-3\">\n                                    {{ noDataMessages[type?.toLowerCase()] || 'No data found' }}\n                                </div>\n\n                            </div>\n                        </div>\n\n                    </div>\n\n\n                    <!-- Split-screen layout (only shown after clicking an image) -->\n                    <div class=\"split-screen-container\" *ngIf=\"splitScreenEnabled && !noData && !loading\">\n                        <!-- Left Panel: Thumbnail List + Related Images -->\n                        <div class=\"left-panel\">\n                            <!-- Main Images List (hidden when duplicate is selected) -->\n                            <ng-container *ngIf=\"selectedRadioType !== 'duplicate'\">\n                                <div class=\"thumbnail-list-section\" *ngFor=\"let group of listViewGroups\">\n                                    <div class=\"time-range-header\">\n                                        <span class=\"time-range-title\">{{ group?.timeRange }}</span>\n                                        <span class=\"time-range-count\">#{{ group?.data?.length || 0 }}</span>\n                                    </div>\n                                    <div class=\"thumbnail-grid\">\n                                        <div class=\"thumbnail-item\" *ngFor=\"let obj of group?.data\"\n                                            [ngClass]=\"{'selected': selectImageArray?.templd === obj?.templd}\"\n                                            (click)=\"selectImageForSplitView(obj)\">\n                                            <img class=\"thumbnail-image\" [src]=\"imageUrl + obj?.filePath\"\n                                                (error)=\"obj.filePath = null\" alt=\"\" *ngIf=\"obj?.filePath\" />\n                                            <div *ngIf=\"!obj?.filePath\" class=\"no-preview\"\n                                                style=\"height: 120px; padding: 20px;\">\n                                                <span style=\"color: #667085; font-size: 11px;\">No preview</span>\n                                            </div>\n                                            <div class=\"thumbnail-info\">\n                                                <div class=\"tango-id\">Tango ID: {{ obj?.templd }}</div>\n                                                <div class=\"entry-time\">Entry Time: {{ obj?.entryTme || obj?.entryTime\n                                                    }}</div>\n                                            </div>\n                                        </div>\n                                    </div>\n                                </div>\n                            </ng-container>\n\n                            <!-- Related Images Section (ONLY shown when duplicate is selected) -->\n                            <div class=\"thumbnail-list-section\"\n                                *ngIf=\"selectedRadioType === 'duplicate' && remainingImagesGroups && remainingImagesGroups.length > 0\">\n                                <!-- <div class=\"time-range-header\">\n                                    <span class=\"time-range-title\">Select related images</span>\n                                </div> -->\n                                <div class=\"thumbnail-list-section\" *ngFor=\"let group of remainingImagesGroups\">\n                                    <div class=\"time-range-header\" style=\"margin-top: 16px;\">\n                                        <span class=\"time-range-title\">{{ group?.timeRange }}</span>\n                                        <span class=\"time-range-count\">#{{ group?.data?.length || 0 }}</span>\n                                    </div>\n                                    <div class=\"thumbnail-grid\">\n                                        <div class=\"thumbnail-item\" *ngFor=\"let obj of group?.data\"\n                                            [ngClass]=\"{'selected': obj.selected}\">\n                                            <div class=\"position-relative\">\n                                                <input *ngIf=\"!revopsTypeValue && selectedRadioType === 'duplicate'\"\n                                                    type=\"checkbox\" [checked]=\"obj.selected\"\n                                                    class=\"position-absolute absolute form-check-input cursor-pointer\"\n                                                    style=\"top: 5px; right: 5px; z-index: 2;\"\n                                                    (change)=\"onImageCheckboxChange($event, obj, 'duplicate')\"\n                                                    (click)=\"$event.stopPropagation()\"\n                                                    [disabled]=\"obj.duplicateImagePath?.length > 0\" />\n                                                <img class=\"thumbnail-image cursor-pointer\"\n                                                    [src]=\"imageUrl + obj?.filePath\" (error)=\"obj.filePath = null\"\n                                                    alt=\"\" *ngIf=\"obj?.filePath\"\n                                                    (click)=\"handleImageClick($event, obj)\" />\n                                                <div *ngIf=\"!obj?.filePath\" class=\"no-preview cursor-pointer\"\n                                                    style=\"height: 120px; padding: 20px;\"\n                                                    (click)=\"handleImageClick($event, obj)\">\n                                                    <span style=\"color: #667085; font-size: 11px;\">No preview</span>\n                                                </div>\n                                                <div class=\"thumbnail-info\">\n                                                    <div class=\"tango-id\">Tango ID: {{ obj?.templd || obj?.tempId }}\n                                                    </div>\n                                                    <div class=\"entry-time\">Entry Time: {{ obj?.entryTme ||\n                                                        obj?.entryTime }}</div>\n                                                </div>\n                                            </div>\n                                        </div>\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n\n                        <!-- Right Panel: Selected Image Details -->\n                        <div class=\"right-panel\" *ngIf=\"selectImageArray\">\n                            <ng-container\n                                *ngTemplateOutlet=\"imageDetailView; context: { $implicit: selectImageArray }\"></ng-container>\n                        </div>\n                        <div class=\"right-panel\" *ngIf=\"!selectImageArray\"\n                            style=\"display: flex; align-items: center; justify-content: center; color: var(--Gray-500, #667085);\">\n                            <div style=\"text-align: center;\">\n                                <p style=\"font-size: 16px; font-weight: 500;\">Select an image to view details</p>\n                            </div>\n                        </div>\n                    </div>\n\n                    <!-- Image Detail View Template for Split-Screen Right Panel -->\n                    <ng-template #imageDetailView let-obj>\n                        <div class=\"border-gray p-3 mb-3\">\n                            <div class=\"position-relative\">\n                                <img class=\"img-src1\" [src]=\"imageUrl + obj?.filePath\" alt=\"\" *ngIf=\"obj?.filePath\" />\n                                <!-- Zoom Icon -->\n                                <div class=\"zoom-icon-button\" (click)=\"openImageZoomModal(imageUrl, obj)\">\n                                    <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\"\n                                        fill=\"none\">\n                                        <path\n                                            d=\"M18.3333 18.3333L15 15M16.6667 9.16667C16.6667 13.3067 13.3067 16.6667 9.16667 16.6667C5.02667 16.6667 1.66667 13.3067 1.66667 9.16667C1.66667 5.02667 5.02667 1.66667 9.16667 1.66667C13.3067 1.66667 16.6667 5.02667 16.6667 9.16667Z\"\n                                            stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                            stroke-linejoin=\"round\" />\n                                        <path d=\"M9.16667 6.66667V11.6667M6.66667 9.16667H11.6667\" stroke=\"#475467\"\n                                            stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                                    </svg>\n                                </div>\n                                <div *ngIf=\"!obj?.filePath\" class=\"no-preview\" style=\"height: 375px;\">\n                                    <span class=\"mb-5\">\n                                        <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\"\n                                            xmlns=\"http://www.w3.org/2000/svg\">\n                                            <g id=\"Group\">\n                                                <path id=\"Vector\"\n                                                    d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\n                                                    stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                    stroke-linejoin=\"round\" />\n                                                <path id=\"Vector_2\"\n                                                    d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\n                                                    stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                    stroke-linejoin=\"round\" />\n                                            </g>\n                                        </svg>\n                                    </span>\n                                    <span class=\"header mb-5 text-center\">Preview not available</span>\n                                    <span class=\"description mb-5 text-center\">The selected camera is not available at\n                                        the moment.</span>\n                                </div>\n                            </div>\n                            <div class=\"row px-2 mb-2 mt-3\">\n                                <div class=\"col-md-7\">\n                                    <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd}}\n                                        <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\">\n                                            <svg style=\"width: 20px; height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\"\n                                                width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n                                                <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n                                                <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                                    d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n                                                    fill=\"#12B76A\" />\n                                            </svg>\n                                        </span>\n                                        <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\">\n                                            <svg style=\"width: 20px; height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\"\n                                                width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n                                                <g clip-path=\"url(#clip0_1428_59484)\">\n                                                    <path\n                                                        d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n                                                        fill=\"#FEE4E2\" />\n                                                    <path\n                                                        d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n                                                        stroke=\"#D92D20\" stroke-linecap=\"round\"\n                                                        stroke-linejoin=\"round\" />\n                                                </g>\n                                                <defs>\n                                                    <clipPath id=\"clip0_1428_59484\">\n                                                        <rect width=\"12\" height=\"12\" fill=\"white\"\n                                                            transform=\"translate(0.599609 0.5)\" />\n                                                    </clipPath>\n                                                </defs>\n                                            </svg>\n                                        </span>\n                                    </div>\n                                    <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme || obj?.entryTime}}</div>\n                                </div>\n                                <div class=\"col-md-5 text-end py-3\">\n                                    <span *ngIf=\"obj?.revopsType ==='non-tagging'\" ngbTooltip=\"Yet to tag the customer\"\n                                        placement=\"top\">\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\n                                            viewBox=\"0 0 19 18\" fill=\"none\">\n                                            <path\n                                                d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n                                                stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                stroke-linejoin=\"round\" />\n                                        </svg>\n                                    </span>\n                                    <span *ngIf=\"obj?.revopsType ==='duplicate'\">\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n                                            viewBox=\"0 0 20 21\" fill=\"none\">\n                                            <g clip-path=\"url(#clip0_2012_94635)\">\n                                                <path\n                                                    d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                    stroke-linejoin=\"round\" />\n                                            </g>\n                                            <defs>\n                                                <clipPath id=\"clip0_2012_94635\">\n                                                    <rect width=\"20\" height=\"20\" fill=\"white\"\n                                                        transform=\"translate(0 0.686035)\" />\n                                                </clipPath>\n                                            </defs>\n                                        </svg>\n                                    </span>\n                                    <span *ngIf=\"obj?.revopsType ==='employee'\">\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n                                            viewBox=\"0 0 20 21\" fill=\"none\">\n                                            <g clip-path=\"url(#clip0_2012_94639)\">\n                                                <path\n                                                    d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                    stroke-linejoin=\"round\" />\n                                            </g>\n                                            <defs>\n                                                <clipPath id=\"clip0_2012_94639\">\n                                                    <rect width=\"20\" height=\"20\" fill=\"white\"\n                                                        transform=\"translate(0 0.686035)\" />\n                                                </clipPath>\n                                            </defs>\n                                        </svg>\n                                    </span>\n                                    <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\n                                            viewBox=\"0 0 21 21\" fill=\"none\">\n                                            <g clip-path=\"url(#clip0_2012_94643)\">\n                                                <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                                    d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n                                                    fill=\"#475467\" />\n                                            </g>\n                                            <defs>\n                                                <clipPath id=\"clip0_2012_94643\">\n                                                    <rect width=\"21\" height=\"20\" fill=\"white\"\n                                                        transform=\"translate(0 0.686035)\" />\n                                                </clipPath>\n                                            </defs>\n                                        </svg>\n                                    </span>\n                                    <span *ngIf=\"obj?.revopsType ==='junk'\">\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\n                                            viewBox=\"0 0 24 24\" fill=\"none\">\n                                            <path\n                                                d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n                                                stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                stroke-linejoin=\"round\" />\n                                        </svg>\n                                    </span>\n                                </div>\n                            </div>\n                        </div>\n                        <div class=\"border-gray p-3\">\n                            <div class=\"row mb-3\">\n                                <div class=\"col-md-6 title-type\">Select non-shopper type</div>\n                                <div class=\"col-md-6 text-end\"\n                                    *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\n                                    <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\" class=\"mb-3 text-end d-inline-flex align-items-center gap-2\">\n                                        <!-- Clear Tag Button (visible when Edit button OR Save/Cancel buttons are visible) -->\n                                        <button\n                                            *ngIf=\"!revopsTypeValue || (revopsTypeValue && editBtnShow)\"\n                                            [disabled]=\"(selectedRadioType === undefined || selectedRadioType === '') || (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\"\n                                            class=\"btn btn-clear-tag d-inline-flex align-items-center justify-content-center\" type=\"button\"\n                                            (click)=\"clearValue()\">\n                                                <svg width=\"49\" height=\"49\" viewBox=\"0 0 49 49\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                                                    <g filter=\"url(#filter0_d_516_96841)\">\n                                                        <rect x=\"2.16797\" y=\"1.08447\" width=\"44.0342\" height=\"44.0284\" rx=\"8.67445\" fill=\"#FEF3F2\" />\n                                                        <rect x=\"2.71012\" y=\"1.62663\" width=\"42.9499\" height=\"42.9441\" rx=\"8.13229\" stroke=\"#FEF3F2\"\n                                                            stroke-width=\"1.08431\" />\n                                                        <path\n                                                            d=\"M33.4893 21.3613L33.4912 21.3643C34.0533 21.9297 34.369 22.6949 34.3691 23.4922C34.3691 24.2895 34.0533 25.0546 33.4912 25.6201L26.7256 32.3857C26.4454 32.6661 26.1122 32.8882 25.7461 33.04C25.3798 33.1919 24.9873 33.2705 24.5908 33.2705C24.1942 33.2705 23.801 33.1919 23.4346 33.04C23.0686 32.8883 22.7361 32.6659 22.4561 32.3857L20.7676 30.6992L22.3682 29.0986L24.0557 30.7842L24.0566 30.7852C24.1267 30.8553 24.2102 30.9112 24.3018 30.9492C24.3933 30.9872 24.4917 31.0068 24.5908 31.0068C24.6899 31.0068 24.7883 30.9872 24.8799 30.9492C24.9713 30.9113 25.0541 30.8552 25.124 30.7852H25.125L31.8877 24.0215C32.0267 23.8804 32.1055 23.6903 32.1055 23.4922C32.1054 23.2941 32.0267 23.1039 31.8877 22.9629L30.1963 21.2715L31.7979 19.6699L33.4893 21.3613ZM24.6982 12.9336C24.9571 12.9594 25.2011 13.0733 25.3867 13.2588L30.1973 18.0693L28.5957 19.6709L24.1162 15.1914H16.2852V23.0225L20.7666 27.499L19.166 29.0996L14.3535 24.293C14.1411 24.0807 14.0215 23.7925 14.0215 23.4922V14.0596C14.0217 13.4346 14.5283 12.9277 15.1533 12.9277H24.5859L24.6982 12.9336ZM19.8789 17.6436C20.5038 17.6436 21.0103 18.1506 21.0107 18.7754C21.0107 19.4005 20.504 19.9082 19.8789 19.9082H19.8691C19.2442 19.908 18.7373 19.4004 18.7373 18.7754C18.7378 18.1508 19.2445 17.6438 19.8691 17.6436H19.8789Z\"\n                                                            fill=\"#B42318\" />\n                                                        <path d=\"M33.1699 14.0845L15.1699 32.0845\" stroke=\"#B42318\" stroke-width=\"2\" stroke-linecap=\"round\" />\n                                                    </g>\n                                                    <defs>\n                                                        <filter id=\"filter0_d_516_96841\" x=\"-0.000643253\" y=\"0.000166655\" width=\"48.3724\" height=\"48.3655\"\n                                                            filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                                            <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\" />\n                                                            <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\"\n                                                                result=\"hardAlpha\" />\n                                                            <feOffset dy=\"1.08431\" />\n                                                            <feGaussianBlur stdDeviation=\"1.08431\" />\n                                                            <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0\" />\n                                                            <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_516_96841\" />\n                                                            <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_516_96841\" result=\"shape\" />\n                                                        </filter>\n                                                    </defs>\n                                                </svg>\n                                        </button>\n                                        <!-- Cancel and Save Buttons (when !revopsTypeValue) -->\n                                        <div *ngIf=\"!revopsTypeValue\">\n                                            <button class=\"btn btn-outline me-2\" (click)=\"cancel()\">Cancel</button>\n                                            <button class=\"btn btn-primary\" id=\"alert-toast\"\n                                                (click)=\"save(selectedType)\"\n                                                [disabled]=\"(selectedRadioType === undefined || selectedRadioType === '') || (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\">Save</button>\n                                        </div>\n                                        <!-- Edit Button (when revopsTypeValue && editBtnShow) -->\n                                        <div *ngIf=\"revopsTypeValue && editBtnShow\">\n                                            <button\n                                                class=\"btn btn-outline me-2\" (click)=\"editValue()\">\n                                                <span class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\"\n                                                        height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n                                                        <path\n                                                            d=\"M14.6554 1.71047C14.8927 1.47315 15.1745 1.2849 15.4845 1.15646C15.7946 1.02802 16.1269 0.961914 16.4626 0.961914C16.7982 0.961914 17.1305 1.02802 17.4406 1.15646C17.7507 1.2849 18.0324 1.47315 18.2697 1.71047C18.5071 1.94779 18.6953 2.22953 18.8238 2.53961C18.9522 2.84969 19.0183 3.18202 19.0183 3.51765C19.0183 3.85327 18.9522 4.18561 18.8238 4.49568C18.6953 4.80576 18.5071 5.0875 18.2697 5.32482L6.0713 17.5233L1.10156 18.8786L2.45695 13.9089L14.6554 1.71047Z\"\n                                                            stroke=\"#344054\" stroke-width=\"1.81079\" stroke-linecap=\"round\"\n                                                            stroke-linejoin=\"round\" />\n                                                    </svg></span>Edit\n                                            </button>\n                                        </div>\n                                    </div>\n                                </div>\n                            </div>\n                            <div class=\"form-check my-15\">\n                                <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"duplicate\"\n                                    id=\"duplicate-split\" [(ngModel)]=\"selectedType\" [value]=\"'duplicate'\"\n                                    (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n                                <label class=\"form-check-label\" for=\"duplicate-split\">\n                                    <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n                                            viewBox=\"0 0 20 21\" fill=\"none\">\n                                            <g clip-path=\"url(#clip0_2012_94635)\">\n                                                <path\n                                                    d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                    stroke-linejoin=\"round\" />\n                                            </g>\n                                            <defs>\n                                                <clipPath id=\"clip0_2012_94635\">\n                                                    <rect width=\"20\" height=\"20\" fill=\"white\"\n                                                        transform=\"translate(0 0.686035)\" />\n                                                </clipPath>\n                                            </defs>\n                                        </svg></span>\n                                    <span class=\"ms-5 tag-class\">Duplicate</span>\n                                </label>\n                            </div>\n                            <div class=\"form-check my-15\">\n                                <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"employee\"\n                                    id=\"employee-split\" [(ngModel)]=\"selectedType\" [value]=\"'employee'\"\n                                    (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n                                <label class=\"form-check-label\" for=\"employee-split\">\n                                    <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n                                            viewBox=\"0 0 20 21\" fill=\"none\">\n                                            <g clip-path=\"url(#clip0_2012_94639)\">\n                                                <path\n                                                    d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                    stroke-linejoin=\"round\" />\n                                            </g>\n                                            <defs>\n                                                <clipPath id=\"clip0_2012_94639\">\n                                                    <rect width=\"20\" height=\"20\" fill=\"white\"\n                                                        transform=\"translate(0 0.686035)\" />\n                                                </clipPath>\n                                            </defs>\n                                        </svg></span>\n                                    <span class=\"ms-5 tag-class\">Employee/Staff</span>\n                                </label>\n                            </div>\n                            <div class=\"form-check my-15\">\n                                <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"house-keeping\"\n                                    id=\"house-keeping-split\" [(ngModel)]=\"selectedType\" [value]=\"'house-keeping'\"\n                                    (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n                                <label class=\"form-check-label\" for=\"house-keeping-split\">\n                                    <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\n                                            viewBox=\"0 0 21 21\" fill=\"none\">\n                                            <g clip-path=\"url(#clip0_2012_94643)\">\n                                                <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                                    d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n                                                    fill=\"#475467\" />\n                                            </g>\n                                            <defs>\n                                                <clipPath id=\"clip0_2012_94643\">\n                                                    <rect width=\"21\" height=\"20\" fill=\"white\"\n                                                        transform=\"translate(0 0.686035)\" />\n                                                </clipPath>\n                                            </defs>\n                                        </svg></span>\n                                    <span class=\"ms-5 tag-class\">House Keeping</span>\n                                </label>\n                            </div>\n                            <div class=\"form-check my-15\">\n                                <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"junk\" id=\"junk-split\"\n                                    [(ngModel)]=\"selectedType\" [value]=\"'junk'\" (change)=\"onRadioChange(selectedType)\"\n                                    [disabled]=\"users?.role ==='user' && users?.userType ==='client' || revopsTypeValue\">\n                                <label class=\"form-check-label\" for=\"junk-split\">\n                                    <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\n                                            viewBox=\"0 0 24 24\" fill=\"none\">\n                                            <path\n                                                d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n                                                stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                stroke-linejoin=\"round\" />\n                                        </svg></span>\n                                    <span class=\"ms-5 tag-class\">Junk</span>\n                                </label>\n                            </div>\n                            <div class=\"mt-3\">\n                                <label class=\"form-label\">Remarks (Optional)</label>\n                                <textarea class=\"form-control\" rows=\"3\" placeholder=\"Comment here\"\n                                    [(ngModel)]=\"userComment\"></textarea>\n                            </div>\n                        </div>\n                    </ng-template>\n\n                    <!-- Grid/List View (shown when split-screen is not enabled) -->\n                    <div class=\"row px-0 img-traffic contain high-400px scroll-y\"\n                        *ngIf=\"viewMode === 'grid' && !noData && !loading && !splitScreenEnabled\">\n                        <ng-container *ngFor=\"let obj of imagesArrayData\">\n                            <ng-container *ngTemplateOutlet=\"imageCard; context: { $implicit: obj }\"></ng-container>\n                        </ng-container>\n                    </div>\n\n                    <div class=\"list-view-wrapper\"\n                        *ngIf=\"viewMode === 'list' && !noData && !loading && !splitScreenEnabled\">\n                        <div class=\"list-group mb-5\" *ngFor=\"let group of listViewGroups\">\n                            <div class=\"list-group-header d-flex align-items-center mb-3\">\n                                <div class=\"group-title\">{{ group?.timeRange }}</div>\n                                <span class=\"group-count badge badge-light-default ms-2\">\n                                    #{{ group?.data?.length || 0 }}\n                                </span>\n                            </div>\n                            <div class=\"row gx-4 list-group-row\">\n                                <ng-container *ngFor=\"let obj of group?.data\">\n                                    <ng-container\n                                        *ngTemplateOutlet=\"imageCard; context: { $implicit: obj }\"></ng-container>\n                                </ng-container>\n                            </div>\n                        </div>\n                    </div>\n\n                    <ng-template #imageCard let-obj>\n                        <div *ngIf=\"type !== 'duplicate' || (type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\"\n                            class=\"col-md-3 border-gray mx-2 p-2 mt-5\">\n                            <!-- Condition: Only show if not duplicate OR duplicate with non-empty duplicateImagePath -->\n                            <ng-container>\n                                <img class=\"img-src cursor-pointer\" [src]=\"imageUrl + obj?.filePath\" (error)=\"obj.filePath = null\" alt=\"\"\n                                    (click)=\"selectImageForSplitView(obj)\" />\n                            </ng-container>\n                    \n                            <div *ngIf=\"!obj?.filePath\" class=\"no-preview\">\n                                <span class=\"mb-5\">\n                                    <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                                        <g id=\"Group\">\n                                            <path id=\"Vector\" d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\n                                                stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                                            <path id=\"Vector_2\"\n                                                d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\n                                                stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                                        </g>\n                                    </svg>\n                    \n                                </span>\n                                <span class=\"header mb-5 text-center\">Preview not available</span>\n                                <span class=\"description mb-5 text-center\">The selected camera is not available at\n                                    the\n                                    moment.</span>\n                            </div>\n                            <div *ngIf=\"type !== 'duplicate' || (type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\"\n                                class=\"row px-2 mb-2\">\n                                <div class=\"col-md-7\">\n                                    <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd}} <span\n                                            *ngIf=\"(type === 'duplicate'&& obj.revopsType === 'duplicate' && obj.duplicateImagePath?.length > 0)\"\n                                            class=\"mx-2 badge badge-light-primary\">{{obj.duplicateImagePath?.length}}\n                                        </span>\n                                        <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\">\n                                            <svg style=\"width: 20px;\n                                                                    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\"\n                                                height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n                                                <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n                                                <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                                    d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n                                                    fill=\"#12B76A\" />\n                                            </svg>\n                                        </span>\n                                        <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\">\n                                            <svg style=\"width: 20px;\n                                                                    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\"\n                                                height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n                                                <g clip-path=\"url(#clip0_1428_59484)\">\n                                                    <path\n                                                        d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n                                                        fill=\"#FEE4E2\" />\n                                                    <path\n                                                        d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n                                                        stroke=\"#D92D20\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                                                </g>\n                                                <defs>\n                                                    <clipPath id=\"clip0_1428_59484\">\n                                                        <rect width=\"12\" height=\"12\" fill=\"white\" transform=\"translate(0.599609 0.5)\" />\n                                                    </clipPath>\n                                                </defs>\n                                            </svg>\n                                        </span>\n                                    </div>\n                                    <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme}}</div>\n                                </div>\n                                <div class=\"col-md-5 text-end py-3\">\n                                    <span *ngIf=\"obj?.revopsType ==='non-tagging'\" ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 19 18\" fill=\"none\">\n                                            <path\n                                                d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n                                                stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                                        </svg>\n                                    </span>\n                                    <span *ngIf=\"obj?.revopsType ==='duplicate'\">\n                                        <svg *ngIf=\"obj?.isParent\" width=\"20\" height=\"21\" viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                                            <g clip-path=\"url(#clip0_568_103657)\">\n                                                <path\n                                                    d=\"M2.08398 6.25001H1.66732C1.4463 6.25001 1.23434 6.16221 1.07806 6.00593C0.921782 5.84965 0.833984 5.63769 0.833984 5.41668V1.66668C0.833984 1.44566 0.921782 1.2337 1.07806 1.07742C1.23434 0.921141 1.4463 0.833344 1.66732 0.833344H5.41732C5.63833 0.833344 5.85029 0.921141 6.00657 1.07742C6.16285 1.2337 6.25065 1.44566 6.25065 1.66668V2.08334M4.58398 3.75001H8.33398C8.79422 3.75001 9.16732 4.12311 9.16732 4.58334V8.33334C9.16732 8.79358 8.79422 9.16668 8.33398 9.16668H4.58398C4.12375 9.16668 3.75065 8.79358 3.75065 8.33334V4.58334C3.75065 4.12311 4.12375 3.75001 4.58398 3.75001Z\"\n                                                    stroke=\"#475467\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                                            </g>\n                                            <rect x=\"4\" y=\"4\" width=\"5\" height=\"5\" fill=\"#475467\" />\n                                            <defs>\n                                                <clipPath id=\"clip0_568_103657\">\n                                                    <rect width=\"10\" height=\"10\" fill=\"white\" />\n                                                </clipPath>\n                                            </defs>\n                                        </svg>\n                                        <svg *ngIf=\"!obj?.isParent\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\n                                            <g clip-path=\"url(#clip0_2012_94635)\">\n                                                <path\n                                                    d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                                            </g>\n                                            <defs>\n                                                <clipPath id=\"clip0_2012_94635\">\n                                                    <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(0 0.686035)\" />\n                                                </clipPath>\n                                            </defs>\n                                        </svg>\n                                    </span>\n                                    <span *ngIf=\"obj?.revopsType ==='employee'\">\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\n                                            <g clip-path=\"url(#clip0_2012_94639)\">\n                                                <path\n                                                    d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                                            </g>\n                                            <defs>\n                                                <clipPath id=\"clip0_2012_94639\">\n                                                    <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(0 0.686035)\" />\n                                                </clipPath>\n                                            </defs>\n                                        </svg>\n                                    </span>\n                                    <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 21 21\" fill=\"none\">\n                                            <g clip-path=\"url(#clip0_2012_94643)\">\n                                                <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                                    d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n                                                    fill=\"#475467\" />\n                                            </g>\n                                            <defs>\n                                                <clipPath id=\"clip0_2012_94643\">\n                                                    <rect width=\"21\" height=\"20\" fill=\"white\" transform=\"translate(0 0.686035)\" />\n                                                </clipPath>\n                                            </defs>\n                                        </svg>\n                                    </span>\n                                    <span *ngIf=\"obj?.revopsType ==='junk'\">\n                    \n                                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 24 24\" fill=\"none\">\n                                            <path\n                                                d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n                                                stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                                        </svg>\n                                    </span>\n                                </div>\n                            </div>\n                        </div>\n                    </ng-template>\n\n                </div>\n            </section>\n\n            <!-- full image View -->\n            <section *ngIf=\"imageFlow\">\n                <div class=\"row\">\n                    <!-- Ticket Block Alert -->\n                    <div *ngIf=\"getSelectedDateCardData()?.raisedStatusEnabled === 'block'\" class=\"col-12 mb-3\">\n                        <div class=\"ticket-block-alert\">\n                            <div class=\"ticket-block-alert-content\">\n                                <div class=\"ticket-block-alert-icon\">\n                                    <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\n                                        xmlns=\"http://www.w3.org/2000/svg\">\n                                        <circle cx=\"12\" cy=\"12\" r=\"12\" fill=\"#F04438\" />\n                                        <path d=\"M12 8V13\" stroke=\"white\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                            stroke-linejoin=\"round\" />\n                                        <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n                                    </svg>\n                                </div>\n                                <div class=\"ticket-block-alert-text\">\n                                    <div class=\"ticket-block-alert-title\">\n                                        You cannot raise ticket for next {{ getSelectedDateCardData()?.noOfBlockedDays\n                                        || '0' }} days\n                                    </div>\n                                    <div class=\"ticket-block-alert-description\">\n                                        It looks like you have achieved 95% accuracy for the three tickets raised this\n                                        month. This limits you from raising more tickets to avoid redundancy.\n                                    </div>\n                                    <div class=\"ticket-block-alert-action\">\n                                        If you still want to raise tickets, <span class=\"ticket-block-alert-link\"\n                                            (click)=\"requestReset()\">send request</span> to reset.\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                    <!-- Ticket Request Success Alert -->\n                    <div *ngIf=\"getSelectedDateCardData()?.raisedStatusEnabled === 'request'\" class=\"col-12 mb-3\">\n                        <div class=\"ticket-request-alert\">\n                            <div class=\"ticket-request-alert-content\">\n                                <div class=\"ticket-request-alert-icon\">\n                                    <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\n                                        xmlns=\"http://www.w3.org/2000/svg\">\n                                        <path d=\"M2 21L23 12L2 3V10L17 12L2 14V21Z\" fill=\"#10B981\" />\n                                    </svg>\n                                </div>\n                                <div class=\"ticket-request-alert-text\">\n                                    <div class=\"ticket-request-alert-title\">\n                                        Reset Request Sent\n                                    </div>\n                                    <div class=\"ticket-request-alert-description\">\n                                        Your request to enable ticket raising has been submitted. You'll be notified\n                                        once it's approved. Please ensure future ticket accuracy remains within the 95%\n                                        threshold.\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                    <div class=\"d-flex mt-2 mb-2 w-100 overflow-x px-0\">\n                        <ng-container *ngTemplateOutlet=\"footfallTrendsTemplate\"></ng-container>\n                    </div>\n                    <ng-container *ngTemplateOutlet=\"ticketStatusTemplate\"></ng-container>\n                    <span class=\"divider\"></span>\n                    <div class=\"d-flex flex-shrink-0 mt-3 justify-content-start align-items-center px-0\">\n                        <div *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\"\n                            class=\"ms-auto text-end\">\n\n                            <button [disabled]=\"!canEnableButton()\" class=\"btn btn-primary\" type=\"button\"\n                                (click)=\"Raised()\">\n                                Raise ticket\n                            </button>\n                        </div>\n                    </div>\n                    <div class=\"nav-group bg-white border-1 btn-group w-auto\">\n                        <ng-container *ngIf=\"!(countData?.length > 0)\">\n\n                            <button class=\"btn btn-outline px-6 py-3\"\n                                [ngClass]=\"type === 'footfall' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n                                (click)=\"selectPlanTrends('footfall')\">\n                                Total Footfall\n                                <span\n                                    [ngClass]=\"type === 'footfall' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n                                    {{ countData?.footfallCount || 0 }}\n                                </span>\n                            </button>\n\n                            <button class=\"btn btn-outline px-6 py-3\"\n                                [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n                                (click)=\"selectPlanTrends('non-tagging')\">\n                                Non-tags\n                                <span\n                                    [ngClass]=\"type === 'non-tagging' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n                                    {{ countData?.nonTags || 0 }}\n                                </span>\n                            </button>\n\n                            <button class=\"btn btn-outline px-6 py-3\"\n                                [ngClass]=\"type === 'duplicate' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n                                (click)=\"selectPlanTrends('duplicate')\">\n                                Duplicated\n                                <span\n                                    [ngClass]=\"type === 'duplicate' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n                                    {{ countData?.duplicate || 0 }}\n                                </span>\n                            </button>\n\n                            <button class=\"btn btn-outline px-6 py-3\"\n                                [ngClass]=\"type === 'employee' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n                                (click)=\"selectPlanTrends('employee')\">\n                                Employee/Staff\n                                <span\n                                    [ngClass]=\"type === 'employee' ? 'activePlanBtn badge badge-active' : 'inactivePlanBtn badge badge-light-default'\">\n                                    {{ countData?.employee || 0 }}\n                                </span>\n                            </button>\n                            <button class=\"btn btn-outline px-6 py-3\"\n                                [ngClass]=\"type === 'junk' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n                                (click)=\"selectPlanTrends('junk')\">\n                                Junk\n                                <span\n                                    [ngClass]=\"type === 'junk' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\n                                    {{ countData?.junk || 0 }}\n                                </span>\n                            </button>\n                            <button class=\"btn btn-outline px-6 py-3\"\n                                [ngClass]=\"type === 'house-keeping' ? 'activePlanBtn' : 'inactivePlanBtn'\"\n                                (click)=\"selectPlanTrends('house-keeping')\">\n                                House Keeping\n                                <span\n                                    [ngClass]=\"type === 'house-keeping' ? 'badge badge-active activePlanBtn' : ' badge badge-light-default inactivePlanBtn'\">\n                                    {{ countData?.housekeeping || 0 }}\n                                </span>\n                            </button>\n\n                        </ng-container>\n\n                    </div>\n\n                    <div class=\"row mx-0 border-gray img-traffic\" *ngIf=\"!noData && !loading\">\n                        <div class=\"col-md-6 p-2  mb-2 mt-5\">\n                            <div class=\"position-relative border-gray p-2 \">\n                                <!-- Main Image -->\n                                <!-- <img class=\"img-src cursor-pointer h-450px\"\n                                    (click)=\"selectedImageArray(imageUrl, selectImageArray)\"\n                                    [src]=\"imageUrl + selectImageArray?.filePath\" appMagnifier alt=\"\"> -->\n                                <img class=\"img-src cursor-pointer h-450px\"\n                                    (click)=\"selectedImageArray(imageUrl, selectImageArray)\"\n                                    [src]=\"imageUrl + selectImageArray?.filePath\" alt=\"\">\n\n                                <!-- Right arrow button -->\n                                <div class=\"row px-2 mb-2\">\n                                    <div class=\"col-md-7\">\n                                        <div class=\"py-2 img-doc-time\">Tango ID : {{selectImageArray?.templd}}\n                                            <span *ngIf=\"selectImageArray?.status ==='approved'\" class=\"ms-2\"><svg\n                                                    style=\"width: 20px;\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n                                                    <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n                                                    <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                                        d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n                                                        fill=\"#12B76A\" />\n                                                </svg></span>\n                                            <span *ngIf=\"selectImageArray?.status ==='rejected'\" class=\"ms-2\"><svg\n                                                    style=\"width: 20px;\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n                                                    <g clip-path=\"url(#clip0_1428_59484)\">\n                                                        <path\n                                                            d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n                                                            fill=\"#FEE4E2\" />\n                                                        <path\n                                                            d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n                                                            stroke=\"#D92D20\" stroke-linecap=\"round\"\n                                                            stroke-linejoin=\"round\" />\n                                                    </g>\n                                                    <defs>\n                                                        <clipPath id=\"clip0_1428_59484\">\n                                                            <rect width=\"12\" height=\"12\" fill=\"white\"\n                                                                transform=\"translate(0.599609 0.5)\" />\n                                                        </clipPath>\n                                                    </defs>\n                                                </svg></span>\n                                        </div>\n                                        <div class=\"img-doc-value\">Entry Time : {{(tempModalImage ||\n                                            selectImageArray)?.entryTme || (tempModalImage ||\n                                            selectImageArray)?.entryTime}}</div>\n                                    </div>\n                                    <div class=\"col-md-5 text-end py-3\">\n                                        <span *ngIf=\"(tempModalImage || selectImageArray)?.revopsType ==='non-tagging'\"\n                                            ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\n                                                viewBox=\"0 0 19 18\" fill=\"none\">\n                                                <path\n                                                    d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                    stroke-linejoin=\"round\" />\n                                            </svg>\n                                        </span>\n                                        <span *ngIf=\"selectImageArray?.revopsType ==='duplicate'\">\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n                                                viewBox=\"0 0 20 21\" fill=\"none\">\n                                                <g clip-path=\"url(#clip0_2012_94635)\">\n                                                    <path\n                                                        d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                        stroke-linejoin=\"round\" />\n                                                </g>\n                                                <defs>\n                                                    <clipPath id=\"clip0_2012_94635\">\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\n                                                            transform=\"translate(0 0.686035)\" />\n                                                    </clipPath>\n                                                </defs>\n                                            </svg>\n                                        </span>\n                                        <span *ngIf=\"selectImageArray?.revopsType ==='employee'\">\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n                                                viewBox=\"0 0 20 21\" fill=\"none\">\n                                                <g clip-path=\"url(#clip0_2012_94639)\">\n                                                    <path\n                                                        d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                        stroke-linejoin=\"round\" />\n                                                </g>\n                                                <defs>\n                                                    <clipPath id=\"clip0_2012_94639\">\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\n                                                            transform=\"translate(0 0.686035)\" />\n                                                    </clipPath>\n                                                </defs>\n                                            </svg>\n                                        </span>\n                                        <span *ngIf=\"selectImageArray?.revopsType ==='house-keeping'\">\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\n                                                viewBox=\"0 0 21 21\" fill=\"none\">\n                                                <g clip-path=\"url(#clip0_2012_94643)\">\n                                                    <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                                        d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n                                                        fill=\"#475467\" />\n                                                </g>\n                                                <defs>\n                                                    <clipPath id=\"clip0_2012_94643\">\n                                                        <rect width=\"21\" height=\"20\" fill=\"white\"\n                                                            transform=\"translate(0 0.686035)\" />\n                                                    </clipPath>\n                                                </defs>\n                                            </svg>\n                                        </span>\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n\n                        <div class=\"col-md-6 p-2 mb-2  mt-5\">\n                            <div class=\"mx-2 \">\n                                <div class=\"row\">\n                                    <div class=\"col-md-6 title-type\">\n                                        Select non-shopper type\n                                    </div>\n\n\n                                    <section class=\"col-md-6 text-end\"\n                                        *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\n\n                                        <div *ngIf=\"!revopsTypeValue\" class=\"mb-5 text-end\" role=\"group\">\n                                            <div\n                                                *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\">\n\n                                                <button [disabled]=\"\n                                        (selectedRadioType === undefined || selectedRadioType === '') ||\n                                        (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\n                                        \" class=\"btn btn-default\" type=\"button\" (click)=\"clearValue()\">Clear</button>\n                                                <button class=\"btn btn-outline me-2\" (click)=\"cancel()\">Cancel</button>\n                                                <button class=\"btn btn-primary\" id=\"alert-toast\"\n                                                    (click)=\"save(selectedType)\" [disabled]=\"\n                                        (selectedRadioType === undefined || selectedRadioType === '') ||\n                                        (selectedRadioType === 'duplicate' && selectedDuplicateImagesList.length === 0)\n                                        \">\n                                                    Save\n                                                </button>\n                                            </div>\n                                        </div>\n\n                                        <div\n                                            *ngIf=\"!(users?.role ==='user' && users?.userType ==='client' && selectedRadioType ==='junk')\">\n                                            <ng-container *ngIf=\"editBtnShow\">\n                                                <div *ngIf=\"revopsTypeValue\" class=\"mb-5 text-end\" role=\"group\">\n                                                    <button\n                                                        *ngIf=\"!getTicketStatuses().includes('open') && !getTicketStatuses().includes('closed')\"\n                                                        class=\"btn btn-outline me-2\" (click)=\"editValue()\"><span\n                                                            class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\"\n                                                                width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n                                                                <path\n                                                                    d=\"M14.6554 1.71047C14.8927 1.47315 15.1745 1.2849 15.4845 1.15646C15.7946 1.02802 16.1269 0.961914 16.4626 0.961914C16.7982 0.961914 17.1305 1.02802 17.4406 1.15646C17.7507 1.2849 18.0324 1.47315 18.2697 1.71047C18.5071 1.94779 18.6953 2.22953 18.8238 2.53961C18.9522 2.84969 19.0183 3.18202 19.0183 3.51765C19.0183 3.85327 18.9522 4.18561 18.8238 4.49568C18.6953 4.80576 18.5071 5.0875 18.2697 5.32482L6.0713 17.5233L1.10156 18.8786L2.45695 13.9089L14.6554 1.71047Z\"\n                                                                    stroke=\"#344054\" stroke-width=\"1.81079\"\n                                                                    stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                                                            </svg></span>Edit</button>\n\n                                                </div>\n                                            </ng-container>\n                                        </div>\n                                    </section>\n\n                                </div>\n\n                                <div class=\"form-check my-15\">\n                                    <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"duplicate\"\n                                        id=\"duplicate\" [(ngModel)]=\"selectedType\" [value]=\"'duplicate'\"\n                                        (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n                                    <label class=\"form-check-label\" for=\"duplicate\">\n                                        <span class=\"ms-5\">\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n                                                viewBox=\"0 0 20 21\" fill=\"none\">\n                                                <g clip-path=\"url(#clip0_2012_94635)\">\n                                                    <path\n                                                        d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                        stroke-linejoin=\"round\" />\n                                                </g>\n                                                <defs>\n                                                    <clipPath id=\"clip0_2012_94635\">\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\n                                                            transform=\"translate(0 0.686035)\" />\n                                                    </clipPath>\n                                                </defs>\n                                            </svg>\n                                        </span>\n                                        <span class=\"ms-5 tag-class\">Duplicate</span>\n                                    </label>\n                                </div>\n                                <div class=\"form-check my-15\">\n                                    <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"employee\"\n                                        id=\"employee\" [(ngModel)]=\"selectedType\" [value]=\"'employee'\"\n                                        (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n                                    <label class=\"form-check-label\" for=\"employee\">\n                                        <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\"\n                                                height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\n                                                <g clip-path=\"url(#clip0_2012_94639)\">\n                                                    <path\n                                                        d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                        stroke-linejoin=\"round\" />\n                                                </g>\n                                                <defs>\n                                                    <clipPath id=\"clip0_2012_94639\">\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\n                                                            transform=\"translate(0 0.686035)\" />\n                                                    </clipPath>\n                                                </defs>\n                                            </svg></span>\n                                        <span class=\"ms-5 tag-class\">Employee/Staff</span>\n                                    </label>\n                                </div>\n                                <div class=\"form-check my-15\">\n                                    <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"house-keeping\"\n                                        id=\"house-keeping\" [(ngModel)]=\"selectedType\" [value]=\"'house-keeping'\"\n                                        (change)=\"onRadioChange(selectedType)\" [disabled]=\"revopsTypeValue\">\n                                    <label class=\"form-check-label\" for=\"house-keeping\">\n                                        <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\"\n                                                height=\"21\" viewBox=\"0 0 21 21\" fill=\"none\">\n                                                <g clip-path=\"url(#clip0_2012_94643)\">\n                                                    <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                                        d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n                                                        fill=\"#475467\" />\n                                                </g>\n                                                <defs>\n                                                    <clipPath id=\"clip0_2012_94643\">\n                                                        <rect width=\"21\" height=\"20\" fill=\"white\"\n                                                            transform=\"translate(0 0.686035)\" />\n                                                    </clipPath>\n                                                </defs>\n                                            </svg></span>\n                                        <span class=\"ms-5 tag-class\"> House Keeping</span>\n                                    </label>\n                                </div>\n                                <div class=\"form-check my-15\">\n                                    <input class=\"form-check-input cursor-pointer\" type=\"radio\" name=\"junk\" id=\"junk\"\n                                        [(ngModel)]=\"selectedType\" [value]=\"'junk'\"\n                                        (change)=\"onRadioChange(selectedType)\"\n                                        [disabled]=\"users?.role ==='user' && this.users?.userType ==='client' || revopsTypeValue\">\n                                    <label class=\"form-check-label\" for=\"junk\">\n                                        <span class=\"ms-5\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\"\n                                                height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n                                                <path\n                                                    d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                    stroke-linejoin=\"round\" />\n                                            </svg></span>\n                                        <span class=\"ms-5 tag-class\"> Junk</span>\n                                    </label>\n                                </div>\n                            </div>\n\n\n                        </div>\n                    </div>\n\n\n                    <div class=\"row px-0 img-traffic mt-3 high-400px scroll-y\">\n                        <div class=\"col-md-3 border-gray mx-2 p-2 mt-5\" *ngFor=\"let obj of remainingImageArray\">\n                            <div class=\"position-relative\">\n                                <input *ngIf=\"!revopsTypeValue && selectedRadioType === 'duplicate'\" type=\"checkbox\"\n                                    [checked]=\"obj.selected\"\n                                    class=\"position-absolute absolute form-check-input cursor-pointer\"\n                                    (change)=\"onImageCheckboxChange($event, obj, 'duplicate')\"\n                                    [disabled]=\"obj.duplicateImagePath?.length > 0\" />\n\n                                <img class=\"img-src\"\n                                    [ngClass]=\"selectedRadioType !== 'duplicate' ? 'cursor-pointer' : 'cursor-pointer'\"\n                                    [src]=\"imageUrl + obj?.filePath\" (error)=\"obj.filePath = null\" alt=\"\"\n                                    (click)=\"handleImageClick($event, obj)\" />\n\n                                <div *ngIf=\"!obj?.filePath\" class=\"no-preview\">\n                                    <span class=\"mb-5\">\n                                        <svg width=\"23\" height=\"20\" viewBox=\"0 0 23 20\" fill=\"none\"\n                                            xmlns=\"http://www.w3.org/2000/svg\">\n                                            <g id=\"Group\">\n                                                <path id=\"Vector\"\n                                                    d=\"M6.5 6.32227H6.51M16.25 9.32227H21.5L18 16.3223L14.91 12.0023\"\n                                                    stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                    stroke-linejoin=\"round\" />\n                                                <path id=\"Vector_2\"\n                                                    d=\"M1.5 16.3229H5.26C5.63273 16.3255 5.99877 16.2239 6.31682 16.0295C6.63487 15.8352 6.89228 15.5558 7.06 15.2229L8.5 12.3229M1.5 18.3229V14.3229M17.5 6.82291L13.5 14.8229L3.11 9.62291C2.42033 9.27553 1.89635 8.6691 1.65272 7.93632C1.40909 7.20354 1.46564 6.4041 1.81 5.71291L3.19 2.92291C3.362 2.58014 3.59984 2.2746 3.88994 2.02375C4.18003 1.7729 4.5167 1.58165 4.88072 1.46093C5.24474 1.34021 5.62897 1.29239 6.01147 1.32018C6.39398 1.34797 6.76726 1.45084 7.11 1.62291L17.5 6.82291Z\"\n                                                    stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                    stroke-linejoin=\"round\" />\n                                            </g>\n                                        </svg>\n\n                                    </span>\n                                    <span class=\"header mb-5 text-center\">Preview not available</span>\n                                    <span class=\"description mb-5 text-center\">The selected camera is not available at\n                                        the\n                                        moment.</span>\n                                </div>\n                                <div class=\"row px-2 mb-2\">\n                                    <div class=\"col-md-7\">\n                                        <div class=\"py-2 img-doc-time\">Tango ID : {{obj?.templd ? obj?.templd :\n                                            obj?.tempId}}\n                                            <span *ngIf=\"obj?.status ==='approved'\" class=\"ms-2\"><svg style=\"width: 20px;\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n                                                    <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n                                                    <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                                        d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n                                                        fill=\"#12B76A\" />\n                                                </svg></span>\n                                            <span *ngIf=\"obj?.status ==='rejected'\" class=\"ms-2\"><svg style=\"width: 20px;\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n                                                    <g clip-path=\"url(#clip0_1428_59484)\">\n                                                        <path\n                                                            d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n                                                            fill=\"#FEE4E2\" />\n                                                        <path\n                                                            d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n                                                            stroke=\"#D92D20\" stroke-linecap=\"round\"\n                                                            stroke-linejoin=\"round\" />\n                                                    </g>\n                                                    <defs>\n                                                        <clipPath id=\"clip0_1428_59484\">\n                                                            <rect width=\"12\" height=\"12\" fill=\"white\"\n                                                                transform=\"translate(0.599609 0.5)\" />\n                                                        </clipPath>\n                                                    </defs>\n                                                </svg></span>\n                                        </div>\n                                        <div class=\"img-doc-value\">Entry Time : {{obj?.entryTme ? obj?.entryTme\n                                            :obj?.entryTime}}</div>\n                                    </div>\n                                    <div class=\"col-md-5 text-end py-3\">\n                                        <span *ngIf=\"obj?.revopsType ==='non-tagging'\"\n                                            ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\"\n                                                viewBox=\"0 0 19 18\" fill=\"none\">\n                                                <path\n                                                    d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                    stroke-linejoin=\"round\" />\n                                            </svg>\n                                        </span>\n                                        <span *ngIf=\"obj?.revopsType ==='duplicate'\">\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n                                                viewBox=\"0 0 20 21\" fill=\"none\">\n                                                <g clip-path=\"url(#clip0_2012_94635)\">\n                                                    <path\n                                                        d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                        stroke-linejoin=\"round\" />\n                                                </g>\n                                                <defs>\n                                                    <clipPath id=\"clip0_2012_94635\">\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\n                                                            transform=\"translate(0 0.686035)\" />\n                                                    </clipPath>\n                                                </defs>\n                                            </svg>\n                                        </span>\n                                        <span *ngIf=\"obj?.revopsType ==='employee'\">\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\"\n                                                viewBox=\"0 0 20 21\" fill=\"none\">\n                                                <g clip-path=\"url(#clip0_2012_94639)\">\n                                                    <path\n                                                        d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n                                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                        stroke-linejoin=\"round\" />\n                                                </g>\n                                                <defs>\n                                                    <clipPath id=\"clip0_2012_94639\">\n                                                        <rect width=\"20\" height=\"20\" fill=\"white\"\n                                                            transform=\"translate(0 0.686035)\" />\n                                                    </clipPath>\n                                                </defs>\n                                            </svg>\n                                        </span>\n                                        <span *ngIf=\"obj?.revopsType ==='house-keeping'\">\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\"\n                                                viewBox=\"0 0 21 21\" fill=\"none\">\n                                                <g clip-path=\"url(#clip0_2012_94643)\">\n                                                    <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                                        d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n                                                        fill=\"#475467\" />\n                                                </g>\n                                                <defs>\n                                                    <clipPath id=\"clip0_2012_94643\">\n                                                        <rect width=\"21\" height=\"20\" fill=\"white\"\n                                                            transform=\"translate(0 0.686035)\" />\n                                                    </clipPath>\n                                                </defs>\n                                            </svg>\n                                        </span>\n                                        <span *ngIf=\"obj?.revopsType ==='junk'\">\n\n                                            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\n                                                viewBox=\"0 0 24 24\" fill=\"none\">\n                                                <path\n                                                    d=\"M3 6H5M5 6H21M5 6V20C5 20.5304 5.21071 21.0391 5.58579 21.4142C5.96086 21.7893 6.46957 22 7 22H17C17.5304 22 18.0391 21.7893 18.4142 21.4142C18.7893 21.0391 19 20.5304 19 20V6H5ZM8 6V4C8 3.46957 8.21071 2.96086 8.58579 2.58579C8.96086 2.21071 9.46957 2 10 2H14C14.5304 2 15.0391 2.21071 15.4142 2.58579C15.7893 2.96086 16 3.46957 16 4V6M10 11V17M14 11V17\"\n                                                    stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                                    stroke-linejoin=\"round\" />\n                                            </svg>\n                                        </span>\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n\n                </div>\n            </section>\n        </div>\n    </section>\n</div>\n\n\n<ng-template #zoomPopup let-model>\n    <div class=\"p-4 m-4\">\n        <div class=\"modal-header border-0 p-0 w-100 flex-column align-items-start\">\n            <span *ngIf=\"popupType === 'non-tagging'\" class=\"my-3\">\n\n                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\n                    <rect width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\n                    <g clip-path=\"url(#clip0_2088_98337)\">\n                        <path\n                            d=\"M29.1693 13.3333V18.3333M29.1693 18.3333H24.1693M29.1693 18.3333L25.3026 14.7C24.407 13.8039 23.299 13.1493 22.0819 12.7973C20.8649 12.4453 19.5785 12.4073 18.3428 12.6869C17.1072 12.9665 15.9624 13.5545 15.0155 14.3962C14.0685 15.2378 13.3502 16.3056 12.9276 17.5M10.8359 26.6666V21.6666M10.8359 21.6666H15.8359M10.8359 21.6666L14.7026 25.3C15.5982 26.1961 16.7062 26.8506 17.9233 27.2027C19.1403 27.5547 20.4267 27.5927 21.6624 27.3131C22.898 27.0335 24.0428 26.4455 24.9897 25.6038C25.9367 24.7621 26.655 23.6943 27.0776 22.5\"\n                            stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                    </g>\n                    <defs>\n                        <clipPath id=\"clip0_2088_98337\">\n                            <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(10 10)\" />\n                        </clipPath>\n                    </defs>\n                </svg>\n            </span>\n            <!-- Heading -->\n            <h5 class=\"modal-title mb-2\">\n                <span *ngIf=\"popupType === 'employee'\">Tagging as employee/staff </span>\n                <span *ngIf=\"popupType === 'duplicate'\">Tagging as duplicates </span>\n                <span *ngIf=\"popupType === 'house-keeping'\">Tagging as house keeping </span>\n                <span *ngIf=\"popupType === 'non-tagging'\">Clear duplicates</span>\n                <span *ngIf=\"popupType ==='junk'\">Tagging as junk</span>\n\n            </h5>\n            <p class=\"mb-3\">\n                <span *ngIf=\"popupType === 'employee'\">Are you sure you want to tag this as employee/staff?</span>\n                <span *ngIf=\"popupType === 'duplicate'\">Are you sure you want to tag this as duplicates? </span>\n                <span *ngIf=\"popupType === 'house-keeping'\">Are you sure you want to tag this as house keeping? </span>\n                <span *ngIf=\"popupType === 'non-tagging'\">This will remove tagged duplicates and move them to\n                    'Non-tag'.</span>\n                <span *ngIf=\"popupType ==='junk'\">Are you sure you want to tag this as junk?</span>\n\n            </p>\n        </div>\n\n        <div class=\"w-100 mt-5 d-flex justify-content-end\">\n            <button class=\"btn btn-outline me-2\" (click)=\"cancelSubmit()\">Cancel</button>\n            <button *ngIf=\"popupType !== 'non-tagging'\" class=\"btn btn-primary\" (click)=\"submitValue(popupType)\">\n                Yes, Tag\n            </button>\n            <button *ngIf=\"popupType === 'non-tagging'\" class=\"btn btn-primary\" (click)=\"submitValue(popupType)\">\n                Yes, clear\n            </button>\n        </div>\n    </div>\n</ng-template>\n\n\n<ng-template #raisedPopup let-model>\n    <div class=\"p-4 m-4\">\n        <div class=\"modal-header border-0 p-0 w-100 flex-column align-items-start\">\n            <span class=\"my-3\">\n\n                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"40\" height=\"40\" viewBox=\"0 0 40 40\" fill=\"none\">\n                    <rect width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\n                    <path\n                        d=\"M21.251 11.0806C21.7405 11.0699 22.2153 11.2487 22.5762 11.5796L23.4922 12.4204C23.8089 12.7097 23.893 13.1017 23.8652 13.4263V13.4272C23.836 13.7478 23.6954 14.0592 23.4785 14.2944C23.3699 14.413 23.2865 14.5525 23.2314 14.7036C23.1764 14.8548 23.1512 15.0155 23.1582 15.1763C23.1652 15.337 23.2035 15.4953 23.2715 15.6411C23.3394 15.7869 23.4362 15.9172 23.5547 16.0259C23.6733 16.1346 23.8117 16.2198 23.9629 16.2749C24.1141 16.33 24.2748 16.3541 24.4355 16.3472C24.5961 16.3402 24.7537 16.3017 24.8994 16.2339C25.0089 16.1829 25.1106 16.116 25.2002 16.0356L25.3701 15.8657C25.5759 15.6748 25.8385 15.5408 26.1152 15.4907C26.2972 15.4546 26.485 15.4617 26.6641 15.5103C26.8439 15.5591 27.0103 15.649 27.1494 15.7729L27.1514 15.7749L28.2598 16.7905C28.445 16.9605 28.5948 17.1658 28.7002 17.394C28.8056 17.6223 28.8648 17.8694 28.874 18.1206C28.8832 18.372 28.8423 18.6234 28.7539 18.8589C28.6655 19.0941 28.5316 19.3096 28.3594 19.4927L20.1113 28.2583C19.937 28.4434 19.7268 28.5912 19.4941 28.6938C19.2614 28.7965 19.0102 28.8522 18.7559 28.856C18.5016 28.8597 18.2493 28.8119 18.0137 28.7163C17.7779 28.6206 17.5636 28.4784 17.3838 28.2983L16.2539 27.1685C15.7511 26.6656 15.8832 25.9552 16.1514 25.5542L16.2061 25.4644C16.3241 25.2486 16.3742 25.0008 16.3496 24.7544C16.3214 24.4731 16.197 24.2102 15.9971 24.0103C15.7971 23.8103 15.5343 23.6859 15.2529 23.6577C14.9715 23.6297 14.6887 23.6995 14.4531 23.856H14.4521C14.0494 24.1222 13.3407 24.2552 12.8379 23.7515L11.6797 22.5933C11.5034 22.4169 11.364 22.2074 11.2686 21.9771C11.1731 21.7467 11.1231 21.4999 11.123 21.2505C11.123 21.001 11.1731 20.7535 11.2686 20.5229C11.364 20.2926 11.5034 20.0831 11.6797 19.9067L19.9492 11.6362C20.2954 11.2902 20.7616 11.0912 21.251 11.0806ZM21.2783 12.3804C21.1237 12.3838 20.9765 12.4468 20.8672 12.5562L12.5967 20.8257C12.5409 20.8814 12.497 20.9482 12.4668 21.021C12.4367 21.0938 12.4209 21.1717 12.4209 21.2505C12.4209 21.3292 12.4367 21.4073 12.4668 21.48C12.497 21.5528 12.541 21.6196 12.5967 21.6753L13.7061 22.7837L13.7314 22.772C14.2169 22.4485 14.7993 22.3035 15.3799 22.3608C15.9608 22.4183 16.5042 22.6747 16.917 23.0874C17.3298 23.5002 17.587 24.0436 17.6445 24.6245C17.702 25.2055 17.5565 25.7892 17.2324 26.2749L17.2305 26.2759C17.2261 26.2822 17.2226 26.2893 17.2197 26.2964L18.3018 27.3804C18.3585 27.4372 18.4266 27.482 18.501 27.5122C18.5755 27.5425 18.6559 27.5574 18.7363 27.5562C18.8166 27.5549 18.8963 27.5378 18.9697 27.5054C19.043 27.4729 19.1091 27.4261 19.1641 27.3677L27.4131 18.6021C27.4673 18.5442 27.5093 18.4761 27.5371 18.4019C27.5649 18.3276 27.5781 18.2487 27.5752 18.1694C27.5722 18.0902 27.5538 18.0119 27.5205 17.9399C27.4872 17.8679 27.4394 17.8032 27.3809 17.7495L26.3223 16.7778C26.2925 16.7885 26.2648 16.8053 26.2432 16.8286C26.0217 17.0788 25.7529 17.2827 25.4521 17.4282C25.15 17.5743 24.8214 17.6585 24.4863 17.6763C24.1511 17.694 23.815 17.6452 23.499 17.5317C23.1832 17.4183 22.8928 17.2429 22.6455 17.0161C22.3982 16.7893 22.1988 16.5153 22.0586 16.2104C21.9183 15.9055 21.8404 15.5752 21.8291 15.2397C21.8178 14.9043 21.8737 14.57 21.9932 14.2563C22.1121 13.9442 22.2915 13.6587 22.5215 13.4165L22.5547 13.3657C22.5594 13.3552 22.5607 13.3437 22.5635 13.3325L21.6973 12.5386V12.5376C21.5833 12.4331 21.4329 12.377 21.2783 12.3804Z\"\n                        fill=\"#00A3FF\" stroke=\"#00A3FF\" stroke-width=\"0.3\" />\n                </svg>\n            </span>\n            <!-- Heading -->\n            <h5 class=\"modal-title mb-2\">\n                <span>Raise tickets for the following</span>\n\n            </h5>\n            <p class=\"mb-3\">\n                <span>Raising a ticket for footfall count issues. Make sure all records are identified for\n                    validation.</span>\n\n\n            </p>\n        </div>\n        <div class=\"row\">\n            <div class=\"col-md-3 my-4\">\n                <div class=\"border border-1 rounded p-3 h-100\">\n                    <div class=\"fw-semibold fs-5 mb-2\">\n                        {{tempRaisedPayload?.duplicateCount ? tempRaisedPayload?.duplicateCount :'0'}}\n                    </div>\n                    <div class=\"fw-semibold text-muted fs-6 mt-2\">\n                        Duplicates\n                    </div>\n                </div>\n            </div>\n\n            <div class=\"col-md-3 my-4\">\n                <div class=\"border border-1 rounded p-3 h-100\">\n                    <div class=\"fw-semibold fs-5 mb-2\">\n                        {{tempRaisedPayload?.employeeCount ? tempRaisedPayload?.employeeCount:'0' }}\n                    </div>\n                    <div class=\"fw-semibold text-muted fs-6 mt-2\">\n                        Employee\n                    </div>\n                </div>\n            </div>\n\n            <div class=\"col-md-3 my-4\">\n                <div class=\"border border-1 rounded p-3 h-100\">\n                    <div class=\"fw-semibold fs-5 mb-2\">\n                        {{tempRaisedPayload?.houseKeepingCount ? tempRaisedPayload?.houseKeepingCount :'0'}}\n                    </div>\n                    <div class=\"fw-semibold text-muted fs-6 mt-2\">\n                        House Keeping\n                    </div>\n                </div>\n            </div>\n            <div class=\"col-md-3 my-4\">\n                <div class=\"border border-1 rounded p-3 h-100\">\n                    <div class=\"fw-semibold fs-5 mb-2\">\n                        {{tempRaisedPayload?.junkCount ? tempRaisedPayload?.junkCount :'0'}}\n                    </div>\n                    <div class=\"fw-semibold text-muted fs-6 mt-2\">\n                        Junk\n                    </div>\n                </div>\n\n            </div>\n        </div>\n\n        <!-- Label and Textarea -->\n        <div class=\"my-3\">\n            <label class=\"form-label\">Description (Optional)</label>\n            <textarea rows=\"3\" [(ngModel)]=\"commentText\" class=\"form-control\"\n                placeholder=\"Enter description\"></textarea>\n        </div>\n        <div class=\"w-100 mt-5 d-flex justify-content-end\">\n\n            <button class=\"btn btn-outline w-50 me-2\" (click)=\"cancelRasied()\">Cancel</button>\n            <button class=\"btn btn-primary w-50\" (click)=\"submitRaised()\">\n                Raise Ticket\n            </button>\n        </div>\n    </div>\n</ng-template>\n\n\n<ng-template #imagePopup let-model>\n    <div class=\"mx-4\">\n        <div class=\"row\">\n            <div class=\" p-2  mb-2 mt-5\">\n                <div *ngIf=\"isModalOpen\" class=\"position-relative border-gray p-2 \">\n                    <!-- <button *ngIf=\"canNavigateLeft\" (click)=\"navigateImage('left')\"\n                                    class=\"btn btn-light position-absolute start-0 top-50 z-index-10\">\n                                    ◀\n                                </button> -->\n\n                    <!-- Main Image -->\n                    <!-- <img class=\" cursor-pointer w-100 h-525px\" \n                        [src]=\"imageUrl + (tempModalImage?.filePath || selectImageArray?.filePath)\"\n                        appMagnifier alt=\"\"> -->\n                    <img class=\" cursor-pointer w-100 h-525px\"\n                        [src]=\"imageUrl + (tempModalImage?.filePath || selectImageArray?.filePath)\" alt=\"\">\n                    <!-- <button *ngIf=\"canNavigateRight\" (click)=\"navigateImage('right')\"\n                                    class=\"btn btn-light position-absolute end-0 top-50 z-index-10\">\n                                    ▶\n                                </button> -->\n\n                    <!-- Right arrow button -->\n                    <div class=\"row px-2 mb-2\">\n                        <div class=\"col-md-7\">\n                            <div class=\"py-2 img-doc-time\">Tango ID : {{(tempModalImage || selectImageArray)?.templd ||\n                                (tempModalImage || selectImageArray)?.tempId}}\n                                <span *ngIf=\"(tempModalImage || selectImageArray)?.status ==='approved'\"\n                                    class=\"ms-2\"><svg style=\"width: 20px;\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"11\" viewBox=\"0 0 10 11\" fill=\"none\">\n                                        <rect y=\"0.5\" width=\"10\" height=\"10\" rx=\"5\" fill=\"#D1FADF\" />\n                                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                            d=\"M7.1222 3.57919L4.13887 6.45836L3.3472 5.61253C3.20137 5.47503 2.9722 5.46669 2.80553 5.58336C2.64303 5.70419 2.5972 5.91669 2.6972 6.08753L3.6347 7.61253C3.72637 7.75419 3.8847 7.84169 4.06387 7.84169C4.2347 7.84169 4.3972 7.75419 4.48887 7.61253C4.63887 7.41669 7.50137 4.00419 7.50137 4.00419C7.87637 3.62086 7.4222 3.28336 7.1222 3.57503V3.57919Z\"\n                                            fill=\"#12B76A\" />\n                                    </svg></span>\n                                <span *ngIf=\"(tempModalImage || selectImageArray)?.status ==='rejected'\"\n                                    class=\"ms-2\"><svg style=\"width: 20px;\n    height: 20px;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"13\" height=\"13\" viewBox=\"0 0 13 13\" fill=\"none\">\n                                        <g clip-path=\"url(#clip0_1428_59484)\">\n                                            <path\n                                                d=\"M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n                                                fill=\"#FEE4E2\" />\n                                            <path\n                                                d=\"M8.09961 5L5.09961 8M5.09961 5L8.09961 8M4.52961 1.5H8.66961L11.5996 4.43V8.57L8.66961 11.5H4.52961L1.59961 8.57V4.43L4.52961 1.5Z\"\n                                                stroke=\"#D92D20\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                                        </g>\n                                        <defs>\n                                            <clipPath id=\"clip0_1428_59484\">\n                                                <rect width=\"12\" height=\"12\" fill=\"white\"\n                                                    transform=\"translate(0.599609 0.5)\" />\n                                            </clipPath>\n                                        </defs>\n                                    </svg></span>\n                            </div>\n                            <div class=\"img-doc-value\">Entry Time : {{(tempModalImage || selectImageArray)?.entryTme ||\n                                (tempModalImage || selectImageArray)?.entryTime}}</div>\n                        </div>\n                        <div class=\"col-md-5 text-end py-3\">\n                            <span *ngIf=\"(tempModalImage || selectImageArray)?.revopsType ==='non-tagging'\"\n                                ngbTooltip=\"Yet to tag the customer\" placement=\"top\">\n                                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"19\" height=\"18\" viewBox=\"0 0 19 18\"\n                                    fill=\"none\">\n                                    <path\n                                        d=\"M6.02344 5.625H6.03094M16.2159 10.4325L10.8384 15.81C10.6991 15.9495 10.5337 16.0601 10.3516 16.1356C10.1695 16.2111 9.97431 16.2499 9.77719 16.2499C9.58006 16.2499 9.38487 16.2111 9.20278 16.1356C9.02068 16.0601 8.85525 15.9495 8.71594 15.81L2.27344 9.375V1.875H9.77344L16.2159 8.3175C16.4953 8.59854 16.6521 8.97872 16.6521 9.375C16.6521 9.77128 16.4953 10.1515 16.2159 10.4325Z\"\n                                        stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                        stroke-linejoin=\"round\" />\n                                </svg>\n                            </span>\n                            <span *ngIf=\"selectImageArray?.revopsType ==='duplicate'\">\n                                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\"\n                                    fill=\"none\">\n                                    <g clip-path=\"url(#clip0_2012_94635)\">\n                                        <path\n                                            d=\"M4.16797 13.1859H3.33464C2.89261 13.1859 2.46868 13.0103 2.15612 12.6977C1.84356 12.3852 1.66797 11.9612 1.66797 11.5192V4.01921C1.66797 3.57718 1.84356 3.15326 2.15612 2.84069C2.46868 2.52813 2.89261 2.35254 3.33464 2.35254H10.8346C11.2767 2.35254 11.7006 2.52813 12.0131 2.84069C12.3257 3.15326 12.5013 3.57718 12.5013 4.01921V4.85254M9.16797 8.18587H16.668C17.5884 8.18587 18.3346 8.93206 18.3346 9.85254V17.3525C18.3346 18.273 17.5884 19.0192 16.668 19.0192H9.16797C8.24749 19.0192 7.5013 18.273 7.5013 17.3525V9.85254C7.5013 8.93206 8.24749 8.18587 9.16797 8.18587Z\"\n                                            stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                            stroke-linejoin=\"round\" />\n                                    </g>\n                                    <defs>\n                                        <clipPath id=\"clip0_2012_94635\">\n                                            <rect width=\"20\" height=\"20\" fill=\"white\"\n                                                transform=\"translate(0 0.686035)\" />\n                                        </clipPath>\n                                    </defs>\n                                </svg>\n                            </span>\n                            <span *ngIf=\"(tempModalImage || selectImageArray)?.revopsType ==='employee'\">\n                                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\"\n                                    fill=\"none\">\n                                    <g clip-path=\"url(#clip0_2012_94639)\">\n                                        <path\n                                            d=\"M14.1654 18.186V16.5194C14.1654 15.6353 13.8142 14.7875 13.1891 14.1623C12.5639 13.5372 11.7161 13.186 10.832 13.186H4.16536C3.28131 13.186 2.43346 13.5372 1.80834 14.1623C1.18322 14.7875 0.832031 15.6353 0.832031 16.5194V18.186M19.1654 18.186V16.5194C19.1648 15.7808 18.919 15.0633 18.4665 14.4796C18.014 13.8959 17.3805 13.479 16.6654 13.2944M13.332 3.29437C14.049 3.47795 14.6846 3.89495 15.1384 4.47963C15.5922 5.0643 15.8386 5.78339 15.8386 6.52354C15.8386 7.26368 15.5922 7.98277 15.1384 8.56744C14.6846 9.15212 14.049 9.56912 13.332 9.7527M10.832 6.51937C10.832 8.36032 9.33965 9.8527 7.4987 9.8527C5.65775 9.8527 4.16536 8.36032 4.16536 6.51937C4.16536 4.67842 5.65775 3.18604 7.4987 3.18604C9.33965 3.18604 10.832 4.67842 10.832 6.51937Z\"\n                                            stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\n                                            stroke-linejoin=\"round\" />\n                                    </g>\n                                    <defs>\n                                        <clipPath id=\"clip0_2012_94639\">\n                                            <rect width=\"20\" height=\"20\" fill=\"white\"\n                                                transform=\"translate(0 0.686035)\" />\n                                        </clipPath>\n                                    </defs>\n                                </svg>\n                            </span>\n                            <span *ngIf=\"(tempModalImage || selectImageArray)?.revopsType ==='house-keeping'\">\n                                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"21\" viewBox=\"0 0 21 21\"\n                                    fill=\"none\">\n                                    <g clip-path=\"url(#clip0_2012_94643)\">\n                                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                            d=\"M9.26219 1.36722C10.1777 0.458974 11.662 0.458974 12.5776 1.36722L20.3133 9.04153C21.2287 9.9498 21.2287 11.4223 20.3133 12.3306L12.5776 20.0049C11.662 20.9131 10.1777 20.9131 9.26219 20.0049L7.05166 17.8119L5.02538 19.8221C4.10987 20.7303 2.62553 20.7303 1.71002 19.8221C0.79451 18.9139 0.79451 17.4413 1.71002 16.5331L3.7363 14.5229L1.52648 12.3306C0.610966 11.4223 0.610966 9.9498 1.52648 9.04153L9.26219 1.36722ZM11.4724 2.46357C11.1672 2.16082 10.6724 2.16082 10.3672 2.46357L4.84145 7.94556L13.6823 16.7163L19.2081 11.2342C19.5133 10.9315 19.5133 10.4406 19.2081 10.1379L15.3399 6.30032L14.0505 7.5794C13.7453 7.88214 13.2506 7.88214 12.9455 7.5794C12.6403 7.27664 12.6403 6.78579 12.9455 6.48305L14.2347 5.20397L13.1299 4.10786L9.99872 7.21418C9.69354 7.51692 9.19873 7.51692 8.89356 7.21418C8.58838 6.91143 8.58838 6.42058 8.89356 6.11783L12.0247 3.01151L11.4724 2.46357ZM12.5771 17.8125L3.73633 9.04191L2.6316 10.1379C2.32642 10.4406 2.32642 10.9315 2.6316 11.2342L10.3672 18.9085C10.6724 19.2113 11.1672 19.2113 11.4724 18.9085L12.5771 17.8125ZM4.84132 15.6192L2.81514 17.6294C2.50997 17.9321 2.50997 18.423 2.81514 18.7258C3.12031 19.0285 3.61509 19.0285 3.92026 18.7258L5.94644 16.7156L4.84132 15.6192Z\"\n                                            fill=\"#475467\" />\n                                    </g>\n                                    <defs>\n                                        <clipPath id=\"clip0_2012_94643\">\n                                            <rect width=\"21\" height=\"20\" fill=\"white\"\n                                                transform=\"translate(0 0.686035)\" />\n                                        </clipPath>\n                                    </defs>\n                                </svg>\n                            </span>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </div>\n\n        <!-- <div class=\"modal-footer py-2 px-0\"> -->\n\n        <div class=\"w-100 py-2 mb-2 px-0 d-flex justify-content-end\">\n\n            <button class=\"btn btn-outline\" (click)=\"closeImage()\">Close</button>\n\n        </div>\n        <!-- </div> -->\n    </div>\n</ng-template>\n\n<!-- Footfall Trends Template -->\n<ng-template #footfallTrendsTemplate>\n    <div class=\"row w-100 mb-3\">\n        <!-- Total Footfall Card -->\n        <div class=\"col-md-4 mb-3 mb-md-0\">\n            <div class=\"metric-card\">\n                <div class=\"metric-header\">\n                    <div class=\"d-flex align-items-center gap-2\">\n                        <span class=\"metric-title\">Total Footfall</span>\n                        <svg placement=\"top\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\"\n                            viewBox=\"0 0 24 24\" fill=\"none\">\n                            <path\n                                d=\"M4 18H9.5V19.25C9.5 19.9793 9.21027 20.6788 8.69454 21.1945C8.17882 21.7103 7.47935 22 6.75 22C6.02065 22 5.32118 21.7103 4.80546 21.1945C4.28973 20.6788 4 19.9793 4 19.25V18ZM8 6.11999C10 6.11999 11 8.99999 11 11C11 12 10.5 13 10 14.5L9.5 16H4C4 15 3.5 13.5 3.5 11C3.5 8.49999 5.498 6.11999 8 6.11999ZM20.054 14.098L19.837 15.329C19.7023 16.0396 19.2931 16.6686 18.698 17.0796C18.1029 17.4907 17.3698 17.6508 16.6576 17.5252C15.9453 17.3996 15.3111 16.9984 14.8925 16.4086C14.4739 15.8188 14.3045 15.0878 14.421 14.374L14.637 13.144L20.054 14.098ZM18.178 1.70499C20.642 2.13899 22.196 4.82999 21.762 7.29199C21.328 9.75399 20.575 11.144 20.402 12.129L14.985 11.174L14.753 9.60999C14.521 8.04599 14.203 6.97399 14.376 5.98999C14.723 4.01999 16.208 1.35799 18.178 1.70499Z\"\n                                fill=\"#00A3FF\" />\n                        </svg>\n                    </div>\n                </div>\n                <div class=\"metric-value\">{{ getCurrentFootfall() || 0 }}</div>\n                <div class=\"metric-trend\" [ngClass]=\"getFootfallPercentageChange() >= 0 ? 'up' : 'down'\">\n                    <svg *ngIf=\"getFootfallPercentageChange() >= 0\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\n                        fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                        <path d=\"M6 2L10 6H7V10H5V6H2L6 2Z\" fill=\"#10B981\" />\n                    </svg>\n                    <svg *ngIf=\"getFootfallPercentageChange() < 0\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\n                        fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                        <path d=\"M6 10L2 6H5V2H7V6H10L6 10Z\" fill=\"#F04438\" />\n                    </svg>\n                    <span>{{ getFootfallPercentageChange() >= 0 ? '+' : '' }}{{\n                        getFootfallPercentageChange() }}% vs Yesterday</span>\n                </div>\n            </div>\n        </div>\n        <!-- Total Downtime Card -->\n        <div class=\"col-md-4 mb-3 mb-md-0\">\n            <div class=\"metric-card\">\n                <div class=\"metric-header\">\n                    <div class=\"d-flex align-items-center gap-2\">\n                        <span class=\"metric-title\">Total Downtime</span>\n                        <div class=\"downtime-icons\">\n                            <svg width=\"40\" height=\"41\" viewBox=\"0 0 40 41\" fill=\"none\"\n                                xmlns=\"http://www.w3.org/2000/svg\">\n                                <rect y=\"0.5\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#DAF1FF\" />\n                                <path\n                                    d=\"M21.9004 12.1675C22.9958 12.1675 24.0423 12.3918 24.9977 12.7987C25.9889 13.2207 26.8809 13.8402 27.6279 14.6087C28.3734 15.3756 28.9756 16.2931 29.3857 17.3162C29.7813 18.299 29.9993 19.3756 29.9993 20.5008C29.9993 21.6277 29.7813 22.7043 29.3857 23.6871C28.9756 24.7068 28.3734 25.6244 27.6263 26.3929C26.8809 27.1598 25.9889 27.7793 24.9945 28.2012C24.0391 28.6081 22.9925 28.8325 21.8988 28.8325C20.8034 28.8325 19.7568 28.6081 18.8014 28.2012C17.8102 27.7793 16.9183 27.1598 16.1729 26.3929L16.1712 26.3912C15.4242 25.6227 14.8236 24.7052 14.4134 23.6871C14.2865 23.3707 14.1774 23.0459 14.0879 22.7127C14.2572 22.7294 14.4297 22.7378 14.6038 22.7378C14.9342 22.7378 15.2565 22.7076 15.5706 22.649C15.6227 22.8098 15.6797 22.9688 15.7415 23.1246C16.0785 23.9617 16.5732 24.7152 17.1885 25.3481C17.8037 25.981 18.5378 26.49 19.3499 26.8366C20.1328 27.1698 20.9938 27.3557 21.8988 27.3557C22.8037 27.3557 23.6631 27.1715 24.4476 26.8366C25.2614 26.49 25.9938 25.981 26.6091 25.3481C27.2243 24.7152 27.7191 23.9601 28.056 23.1246C28.3799 22.3192 28.5605 21.4334 28.5605 20.5025C28.5605 19.5715 28.3815 18.6875 28.056 17.8804C27.7191 17.0432 27.2243 16.2898 26.6091 15.6569C25.9938 15.024 25.2598 14.5149 24.4476 14.1684C23.6647 13.8352 22.8037 13.6493 21.8988 13.6493C20.9938 13.6493 20.1344 13.8335 19.3499 14.1684C19.2799 14.1985 19.21 14.2303 19.1416 14.2621C18.8747 13.8301 18.5524 13.4383 18.1829 13.0984C18.3848 12.9913 18.5915 12.8925 18.8014 12.8021C19.7601 12.3918 20.805 12.1675 21.9004 12.1675ZM20.971 16.5393C20.971 16.335 21.0524 16.1508 21.181 16.0169C21.3112 15.8829 21.4902 15.8009 21.6888 15.8009C21.8874 15.8009 22.0664 15.8829 22.1966 16.0169C22.3268 16.1508 22.4066 16.335 22.4066 16.5393V20.4271L25.2305 22.1501C25.3997 22.2539 25.5137 22.4196 25.5592 22.6021C25.6048 22.7847 25.5837 22.9856 25.4827 23.1597V23.1614C25.3818 23.3355 25.2207 23.4527 25.0433 23.4996C24.8659 23.5465 24.6706 23.5247 24.5013 23.4209H24.4997L21.3405 21.4937C21.2314 21.4318 21.1419 21.3413 21.0768 21.2342C21.0101 21.122 20.971 20.9897 20.971 20.8491V16.5393Z\"\n                                    fill=\"#667085\" />\n                                <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\n                                    d=\"M14.3913 12.6095C16.8164 12.6095 18.7826 14.6321 18.7826 17.1269C18.7826 19.6218 16.8164 21.6444 14.3913 21.6444C11.9661 21.6444 10 19.6218 10 17.1269C10 14.6321 11.9661 12.6095 14.3913 12.6095ZM14.3913 19.7172L16.748 16.7201H15.2848V15.1261H13.4977V16.7201H12.0345L14.3913 19.7172Z\"\n                                    fill=\"#F04438\" />\n                            </svg>\n                        </div>\n                    </div>\n                </div>\n                <div class=\"metric-value\">{{ getFormattedDowntime() || '-' }}</div>\n                <!-- <div class=\"metric-tag success\" *ngIf=\"hasDowntime()\"> -->\n                <!-- <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                        <path d=\"M11.6667 3.5L5.25 9.91667L2.33334 7\" stroke=\"#10B981\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                    </svg> -->\n                <!-- <span>Issue submitted</span>\n                    <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                        <path d=\"M4.5 2.5L7.5 5.5L10.5 2.5\" stroke=\"#10B981\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                    </svg> -->\n                <!-- </div> -->\n            </div>\n        </div>\n\n        <!-- Ticket Status Card -->\n        <div class=\"col-md-4\">\n            <div class=\"metric-card\">\n                <div class=\"metric-header\">\n                    <span class=\"metric-title\">Ticket status</span>\n                </div>\n                <div class=\"metric-value\">{{ getTicketStatus() === '-' ? '-' : (getTicketStatus() |\n                    titlecase) }}</div>\n            </div>\n        </div>\n    </div>\n</ng-template>\n\n<ng-template #resetRequestPopup let-model>\n    <div class=\"p-4\">\n        <div class=\"modal-header border-0 p-0 w-100\">\n            <h5 class=\"modal-title mb-3 fw-bold\">\n                Reset request.\n            </h5>\n        </div>\n        <div class=\"modal-body p-0\">\n            <p class=\"text-muted mb-3\">\n                You're requesting to re-enable footfall tickets, disabled after three instances of exceeding 95%\n                accuracy.\n            </p>\n            <p class=\"text-muted mb-0\">\n                Please ensure future accuracy stays on or within 95%.\n            </p>\n        </div>\n        <div class=\"modal-footer border-0 p-0 mt-4 d-flex justify-content-end gap-2\">\n            <button type=\"button\" class=\"btn btn-outline\" (click)=\"cancelResetRequest()\">\n                Cancel\n            </button>\n            <button type=\"button\" class=\"btn btn-primary\" (click)=\"submitResetRequest()\">\n                Send Request\n            </button>\n        </div>\n    </div>\n</ng-template>\n\n<ng-template #ticketStatusTemplate let-model>\n    <!-- Ticket Review Card (shown when ticket status is raised) -->\n    <div class=\"col-12 mb-3\" *ngIf=\"(isTicketRaised() || isTicketClosed()) && getTaggingData('tagging')\">\n        <div class=\"ticket-review-card\">\n            <!-- Actual Footfall Header -->\n            <div class=\"actual-footfall-header\">\n                <span class=\"actual-footfall-number\">{{ getTaggingData('tagging')?.footfall || 0 }}</span>\n                <span class=\"actual-footfall-label\">Actual Footfall</span>\n            </div>\n            <!-- Ticket Created By Section -->\n            <div class=\"ticket-creator-section\"\n                *ngIf=\"getTaggingData('tagging')?.createdByEmail || getTaggingData('tagging')?.createdAt\">\n                <div class=\"d-flex align-items-center gap-2\">\n                    <!-- <div class=\"creator-avatar\" *ngIf=\"getTaggingData()?.createdByEmail?.profilePicture\">\n                        <img [src]=\"getTaggingData()?.createdByEmail?.profilePicture\" alt=\"Profile\" />\n                    </div> -->\n                    <div class=\"creator-avatar-placeholder\"\n                        *ngIf=\"!getTaggingData('tagging')?.createdByEmail?.profilePicture\">\n                        <svg width=\"32\" height=\"32\" viewBox=\"0 0 32 32\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                            <rect width=\"32\" height=\"32\" rx=\"16\" fill=\"#EAF8FF\" />\n                            <path\n                                d=\"M16 10C17.6569 10 19 11.3431 19 13C19 14.6569 17.6569 16 16 16C14.3431 16 13 14.6569 13 13C13 11.3431 14.3431 10 16 10Z\"\n                                fill=\"#00A3FF\" />\n                            <path d=\"M11 22C11 19.2386 13.2386 17 16 17C18.7614 17 21 19.2386 21 22V23H11V22Z\"\n                                fill=\"#00A3FF\" />\n                        </svg>\n                    </div>\n                    <div class=\"creator-info\">\n                        <div class=\"creator-label\">Ticket created by</div>\n                        <div class=\"creator-details\">\n                            <span class=\"creator-email\">{{ getTaggingData('tagging')?.createdByEmail ||\n                                getTaggingData('tagging')?.createdByEmail || 'N/A' }}</span>\n                            <span class=\"creator-separator\" *ngIf=\"getTaggingData('tagging')?.createdAt\">•</span>\n                            <span class=\"creator-time\" *ngIf=\"getTaggingData('tagging')?.createdAt\">{{\n                                getTaggingData('tagging')?.createdAt | date:'h:mm:ss a - d MMM yyyy' }}</span>\n                        </div>\n                    </div>\n                </div>\n            </div>\n\n            <!-- Ticket Revised Footfall and Metrics -->\n            <div class=\"revised-footfall-section\">\n                <div class=\"metrics-row\">\n                    <div class=\"metric-item\">\n                        <div class=\"metric-number blue-text\">\n                            {{ getTaggingData('tagging')?.revicedFootfall || 0 }}\n                            <span class=\"metric-percentage\">\n                                ({{ getTaggingData('tagging')?.revicedPerc || 0 }}%)\n                            </span>\n                            <span class=\"metric-arrow\">↓</span>\n                        </div>\n                        <div class=\"metric-label\">Revised footfall</div>\n                    </div>\n                    <div class=\"metric-item\">\n                        <div class=\"metric-number\">({{ getRevisionCalculation('tagging')}}%)</div>\n                        <div class=\"metric-label\">Ticket%</div>\n                    </div>\n                    <div class=\"metric-item\">\n                        <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'duplicate') }}</div>\n                        <div class=\"metric-label\">Duplicates</div>\n                    </div>\n                    <div class=\"metric-item\">\n                        <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'employee') }}</div>\n                        <div class=\"metric-label\">Employee/Staff</div>\n                    </div>\n                    <div class=\"metric-item\">\n                        <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'junk') }}</div>\n                        <div class=\"metric-label\">Junk</div>\n                    </div>\n                    <div class=\"metric-item\">\n                        <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'houseKeeping') }}</div>\n                        <div class=\"metric-label\">House Keeping</div>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </div>\n\n    <!-- Ticket Final revision Card (shown when ticket status is closed) -->\n    <div class=\"col-12 mb-3\" *ngIf=\"isTicketClosed() && getTaggingData('finalreview')\">\n        <div class=\"ticket-review-card\">\n            <!-- Ticket card section in revision start -->\n\n            <!-- Actual Footfall Header -->\n            <div class=\"actual-footfall-header\">\n                <span class=\"actual-footfall-number\">{{ getTaggingData('tagging')?.footfall || 0 }}</span>\n                <span class=\"actual-footfall-label\">Actual Footfall</span>\n            </div>\n            <!-- Ticket Created By Section -->\n            <div class=\"ticket-creator-section\"\n                *ngIf=\"getTaggingData('tagging')?.createdByEmail || getTaggingData('tagging')?.createdAt\">\n                <div class=\"d-flex align-items-center gap-2\">\n                    <!-- <div class=\"creator-avatar\" *ngIf=\"getTaggingData()?.createdByEmail?.profilePicture\">\n                        <img [src]=\"getTaggingData()?.createdByEmail?.profilePicture\" alt=\"Profile\" />\n                    </div> -->\n                    <div class=\"creator-avatar-placeholder\"\n                        *ngIf=\"!getTaggingData('tagging')?.createdByEmail?.profilePicture\">\n                        <svg width=\"32\" height=\"32\" viewBox=\"0 0 32 32\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                            <rect width=\"32\" height=\"32\" rx=\"16\" fill=\"#EAF8FF\" />\n                            <path\n                                d=\"M16 10C17.6569 10 19 11.3431 19 13C19 14.6569 17.6569 16 16 16C14.3431 16 13 14.6569 13 13C13 11.3431 14.3431 10 16 10Z\"\n                                fill=\"#00A3FF\" />\n                            <path d=\"M11 22C11 19.2386 13.2386 17 16 17C18.7614 17 21 19.2386 21 22V23H11V22Z\"\n                                fill=\"#00A3FF\" />\n                        </svg>\n                    </div>\n                    <div class=\"creator-info\">\n                        <div class=\"creator-label\">Ticket created by</div>\n                        <div class=\"creator-details\">\n                            <span class=\"creator-email\">{{ getTaggingData('tagging')?.createdByEmail ||\n                                getTaggingData('tagging')?.createdByEmail || 'N/A' }}</span>\n                            <span class=\"creator-separator\" *ngIf=\"getTaggingData('tagging')?.createdAt\">•</span>\n                            <span class=\"creator-time\" *ngIf=\"getTaggingData('tagging')?.createdAt\">{{\n                                getTaggingData('tagging')?.createdAt | date:'h:mm:ss a - d MMM yyyy' }}</span>\n                        </div>\n                    </div>\n                </div>\n            </div>\n\n            <!-- Ticket Revised Footfall and Metrics -->\n            <div class=\"revised-footfall-section\">\n                <div class=\"metrics-row\">\n                    <div class=\"metric-item\">\n                        <div class=\"metric-number blue-text\">\n                            {{ getTaggingData('tagging')?.revicedFootfall || 0 }}\n                            <span class=\"metric-percentage\">\n                                ({{ getTaggingData('tagging')?.revicedPerc || 0 }}%)\n                            </span>\n                            <span class=\"metric-arrow\">↓</span>\n                        </div>\n                        <div class=\"metric-label\">Revised footfall</div>\n                    </div>\n                    <div class=\"metric-item\">\n                        <div class=\"metric-number\">({{ getRevisionCalculation('tagging')}}%)</div>\n                        <div class=\"metric-label\">Ticket%</div>\n                    </div>\n                    <div class=\"metric-item\">\n                        <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'duplicate') }}</div>\n                        <div class=\"metric-label\">Duplicates</div>\n                    </div>\n                    <div class=\"metric-item\">\n                        <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'employee') }}</div>\n                        <div class=\"metric-label\">Employee/Staff</div>\n                    </div>\n                    <div class=\"metric-item\">\n                        <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'junk') }}</div>\n                        <div class=\"metric-label\">Junk</div>\n                    </div>\n                    <div class=\"metric-item\">\n                        <div class=\"metric-number\">{{ getCountByType(getTaggingData('tagging'), 'houseKeeping') }}</div>\n                        <div class=\"metric-label\">House Keeping</div>\n                    </div>\n                </div>\n            </div>\n            <!-- Ticket card section in revision end -->\n\n            <!-- Final Revision Section -->\n            <div class=\"revision-section\">\n                <div class=\"revision-title\">Final revision</div>\n                <div class=\"final-revision-note\">\n                    Please reach centraloperations&#64;lenskart.in for any further discrepancies\n                </div>\n                <div class=\"revised-footfall-section\">\n                    <div class=\"metrics-row\">\n                        <div class=\"metric-item\">\n                            <div class=\"metric-number blue-text\">\n                                {{ getTaggingData('finalreview')?.revicedFootfall || 0 }}\n                                <span class=\"metric-percentage\">\n                                    ({{ getTaggingData('finalreview')?.revicedPerc || 0}}%)\n                                </span>\n                                <span class=\"metric-arrow\">↑</span>\n                            </div>\n                            <div class=\"metric-label\">Revised footfall</div>\n                        </div>\n                        <div class=\"metric-item\">\n                            <div class=\"metric-number\">({{ getRevisionCalculation('finalreview')}}%)</div>\n                            <div class=\"metric-label\">Ticket%</div>\n                        </div>\n                        <div class=\"metric-item\">\n                            <div class=\"metric-number\">{{ getCountByType(getTaggingData('finalreview'), 'duplicate') }}\n                            </div>\n                            <div class=\"metric-label\">Duplicates</div>\n                        </div>\n                        <div class=\"metric-item\">\n                            <div class=\"metric-number\">{{ getCountByType(getTaggingData('finalreview'), 'employee') }}\n                            </div>\n                            <div class=\"metric-label\">Employee/Staff</div>\n                        </div>\n                        <div class=\"metric-item\">\n                            <div class=\"metric-number\">{{ getCountByType(getTaggingData('finalreview'), 'junk') }}</div>\n                            <div class=\"metric-label\">Junk</div>\n                        </div>\n                        <div class=\"metric-item\">\n                            <div class=\"metric-number\">{{ getCountByType(getTaggingData('finalreview'), 'houseKeeping')\n                                }}</div>\n                            <div class=\"metric-label\">House Keeping</div>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </div>\n</ng-template>"]}
|