tango-app-ui-manage-tickets 3.7.0-beta.7 → 3.7.0-beta.70
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/.eslintrc.json +37 -0
- package/ng-package.json +7 -0
- package/package.json +12 -25
- package/src/lib/components/add-csm-modal/add-csm-modal.component.html +32 -0
- package/src/lib/components/add-csm-modal/add-csm-modal.component.scss +14 -0
- package/src/lib/components/add-csm-modal/add-csm-modal.component.spec.ts +23 -0
- package/src/lib/components/add-csm-modal/add-csm-modal.component.ts +94 -0
- package/src/lib/components/audit-log/audit-log.component.html +1 -0
- package/src/lib/components/audit-log/audit-log.component.scss +0 -0
- package/src/lib/components/audit-log/audit-log.component.spec.ts +23 -0
- package/src/lib/components/audit-log/audit-log.component.ts +10 -0
- package/src/lib/components/audit-mapping-list/audit-mapping-list.component.html +234 -0
- package/src/lib/components/audit-mapping-list/audit-mapping-list.component.scss +186 -0
- package/src/lib/components/audit-mapping-list/audit-mapping-list.component.spec.ts +23 -0
- package/src/lib/components/audit-mapping-list/audit-mapping-list.component.ts +536 -0
- package/src/lib/components/audit-metrics/audit-metrics.component.html +345 -0
- package/src/lib/components/audit-metrics/audit-metrics.component.scss +34 -0
- package/src/lib/components/audit-metrics/audit-metrics.component.spec.ts +23 -0
- package/src/lib/components/audit-metrics/audit-metrics.component.ts +292 -0
- package/src/lib/components/audit-report-popup/audit-report-popup.component.html +111 -0
- package/src/lib/components/audit-report-popup/audit-report-popup.component.scss +101 -0
- package/src/lib/components/audit-report-popup/audit-report-popup.component.spec.ts +23 -0
- package/src/lib/components/audit-report-popup/audit-report-popup.component.ts +397 -0
- package/src/lib/components/audit-retag/audit-retag.component.html +129 -0
- package/src/lib/components/audit-retag/audit-retag.component.scss +146 -0
- package/src/lib/components/audit-retag/audit-retag.component.spec.ts +23 -0
- package/src/lib/components/audit-retag/audit-retag.component.ts +497 -0
- package/src/lib/components/comment-model/comment-model.component.html +24 -0
- package/src/lib/components/comment-model/comment-model.component.scss +20 -0
- package/src/lib/components/comment-model/comment-model.component.spec.ts +23 -0
- package/src/lib/components/comment-model/comment-model.component.ts +53 -0
- package/src/lib/components/count/count.component.html +54 -0
- package/src/lib/components/count/count.component.scss +14 -0
- package/src/lib/components/count/count.component.spec.ts +23 -0
- package/src/lib/components/count/count.component.ts +82 -0
- package/src/lib/components/custom-select/custom-select.component.html +134 -0
- package/src/lib/components/custom-select/custom-select.component.scss +204 -0
- package/src/lib/components/custom-select/custom-select.component.spec.ts +23 -0
- package/src/lib/components/custom-select/custom-select.component.ts +189 -0
- package/src/lib/components/filter-options/filter-options.component.html +51 -0
- package/src/lib/components/filter-options/filter-options.component.scss +102 -0
- package/src/lib/components/filter-options/filter-options.component.spec.ts +23 -0
- package/src/lib/components/filter-options/filter-options.component.ts +38 -0
- package/src/lib/components/footfall-dic/footfall-dic.component.html +1275 -0
- package/src/lib/components/footfall-dic/footfall-dic.component.scss +273 -0
- package/src/lib/components/footfall-dic/footfall-dic.component.spec.ts +23 -0
- package/src/lib/components/footfall-dic/footfall-dic.component.ts +1206 -0
- package/src/lib/components/footfall-dicview/footfall-dicview.component.html +1136 -0
- package/src/lib/components/footfall-dicview/footfall-dicview.component.scss +416 -0
- package/src/lib/components/footfall-dicview/footfall-dicview.component.spec.ts +23 -0
- package/src/lib/components/footfall-dicview/footfall-dicview.component.ts +1168 -0
- package/src/lib/components/footfall-popup/footfall-popup.component.html +61 -0
- package/src/lib/components/footfall-popup/footfall-popup.component.scss +20 -0
- package/src/lib/components/footfall-popup/footfall-popup.component.spec.ts +23 -0
- package/src/lib/components/footfall-popup/footfall-popup.component.ts +12 -0
- package/src/lib/components/group-select/group-select.component.html +44 -0
- package/src/lib/components/group-select/group-select.component.scss +144 -0
- package/src/lib/components/group-select/group-select.component.spec.ts +23 -0
- package/src/lib/components/group-select/group-select.component.ts +145 -0
- package/src/lib/components/re-trigger/re-trigger.component.html +53 -0
- package/src/lib/components/re-trigger/re-trigger.component.scss +16 -0
- package/src/lib/components/re-trigger/re-trigger.component.spec.ts +23 -0
- package/src/lib/components/re-trigger/re-trigger.component.ts +96 -0
- package/src/lib/components/reactive-select/reactive-select.component.html +18 -0
- package/src/lib/components/reactive-select/reactive-select.component.scss +52 -0
- package/src/lib/components/reactive-select/reactive-select.component.spec.ts +23 -0
- package/src/lib/components/reactive-select/reactive-select.component.ts +104 -0
- package/src/lib/components/remove-audit/remove-audit.component.html +38 -0
- package/src/lib/components/remove-audit/remove-audit.component.scss +27 -0
- package/src/lib/components/remove-audit/remove-audit.component.spec.ts +23 -0
- package/src/lib/components/remove-audit/remove-audit.component.ts +81 -0
- package/src/lib/components/start-audit/start-audit.component.html +174 -0
- package/src/lib/components/start-audit/start-audit.component.scss +185 -0
- package/src/lib/components/start-audit/start-audit.component.spec.ts +23 -0
- package/src/lib/components/start-audit/start-audit.component.ts +772 -0
- package/src/lib/components/tango-manage-tickets/tango-manage-tickets.component.html +43 -0
- package/src/lib/components/tango-manage-tickets/tango-manage-tickets.component.scss +35 -0
- package/src/lib/components/tango-manage-tickets/tango-manage-tickets.component.spec.ts +23 -0
- package/src/lib/components/tango-manage-tickets/tango-manage-tickets.component.ts +118 -0
- package/src/lib/components/ticket-filter-panel/ticket-filter-panel.component.html +386 -0
- package/src/lib/components/ticket-filter-panel/ticket-filter-panel.component.scss +87 -0
- package/src/lib/components/ticket-filter-panel/ticket-filter-panel.component.spec.ts +23 -0
- package/src/lib/components/ticket-filter-panel/ticket-filter-panel.component.ts +493 -0
- package/src/lib/components/ticket-footfall-new/ticket-footfall-new.component.html +3751 -0
- package/src/lib/components/ticket-footfall-new/ticket-footfall-new.component.scss +1240 -0
- package/src/lib/components/ticket-footfall-new/ticket-footfall-new.component.spec.ts +23 -0
- package/src/lib/components/ticket-footfall-new/ticket-footfall-new.component.ts +2863 -0
- package/src/lib/components/ticketclosepopup/ticketclosepopup.component.html +100 -0
- package/src/lib/components/ticketclosepopup/ticketclosepopup.component.scss +34 -0
- package/src/lib/components/ticketclosepopup/ticketclosepopup.component.spec.ts +23 -0
- package/src/lib/components/ticketclosepopup/ticketclosepopup.component.ts +48 -0
- package/src/lib/components/tickets/tickets.component.html +451 -0
- package/src/lib/components/tickets/tickets.component.scss +131 -0
- package/src/lib/components/tickets/tickets.component.spec.ts +23 -0
- package/src/lib/components/tickets/tickets.component.ts +809 -0
- package/src/lib/components/viewcategory/viewcategory.component.html +38 -0
- package/src/lib/components/viewcategory/viewcategory.component.scss +29 -0
- package/src/lib/components/viewcategory/viewcategory.component.spec.ts +23 -0
- package/src/lib/components/viewcategory/viewcategory.component.ts +79 -0
- package/src/lib/services/audit.service.spec.ts +16 -0
- package/src/lib/services/audit.service.ts +98 -0
- package/src/lib/services/excel.service.ts +48 -0
- package/src/lib/services/ticket.service.spec.ts +16 -0
- package/src/lib/services/ticket.service.ts +501 -0
- package/src/lib/services/timer.service.spec.ts +16 -0
- package/src/lib/services/timer.service.ts +92 -0
- package/src/lib/tango-manage-tickets-routing.module.ts +37 -0
- package/src/lib/tango-manage-tickets.module.ts +68 -0
- package/{public-api.d.ts → src/public-api.ts} +8 -2
- package/tsconfig.lib.json +14 -0
- package/tsconfig.lib.prod.json +10 -0
- package/tsconfig.spec.json +14 -0
- package/esm2022/lib/components/add-csm-modal/add-csm-modal.component.mjs +0 -98
- package/esm2022/lib/components/audit-log/audit-log.component.mjs +0 -11
- package/esm2022/lib/components/audit-metrics/audit-metrics.component.mjs +0 -298
- package/esm2022/lib/components/comment-model/comment-model.component.mjs +0 -58
- package/esm2022/lib/components/count/count.component.mjs +0 -89
- package/esm2022/lib/components/footfall-dic/footfall-dic.component.mjs +0 -894
- package/esm2022/lib/components/group-select/group-select.component.mjs +0 -155
- package/esm2022/lib/components/re-trigger/re-trigger.component.mjs +0 -96
- package/esm2022/lib/components/reactive-select/reactive-select.component.mjs +0 -108
- package/esm2022/lib/components/tango-manage-tickets/tango-manage-tickets.component.mjs +0 -127
- package/esm2022/lib/components/tickets/tickets.component.mjs +0 -793
- package/esm2022/lib/services/excel.service.mjs +0 -45
- package/esm2022/lib/services/ticket.service.mjs +0 -158
- package/esm2022/lib/tango-manage-tickets-routing.module.mjs +0 -24
- package/esm2022/lib/tango-manage-tickets.module.mjs +0 -54
- package/esm2022/public-api.mjs +0 -6
- package/esm2022/tango-app-ui-manage-tickets.mjs +0 -5
- package/fesm2022/tango-app-ui-manage-tickets.mjs +0 -2914
- package/fesm2022/tango-app-ui-manage-tickets.mjs.map +0 -1
- package/index.d.ts +0 -5
- package/lib/components/add-csm-modal/add-csm-modal.component.d.ts +0 -30
- package/lib/components/audit-log/audit-log.component.d.ts +0 -5
- package/lib/components/audit-metrics/audit-metrics.component.d.ts +0 -59
- package/lib/components/comment-model/comment-model.component.d.ts +0 -17
- package/lib/components/count/count.component.d.ts +0 -23
- package/lib/components/footfall-dic/footfall-dic.component.d.ts +0 -130
- package/lib/components/group-select/group-select.component.d.ts +0 -33
- package/lib/components/re-trigger/re-trigger.component.d.ts +0 -32
- package/lib/components/reactive-select/reactive-select.component.d.ts +0 -32
- package/lib/components/tango-manage-tickets/tango-manage-tickets.component.d.ts +0 -27
- package/lib/components/tickets/tickets.component.d.ts +0 -84
- package/lib/services/excel.service.d.ts +0 -10
- package/lib/services/ticket.service.d.ts +0 -49
- package/lib/tango-manage-tickets-routing.module.d.ts +0 -7
- package/lib/tango-manage-tickets.module.d.ts +0 -21
|
@@ -1,2914 +0,0 @@
|
|
|
1
|
-
import * as i0 from '@angular/core';
|
|
2
|
-
import { Injectable, Component, Input, HostListener, ViewChild, forwardRef, EventEmitter, Output, NgModule } from '@angular/core';
|
|
3
|
-
import * as i6$1 from '@angular/common';
|
|
4
|
-
import { CommonModule } from '@angular/common';
|
|
5
|
-
import * as i2 from '@angular/router';
|
|
6
|
-
import { RouterModule } from '@angular/router';
|
|
7
|
-
import { BehaviorSubject, Subject, takeUntil } from 'rxjs';
|
|
8
|
-
import * as i1$1 from 'tango-app-ui-global';
|
|
9
|
-
import * as i1 from '@angular/common/http';
|
|
10
|
-
import { HttpParams } from '@angular/common/http';
|
|
11
|
-
import * as i6 from '@angular/forms';
|
|
12
|
-
import { FormControl, NG_VALUE_ACCESSOR, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
13
|
-
import * as i1$2 from '@ng-bootstrap/ng-bootstrap';
|
|
14
|
-
import * as i4 from 'tango-app-ui-shared';
|
|
15
|
-
import { CommonSharedModule } from 'tango-app-ui-shared';
|
|
16
|
-
import * as FileSaver from 'file-saver';
|
|
17
|
-
import * as XLSX from 'xlsx';
|
|
18
|
-
import dayjs from 'dayjs';
|
|
19
|
-
import 'dayjs/locale/en';
|
|
20
|
-
|
|
21
|
-
class TicketService {
|
|
22
|
-
http;
|
|
23
|
-
gs;
|
|
24
|
-
userApiUrl;
|
|
25
|
-
ticketsApiUrl;
|
|
26
|
-
auditApiUrl;
|
|
27
|
-
auditmetricApiUrl;
|
|
28
|
-
zoneauditApiUrl;
|
|
29
|
-
footfallDirapiUrl;
|
|
30
|
-
footfallCDN;
|
|
31
|
-
trafficApiUrl;
|
|
32
|
-
dropDownTrigger = new BehaviorSubject(null);
|
|
33
|
-
constructor(http, gs) {
|
|
34
|
-
this.http = http;
|
|
35
|
-
this.gs = gs;
|
|
36
|
-
this.gs.environment.subscribe((env) => {
|
|
37
|
-
if (env) {
|
|
38
|
-
this.userApiUrl = env.userApiUrl;
|
|
39
|
-
this.ticketsApiUrl = env.ticketsApiUrl;
|
|
40
|
-
this.auditmetricApiUrl = env.auditmetricApiUrl;
|
|
41
|
-
this.auditApiUrl = env.auditApiUrl;
|
|
42
|
-
this.zoneauditApiUrl = env.zoneauditApiUrl;
|
|
43
|
-
this.footfallDirapiUrl = env.footfallDirapiUrl;
|
|
44
|
-
this.footfallCDN = env.footfallCDN;
|
|
45
|
-
this.trafficApiUrl = env.trafficApiUrl;
|
|
46
|
-
}
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
getUserList(params) {
|
|
50
|
-
return this.http.post(`${this.userApiUrl}/get-list`, params);
|
|
51
|
-
}
|
|
52
|
-
exportInstallationList(data) {
|
|
53
|
-
return this.http.post(`${this.ticketsApiUrl}/infra/installationTable`, data, { responseType: 'arraybuffer' });
|
|
54
|
-
}
|
|
55
|
-
exportInfraList(data) {
|
|
56
|
-
return this.http.post(`${this.ticketsApiUrl}/infra/infraTable`, data, { responseType: 'arraybuffer' });
|
|
57
|
-
}
|
|
58
|
-
exportMatList(data) {
|
|
59
|
-
return this.http.post(`${this.ticketsApiUrl}/infra/matTable`, data, { responseType: 'arraybuffer' });
|
|
60
|
-
}
|
|
61
|
-
getSotresList(data) {
|
|
62
|
-
return this.http.post(`${this.ticketsApiUrl}/infra/storeFilter`, data);
|
|
63
|
-
}
|
|
64
|
-
getInstallationList(data) {
|
|
65
|
-
return this.http.post(`${this.ticketsApiUrl}/infra/installationTable`, data);
|
|
66
|
-
}
|
|
67
|
-
getInfraList(data) {
|
|
68
|
-
return this.http.post(`${this.ticketsApiUrl}/infra/infraTable`, data);
|
|
69
|
-
}
|
|
70
|
-
getAssignTicket(data) {
|
|
71
|
-
return this.http.post(`${this.ticketsApiUrl}/infra/assignTicket`, data);
|
|
72
|
-
}
|
|
73
|
-
getMatList(data) {
|
|
74
|
-
return this.http.post(`${this.ticketsApiUrl}/infra/matTable`, data);
|
|
75
|
-
}
|
|
76
|
-
updateTicketIssue(data) {
|
|
77
|
-
return this.http.post(`${this.ticketsApiUrl}/employeeTraning/updatecomment`, data);
|
|
78
|
-
}
|
|
79
|
-
getUserActiveList(params) {
|
|
80
|
-
return this.http.post(`${this.userApiUrl}/list`, params);
|
|
81
|
-
}
|
|
82
|
-
getDataMismathList(data) {
|
|
83
|
-
return this.http.post(`${this.ticketsApiUrl}/infra/dataMismatchTable`, data);
|
|
84
|
-
}
|
|
85
|
-
exportDataMismatchList(data) {
|
|
86
|
-
return this.http.post(`${this.ticketsApiUrl}/infra/dataMismatchTable`, data, { responseType: 'arraybuffer' });
|
|
87
|
-
}
|
|
88
|
-
getAllCounts(data) {
|
|
89
|
-
return this.http.post(`${this.ticketsApiUrl}/infra/allCounts`, data);
|
|
90
|
-
}
|
|
91
|
-
getstoreMetrics(data) {
|
|
92
|
-
return this.http.post(`${this.auditApiUrl}/metrics/store-metrics`, data);
|
|
93
|
-
}
|
|
94
|
-
getstoreMetricsExport(data) {
|
|
95
|
-
return this.http.post(`${this.auditApiUrl}/metrics/store-metrics`, data, { responseType: 'arraybuffer' });
|
|
96
|
-
}
|
|
97
|
-
getclientList() {
|
|
98
|
-
return this.http.get(`${this.auditApiUrl}/clients`);
|
|
99
|
-
}
|
|
100
|
-
getuserList() {
|
|
101
|
-
return this.http.get(`${this.auditApiUrl}/tango-users`);
|
|
102
|
-
}
|
|
103
|
-
auditretrigger(data) {
|
|
104
|
-
return this.http.post(`${this.auditApiUrl}/metrics/re-trigger`, data);
|
|
105
|
-
}
|
|
106
|
-
getstoreList(data) {
|
|
107
|
-
return this.http.post(`${this.auditApiUrl}/audit-stores`, data);
|
|
108
|
-
}
|
|
109
|
-
getAuditImages(data) {
|
|
110
|
-
return this.http.get(`${this.auditApiUrl}/audit-images?fileDate=${data?.fileDate}&storeId=${data?.storeId}&imageType=${data?.imageType}&export=${data?.export}&zoneName=${data?.zoneName}&moduleType=${data?.moduleType}`);
|
|
111
|
-
}
|
|
112
|
-
ExportAuditImagesasxlsx(data) {
|
|
113
|
-
return this.http.get(`${this.auditApiUrl}/audit-images?fileDate=${data?.fileDate}&storeId=${data?.storeId}&imageType=${data?.imageType}&export=${data?.export}&zoneName=${data?.zoneName}&moduleType=${data?.moduleType}`, { responseType: 'arraybuffer' });
|
|
114
|
-
}
|
|
115
|
-
getTicketSummaryApi(client, fromDate, toDate) {
|
|
116
|
-
return this.http.get(`${this.footfallDirapiUrl}/ticket-summary?clientId=${client}&fromDate=${fromDate}&toDate=${toDate}`);
|
|
117
|
-
}
|
|
118
|
-
getTicketListApi(client, fromDate, toDate, searchvalue, limit, offset, isExport, sortBy, sortOrder) {
|
|
119
|
-
return this.http.get(`${this.footfallDirapiUrl}/ticket-list?clientId=${client}&fromDate=${fromDate}&toDate=${toDate}&searchValue=${searchvalue}&limit=${limit}&offset=${offset}&isExport=${isExport}&sortBy=${sortBy}&sortOrder=${sortOrder}`);
|
|
120
|
-
}
|
|
121
|
-
getTicketListExportApi(client, fromDate, toDate, searchvalue, limit, offset, isExport, sortBy, sortOrder) {
|
|
122
|
-
return this.http.get(`${this.footfallDirapiUrl}/ticket-list?clientId=${client}&fromDate=${fromDate}&toDate=${toDate}&searchValue=${searchvalue}&limit=${limit}&offset=${offset}&isExport=${isExport}&sortBy=${sortBy}&sortOrder=${sortOrder}`, { responseType: 'arraybuffer' });
|
|
123
|
-
}
|
|
124
|
-
getTicketsApi(store, fromDate, toDate, revopsType, status, action, offset, limit) {
|
|
125
|
-
let params = new HttpParams()
|
|
126
|
-
.set('storeId', store)
|
|
127
|
-
.set('fromDate', fromDate)
|
|
128
|
-
.set('toDate', toDate)
|
|
129
|
-
.set('offset', offset)
|
|
130
|
-
.set('limit', limit);
|
|
131
|
-
if (revopsType) {
|
|
132
|
-
params = params.set('revopsType', revopsType);
|
|
133
|
-
}
|
|
134
|
-
if (status) {
|
|
135
|
-
params = params.set('status', status);
|
|
136
|
-
}
|
|
137
|
-
if (action) {
|
|
138
|
-
params = params.set('action', action);
|
|
139
|
-
}
|
|
140
|
-
return this.http.get(`${this.footfallDirapiUrl}/get-tickets`, { params });
|
|
141
|
-
}
|
|
142
|
-
getTaggedStoresApi(client, fromDate, toDate, searchValue, clusters) {
|
|
143
|
-
let params = new HttpParams()
|
|
144
|
-
.set('clientId', client)
|
|
145
|
-
.set('fromDate', fromDate)
|
|
146
|
-
.set('toDate', toDate); // Add searchValue as an empty string if not provided
|
|
147
|
-
// Only add 'clusters' if it's not null, undefined, or an empty array/string
|
|
148
|
-
if (searchValue) {
|
|
149
|
-
params = params.set('searchValue', searchValue);
|
|
150
|
-
}
|
|
151
|
-
if (clusters && clusters.length > 0) {
|
|
152
|
-
params = params.set('clusters', clusters);
|
|
153
|
-
}
|
|
154
|
-
return this.http.get(`${this.footfallDirapiUrl}/get-tagged-stores`, { params });
|
|
155
|
-
}
|
|
156
|
-
getUpdateStatusApi(data) {
|
|
157
|
-
const url = `${this.footfallDirapiUrl}/update-status`;
|
|
158
|
-
return this.http.put(url, data);
|
|
159
|
-
}
|
|
160
|
-
getclusters(data) {
|
|
161
|
-
return this.http.post(`${this.trafficApiUrl}/headercluster_v2`, data);
|
|
162
|
-
}
|
|
163
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TicketService, deps: [{ token: i1.HttpClient }, { token: i1$1.GlobalStateService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
164
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TicketService, providedIn: 'root' });
|
|
165
|
-
}
|
|
166
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TicketService, decorators: [{
|
|
167
|
-
type: Injectable,
|
|
168
|
-
args: [{
|
|
169
|
-
providedIn: 'root'
|
|
170
|
-
}]
|
|
171
|
-
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i1$1.GlobalStateService }] });
|
|
172
|
-
|
|
173
|
-
class AddCsmModalComponent {
|
|
174
|
-
activeModal;
|
|
175
|
-
gs;
|
|
176
|
-
service;
|
|
177
|
-
toast;
|
|
178
|
-
ticketId;
|
|
179
|
-
csmUserList = [];
|
|
180
|
-
csmSelectInput = new FormControl("");
|
|
181
|
-
destroy$ = new Subject();
|
|
182
|
-
headerFilters;
|
|
183
|
-
userList_req;
|
|
184
|
-
users = [];
|
|
185
|
-
userList = [];
|
|
186
|
-
constructor(activeModal, gs, service, toast) {
|
|
187
|
-
this.activeModal = activeModal;
|
|
188
|
-
this.gs = gs;
|
|
189
|
-
this.service = service;
|
|
190
|
-
this.toast = toast;
|
|
191
|
-
}
|
|
192
|
-
ngOnInit() {
|
|
193
|
-
const userData = JSON.parse(localStorage.getItem("user-info") || "{}");
|
|
194
|
-
this.users = userData;
|
|
195
|
-
this.gs.dataRangeValue?.pipe(takeUntil(this.destroy$))?.subscribe({
|
|
196
|
-
next: (data) => {
|
|
197
|
-
if (data) {
|
|
198
|
-
this.headerFilters = data;
|
|
199
|
-
this.userList_req = {
|
|
200
|
-
"userType": this.users.userType, "isActive": true
|
|
201
|
-
// clientId: this.headerFilters.client,
|
|
202
|
-
// limit: 10000,
|
|
203
|
-
// offset: 1,
|
|
204
|
-
// userType: this.users.userType,
|
|
205
|
-
// FilterByStatus:'isActive'
|
|
206
|
-
};
|
|
207
|
-
this.getuserlist();
|
|
208
|
-
}
|
|
209
|
-
},
|
|
210
|
-
});
|
|
211
|
-
}
|
|
212
|
-
ngOnDestroy() {
|
|
213
|
-
this.destroy$.next(true);
|
|
214
|
-
this.destroy$.complete();
|
|
215
|
-
}
|
|
216
|
-
getuserlist() {
|
|
217
|
-
this.service
|
|
218
|
-
.getUserActiveList(this.userList_req)
|
|
219
|
-
.pipe(takeUntil(this.destroy$))
|
|
220
|
-
.subscribe((res) => {
|
|
221
|
-
if (res && res.code === 200) {
|
|
222
|
-
this.userList = res?.data?.result;
|
|
223
|
-
}
|
|
224
|
-
});
|
|
225
|
-
}
|
|
226
|
-
assignCsm() {
|
|
227
|
-
let obj = {
|
|
228
|
-
tickets: this.ticketId,
|
|
229
|
-
user: this.csmSelectInput.value,
|
|
230
|
-
};
|
|
231
|
-
this.service
|
|
232
|
-
.getAssignTicket(obj)
|
|
233
|
-
.pipe(takeUntil(this.destroy$))
|
|
234
|
-
.subscribe({
|
|
235
|
-
next: (res) => {
|
|
236
|
-
if (res && res.code === 200) {
|
|
237
|
-
this.toast.getSuccessToast(res.message);
|
|
238
|
-
this.activeModal.close("submit");
|
|
239
|
-
}
|
|
240
|
-
},
|
|
241
|
-
error: (err) => {
|
|
242
|
-
this.toast.getErrorToast(err.error.error ? err.error.error : err.error);
|
|
243
|
-
},
|
|
244
|
-
complete: () => { },
|
|
245
|
-
});
|
|
246
|
-
}
|
|
247
|
-
onCsmSelect(selectedCsm) {
|
|
248
|
-
this.csmSelectInput.setValue(selectedCsm?._id);
|
|
249
|
-
}
|
|
250
|
-
cancel() {
|
|
251
|
-
this.activeModal.close("submit");
|
|
252
|
-
}
|
|
253
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AddCsmModalComponent, deps: [{ token: i1$2.NgbActiveModal }, { token: i1$1.GlobalStateService }, { token: TicketService }, { token: i4.ToastService }], target: i0.ɵɵFactoryTarget.Component });
|
|
254
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AddCsmModalComponent, selector: "lib-add-csm-modal", inputs: { ticketId: "ticketId" }, ngImport: i0, template: "<div class=\"card py-0\">\r\n <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n <div class=\"my-5\">\r\n <div class=\"symbol symbol-75px symbol-circle\">\r\n <svg width=\"56\" height=\"56\" viewBox=\"0 0 56 56\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"4\" y=\"4\" width=\"48\" height=\"48\" rx=\"24\" fill=\"#DAF1FF\"/>\r\n <rect x=\"4\" y=\"4\" width=\"48\" height=\"48\" rx=\"24\" stroke=\"#EAF8FF\" stroke-width=\"8\"/>\r\n <path d=\"M32 37V35C32 33.9391 31.5786 32.9217 30.8284 32.1716C30.0783 31.4214 29.0609 31 28 31H21C19.9391 31 18.9217 31.4214 18.1716 32.1716C17.4214 32.9217 17 33.9391 17 35V37M36 24V30M39 27H33M28.5 23C28.5 25.2091 26.7091 27 24.5 27C22.2909 27 20.5 25.2091 20.5 23C20.5 20.7909 22.2909 19 24.5 19C26.7091 19 28.5 20.7909 28.5 23Z\" stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n </div>\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Assign Ticket</a>\r\n <p class=\"text-sub\">Assign the ticket to a particular user</p>\r\n <div class=\"mt-5 w-100\">\r\n <!-- <lib-reactive-select [formControl]=\"csmSelectInput\" [idField]=\"'email'\" [nameField]=\"'userName'\" [data]=\"csmUserList\" ></lib-reactive-select> -->\r\n\r\n <!-- <select [formControl]=\"csmSelectInput\" class=\"form-select border-val my-3\">\r\n <option [value]=\"user.email\" *ngFor=\"let user of csmUserList\">{{user.userName}}</option>\r\n </select> -->\r\n\r\n <lib-select [items]=\"userList\" [multi]=\"false\" [searchField]=\"'userName'\" [idField]=\"'_id'\"\r\n (selected)=\"onCsmSelect($event)\" ></lib-select>\r\n\r\n <div class=\"d-flex my-7\" role=\"group\">\r\n <button class=\"btn btn-outline w-100 me-3\" (click)=\"cancel()\">Cancel</button>\r\n <button class=\"btn btn-primary w-100 ms-3\" [disabled]=\"!csmSelectInput.value\" (click)=\"assignCsm()\">Submit</button>\r\n </div>\r\n \r\n </div>\r\n\r\n </div>\r\n</div>", styles: ["::ng-deep .modal-content{border-radius:12px!important;overflow:unset!important}::ng-deep ngb-modal-window .component-host-scrollable{overflow:unset!important}.text-sub{color:var(--Gray-500, #667085)!important;font-size:14px;font-weight:400;line-height:20px}\n"], dependencies: [{ kind: "component", type: i4.CustomSelectComponent, selector: "lib-select", inputs: ["items", "searchField", "multi", "idField", "selectedValues", "disabled", "label"], outputs: ["selected"] }] });
|
|
255
|
-
}
|
|
256
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AddCsmModalComponent, decorators: [{
|
|
257
|
-
type: Component,
|
|
258
|
-
args: [{ selector: "lib-add-csm-modal", template: "<div class=\"card py-0\">\r\n <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n <div class=\"my-5\">\r\n <div class=\"symbol symbol-75px symbol-circle\">\r\n <svg width=\"56\" height=\"56\" viewBox=\"0 0 56 56\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"4\" y=\"4\" width=\"48\" height=\"48\" rx=\"24\" fill=\"#DAF1FF\"/>\r\n <rect x=\"4\" y=\"4\" width=\"48\" height=\"48\" rx=\"24\" stroke=\"#EAF8FF\" stroke-width=\"8\"/>\r\n <path d=\"M32 37V35C32 33.9391 31.5786 32.9217 30.8284 32.1716C30.0783 31.4214 29.0609 31 28 31H21C19.9391 31 18.9217 31.4214 18.1716 32.1716C17.4214 32.9217 17 33.9391 17 35V37M36 24V30M39 27H33M28.5 23C28.5 25.2091 26.7091 27 24.5 27C22.2909 27 20.5 25.2091 20.5 23C20.5 20.7909 22.2909 19 24.5 19C26.7091 19 28.5 20.7909 28.5 23Z\" stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n </div>\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Assign Ticket</a>\r\n <p class=\"text-sub\">Assign the ticket to a particular user</p>\r\n <div class=\"mt-5 w-100\">\r\n <!-- <lib-reactive-select [formControl]=\"csmSelectInput\" [idField]=\"'email'\" [nameField]=\"'userName'\" [data]=\"csmUserList\" ></lib-reactive-select> -->\r\n\r\n <!-- <select [formControl]=\"csmSelectInput\" class=\"form-select border-val my-3\">\r\n <option [value]=\"user.email\" *ngFor=\"let user of csmUserList\">{{user.userName}}</option>\r\n </select> -->\r\n\r\n <lib-select [items]=\"userList\" [multi]=\"false\" [searchField]=\"'userName'\" [idField]=\"'_id'\"\r\n (selected)=\"onCsmSelect($event)\" ></lib-select>\r\n\r\n <div class=\"d-flex my-7\" role=\"group\">\r\n <button class=\"btn btn-outline w-100 me-3\" (click)=\"cancel()\">Cancel</button>\r\n <button class=\"btn btn-primary w-100 ms-3\" [disabled]=\"!csmSelectInput.value\" (click)=\"assignCsm()\">Submit</button>\r\n </div>\r\n \r\n </div>\r\n\r\n </div>\r\n</div>", styles: ["::ng-deep .modal-content{border-radius:12px!important;overflow:unset!important}::ng-deep ngb-modal-window .component-host-scrollable{overflow:unset!important}.text-sub{color:var(--Gray-500, #667085)!important;font-size:14px;font-weight:400;line-height:20px}\n"] }]
|
|
259
|
-
}], ctorParameters: () => [{ type: i1$2.NgbActiveModal }, { type: i1$1.GlobalStateService }, { type: TicketService }, { type: i4.ToastService }], propDecorators: { ticketId: [{
|
|
260
|
-
type: Input
|
|
261
|
-
}] } });
|
|
262
|
-
|
|
263
|
-
class CommentModelComponent {
|
|
264
|
-
activeModal;
|
|
265
|
-
service;
|
|
266
|
-
toast;
|
|
267
|
-
ticketId;
|
|
268
|
-
comment = "";
|
|
269
|
-
destroy$ = new Subject();
|
|
270
|
-
constructor(activeModal, service, toast) {
|
|
271
|
-
this.activeModal = activeModal;
|
|
272
|
-
this.service = service;
|
|
273
|
-
this.toast = toast;
|
|
274
|
-
}
|
|
275
|
-
cancel() {
|
|
276
|
-
this.activeModal.close();
|
|
277
|
-
}
|
|
278
|
-
commentSubmit() {
|
|
279
|
-
if (this.comment == '') {
|
|
280
|
-
return this.toast.getErrorToast("Please Enter Any comment");
|
|
281
|
-
}
|
|
282
|
-
let obj = {
|
|
283
|
-
"ticketId": this.ticketId,
|
|
284
|
-
"primary": "",
|
|
285
|
-
"secondary": [],
|
|
286
|
-
"comment": this.comment,
|
|
287
|
-
};
|
|
288
|
-
this.service
|
|
289
|
-
.updateTicketIssue(obj)
|
|
290
|
-
.pipe(takeUntil(this.destroy$))
|
|
291
|
-
.subscribe({
|
|
292
|
-
next: (res) => {
|
|
293
|
-
if (res && res.code === 200) {
|
|
294
|
-
this.toast.getSuccessToast(res.message);
|
|
295
|
-
this.activeModal.close("submit");
|
|
296
|
-
}
|
|
297
|
-
},
|
|
298
|
-
error: (err) => {
|
|
299
|
-
this.toast.getErrorToast(err.error.error ? err.error.error : err.error);
|
|
300
|
-
},
|
|
301
|
-
complete: () => { },
|
|
302
|
-
});
|
|
303
|
-
}
|
|
304
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CommentModelComponent, deps: [{ token: i1$2.NgbActiveModal }, { token: TicketService }, { token: i4.ToastService }], target: i0.ɵɵFactoryTarget.Component });
|
|
305
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CommentModelComponent, selector: "lib-comment-model", inputs: { ticketId: "ticketId" }, ngImport: i0, template: "<div class=\"card py-0\">\r\n <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n <div class=\"my-5\">\r\n <div class=\"symbol symbol-75px symbol-circle\">\r\n <svg width=\"56\" height=\"56\" viewBox=\"0 0 56 56\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"4\" y=\"4\" width=\"48\" height=\"48\" rx=\"24\" fill=\"#DAF1FF\"/>\r\n <rect x=\"4\" y=\"4\" width=\"48\" height=\"48\" rx=\"24\" stroke=\"#EAF8FF\" stroke-width=\"8\"/>\r\n <path d=\"M37 31C37 31.5304 36.7893 32.0391 36.4142 32.4142C36.0391 32.7893 35.5304 33 35 33H23L19 37V21C19 20.4696 19.2107 19.9609 19.5858 19.5858C19.9609 19.2107 20.4696 19 21 19H35C35.5304 19 36.0391 19.2107 36.4142 19.5858C36.7893 19.9609 37 20.4696 37 21V31Z\" stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n </div>\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Comment</a>\r\n <p class=\"text-sub\">Add comment for the ticket</p>\r\n <div class=\"w-100\">\r\n <label class=\"label my-2\">Comments</label>\r\n <textarea class=\"form-control\" [(ngModel)]=\"comment\" rows=\"4\" type=\"text\"></textarea>\r\n\r\n <div class=\"d-flex my-7\" role=\"group\">\r\n <button class=\"btn btn-outline w-100 me-3\" (click)=\"cancel()\">Cancel</button>\r\n <button class=\"btn btn-primary w-100 ms-3\" (click)=\"commentSubmit()\">Submit</button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: ["::ng-deep .modal-content{border-radius:12px!important;overflow:unset!important}::ng-deep ngb-modal-window .component-host-scrollable{overflow:unset!important}.text-sub{color:var(--Gray-500, #667085)!important;font-size:14px;font-weight:400;line-height:20px}.label{color:var(--Gray-700, #344054)!important;font-size:14px;font-weight:500;line-height:20px}\n"], dependencies: [{ kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
306
|
-
}
|
|
307
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CommentModelComponent, decorators: [{
|
|
308
|
-
type: Component,
|
|
309
|
-
args: [{ selector: 'lib-comment-model', template: "<div class=\"card py-0\">\r\n <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n <div class=\"my-5\">\r\n <div class=\"symbol symbol-75px symbol-circle\">\r\n <svg width=\"56\" height=\"56\" viewBox=\"0 0 56 56\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"4\" y=\"4\" width=\"48\" height=\"48\" rx=\"24\" fill=\"#DAF1FF\"/>\r\n <rect x=\"4\" y=\"4\" width=\"48\" height=\"48\" rx=\"24\" stroke=\"#EAF8FF\" stroke-width=\"8\"/>\r\n <path d=\"M37 31C37 31.5304 36.7893 32.0391 36.4142 32.4142C36.0391 32.7893 35.5304 33 35 33H23L19 37V21C19 20.4696 19.2107 19.9609 19.5858 19.5858C19.9609 19.2107 20.4696 19 21 19H35C35.5304 19 36.0391 19.2107 36.4142 19.5858C36.7893 19.9609 37 20.4696 37 21V31Z\" stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </div>\r\n </div>\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Comment</a>\r\n <p class=\"text-sub\">Add comment for the ticket</p>\r\n <div class=\"w-100\">\r\n <label class=\"label my-2\">Comments</label>\r\n <textarea class=\"form-control\" [(ngModel)]=\"comment\" rows=\"4\" type=\"text\"></textarea>\r\n\r\n <div class=\"d-flex my-7\" role=\"group\">\r\n <button class=\"btn btn-outline w-100 me-3\" (click)=\"cancel()\">Cancel</button>\r\n <button class=\"btn btn-primary w-100 ms-3\" (click)=\"commentSubmit()\">Submit</button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: ["::ng-deep .modal-content{border-radius:12px!important;overflow:unset!important}::ng-deep ngb-modal-window .component-host-scrollable{overflow:unset!important}.text-sub{color:var(--Gray-500, #667085)!important;font-size:14px;font-weight:400;line-height:20px}.label{color:var(--Gray-700, #344054)!important;font-size:14px;font-weight:500;line-height:20px}\n"] }]
|
|
310
|
-
}], ctorParameters: () => [{ type: i1$2.NgbActiveModal }, { type: TicketService }, { type: i4.ToastService }], propDecorators: { ticketId: [{
|
|
311
|
-
type: Input
|
|
312
|
-
}] } });
|
|
313
|
-
|
|
314
|
-
const EXCEL_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8';
|
|
315
|
-
const EXCEL_EXTENSION = '.xlsx';
|
|
316
|
-
const ZIP_TYPE = 'application/zip';
|
|
317
|
-
const ZIP_EXTENSION = '.zip';
|
|
318
|
-
class ExcelService {
|
|
319
|
-
constructor() { }
|
|
320
|
-
exportAsExcelFile(json, excelFileName) {
|
|
321
|
-
const worksheet = XLSX.utils.json_to_sheet(json);
|
|
322
|
-
const workbook = { Sheets: { 'data': worksheet }, SheetNames: ['data'] };
|
|
323
|
-
const excelBuffer = XLSX.write(workbook, { bookType: 'xlsx', type: 'array' });
|
|
324
|
-
this.saveAsExcelFile(excelBuffer, excelFileName);
|
|
325
|
-
}
|
|
326
|
-
saveAsExcelFile(buffer, fileName) {
|
|
327
|
-
console.log(buffer, fileName);
|
|
328
|
-
const data = new Blob([buffer], {
|
|
329
|
-
type: EXCEL_TYPE
|
|
330
|
-
});
|
|
331
|
-
FileSaver.saveAs(data, fileName + 'list' + EXCEL_EXTENSION);
|
|
332
|
-
}
|
|
333
|
-
saveAsTemplate(buffer, fileName) {
|
|
334
|
-
const data = new Blob([buffer], {
|
|
335
|
-
type: EXCEL_TYPE
|
|
336
|
-
});
|
|
337
|
-
FileSaver.saveAs(data, fileName + EXCEL_EXTENSION);
|
|
338
|
-
}
|
|
339
|
-
saveAsZipFile(buffer, fileName) {
|
|
340
|
-
const data = new Blob([buffer], {
|
|
341
|
-
type: ZIP_TYPE
|
|
342
|
-
});
|
|
343
|
-
FileSaver.saveAs(data, fileName + 'Images' + ZIP_EXTENSION);
|
|
344
|
-
}
|
|
345
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ExcelService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
346
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ExcelService, providedIn: 'root' });
|
|
347
|
-
}
|
|
348
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ExcelService, decorators: [{
|
|
349
|
-
type: Injectable,
|
|
350
|
-
args: [{
|
|
351
|
-
providedIn: 'root'
|
|
352
|
-
}]
|
|
353
|
-
}], ctorParameters: () => [] });
|
|
354
|
-
|
|
355
|
-
class TicketsComponent {
|
|
356
|
-
cd;
|
|
357
|
-
router;
|
|
358
|
-
route;
|
|
359
|
-
gs;
|
|
360
|
-
modalService;
|
|
361
|
-
service;
|
|
362
|
-
excelservice;
|
|
363
|
-
type = "Infra";
|
|
364
|
-
searchValue = "";
|
|
365
|
-
selectedTab = "total";
|
|
366
|
-
// paginationVariables
|
|
367
|
-
itemsPerPage = 10;
|
|
368
|
-
currentPage = 1;
|
|
369
|
-
totalItems = 0;
|
|
370
|
-
paginationSizes = [10, 20, 30];
|
|
371
|
-
pageSize = 10;
|
|
372
|
-
destroy$ = new Subject();
|
|
373
|
-
assignTicket = false;
|
|
374
|
-
filterByStores = [];
|
|
375
|
-
filterByinstalled = [];
|
|
376
|
-
filterByStatus = [];
|
|
377
|
-
filterByQueryType = [];
|
|
378
|
-
issueType = [];
|
|
379
|
-
sortedColumn;
|
|
380
|
-
sortDirection;
|
|
381
|
-
headerFilters;
|
|
382
|
-
userList_req;
|
|
383
|
-
userList = [];
|
|
384
|
-
dataObject = [];
|
|
385
|
-
storeList = [];
|
|
386
|
-
statusType;
|
|
387
|
-
typeName;
|
|
388
|
-
users;
|
|
389
|
-
limit = 10;
|
|
390
|
-
offset = 1;
|
|
391
|
-
sortBy = -1;
|
|
392
|
-
sortColumName = "";
|
|
393
|
-
listArray = [];
|
|
394
|
-
tableListArray = [];
|
|
395
|
-
loading = true;
|
|
396
|
-
noData = false;
|
|
397
|
-
selectAll = false;
|
|
398
|
-
assignStores = [];
|
|
399
|
-
issueTypeList = [];
|
|
400
|
-
queryTypeList = [];
|
|
401
|
-
constructor(cd, router, route, gs, modalService, service, excelservice) {
|
|
402
|
-
this.cd = cd;
|
|
403
|
-
this.router = router;
|
|
404
|
-
this.route = route;
|
|
405
|
-
this.gs = gs;
|
|
406
|
-
this.modalService = modalService;
|
|
407
|
-
this.service = service;
|
|
408
|
-
this.excelservice = excelservice;
|
|
409
|
-
}
|
|
410
|
-
ngOnInit() {
|
|
411
|
-
const userData = JSON.parse(localStorage.getItem("user-info") || "{}");
|
|
412
|
-
this.users = userData;
|
|
413
|
-
this.route?.queryParams
|
|
414
|
-
?.pipe(takeUntil(this.destroy$))
|
|
415
|
-
.subscribe((params) => {
|
|
416
|
-
this.type = params.type;
|
|
417
|
-
this.filterByStores = [];
|
|
418
|
-
this.storeList = [];
|
|
419
|
-
this.filterByinstalled = [];
|
|
420
|
-
this.statusType = [];
|
|
421
|
-
this.filterByStatus = [];
|
|
422
|
-
this.userList = [];
|
|
423
|
-
this.issueType = [];
|
|
424
|
-
this.issueTypeList = [];
|
|
425
|
-
this.filterByQueryType = [];
|
|
426
|
-
this.queryTypeList = [];
|
|
427
|
-
this.dataObject = [];
|
|
428
|
-
this.gs.manageRefreshTrigger.next(true);
|
|
429
|
-
this.getInitload();
|
|
430
|
-
this.gs.dataRangeValue?.pipe(takeUntil(this.destroy$))?.subscribe({
|
|
431
|
-
next: (data) => {
|
|
432
|
-
if (data) {
|
|
433
|
-
this.headerFilters = data;
|
|
434
|
-
this.userList_req = {
|
|
435
|
-
limit: 10000,
|
|
436
|
-
offset: 1,
|
|
437
|
-
userType: this.users.userType,
|
|
438
|
-
};
|
|
439
|
-
this.getstoreFilter();
|
|
440
|
-
}
|
|
441
|
-
},
|
|
442
|
-
});
|
|
443
|
-
if (this.type === "installation") {
|
|
444
|
-
this.typeName = "Installed By";
|
|
445
|
-
this.statusType = [
|
|
446
|
-
{ text: "Onboarded", id: "onboarded" },
|
|
447
|
-
{ text: "Paired", id: "paired" },
|
|
448
|
-
{ text: "Installationfailed", id: "installationfailed" },
|
|
449
|
-
{ text: "Deployed", id: "deployed" },
|
|
450
|
-
];
|
|
451
|
-
}
|
|
452
|
-
else {
|
|
453
|
-
this.typeName = "Resolved By";
|
|
454
|
-
if (this.users.userType === "tango" && this.type === 'infra') {
|
|
455
|
-
this.statusType = [
|
|
456
|
-
{ text: "Open", id: "open" },
|
|
457
|
-
{ text: "In Progress", id: "inprogress" },
|
|
458
|
-
{ text: "Refresh Ticket", id: "refreshticket" },
|
|
459
|
-
{ text: "Closed", id: "closed" },
|
|
460
|
-
];
|
|
461
|
-
}
|
|
462
|
-
else {
|
|
463
|
-
this.statusType = [
|
|
464
|
-
{ text: "Open", id: "open" },
|
|
465
|
-
{ text: "In Progress", id: "inprogress" },
|
|
466
|
-
{ text: "Closed", id: "closed" },
|
|
467
|
-
];
|
|
468
|
-
}
|
|
469
|
-
this.issueTypeList = [
|
|
470
|
-
{ text: "High Count", id: "highcount" },
|
|
471
|
-
{ text: "Low Count", id: "lowcount" },
|
|
472
|
-
];
|
|
473
|
-
this.queryTypeList = [
|
|
474
|
-
{ text: "Internal", id: "internal" },
|
|
475
|
-
{ text: "External", id: "external" },
|
|
476
|
-
];
|
|
477
|
-
}
|
|
478
|
-
});
|
|
479
|
-
}
|
|
480
|
-
getInitload() {
|
|
481
|
-
this.searchValue = "";
|
|
482
|
-
this.limit = 10;
|
|
483
|
-
this.pageSize = 10;
|
|
484
|
-
this.currentPage = 1;
|
|
485
|
-
this.offset = 1;
|
|
486
|
-
this.selectedTab = "total";
|
|
487
|
-
this.loading = true;
|
|
488
|
-
this.noData = false;
|
|
489
|
-
this.sortedColumn = '';
|
|
490
|
-
}
|
|
491
|
-
getstoreFilter() {
|
|
492
|
-
this.service
|
|
493
|
-
.getSotresList({ issueType: this.type, clientId: this.headerFilters.clients })
|
|
494
|
-
.pipe(takeUntil(this.destroy$))
|
|
495
|
-
.subscribe({
|
|
496
|
-
next: (res) => {
|
|
497
|
-
if (res && res.code === 200) {
|
|
498
|
-
this.storeList = res?.data?.data;
|
|
499
|
-
this.storeList.forEach((element) => {
|
|
500
|
-
element.text = element.storeId;
|
|
501
|
-
element.id = element.storeId;
|
|
502
|
-
});
|
|
503
|
-
if (this.users.userType === "tango") {
|
|
504
|
-
this.getuserlist();
|
|
505
|
-
}
|
|
506
|
-
else {
|
|
507
|
-
if (this.type === 'installation') {
|
|
508
|
-
this.dataObject = [
|
|
509
|
-
{ Description: "Store ID", Issues: this.storeList },
|
|
510
|
-
{ Description: "Deployed Status", Issues: this.statusType },
|
|
511
|
-
];
|
|
512
|
-
}
|
|
513
|
-
else if (this.type === 'infra' || this.type === 'dataMismatch') {
|
|
514
|
-
this.dataObject = [
|
|
515
|
-
{ Description: "Store ID", Issues: this.storeList },
|
|
516
|
-
{ Description: "Status", Issues: this.statusType },
|
|
517
|
-
];
|
|
518
|
-
}
|
|
519
|
-
else if (this.type === 'mat') {
|
|
520
|
-
this.dataObject = [
|
|
521
|
-
{ Description: "Status", Issues: this.statusType },
|
|
522
|
-
];
|
|
523
|
-
}
|
|
524
|
-
}
|
|
525
|
-
this.getTable();
|
|
526
|
-
}
|
|
527
|
-
else {
|
|
528
|
-
this.getTable();
|
|
529
|
-
}
|
|
530
|
-
},
|
|
531
|
-
error: (err) => {
|
|
532
|
-
this.loading = false;
|
|
533
|
-
this.noData = true;
|
|
534
|
-
this.cd.detectChanges();
|
|
535
|
-
},
|
|
536
|
-
complete: () => { },
|
|
537
|
-
});
|
|
538
|
-
}
|
|
539
|
-
getuserlist() {
|
|
540
|
-
this.service
|
|
541
|
-
.getUserList(this.userList_req)
|
|
542
|
-
.pipe(takeUntil(this.destroy$))
|
|
543
|
-
.subscribe((res) => {
|
|
544
|
-
if (res && res.code === 200) {
|
|
545
|
-
this.userList = res?.data?.result;
|
|
546
|
-
this.userList?.forEach((element) => {
|
|
547
|
-
element.text = element.userName;
|
|
548
|
-
element.id = element.email;
|
|
549
|
-
});
|
|
550
|
-
}
|
|
551
|
-
if (this.users.userType === "tango" && (this.type === 'installation')) {
|
|
552
|
-
this.dataObject = [
|
|
553
|
-
{ Description: "Store ID", Issues: this.storeList },
|
|
554
|
-
{ Description: "Deployed Status", Issues: this.statusType },
|
|
555
|
-
{ Description: this.typeName, Issues: this.userList },
|
|
556
|
-
];
|
|
557
|
-
}
|
|
558
|
-
else if (this.users.userType === "tango" && this.type === 'infra') {
|
|
559
|
-
this.dataObject = [
|
|
560
|
-
{ Description: "Store ID", Issues: this.storeList },
|
|
561
|
-
{ Description: "Status", Issues: this.statusType },
|
|
562
|
-
{ Description: this.typeName, Issues: this.userList },
|
|
563
|
-
];
|
|
564
|
-
}
|
|
565
|
-
else if (this.users.userType === "tango" && this.type === 'dataMismatch') {
|
|
566
|
-
this.dataObject = [
|
|
567
|
-
{ Description: "Store ID", Issues: this.storeList },
|
|
568
|
-
{ Description: "Query Type", Issues: this.queryTypeList },
|
|
569
|
-
{ Description: "Status", Issues: this.statusType },
|
|
570
|
-
];
|
|
571
|
-
}
|
|
572
|
-
else if (this.type === 'mat') {
|
|
573
|
-
this.dataObject = [
|
|
574
|
-
{ Description: "Status", Issues: this.statusType },
|
|
575
|
-
];
|
|
576
|
-
}
|
|
577
|
-
});
|
|
578
|
-
}
|
|
579
|
-
ngOnDestroy() {
|
|
580
|
-
this.destroy$.next(true);
|
|
581
|
-
this.destroy$.complete();
|
|
582
|
-
}
|
|
583
|
-
searchData() {
|
|
584
|
-
this.currentPage = 1;
|
|
585
|
-
this.offset = 1;
|
|
586
|
-
this.limit = 10;
|
|
587
|
-
this.getTable();
|
|
588
|
-
}
|
|
589
|
-
onSort(column) {
|
|
590
|
-
if (this.sortedColumn === column) {
|
|
591
|
-
this.sortDirection = this.sortDirection === 1 ? -1 : 1;
|
|
592
|
-
}
|
|
593
|
-
else {
|
|
594
|
-
this.sortedColumn = column;
|
|
595
|
-
this.sortDirection = 1;
|
|
596
|
-
}
|
|
597
|
-
this.getTable();
|
|
598
|
-
}
|
|
599
|
-
exportXLSX() {
|
|
600
|
-
let obj = {
|
|
601
|
-
clientId: this.headerFilters?.clients,
|
|
602
|
-
fromDate: this.headerFilters?.date?.startDate,
|
|
603
|
-
toDate: this.headerFilters?.date?.endDate,
|
|
604
|
-
offset: this.offset,
|
|
605
|
-
limit: this.limit,
|
|
606
|
-
filterIssue: this.selectedTab ? this.selectedTab : "",
|
|
607
|
-
searchValue: this.searchValue ? this.searchValue : "",
|
|
608
|
-
export: true,
|
|
609
|
-
};
|
|
610
|
-
if (this.sortedColumn) {
|
|
611
|
-
obj.sortColumName = this.sortedColumn;
|
|
612
|
-
obj.sortBy = this.sortDirection;
|
|
613
|
-
}
|
|
614
|
-
if (this.type === "installation" || this.type === "infra") {
|
|
615
|
-
if (this.filterByStores?.length) {
|
|
616
|
-
obj.storeIdFilter = this.filterByStores ? this.filterByStores : [];
|
|
617
|
-
}
|
|
618
|
-
if (this.filterByStatus?.length) {
|
|
619
|
-
obj.statusFilter = this.filterByStatus ? this.filterByStatus : [];
|
|
620
|
-
}
|
|
621
|
-
if (this.filterByinstalled?.length) {
|
|
622
|
-
obj.userFilter = this.filterByinstalled ? this.filterByinstalled : [];
|
|
623
|
-
}
|
|
624
|
-
}
|
|
625
|
-
else if (this.type === "mat") {
|
|
626
|
-
if (this.filterByStatus?.length) {
|
|
627
|
-
obj.statusFilter = this.filterByStatus ? this.filterByStatus : [];
|
|
628
|
-
}
|
|
629
|
-
}
|
|
630
|
-
else {
|
|
631
|
-
if (this.filterByStores?.length) {
|
|
632
|
-
obj.filterByStores = this.filterByStores ? this.filterByStores : [];
|
|
633
|
-
}
|
|
634
|
-
if (this.filterByStatus?.length) {
|
|
635
|
-
obj.filterByStatus = this.filterByStatus ? this.filterByStatus : [];
|
|
636
|
-
}
|
|
637
|
-
if (this.filterByQueryType?.length) {
|
|
638
|
-
obj.filterByQueryType = this.filterByQueryType ? this.filterByQueryType : [];
|
|
639
|
-
}
|
|
640
|
-
}
|
|
641
|
-
if (this.type === "installation") {
|
|
642
|
-
this.service
|
|
643
|
-
.exportInstallationList(obj)
|
|
644
|
-
.pipe(takeUntil(this.destroy$))
|
|
645
|
-
.subscribe({
|
|
646
|
-
next: (res) => {
|
|
647
|
-
this.excelservice.saveAsExcelFile(res, 'Installation');
|
|
648
|
-
},
|
|
649
|
-
error: (err) => {
|
|
650
|
-
this.loading = false;
|
|
651
|
-
this.noData = true;
|
|
652
|
-
this.cd.detectChanges();
|
|
653
|
-
},
|
|
654
|
-
complete: () => { },
|
|
655
|
-
});
|
|
656
|
-
}
|
|
657
|
-
else if (this.type === "infra") {
|
|
658
|
-
this.service
|
|
659
|
-
.exportInfraList(obj)
|
|
660
|
-
.pipe(takeUntil(this.destroy$))
|
|
661
|
-
.subscribe({
|
|
662
|
-
next: (res) => {
|
|
663
|
-
this.excelservice.saveAsExcelFile(res, 'Infra');
|
|
664
|
-
},
|
|
665
|
-
error: (err) => {
|
|
666
|
-
this.loading = false;
|
|
667
|
-
this.noData = true;
|
|
668
|
-
this.cd.detectChanges();
|
|
669
|
-
},
|
|
670
|
-
complete: () => { },
|
|
671
|
-
});
|
|
672
|
-
}
|
|
673
|
-
else if (this.type === "mat") {
|
|
674
|
-
this.service
|
|
675
|
-
.exportMatList(obj)
|
|
676
|
-
.pipe(takeUntil(this.destroy$))
|
|
677
|
-
.subscribe({
|
|
678
|
-
next: (res) => {
|
|
679
|
-
this.excelservice.saveAsExcelFile(res, 'Mat');
|
|
680
|
-
},
|
|
681
|
-
error: (err) => {
|
|
682
|
-
this.loading = false;
|
|
683
|
-
this.noData = true;
|
|
684
|
-
this.cd.detectChanges();
|
|
685
|
-
},
|
|
686
|
-
complete: () => { },
|
|
687
|
-
});
|
|
688
|
-
}
|
|
689
|
-
else if (this.type === 'dataMismatch') {
|
|
690
|
-
this.service
|
|
691
|
-
.exportDataMismatchList(obj)
|
|
692
|
-
.pipe(takeUntil(this.destroy$))
|
|
693
|
-
.subscribe({
|
|
694
|
-
next: (res) => {
|
|
695
|
-
this.excelservice.saveAsExcelFile(res, 'Data Mismatch');
|
|
696
|
-
},
|
|
697
|
-
error: (err) => {
|
|
698
|
-
this.loading = false;
|
|
699
|
-
this.noData = true;
|
|
700
|
-
this.cd.detectChanges();
|
|
701
|
-
},
|
|
702
|
-
complete: () => { },
|
|
703
|
-
});
|
|
704
|
-
}
|
|
705
|
-
}
|
|
706
|
-
selectedTabs(type) {
|
|
707
|
-
this.currentPage = 1;
|
|
708
|
-
this.offset = 1;
|
|
709
|
-
this.limit = 10;
|
|
710
|
-
if (this.type === 'dataMismatch') {
|
|
711
|
-
this.selectedTab = type.name.replace(/\s+/g, '').toLocaleLowerCase();
|
|
712
|
-
this.currentPage = 1;
|
|
713
|
-
this.offset = 1;
|
|
714
|
-
this.limit = 10;
|
|
715
|
-
this.pageSize = 10;
|
|
716
|
-
this.getTable();
|
|
717
|
-
this.transformName(type);
|
|
718
|
-
}
|
|
719
|
-
else {
|
|
720
|
-
this.selectedTab = type.name;
|
|
721
|
-
this.currentPage = 1;
|
|
722
|
-
this.offset = 1;
|
|
723
|
-
this.limit = 10;
|
|
724
|
-
this.pageSize = 10;
|
|
725
|
-
this.getTable();
|
|
726
|
-
}
|
|
727
|
-
}
|
|
728
|
-
transformName(name) {
|
|
729
|
-
return name.toLocaleLowerCase().replace(/\s+/g, '');
|
|
730
|
-
}
|
|
731
|
-
onPageChange(pageOffset) {
|
|
732
|
-
this.currentPage = Number(pageOffset);
|
|
733
|
-
this.offset = Number(pageOffset);
|
|
734
|
-
this.limit = 10;
|
|
735
|
-
this.getTable();
|
|
736
|
-
}
|
|
737
|
-
onPageSizeChange(pageSize) {
|
|
738
|
-
this.pageSize = Number(pageSize);
|
|
739
|
-
this.limit = Number(pageSize);
|
|
740
|
-
this.currentPage = 1;
|
|
741
|
-
this.offset = 1;
|
|
742
|
-
this.getTable();
|
|
743
|
-
}
|
|
744
|
-
selectAllStore(event) {
|
|
745
|
-
this.selectAll = event.target.checked;
|
|
746
|
-
this.tableListArray.forEach((obj) => (obj.checked = this.selectAll));
|
|
747
|
-
// If all checkboxes are checked, assign all ticketIds to assignStores, otherwise clear assignStores
|
|
748
|
-
this.assignStores = this.selectAll
|
|
749
|
-
? this.tableListArray.map((obj) => obj.ticketId)
|
|
750
|
-
: [];
|
|
751
|
-
this.assignTicket = this.selectAll; // Update assignTicket based on selectAll state
|
|
752
|
-
}
|
|
753
|
-
updateCheck(event, ticketId) {
|
|
754
|
-
const ticket = this.tableListArray.find((obj) => obj.ticketId === ticketId);
|
|
755
|
-
if (ticket) {
|
|
756
|
-
ticket.checked = event.target.checked;
|
|
757
|
-
// If the checkbox is checked, add or remove the corresponding array from the selected arrays
|
|
758
|
-
if (event.target.checked) {
|
|
759
|
-
this.assignStores.push(ticketId);
|
|
760
|
-
}
|
|
761
|
-
else {
|
|
762
|
-
const index = this.assignStores.indexOf(ticketId);
|
|
763
|
-
if (index !== -1) {
|
|
764
|
-
this.assignStores.splice(index, 1);
|
|
765
|
-
}
|
|
766
|
-
}
|
|
767
|
-
// Update selectAll based on the current state of checkboxes
|
|
768
|
-
this.selectAll = this.tableListArray.every((obj) => obj.checked);
|
|
769
|
-
// Update assignTicket based on whether any individual ticket checkbox is checked
|
|
770
|
-
this.assignTicket = this.tableListArray.some((obj) => obj.checked);
|
|
771
|
-
}
|
|
772
|
-
}
|
|
773
|
-
addAssignTicket() {
|
|
774
|
-
const modalRef = this.modalService.open(AddCsmModalComponent, {
|
|
775
|
-
centered: true,
|
|
776
|
-
size: "md",
|
|
777
|
-
scrollable: true,
|
|
778
|
-
backdrop: "static"
|
|
779
|
-
});
|
|
780
|
-
modalRef.componentInstance.ticketId = this.assignStores;
|
|
781
|
-
modalRef.result.then((result) => {
|
|
782
|
-
if (result === "submit") {
|
|
783
|
-
this.searchValue = "";
|
|
784
|
-
this.assignStores = [];
|
|
785
|
-
this.selectAll = false;
|
|
786
|
-
this.assignTicket = false;
|
|
787
|
-
this.getTable();
|
|
788
|
-
}
|
|
789
|
-
});
|
|
790
|
-
}
|
|
791
|
-
applyFilters(event) {
|
|
792
|
-
if (event?.length) {
|
|
793
|
-
event.forEach((element) => {
|
|
794
|
-
if (element.Description === "Store ID") {
|
|
795
|
-
this.filterByStores = element.Issues.map((val) => val?.id);
|
|
796
|
-
}
|
|
797
|
-
if (this.type !== 'installation') {
|
|
798
|
-
if (element.Description === "Status") {
|
|
799
|
-
this.filterByStatus = element.Issues.map((val) => val?.id);
|
|
800
|
-
}
|
|
801
|
-
}
|
|
802
|
-
if (this.type === 'installation') {
|
|
803
|
-
if (element.Description === "Deployed Status") {
|
|
804
|
-
this.filterByStatus = element.Issues.map((val) => val?.id);
|
|
805
|
-
}
|
|
806
|
-
}
|
|
807
|
-
if (this.users.userType === "tango" && (this.type === 'installation' || this.type === 'infra')) {
|
|
808
|
-
if (element.Description === this.typeName) {
|
|
809
|
-
this.filterByinstalled = element.Issues.map((val) => val?.id);
|
|
810
|
-
}
|
|
811
|
-
}
|
|
812
|
-
else {
|
|
813
|
-
this.filterByinstalled = [];
|
|
814
|
-
}
|
|
815
|
-
if (element.Description === "Query Type") {
|
|
816
|
-
this.filterByQueryType = element.Issues.map((val) => val?.id);
|
|
817
|
-
}
|
|
818
|
-
// if (element.Description === "Issue Type") {
|
|
819
|
-
// this.issueType = element.Issues.map((val: any) => val?.id);
|
|
820
|
-
// }
|
|
821
|
-
});
|
|
822
|
-
}
|
|
823
|
-
this.currentPage = 1;
|
|
824
|
-
this.offset = 1;
|
|
825
|
-
this.limit = 10;
|
|
826
|
-
this.getTable();
|
|
827
|
-
}
|
|
828
|
-
getTable() {
|
|
829
|
-
this.loading = true;
|
|
830
|
-
this.noData = false;
|
|
831
|
-
let obj = {
|
|
832
|
-
clientId: this.headerFilters?.clients,
|
|
833
|
-
fromDate: this.headerFilters?.date?.startDate,
|
|
834
|
-
toDate: this.headerFilters?.date?.endDate,
|
|
835
|
-
offset: this.offset,
|
|
836
|
-
limit: this.limit,
|
|
837
|
-
filterIssue: this.selectedTab ? this.selectedTab : "",
|
|
838
|
-
searchValue: this.searchValue ? this.searchValue : "",
|
|
839
|
-
export: false,
|
|
840
|
-
};
|
|
841
|
-
if (this.sortedColumn) {
|
|
842
|
-
if (this.type === 'dataMismatch') {
|
|
843
|
-
obj.sortColumnName = this.sortedColumn;
|
|
844
|
-
obj.sortBy = this.sortDirection;
|
|
845
|
-
}
|
|
846
|
-
else {
|
|
847
|
-
obj.sortColumName = this.sortedColumn;
|
|
848
|
-
obj.sortBy = this.sortDirection;
|
|
849
|
-
}
|
|
850
|
-
}
|
|
851
|
-
if (this.type === "installation" || this.type === "infra") {
|
|
852
|
-
if (this.filterByStores?.length) {
|
|
853
|
-
obj.storeIdFilter = this.filterByStores ? this.filterByStores : [];
|
|
854
|
-
}
|
|
855
|
-
if (this.filterByStatus?.length) {
|
|
856
|
-
obj.statusFilter = this.filterByStatus ? this.filterByStatus : [];
|
|
857
|
-
}
|
|
858
|
-
if (this.filterByinstalled?.length) {
|
|
859
|
-
obj.userFilter = this.filterByinstalled ? this.filterByinstalled : [];
|
|
860
|
-
}
|
|
861
|
-
}
|
|
862
|
-
else if (this.type === "mat") {
|
|
863
|
-
if (this.filterByStatus?.length) {
|
|
864
|
-
obj.statusFilter = this.filterByStatus ? this.filterByStatus : [];
|
|
865
|
-
}
|
|
866
|
-
}
|
|
867
|
-
else {
|
|
868
|
-
if (this.filterByStores?.length) {
|
|
869
|
-
obj.filterByStores = this.filterByStores ? this.filterByStores : [];
|
|
870
|
-
}
|
|
871
|
-
if (this.filterByStatus?.length) {
|
|
872
|
-
obj.filterByStatus = this.filterByStatus ? this.filterByStatus : [];
|
|
873
|
-
}
|
|
874
|
-
if (this.filterByQueryType?.length) {
|
|
875
|
-
obj.filterByQueryType = this.filterByQueryType ? this.filterByQueryType : [];
|
|
876
|
-
}
|
|
877
|
-
}
|
|
878
|
-
// console.log(obj)
|
|
879
|
-
// return
|
|
880
|
-
if (this.type === "installation") {
|
|
881
|
-
this.service
|
|
882
|
-
.getInstallationList(obj)
|
|
883
|
-
.pipe(takeUntil(this.destroy$))
|
|
884
|
-
.subscribe({
|
|
885
|
-
next: (res) => {
|
|
886
|
-
if (res && res.code === 200) {
|
|
887
|
-
this.listArray = res.data.response;
|
|
888
|
-
if (res.data.result.length === 0) {
|
|
889
|
-
this.loading = false;
|
|
890
|
-
this.noData = true;
|
|
891
|
-
}
|
|
892
|
-
else {
|
|
893
|
-
this.tableListArray = res.data.result;
|
|
894
|
-
this.totalItems = res.data?.count;
|
|
895
|
-
if (this.totalItems < 10) {
|
|
896
|
-
this.paginationSizes = [this.totalItems];
|
|
897
|
-
}
|
|
898
|
-
else {
|
|
899
|
-
this.paginationSizes = [10, 20, 30];
|
|
900
|
-
}
|
|
901
|
-
this.loading = false;
|
|
902
|
-
this.noData = false;
|
|
903
|
-
this.selectAll = false;
|
|
904
|
-
this.assignTicket = false;
|
|
905
|
-
this.cd.detectChanges();
|
|
906
|
-
}
|
|
907
|
-
}
|
|
908
|
-
else {
|
|
909
|
-
this.loading = false;
|
|
910
|
-
this.noData = true;
|
|
911
|
-
}
|
|
912
|
-
},
|
|
913
|
-
error: (err) => {
|
|
914
|
-
this.loading = false;
|
|
915
|
-
this.noData = true;
|
|
916
|
-
this.cd.detectChanges();
|
|
917
|
-
},
|
|
918
|
-
complete: () => { },
|
|
919
|
-
});
|
|
920
|
-
}
|
|
921
|
-
else if (this.type === "infra") {
|
|
922
|
-
this.service
|
|
923
|
-
.getInfraList(obj)
|
|
924
|
-
.pipe(takeUntil(this.destroy$))
|
|
925
|
-
.subscribe({
|
|
926
|
-
next: (res) => {
|
|
927
|
-
if (res && res.code === 200) {
|
|
928
|
-
this.listArray = res.data.response;
|
|
929
|
-
if (res.data.result.length === 0) {
|
|
930
|
-
this.loading = false;
|
|
931
|
-
this.noData = true;
|
|
932
|
-
}
|
|
933
|
-
else {
|
|
934
|
-
this.tableListArray = res.data.result;
|
|
935
|
-
this.totalItems = res.data?.count;
|
|
936
|
-
if (this.totalItems < 10) {
|
|
937
|
-
this.paginationSizes = [this.totalItems];
|
|
938
|
-
}
|
|
939
|
-
else {
|
|
940
|
-
this.paginationSizes = [10, 20, 30];
|
|
941
|
-
}
|
|
942
|
-
this.loading = false;
|
|
943
|
-
this.noData = false;
|
|
944
|
-
this.selectAll = false;
|
|
945
|
-
this.assignTicket = false;
|
|
946
|
-
}
|
|
947
|
-
}
|
|
948
|
-
else {
|
|
949
|
-
this.loading = false;
|
|
950
|
-
this.noData = true;
|
|
951
|
-
}
|
|
952
|
-
},
|
|
953
|
-
error: (err) => {
|
|
954
|
-
this.loading = false;
|
|
955
|
-
this.noData = true;
|
|
956
|
-
this.cd.detectChanges();
|
|
957
|
-
},
|
|
958
|
-
complete: () => { },
|
|
959
|
-
});
|
|
960
|
-
}
|
|
961
|
-
else if (this.type === "mat") {
|
|
962
|
-
this.service
|
|
963
|
-
.getMatList(obj)
|
|
964
|
-
.pipe(takeUntil(this.destroy$))
|
|
965
|
-
.subscribe({
|
|
966
|
-
next: (res) => {
|
|
967
|
-
if (res && res.code === 200) {
|
|
968
|
-
this.listArray = res?.data?.response;
|
|
969
|
-
this.tableListArray = res?.data?.result;
|
|
970
|
-
this.totalItems = res.data?.count;
|
|
971
|
-
if (this.totalItems < 10) {
|
|
972
|
-
this.paginationSizes = [this.totalItems];
|
|
973
|
-
}
|
|
974
|
-
else {
|
|
975
|
-
this.paginationSizes = [10, 20, 30];
|
|
976
|
-
}
|
|
977
|
-
this.loading = false;
|
|
978
|
-
this.noData = false;
|
|
979
|
-
}
|
|
980
|
-
else {
|
|
981
|
-
this.loading = false;
|
|
982
|
-
this.noData = true;
|
|
983
|
-
}
|
|
984
|
-
},
|
|
985
|
-
error: (err) => {
|
|
986
|
-
this.loading = false;
|
|
987
|
-
this.noData = true;
|
|
988
|
-
this.cd.detectChanges();
|
|
989
|
-
},
|
|
990
|
-
complete: () => { },
|
|
991
|
-
});
|
|
992
|
-
}
|
|
993
|
-
else if (this.type === 'dataMismatch') {
|
|
994
|
-
this.service
|
|
995
|
-
.getDataMismathList(obj)
|
|
996
|
-
.pipe(takeUntil(this.destroy$))
|
|
997
|
-
.subscribe({
|
|
998
|
-
next: (res) => {
|
|
999
|
-
if (res && res.code === 200) {
|
|
1000
|
-
this.listArray = res?.data?.response;
|
|
1001
|
-
if (res.data.result.length === 0) {
|
|
1002
|
-
this.loading = false;
|
|
1003
|
-
this.noData = true;
|
|
1004
|
-
}
|
|
1005
|
-
else {
|
|
1006
|
-
this.tableListArray = res?.data?.result;
|
|
1007
|
-
this.totalItems = res.data?.count;
|
|
1008
|
-
if (this.totalItems < 10) {
|
|
1009
|
-
this.paginationSizes = [this.totalItems];
|
|
1010
|
-
}
|
|
1011
|
-
else {
|
|
1012
|
-
this.paginationSizes = [10, 20, 30];
|
|
1013
|
-
}
|
|
1014
|
-
this.loading = false;
|
|
1015
|
-
this.noData = false;
|
|
1016
|
-
this.selectAll = false;
|
|
1017
|
-
this.assignTicket = false;
|
|
1018
|
-
this.cd.detectChanges();
|
|
1019
|
-
}
|
|
1020
|
-
}
|
|
1021
|
-
else {
|
|
1022
|
-
this.loading = false;
|
|
1023
|
-
this.noData = true;
|
|
1024
|
-
}
|
|
1025
|
-
},
|
|
1026
|
-
error: (err) => {
|
|
1027
|
-
this.loading = false;
|
|
1028
|
-
this.noData = true;
|
|
1029
|
-
this.cd.detectChanges();
|
|
1030
|
-
},
|
|
1031
|
-
complete: () => { },
|
|
1032
|
-
});
|
|
1033
|
-
}
|
|
1034
|
-
}
|
|
1035
|
-
routeToStore(storeId, clientId) {
|
|
1036
|
-
let data = JSON.parse(localStorage.getItem("header-filters") || "");
|
|
1037
|
-
data.store = storeId;
|
|
1038
|
-
data.client = clientId;
|
|
1039
|
-
localStorage.setItem("header-filters", JSON.stringify(data));
|
|
1040
|
-
this.gs.dataRangeValue.next(data);
|
|
1041
|
-
this.router.navigate(['/manage/stores/infra-ticket'], {
|
|
1042
|
-
queryParams: { storeId: storeId }
|
|
1043
|
-
});
|
|
1044
|
-
}
|
|
1045
|
-
routeToMat(storeId, clientId, clientName) {
|
|
1046
|
-
let data = JSON.parse(localStorage.getItem("header-filters") || "");
|
|
1047
|
-
data.store = storeId;
|
|
1048
|
-
data.client = clientId;
|
|
1049
|
-
data.clientName = clientName ? clientName : 'Stores';
|
|
1050
|
-
localStorage.setItem("header-filters", JSON.stringify(data));
|
|
1051
|
-
this.gs.dataRangeValue.next(data);
|
|
1052
|
-
this.router.navigate(['/manage/stores/mat'], {
|
|
1053
|
-
queryParams: { storeId: storeId }
|
|
1054
|
-
});
|
|
1055
|
-
}
|
|
1056
|
-
commentModal(obj) {
|
|
1057
|
-
const modalRef = this.modalService.open(CommentModelComponent, {
|
|
1058
|
-
centered: true,
|
|
1059
|
-
size: "md",
|
|
1060
|
-
scrollable: true,
|
|
1061
|
-
backdrop: "static"
|
|
1062
|
-
});
|
|
1063
|
-
modalRef.componentInstance.ticketId = obj.ticketId;
|
|
1064
|
-
modalRef.result.then((result) => {
|
|
1065
|
-
});
|
|
1066
|
-
}
|
|
1067
|
-
tickets(type, clientId, storeId, clientName) {
|
|
1068
|
-
if (type === 'mat') {
|
|
1069
|
-
let data = JSON.parse(localStorage.getItem("header-filters") || "");
|
|
1070
|
-
data.store = storeId;
|
|
1071
|
-
data.client = clientId;
|
|
1072
|
-
data.clientName = clientName ? clientName : 'Stores';
|
|
1073
|
-
localStorage.setItem("header-filters", JSON.stringify(data));
|
|
1074
|
-
this.gs.dataRangeValue.next(data);
|
|
1075
|
-
this.router.navigate(['/manage/stores/mat'], {
|
|
1076
|
-
queryParams: { storeId: storeId }
|
|
1077
|
-
});
|
|
1078
|
-
}
|
|
1079
|
-
else {
|
|
1080
|
-
let data = JSON.parse(localStorage.getItem("header-filters") || "");
|
|
1081
|
-
data.store = storeId;
|
|
1082
|
-
data.client = clientId;
|
|
1083
|
-
data.clientName = clientName ? clientName : 'Stores';
|
|
1084
|
-
localStorage.setItem("header-filters", JSON.stringify(data));
|
|
1085
|
-
this.gs.dataRangeValue.next(data);
|
|
1086
|
-
this.router.navigate(['/manage/stores/infra-ticket'], {
|
|
1087
|
-
queryParams: { storeId: storeId, type: type }
|
|
1088
|
-
});
|
|
1089
|
-
}
|
|
1090
|
-
}
|
|
1091
|
-
clientTickets(clientId, storeId, clientName) {
|
|
1092
|
-
let data = JSON.parse(localStorage.getItem("header-filters") || "");
|
|
1093
|
-
data.store = storeId;
|
|
1094
|
-
data.client = clientId;
|
|
1095
|
-
data.clientName = clientName ? clientName : 'Stores';
|
|
1096
|
-
localStorage.setItem("header-filters", JSON.stringify(data));
|
|
1097
|
-
this.gs.dataRangeValue.next(data);
|
|
1098
|
-
this.router.navigate(['/manage/stores']);
|
|
1099
|
-
}
|
|
1100
|
-
storeTickets(clientId, storeId, clientName) {
|
|
1101
|
-
let data = JSON.parse(localStorage.getItem("header-filters") || "");
|
|
1102
|
-
data.store = storeId;
|
|
1103
|
-
data.client = clientId;
|
|
1104
|
-
data.clientName = clientName ? clientName : 'Stores';
|
|
1105
|
-
localStorage.setItem("header-filters", JSON.stringify(data));
|
|
1106
|
-
this.gs.dataRangeValue.next(data);
|
|
1107
|
-
this.router.navigate(['/manage/stores/cameras'], {
|
|
1108
|
-
queryParams: { storeId: storeId }
|
|
1109
|
-
});
|
|
1110
|
-
}
|
|
1111
|
-
userTickets(clientId, storeId) {
|
|
1112
|
-
let data = JSON.parse(localStorage.getItem("header-filters") || "");
|
|
1113
|
-
data.store = storeId;
|
|
1114
|
-
data.client = clientId;
|
|
1115
|
-
localStorage.setItem("header-filters", JSON.stringify(data));
|
|
1116
|
-
this.gs.dataRangeValue.next(data);
|
|
1117
|
-
this.router.navigate(['/manage/users']);
|
|
1118
|
-
}
|
|
1119
|
-
setpageSize() {
|
|
1120
|
-
if (this.totalItems < 10) {
|
|
1121
|
-
return this.totalItems;
|
|
1122
|
-
}
|
|
1123
|
-
else {
|
|
1124
|
-
return this.pageSize;
|
|
1125
|
-
}
|
|
1126
|
-
}
|
|
1127
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TicketsComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i2.Router }, { token: i2.ActivatedRoute }, { token: i1$1.GlobalStateService }, { token: i1$2.NgbModal }, { token: TicketService }, { token: ExcelService }], target: i0.ɵɵFactoryTarget.Component });
|
|
1128
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TicketsComponent, selector: "lib-tickets", ngImport: i0, template: "<div class=\"card\">\r\n <div class=\"card-header border-0 pt-3\">\r\n <h3 class=\"card-title align-items-start flex-column\">\r\n <span *ngIf=\"type !=='dataMismatch' && type !== 'mat'\" class=\"card-label mb-2\">{{type | titlecase}}</span>\r\n <span *ngIf=\"type ==='dataMismatch'\" class=\"card-label mb-2\">Data Mismatch</span>\r\n <span *ngIf=\"type ==='mat'\" class=\"card-label mb-2\">Employee Mat</span>\r\n\r\n <!-- <span class=\"text-sub mb-2\">Last updated 1 hour ago</span> -->\r\n </h3>\r\n <div class=\"card-toolbar\">\r\n <div *ngIf=\"!assignTicket\" class=\"d-flex\">\r\n <div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\" height=\"2\" rx=\"1\"\r\n transform=\"rotate(45 17.0365 15.1223)\" fill=\"currentColor\"></rect>\r\n <path\r\n d=\"M11 19C6.55556 19 3 15.4444 3 11C3 6.55556 6.55556 3 11 3C15.4444 3 19 6.55556 19 11C19 15.4444 15.4444 19 11 19ZM11 5C7.53333 5 5 7.53333 5 11C5 14.4667 7.53333 17 11 17C14.4667 17 17 14.4667 17 11C17 7.53333 14.4667 5 11 5Z\"\r\n fill=\"currentColor\"></path>\r\n </svg>\r\n </span>\r\n <input type=\"text\" class=\"form-control ps-14 me-2\" placeholder=\"Search\" autocomplete=\"off\"\r\n (change)=\"searchData()\" [(ngModel)]=\"searchValue\" />\r\n <lib-filters *ngIf=\"users.userType === 'tango' && userList?.length || users.userType === 'client' && storeList?.length\" [dataObject]=\"dataObject\"\r\n (appliedFilters)=\"applyFilters($event)\"></lib-filters>\r\n\r\n <button type=\"button\" *ngIf=\"!noData&&!loading\" (click)=\"exportXLSX()\"\r\n class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n <span class=\"ms-2\">Export</span>\r\n </button>\r\n </div>\r\n </div>\r\n <div *ngIf=\"assignTicket\" class=\"d-flex\">\r\n <button type=\"button\" (click)=\"addAssignTicket()\"\r\n class=\"btn mx-2 btn-primary rounded-3 text-nowrap border-val\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path d=\"M9.99984 4.1665V15.8332M4.1665 9.99984H15.8332\" stroke=\"white\" stroke-width=\"1.67\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n <span class=\"ms-2 text-white\">Assign Ticket</span>\r\n </button>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"card-body\">\r\n\r\n\r\n <ul *ngIf=\"!loading && listArray?.length && type !== 'mat' && type !== 'dataMismatch'\" class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap horizontal-scroll\">\r\n <li class=\"nav-item\" *ngFor=\"let obj of listArray.slice().reverse()\" (click)=\"selectedTabs(obj)\">\r\n <a [ngClass]=\"{'active': selectedTab === obj.name}\" class=\"nav-link cursor-pointer no-border me-2\">\r\n {{obj.name | titlecase}} <span class=\"mx-2\"\r\n [ngClass]=\"selectedTab === obj.name ? 'text-border-priamry' : 'text-border'\">{{obj.count}}</span>\r\n </a>\r\n </li>\r\n </ul>\r\n <ul *ngIf=\"!loading && listArray?.length && type === 'dataMismatch'\" class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap horizontal-scroll\">\r\n <li class=\"nav-item\" *ngFor=\"let obj of listArray.slice().reverse()\" (click)=\"selectedTabs(obj)\">\r\n <a [ngClass]=\"selectedTab === transformName(obj.name) ? 'active' : ''\" class=\"nav-link cursor-pointer no-border me-2\">\r\n {{obj.name | titlecase}} <span class=\"mx-2\"\r\n [ngClass]=\"selectedTab === transformName(obj.name) ? 'text-border-priamry' : 'text-border'\">{{obj.count}}</span>\r\n </a>\r\n </li>\r\n </ul>\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 <div class=\"col-lg-12 mb-3\">\r\n <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n <img class=\"img-src\" src=\"./assets/tango/Icons/Nodata.svg\" alt=\"\">\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"!loading && !noData\" class=\"table-responsive mt-5\">\r\n <table class=\"table bottom-border text-nowrap \">\r\n <thead>\r\n <tr>\r\n <th class=\"cursor-pointer\" >\r\n \r\n <input *ngIf=\"this.users.userType ==='tango'\"\r\n class=\"form-check-input cursor-pointer me-4\" type=\"checkbox\" [(ngModel)]=\"selectAll\"\r\n (click)=\"selectAllStore($event)\"> <span class=\"cursor-pointer\" (click)=\"onSort('ticketId')\"> Ticket ID <svg\r\n [ngClass]=\"sortedColumn === 'ticketId' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'ticketId' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></span> \r\n </th>\r\n <th class=\"cursor-pointer\" *ngIf=\"type !=='dataMismatch'\" (click)=\"onSort('issueDate')\"> Created Date\r\n <svg [ngClass]=\"sortedColumn === 'issueDate' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'issueDate' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"type ==='infra'\" (click)=\"onSort('createdAt')\"> Created Time\r\n <svg [ngClass]=\"sortedColumn === 'createdAt' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'createdAt' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"type ==='infra'\" (click)=\"onSort('issueClosedDate')\"> Closed Time\r\n <svg [ngClass]=\"sortedColumn === 'issueClosedDate' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'issueClosedDate' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('createdAt')\"> Created Date\r\n <svg [ngClass]=\"sortedColumn === 'createdAt' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'createdAt' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" ><span (click)=\"onSort('issueDate')\">Issue Date\r\n <svg [ngClass]=\"sortedColumn === 'issueDate' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'issueDate' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></span>\r\n </th>\r\n <th class=\"cursor-pointer\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\" class=\"cursor-pointer\" (click)=\"onSort('clientName')\">Brand Name<svg\r\n [ngClass]=\"sortedColumn === 'clientName' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'clientName' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\" class=\"cursor-pointer\" (click)=\"onSort('clientId')\">Brand ID<svg\r\n [ngClass]=\"sortedColumn === 'clientId' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'clientId' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('storeName')\">Store Name<svg\r\n [ngClass]=\"sortedColumn === 'storeName' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'storeName' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('storeId')\">Store ID<svg\r\n [ngClass]=\"sortedColumn === 'storeId' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'storeId' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"this.users.userType ==='tango' && (type ==='infra'||type ==='dataMismatch'||type ==='mat')\" (click)=\"onSort('userName')\">Resolved By<svg [ngClass]=\"sortedColumn === 'userName' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'userName' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"this.users.userType ==='tango' && type ==='installation'\" (click)=\"onSort('userName')\">Installed By<svg [ngClass]=\"sortedColumn === 'userName' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'userName' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('issueType')\">Issue Type\r\n <svg [ngClass]=\"sortedColumn === 'issueType' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'issueType' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('type')\">Query Type\r\n <svg [ngClass]=\"sortedColumn === 'type' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'type' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('reportedFootfall')\">Reported Footfall\r\n <svg [ngClass]=\"sortedColumn === 'reportedFootfall' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'reportedFootfall' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('mappedCount')\">Unique Images\r\n <svg [ngClass]=\"sortedColumn === 'mappedCount' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'mappedCount' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('successPercentage')\">Success Percentage\r\n <svg [ngClass]=\"sortedColumn === 'successPercentage' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'successPercentage' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th class=\"cursor-pointer\" *ngIf=\"type ==='installation'\" (click)=\"onSort('status')\">Deployed Status<svg\r\n [ngClass]=\"sortedColumn === 'status' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'status' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th *ngIf=\"type ==='dataMismatch' ||type ==='mat'|| type ==='infra'\" class=\"cursor-pointer\" (click)=\"onSort('status')\">Status<svg\r\n [ngClass]=\"sortedColumn === 'status' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'status' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n<!-- added config and total downtime as per the prioduct team requirement -->\r\n <th>Configured Ticket Time\r\n </th> \r\n\r\n <th >Total Downtime\r\n </th>\r\n<!-- -->\r\n\r\n <th *ngIf=\"type !== 'mat' && type !== 'dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('primaryIssue')\">Primary Issues<svg\r\n [ngClass]=\"sortedColumn === 'primaryIssue' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'primaryIssue' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th *ngIf=\"type !== 'mat' && type !== 'dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('secondaryIssue')\">Secondary Issues<svg\r\n [ngClass]=\"sortedColumn === 'secondaryIssue' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'secondaryIssue' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th *ngIf=\"type!=='installation'\">Actions</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let obj of tableListArray\">\r\n <td>\r\n <input *ngIf=\"this.users.userType ==='tango'\" class=\"form-check-input cursor-pointer me-4 mt-3\" type=\"checkbox\" [(ngModel)]=\"obj.checked\"\r\n (change)=\"updateCheck($event,obj?.ticketId)\">\r\n <span *ngIf=\"type === 'dataMismatch' || type === 'mat' || type === 'infra'\"\r\n class=\"txt-light-primary cursor-pointer\" (click)=\"tickets(type,obj.clientId,obj.storeId,obj.clientName)\">\r\n {{obj.ticketId}}\r\n </span>\r\n <span *ngIf=\"type === 'installation'\">\r\n {{obj.ticketId}}\r\n </span>\r\n </td>\r\n <td *ngIf=\"type === 'dataMismatch'\">\r\n {{obj?.createdAt |\r\n date: 'dd MMM, yyyy'}}</td>\r\n <td *ngIf=\"type === 'dataMismatch'\">\r\n {{obj?.issueDate |\r\n date: 'dd MMM, yyyy'}}</td>\r\n <td *ngIf=\"type !== 'dataMismatch'\">\r\n {{obj?.createdAt |\r\n date: 'dd MMM, yyyy'}}\r\n </td>\r\n <td *ngIf=\"type === 'infra'\">\r\n {{obj?.createdAt |\r\n date: 'hh:mm a' | uppercase}}\r\n </td>\r\n <td *ngIf=\"type === 'infra'\">\r\n {{obj?.issueClosedDate?(obj?.issueClosedDate |\r\n date: 'hh:mm a' | uppercase):\"--\"}}\r\n </td>\r\n <td *ngIf=\"this.users.userType ==='tango'\">\r\n <div class=\"table-title cursor-pointer\" (click)=\"clientTickets(obj.clientId,obj.storeId,obj.clientName)\">\r\n <span class=\"txt-light-primary\">\r\n {{obj.clientName}}\r\n </span>\r\n </div>\r\n </td>\r\n <td *ngIf=\"this.users.userType ==='tango'\">{{obj.clientId}}\r\n </td>\r\n <td>\r\n <div class=\"table-title cursor-pointer\" (click)=\"storeTickets(obj.clientId,obj.storeId,obj.clientName)\">\r\n <span class=\"txt-light-primary\">\r\n {{obj.storeName}}\r\n </span>\r\n </div>\r\n </td>\r\n <td>{{obj.storeId}}\r\n </td>\r\n \r\n <td *ngIf=\"this.users.userType ==='tango'\">\r\n <div class=\"table-title cursor-pointer\" >\r\n <span >\r\n {{obj.userName}}\r\n </span>\r\n </div>\r\n </td>\r\n <td *ngIf=\"type ==='dataMismatch' && obj.issueType ==='lowcount'\" >Low Count</td>\r\n <td *ngIf=\"type ==='dataMismatch' && obj.issueType ==='highcount'\">High Count</td>\r\n <td class=\"text-capitalize\" *ngIf=\"type ==='dataMismatch'\">{{obj?.type ? obj?.type:'--'}}</td>\r\n <td class=\"text-capitalize\" *ngIf=\"type ==='dataMismatch'\">{{obj?.reportedFootfall ? obj?.reportedFootfall:'--'}}</td>\r\n <td class=\"text-capitalize\" *ngIf=\"type ==='dataMismatch'\">{{obj?.mappedCount ? obj?.mappedCount:'--'}}</td>\r\n <td class=\"text-capitalize\" *ngIf=\"type ==='dataMismatch'\">{{obj?.successPercentage ? obj?.successPercentage:'--'}}</td>\r\n <td *ngIf=\"type==='installation'\">\r\n <span *ngIf=\"obj.installationStatus ==='paired' || obj.installationStatus ==='onboarded'\"\r\n class=\"badge badge-light-primary mx-4\">{{obj.installationStatus | titlecase}}</span>\r\n <span *ngIf=\"obj.installationStatus ==='live'\" class=\"badge badge-light-success mx-4\">Live</span>\r\n <span *ngIf=\"obj.installationStatus ==='installationfailed'\"\r\n class=\"badge badge-light-warning mx-4\">Installationfailed</span>\r\n <span *ngIf=\"obj.installationStatus ==='deployed'\"\r\n class=\"badge badge-light-success mx-4 text-capitalize\">deployed</span>\r\n </td>\r\n <td *ngIf=\"type==='infra' || type==='mat' || type==='dataMismatch'\">\r\n <span *ngIf=\"obj.status ==='open'\" class=\"badge badge-light-danger\">Open</span>\r\n <span *ngIf=\"obj.status ==='closed'\" class=\"badge badge-light-success\">Closed</span>\r\n <span *ngIf=\"obj.status ==='inprogress'\" class=\"badge badge-light-primary\">In\r\n Progress</span>\r\n </td>\r\n <td *ngIf=\"type==='infra'\">\r\n{{obj.configuredDownTime?obj.configuredDownTime*60:0 || 0 }} {{obj.configuredDownTime > 1? 'mins' : 'min'}} \r\n </td>\r\n <td *ngIf=\"type==='infra'\"> \r\n{{obj.totalDownTime || 0 }} {{obj.totalDownTime > 1? 'mins' : 'min'}} \r\n </td>\r\n <td *ngIf=\"type==='installation' || type==='infra'\">\r\n <div>\r\n <span *ngIf=\"obj.primaryIssue !=='-'\">{{obj.primaryIssue ? obj.primaryIssue :'Issue not identified'}}</span>\r\n <span *ngIf=\"obj.primaryIssue ==='-'\">Issue not identified</span>\r\n </div>\r\n </td>\r\n <td *ngIf=\"type==='installation' || type==='infra'\">\r\n <span *ngIf=\"obj.secondaryIssue\">{{obj.secondaryIssue}}</span>\r\n </td>\r\n <td *ngIf=\"type==='infra' || type ==='dataMismatch'\">\r\n <span class=\"mx-2 cursor-pointer\" *ngIf=\"this.users.userType ==='tango'\" (click)=\"commentModal(obj)\"><svg\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"20\" viewBox=\"0 0 21 20\" fill=\"none\">\r\n <path\r\n d=\"M17.6431 12.5C17.6431 12.942 17.4675 13.366 17.1549 13.6785C16.8423 13.9911 16.4184 14.1667 15.9764 14.1667H5.9764L2.64307 17.5V4.16667C2.64307 3.72464 2.81866 3.30072 3.13122 2.98816C3.44378 2.67559 3.86771 2.5 4.30973 2.5H15.9764C16.4184 2.5 16.8423 2.67559 17.1549 2.98816C17.4675 3.30072 17.6431 3.72464 17.6431 4.16667V12.5Z\"\r\n stroke=\"#667085\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg></span>\r\n <span class=\"mx-2 cursor-pointer\" (click)=\"tickets(type,obj.clientId,obj.storeId,obj.clientName)\"><svg\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"20\" viewBox=\"0 0 21 20\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_10640_18061)\">\r\n <path\r\n d=\"M0.976562 10C0.976562 10 4.3099 3.33337 10.1432 3.33337C15.9766 3.33337 19.3099 10 19.3099 10C19.3099 10 15.9766 16.6667 10.1432 16.6667C4.3099 16.6667 0.976562 10 0.976562 10Z\"\r\n stroke=\"#667085\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n <path\r\n d=\"M10.1432 12.5C11.5239 12.5 12.6432 11.3808 12.6432 10C12.6432 8.61933 11.5239 7.50004 10.1432 7.50004C8.76252 7.50004 7.64323 8.61933 7.64323 10C7.64323 11.3808 8.76252 12.5 10.1432 12.5Z\"\r\n stroke=\"#667085\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_10640_18061\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(0.143066)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n </td>\r\n <td *ngIf=\"type === 'mat'\">\r\n <span class=\"mx-2 cursor-pointer\" (click)=\"routeToMat(obj.storeId,obj.clientId,obj.clientName)\"><svg\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"20\" viewBox=\"0 0 21 20\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_10640_18061)\">\r\n <path\r\n d=\"M0.976562 10C0.976562 10 4.3099 3.33337 10.1432 3.33337C15.9766 3.33337 19.3099 10 19.3099 10C19.3099 10 15.9766 16.6667 10.1432 16.6667C4.3099 16.6667 0.976562 10 0.976562 10Z\"\r\n stroke=\"#667085\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n <path\r\n d=\"M10.1432 12.5C11.5239 12.5 12.6432 11.3808 12.6432 10C12.6432 8.61933 11.5239 7.50004 10.1432 7.50004C8.76252 7.50004 7.64323 8.61933 7.64323 10C7.64323 11.3808 8.76252 12.5 10.1432 12.5Z\"\r\n stroke=\"#667085\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_10640_18061\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(0.143066)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span> \r\n \r\n </td>\r\n \r\n \r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n <div *ngIf=\"!loading && !noData\" class=\"my-3\">\r\n <lib-pagination [itemsPerPage]=\"pageSize\" [currentPage]=\"currentPage\" [totalItems]=\"totalItems\"\r\n [paginationSizes]=\"paginationSizes\" [pageSize]=\"setpageSize()\" (pageChange)=\"onPageChange($event)\"\r\n (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n </div>\r\n </div>\r\n</div>", styles: [".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}.text-border{border-radius:16px!important;background:var(--Gray-100, #F2F4F7)!important;color:var(--Gray-700, #344054);text-align:center;font-size:14px;font-weight:500;line-height:20px;padding:2px 10px!important}.text-border-priamry{border-radius:16px;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3);text-align:center;font-size:14px;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}.text-sub{color:var(--Gray-500, #667085)!important;font-family:Inter;font-size:14px!important;font-weight:400!important;line-height:20px}.border-val{color:var(--Gray-700, #344054)!important;font-family:Inter;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize}td{vertical-align:middle;line-height:35px!important}.table-title-primary{color:var(--Primary-700, #009BF3)!important;font-weight:500!important}.table-sub{line-height:30px!important;color:var(--Gray-500, #667085)!important}.txt-light-primary{color:#009bf3!important}input[type=checkbox]{width:16px!important;height:16px!important;margin:0 5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-300, #D0D5DD);box-shadow:none;font-size:.8em;text-align:center;line-height:1em;background:#fff}input[type=checkbox]:checked{outline:1px solid var(--primary-600, #00A3FF);background-color:var(--primary-50, #EAF8FF)}input[type=checkbox]:checked:after{content:\"\";transform:rotate(45deg);border-bottom:2px solid #00A3FF;border-right:2px solid #00A3FF;display:inline-block;width:.2em;padding-left:0;padding-top:9px;padding-right:4px}.img-src{width:25%;height:20%}.rotate{rotate:180deg;transition:1s}.viewbutton{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);box-shadow:0 1px 2px #1018280d;padding:10px 16px;justify-content:center;align-items:center;gap:10px;color:var(--Gray-700, #344054);font-family:Inter;font-size:12px;font-weight:600}.horizontal-scroll{overflow-x:auto;overflow-y:hidden;white-space:nowrap}\n"], dependencies: [{ kind: "directive", type: i6$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.PaginationComponent, selector: "lib-pagination", inputs: ["collection", "itemsPerPage", "currentPage", "totalItems", "directionLinks", "pageSize", "paginationSizes"], outputs: ["pageChange", "pageSizeChange"] }, { kind: "component", type: i4.FiltersComponent, selector: "lib-filters", inputs: ["dataObject"], outputs: ["appliedFilters"] }, { kind: "pipe", type: i6$1.AsyncPipe, name: "async" }, { kind: "pipe", type: i6$1.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i6$1.TitleCasePipe, name: "titlecase" }, { kind: "pipe", type: i6$1.DatePipe, name: "date" }] });
|
|
1129
|
-
}
|
|
1130
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TicketsComponent, decorators: [{
|
|
1131
|
-
type: Component,
|
|
1132
|
-
args: [{ selector: "lib-tickets", template: "<div class=\"card\">\r\n <div class=\"card-header border-0 pt-3\">\r\n <h3 class=\"card-title align-items-start flex-column\">\r\n <span *ngIf=\"type !=='dataMismatch' && type !== 'mat'\" class=\"card-label mb-2\">{{type | titlecase}}</span>\r\n <span *ngIf=\"type ==='dataMismatch'\" class=\"card-label mb-2\">Data Mismatch</span>\r\n <span *ngIf=\"type ==='mat'\" class=\"card-label mb-2\">Employee Mat</span>\r\n\r\n <!-- <span class=\"text-sub mb-2\">Last updated 1 hour ago</span> -->\r\n </h3>\r\n <div class=\"card-toolbar\">\r\n <div *ngIf=\"!assignTicket\" class=\"d-flex\">\r\n <div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\" height=\"2\" rx=\"1\"\r\n transform=\"rotate(45 17.0365 15.1223)\" fill=\"currentColor\"></rect>\r\n <path\r\n d=\"M11 19C6.55556 19 3 15.4444 3 11C3 6.55556 6.55556 3 11 3C15.4444 3 19 6.55556 19 11C19 15.4444 15.4444 19 11 19ZM11 5C7.53333 5 5 7.53333 5 11C5 14.4667 7.53333 17 11 17C14.4667 17 17 14.4667 17 11C17 7.53333 14.4667 5 11 5Z\"\r\n fill=\"currentColor\"></path>\r\n </svg>\r\n </span>\r\n <input type=\"text\" class=\"form-control ps-14 me-2\" placeholder=\"Search\" autocomplete=\"off\"\r\n (change)=\"searchData()\" [(ngModel)]=\"searchValue\" />\r\n <lib-filters *ngIf=\"users.userType === 'tango' && userList?.length || users.userType === 'client' && storeList?.length\" [dataObject]=\"dataObject\"\r\n (appliedFilters)=\"applyFilters($event)\"></lib-filters>\r\n\r\n <button type=\"button\" *ngIf=\"!noData&&!loading\" (click)=\"exportXLSX()\"\r\n class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n <span class=\"ms-2\">Export</span>\r\n </button>\r\n </div>\r\n </div>\r\n <div *ngIf=\"assignTicket\" class=\"d-flex\">\r\n <button type=\"button\" (click)=\"addAssignTicket()\"\r\n class=\"btn mx-2 btn-primary rounded-3 text-nowrap border-val\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path d=\"M9.99984 4.1665V15.8332M4.1665 9.99984H15.8332\" stroke=\"white\" stroke-width=\"1.67\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n <span class=\"ms-2 text-white\">Assign Ticket</span>\r\n </button>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"card-body\">\r\n\r\n\r\n <ul *ngIf=\"!loading && listArray?.length && type !== 'mat' && type !== 'dataMismatch'\" class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap horizontal-scroll\">\r\n <li class=\"nav-item\" *ngFor=\"let obj of listArray.slice().reverse()\" (click)=\"selectedTabs(obj)\">\r\n <a [ngClass]=\"{'active': selectedTab === obj.name}\" class=\"nav-link cursor-pointer no-border me-2\">\r\n {{obj.name | titlecase}} <span class=\"mx-2\"\r\n [ngClass]=\"selectedTab === obj.name ? 'text-border-priamry' : 'text-border'\">{{obj.count}}</span>\r\n </a>\r\n </li>\r\n </ul>\r\n <ul *ngIf=\"!loading && listArray?.length && type === 'dataMismatch'\" class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap horizontal-scroll\">\r\n <li class=\"nav-item\" *ngFor=\"let obj of listArray.slice().reverse()\" (click)=\"selectedTabs(obj)\">\r\n <a [ngClass]=\"selectedTab === transformName(obj.name) ? 'active' : ''\" class=\"nav-link cursor-pointer no-border me-2\">\r\n {{obj.name | titlecase}} <span class=\"mx-2\"\r\n [ngClass]=\"selectedTab === transformName(obj.name) ? 'text-border-priamry' : 'text-border'\">{{obj.count}}</span>\r\n </a>\r\n </li>\r\n </ul>\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 <div class=\"col-lg-12 mb-3\">\r\n <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n <img class=\"img-src\" src=\"./assets/tango/Icons/Nodata.svg\" alt=\"\">\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"!loading && !noData\" class=\"table-responsive mt-5\">\r\n <table class=\"table bottom-border text-nowrap \">\r\n <thead>\r\n <tr>\r\n <th class=\"cursor-pointer\" >\r\n \r\n <input *ngIf=\"this.users.userType ==='tango'\"\r\n class=\"form-check-input cursor-pointer me-4\" type=\"checkbox\" [(ngModel)]=\"selectAll\"\r\n (click)=\"selectAllStore($event)\"> <span class=\"cursor-pointer\" (click)=\"onSort('ticketId')\"> Ticket ID <svg\r\n [ngClass]=\"sortedColumn === 'ticketId' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'ticketId' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></span> \r\n </th>\r\n <th class=\"cursor-pointer\" *ngIf=\"type !=='dataMismatch'\" (click)=\"onSort('issueDate')\"> Created Date\r\n <svg [ngClass]=\"sortedColumn === 'issueDate' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'issueDate' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"type ==='infra'\" (click)=\"onSort('createdAt')\"> Created Time\r\n <svg [ngClass]=\"sortedColumn === 'createdAt' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'createdAt' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"type ==='infra'\" (click)=\"onSort('issueClosedDate')\"> Closed Time\r\n <svg [ngClass]=\"sortedColumn === 'issueClosedDate' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'issueClosedDate' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('createdAt')\"> Created Date\r\n <svg [ngClass]=\"sortedColumn === 'createdAt' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'createdAt' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" ><span (click)=\"onSort('issueDate')\">Issue Date\r\n <svg [ngClass]=\"sortedColumn === 'issueDate' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'issueDate' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></span>\r\n </th>\r\n <th class=\"cursor-pointer\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\" class=\"cursor-pointer\" (click)=\"onSort('clientName')\">Brand Name<svg\r\n [ngClass]=\"sortedColumn === 'clientName' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'clientName' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"(gs.userAccess | async)?.userType === 'tango'\" class=\"cursor-pointer\" (click)=\"onSort('clientId')\">Brand ID<svg\r\n [ngClass]=\"sortedColumn === 'clientId' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'clientId' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('storeName')\">Store Name<svg\r\n [ngClass]=\"sortedColumn === 'storeName' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'storeName' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('storeId')\">Store ID<svg\r\n [ngClass]=\"sortedColumn === 'storeId' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'storeId' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"this.users.userType ==='tango' && (type ==='infra'||type ==='dataMismatch'||type ==='mat')\" (click)=\"onSort('userName')\">Resolved By<svg [ngClass]=\"sortedColumn === 'userName' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'userName' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" *ngIf=\"this.users.userType ==='tango' && type ==='installation'\" (click)=\"onSort('userName')\">Installed By<svg [ngClass]=\"sortedColumn === 'userName' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'userName' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('issueType')\">Issue Type\r\n <svg [ngClass]=\"sortedColumn === 'issueType' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'issueType' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('type')\">Query Type\r\n <svg [ngClass]=\"sortedColumn === 'type' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'type' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('reportedFootfall')\">Reported Footfall\r\n <svg [ngClass]=\"sortedColumn === 'reportedFootfall' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'reportedFootfall' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('mappedCount')\">Unique Images\r\n <svg [ngClass]=\"sortedColumn === 'mappedCount' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'mappedCount' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th *ngIf=\"type ==='dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('successPercentage')\">Success Percentage\r\n <svg [ngClass]=\"sortedColumn === 'successPercentage' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'successPercentage' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th class=\"cursor-pointer\" *ngIf=\"type ==='installation'\" (click)=\"onSort('status')\">Deployed Status<svg\r\n [ngClass]=\"sortedColumn === 'status' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'status' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th *ngIf=\"type ==='dataMismatch' ||type ==='mat'|| type ==='infra'\" class=\"cursor-pointer\" (click)=\"onSort('status')\">Status<svg\r\n [ngClass]=\"sortedColumn === 'status' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'status' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n<!-- added config and total downtime as per the prioduct team requirement -->\r\n <th>Configured Ticket Time\r\n </th> \r\n\r\n <th >Total Downtime\r\n </th>\r\n<!-- -->\r\n\r\n <th *ngIf=\"type !== 'mat' && type !== 'dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('primaryIssue')\">Primary Issues<svg\r\n [ngClass]=\"sortedColumn === 'primaryIssue' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'primaryIssue' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th *ngIf=\"type !== 'mat' && type !== 'dataMismatch'\" class=\"cursor-pointer\" (click)=\"onSort('secondaryIssue')\">Secondary Issues<svg\r\n [ngClass]=\"sortedColumn === 'secondaryIssue' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'secondaryIssue' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th *ngIf=\"type!=='installation'\">Actions</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let obj of tableListArray\">\r\n <td>\r\n <input *ngIf=\"this.users.userType ==='tango'\" class=\"form-check-input cursor-pointer me-4 mt-3\" type=\"checkbox\" [(ngModel)]=\"obj.checked\"\r\n (change)=\"updateCheck($event,obj?.ticketId)\">\r\n <span *ngIf=\"type === 'dataMismatch' || type === 'mat' || type === 'infra'\"\r\n class=\"txt-light-primary cursor-pointer\" (click)=\"tickets(type,obj.clientId,obj.storeId,obj.clientName)\">\r\n {{obj.ticketId}}\r\n </span>\r\n <span *ngIf=\"type === 'installation'\">\r\n {{obj.ticketId}}\r\n </span>\r\n </td>\r\n <td *ngIf=\"type === 'dataMismatch'\">\r\n {{obj?.createdAt |\r\n date: 'dd MMM, yyyy'}}</td>\r\n <td *ngIf=\"type === 'dataMismatch'\">\r\n {{obj?.issueDate |\r\n date: 'dd MMM, yyyy'}}</td>\r\n <td *ngIf=\"type !== 'dataMismatch'\">\r\n {{obj?.createdAt |\r\n date: 'dd MMM, yyyy'}}\r\n </td>\r\n <td *ngIf=\"type === 'infra'\">\r\n {{obj?.createdAt |\r\n date: 'hh:mm a' | uppercase}}\r\n </td>\r\n <td *ngIf=\"type === 'infra'\">\r\n {{obj?.issueClosedDate?(obj?.issueClosedDate |\r\n date: 'hh:mm a' | uppercase):\"--\"}}\r\n </td>\r\n <td *ngIf=\"this.users.userType ==='tango'\">\r\n <div class=\"table-title cursor-pointer\" (click)=\"clientTickets(obj.clientId,obj.storeId,obj.clientName)\">\r\n <span class=\"txt-light-primary\">\r\n {{obj.clientName}}\r\n </span>\r\n </div>\r\n </td>\r\n <td *ngIf=\"this.users.userType ==='tango'\">{{obj.clientId}}\r\n </td>\r\n <td>\r\n <div class=\"table-title cursor-pointer\" (click)=\"storeTickets(obj.clientId,obj.storeId,obj.clientName)\">\r\n <span class=\"txt-light-primary\">\r\n {{obj.storeName}}\r\n </span>\r\n </div>\r\n </td>\r\n <td>{{obj.storeId}}\r\n </td>\r\n \r\n <td *ngIf=\"this.users.userType ==='tango'\">\r\n <div class=\"table-title cursor-pointer\" >\r\n <span >\r\n {{obj.userName}}\r\n </span>\r\n </div>\r\n </td>\r\n <td *ngIf=\"type ==='dataMismatch' && obj.issueType ==='lowcount'\" >Low Count</td>\r\n <td *ngIf=\"type ==='dataMismatch' && obj.issueType ==='highcount'\">High Count</td>\r\n <td class=\"text-capitalize\" *ngIf=\"type ==='dataMismatch'\">{{obj?.type ? obj?.type:'--'}}</td>\r\n <td class=\"text-capitalize\" *ngIf=\"type ==='dataMismatch'\">{{obj?.reportedFootfall ? obj?.reportedFootfall:'--'}}</td>\r\n <td class=\"text-capitalize\" *ngIf=\"type ==='dataMismatch'\">{{obj?.mappedCount ? obj?.mappedCount:'--'}}</td>\r\n <td class=\"text-capitalize\" *ngIf=\"type ==='dataMismatch'\">{{obj?.successPercentage ? obj?.successPercentage:'--'}}</td>\r\n <td *ngIf=\"type==='installation'\">\r\n <span *ngIf=\"obj.installationStatus ==='paired' || obj.installationStatus ==='onboarded'\"\r\n class=\"badge badge-light-primary mx-4\">{{obj.installationStatus | titlecase}}</span>\r\n <span *ngIf=\"obj.installationStatus ==='live'\" class=\"badge badge-light-success mx-4\">Live</span>\r\n <span *ngIf=\"obj.installationStatus ==='installationfailed'\"\r\n class=\"badge badge-light-warning mx-4\">Installationfailed</span>\r\n <span *ngIf=\"obj.installationStatus ==='deployed'\"\r\n class=\"badge badge-light-success mx-4 text-capitalize\">deployed</span>\r\n </td>\r\n <td *ngIf=\"type==='infra' || type==='mat' || type==='dataMismatch'\">\r\n <span *ngIf=\"obj.status ==='open'\" class=\"badge badge-light-danger\">Open</span>\r\n <span *ngIf=\"obj.status ==='closed'\" class=\"badge badge-light-success\">Closed</span>\r\n <span *ngIf=\"obj.status ==='inprogress'\" class=\"badge badge-light-primary\">In\r\n Progress</span>\r\n </td>\r\n <td *ngIf=\"type==='infra'\">\r\n{{obj.configuredDownTime?obj.configuredDownTime*60:0 || 0 }} {{obj.configuredDownTime > 1? 'mins' : 'min'}} \r\n </td>\r\n <td *ngIf=\"type==='infra'\"> \r\n{{obj.totalDownTime || 0 }} {{obj.totalDownTime > 1? 'mins' : 'min'}} \r\n </td>\r\n <td *ngIf=\"type==='installation' || type==='infra'\">\r\n <div>\r\n <span *ngIf=\"obj.primaryIssue !=='-'\">{{obj.primaryIssue ? obj.primaryIssue :'Issue not identified'}}</span>\r\n <span *ngIf=\"obj.primaryIssue ==='-'\">Issue not identified</span>\r\n </div>\r\n </td>\r\n <td *ngIf=\"type==='installation' || type==='infra'\">\r\n <span *ngIf=\"obj.secondaryIssue\">{{obj.secondaryIssue}}</span>\r\n </td>\r\n <td *ngIf=\"type==='infra' || type ==='dataMismatch'\">\r\n <span class=\"mx-2 cursor-pointer\" *ngIf=\"this.users.userType ==='tango'\" (click)=\"commentModal(obj)\"><svg\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"20\" viewBox=\"0 0 21 20\" fill=\"none\">\r\n <path\r\n d=\"M17.6431 12.5C17.6431 12.942 17.4675 13.366 17.1549 13.6785C16.8423 13.9911 16.4184 14.1667 15.9764 14.1667H5.9764L2.64307 17.5V4.16667C2.64307 3.72464 2.81866 3.30072 3.13122 2.98816C3.44378 2.67559 3.86771 2.5 4.30973 2.5H15.9764C16.4184 2.5 16.8423 2.67559 17.1549 2.98816C17.4675 3.30072 17.6431 3.72464 17.6431 4.16667V12.5Z\"\r\n stroke=\"#667085\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg></span>\r\n <span class=\"mx-2 cursor-pointer\" (click)=\"tickets(type,obj.clientId,obj.storeId,obj.clientName)\"><svg\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"20\" viewBox=\"0 0 21 20\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_10640_18061)\">\r\n <path\r\n d=\"M0.976562 10C0.976562 10 4.3099 3.33337 10.1432 3.33337C15.9766 3.33337 19.3099 10 19.3099 10C19.3099 10 15.9766 16.6667 10.1432 16.6667C4.3099 16.6667 0.976562 10 0.976562 10Z\"\r\n stroke=\"#667085\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n <path\r\n d=\"M10.1432 12.5C11.5239 12.5 12.6432 11.3808 12.6432 10C12.6432 8.61933 11.5239 7.50004 10.1432 7.50004C8.76252 7.50004 7.64323 8.61933 7.64323 10C7.64323 11.3808 8.76252 12.5 10.1432 12.5Z\"\r\n stroke=\"#667085\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_10640_18061\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(0.143066)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>\r\n </td>\r\n <td *ngIf=\"type === 'mat'\">\r\n <span class=\"mx-2 cursor-pointer\" (click)=\"routeToMat(obj.storeId,obj.clientId,obj.clientName)\"><svg\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"21\" height=\"20\" viewBox=\"0 0 21 20\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_10640_18061)\">\r\n <path\r\n d=\"M0.976562 10C0.976562 10 4.3099 3.33337 10.1432 3.33337C15.9766 3.33337 19.3099 10 19.3099 10C19.3099 10 15.9766 16.6667 10.1432 16.6667C4.3099 16.6667 0.976562 10 0.976562 10Z\"\r\n stroke=\"#667085\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n <path\r\n d=\"M10.1432 12.5C11.5239 12.5 12.6432 11.3808 12.6432 10C12.6432 8.61933 11.5239 7.50004 10.1432 7.50004C8.76252 7.50004 7.64323 8.61933 7.64323 10C7.64323 11.3808 8.76252 12.5 10.1432 12.5Z\"\r\n stroke=\"#667085\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_10640_18061\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\" transform=\"translate(0.143066)\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span> \r\n \r\n </td>\r\n \r\n \r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n <div *ngIf=\"!loading && !noData\" class=\"my-3\">\r\n <lib-pagination [itemsPerPage]=\"pageSize\" [currentPage]=\"currentPage\" [totalItems]=\"totalItems\"\r\n [paginationSizes]=\"paginationSizes\" [pageSize]=\"setpageSize()\" (pageChange)=\"onPageChange($event)\"\r\n (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n </div>\r\n </div>\r\n</div>", styles: [".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}.text-border{border-radius:16px!important;background:var(--Gray-100, #F2F4F7)!important;color:var(--Gray-700, #344054);text-align:center;font-size:14px;font-weight:500;line-height:20px;padding:2px 10px!important}.text-border-priamry{border-radius:16px;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3);text-align:center;font-size:14px;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}.text-sub{color:var(--Gray-500, #667085)!important;font-family:Inter;font-size:14px!important;font-weight:400!important;line-height:20px}.border-val{color:var(--Gray-700, #344054)!important;font-family:Inter;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize}td{vertical-align:middle;line-height:35px!important}.table-title-primary{color:var(--Primary-700, #009BF3)!important;font-weight:500!important}.table-sub{line-height:30px!important;color:var(--Gray-500, #667085)!important}.txt-light-primary{color:#009bf3!important}input[type=checkbox]{width:16px!important;height:16px!important;margin:0 5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-300, #D0D5DD);box-shadow:none;font-size:.8em;text-align:center;line-height:1em;background:#fff}input[type=checkbox]:checked{outline:1px solid var(--primary-600, #00A3FF);background-color:var(--primary-50, #EAF8FF)}input[type=checkbox]:checked:after{content:\"\";transform:rotate(45deg);border-bottom:2px solid #00A3FF;border-right:2px solid #00A3FF;display:inline-block;width:.2em;padding-left:0;padding-top:9px;padding-right:4px}.img-src{width:25%;height:20%}.rotate{rotate:180deg;transition:1s}.viewbutton{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);box-shadow:0 1px 2px #1018280d;padding:10px 16px;justify-content:center;align-items:center;gap:10px;color:var(--Gray-700, #344054);font-family:Inter;font-size:12px;font-weight:600}.horizontal-scroll{overflow-x:auto;overflow-y:hidden;white-space:nowrap}\n"] }]
|
|
1133
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i1$1.GlobalStateService }, { type: i1$2.NgbModal }, { type: TicketService }, { type: ExcelService }] });
|
|
1134
|
-
|
|
1135
|
-
class ReTriggerComponent {
|
|
1136
|
-
activeModal;
|
|
1137
|
-
service;
|
|
1138
|
-
dropDown = false;
|
|
1139
|
-
loading = true;
|
|
1140
|
-
noData = false;
|
|
1141
|
-
dropdownItems = [];
|
|
1142
|
-
selectedItem = 'Audit';
|
|
1143
|
-
selectedData = 'To Queue';
|
|
1144
|
-
standardData = ['To Queue', 'To User'];
|
|
1145
|
-
Comment = '';
|
|
1146
|
-
userId = '';
|
|
1147
|
-
destroy$ = new Subject();
|
|
1148
|
-
reTrigerData;
|
|
1149
|
-
userList = [];
|
|
1150
|
-
constructor(activeModal, service) {
|
|
1151
|
-
this.activeModal = activeModal;
|
|
1152
|
-
this.service = service;
|
|
1153
|
-
}
|
|
1154
|
-
onClick(event) {
|
|
1155
|
-
const target = event.target;
|
|
1156
|
-
if (!target.closest('.dropDown')) {
|
|
1157
|
-
this.dropDown = false;
|
|
1158
|
-
}
|
|
1159
|
-
}
|
|
1160
|
-
ngOnInit() {
|
|
1161
|
-
if (this.reTrigerData?.data?.auditType === 'ReAudit') {
|
|
1162
|
-
this.dropdownItems = ['Audit', 'ReAudit'];
|
|
1163
|
-
}
|
|
1164
|
-
else if (this.reTrigerData?.data?.auditType === 'Audit') {
|
|
1165
|
-
this.dropdownItems = ['Audit'];
|
|
1166
|
-
}
|
|
1167
|
-
this.getuserList();
|
|
1168
|
-
}
|
|
1169
|
-
getuserList() {
|
|
1170
|
-
this.service.getuserList().subscribe({
|
|
1171
|
-
next: (res) => {
|
|
1172
|
-
if (res && res.code === 200) {
|
|
1173
|
-
this.userList = res?.data?.result;
|
|
1174
|
-
}
|
|
1175
|
-
},
|
|
1176
|
-
});
|
|
1177
|
-
}
|
|
1178
|
-
ngOnDestroy() {
|
|
1179
|
-
this.destroy$.next(true);
|
|
1180
|
-
this.destroy$.complete();
|
|
1181
|
-
}
|
|
1182
|
-
selectRadio(value) {
|
|
1183
|
-
this.selectedData = value;
|
|
1184
|
-
}
|
|
1185
|
-
openDropdown(event) {
|
|
1186
|
-
event.stopPropagation();
|
|
1187
|
-
this.dropDown = !this.dropDown;
|
|
1188
|
-
}
|
|
1189
|
-
selectItem(value) {
|
|
1190
|
-
this.selectedItem = value;
|
|
1191
|
-
this.dropDown = false;
|
|
1192
|
-
}
|
|
1193
|
-
onReportSelect(event) {
|
|
1194
|
-
this.userId = event;
|
|
1195
|
-
}
|
|
1196
|
-
closeModal() {
|
|
1197
|
-
let data = {
|
|
1198
|
-
fileDate: this.reTrigerData?.data?.fileDate,
|
|
1199
|
-
storeId: this.reTrigerData?.data?.storeId,
|
|
1200
|
-
auditType: this.selectedItem,
|
|
1201
|
-
zoneName: this.reTrigerData?.data?.zoneName,
|
|
1202
|
-
triggerType: this.selectedData === 'To Queue' ? 'queue' : 'user',
|
|
1203
|
-
totalCount: this.selectedItem === 'Audit' ? this.reTrigerData?.data?.beforeCount : this.reTrigerData?.data?.afterCount,
|
|
1204
|
-
comments: this.Comment,
|
|
1205
|
-
moduleType: this.reTrigerData?.data?.moduleType
|
|
1206
|
-
};
|
|
1207
|
-
this.selectedData === 'To User' ? data.userId = this.userId.userId : '';
|
|
1208
|
-
this.activeModal.close(data);
|
|
1209
|
-
}
|
|
1210
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ReTriggerComponent, deps: [{ token: i1$2.NgbActiveModal }, { token: TicketService }], target: i0.ɵɵFactoryTarget.Component });
|
|
1211
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ReTriggerComponent, selector: "lib-retrigger", inputs: { reTrigerData: "reTrigerData" }, host: { listeners: { "document:click": "onClick($event)" } }, ngImport: i0, template: "<div class=\"card\">\r\n \r\n <div class=\"card-header border-0\">\r\n <div class=\"card-title d-grid\">\r\n <div class=\"card-title\">Re-trigger File</div>\r\n <div class=\"text-sub\">Re-trigger the file to a queue or other users</div>\r\n </div>\r\n </div>\r\n <div class=\"card-body\">\r\n <div class=\"\">\r\n <label class=\"label\">Push Form</label>\r\n <div class=\"position-relative w-100 mt-3 mb-5\">\r\n <button type=\"button\" (click)=\"openDropdown($event)\"\r\n class=\"btn btn-default w-100 btn-outline btn-outline-default rounded-3 text-nowrap border-val d-flex justify-content-between\">\r\n {{selectedItem}}\r\n <span><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\"\r\n viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path d=\"M5 7.5L10 12.5L15 7.5\" stroke=\"#667085\" stroke-width=\"1.66667\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg></span>\r\n </button>\r\n <div *ngIf=\"dropDown\" class=\"card py-1 w-100 position-absolute top-50px end-0\">\r\n <ul *ngFor=\"let item of dropdownItems\" class=\"list-unstyled\">\r\n <li [ngClass]=\"selectedItem === item ? 'active' : ''\"\r\n class=\"camera px-5 items fw-semibold cursor-pointer py-2\"\r\n (click)=\"selectItem(item)\">{{item}}\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"mt-5 cursor-pointer d-flex mb-5\">\r\n <div *ngFor=\"let data of standardData\" (click)=\"selectRadio(data)\" class=\"d-flex align-items-center me-20\">\r\n <input [checked]=\"selectedData === data\" type=\"radio\" class=\"radio\">\r\n <span class=\"ms-3 standard\">{{data}}</span>\r\n </div>\r\n </div>\r\n <div *ngIf=\"selectedData === 'To User'\" class=\"w-100 mb-5\">\r\n <label for=\"infraDownTime\" class=\"label mb-3\">Select User<span class=\"alert-required\"></span></label>\r\n <lib-select [items]=\"userList\" [multi]=\"false\" [searchField]=\"'userName'\" [idField]=\"'userId'\"\r\n (selected)=\"onReportSelect($event)\" [selectedValues]=\"[userId]\"></lib-select>\r\n </div>\r\n <div>\r\n <label class=\"label mb-3\">Comments</label>\r\n <textarea class=\"form-control\" [(ngModel)]=\"Comment\"></textarea>\r\n </div>\r\n <div class=\"d-flex mt-5\">\r\n <button class=\"btn btn-outline w-100 me-2\" (click)=\"activeModal.dismiss()\">Cancel</button>\r\n <button *ngIf=\"selectedData === 'To User'\" class=\"btn btn-primary w-100 ms-2\" [disabled]=\"!userId || !Comment\" (click)=\"closeModal()\">Submit</button>\r\n <button *ngIf=\"selectedData === 'To Queue'\" class=\"btn btn-primary w-100 ms-2\" [disabled]=\"!Comment\" (click)=\"closeModal()\">Submit</button>\r\n </div>\r\n </div>\r\n</div>", styles: [".label{color:var(--Gray-700, #344054);font-size:14px;font-weight:500;line-height:20px}.standard{color:var(--Gray-700, #344054);font-size:16px;font-weight:500;line-height:24px}.radio{width:16px!important;height:16px!important}\n"], dependencies: [{ kind: "directive", type: i6$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.CustomSelectComponent, selector: "lib-select", inputs: ["items", "searchField", "multi", "idField", "selectedValues", "disabled", "label"], outputs: ["selected"] }] });
|
|
1212
|
-
}
|
|
1213
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ReTriggerComponent, decorators: [{
|
|
1214
|
-
type: Component,
|
|
1215
|
-
args: [{ selector: 'lib-retrigger', template: "<div class=\"card\">\r\n \r\n <div class=\"card-header border-0\">\r\n <div class=\"card-title d-grid\">\r\n <div class=\"card-title\">Re-trigger File</div>\r\n <div class=\"text-sub\">Re-trigger the file to a queue or other users</div>\r\n </div>\r\n </div>\r\n <div class=\"card-body\">\r\n <div class=\"\">\r\n <label class=\"label\">Push Form</label>\r\n <div class=\"position-relative w-100 mt-3 mb-5\">\r\n <button type=\"button\" (click)=\"openDropdown($event)\"\r\n class=\"btn btn-default w-100 btn-outline btn-outline-default rounded-3 text-nowrap border-val d-flex justify-content-between\">\r\n {{selectedItem}}\r\n <span><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\"\r\n viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path d=\"M5 7.5L10 12.5L15 7.5\" stroke=\"#667085\" stroke-width=\"1.66667\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg></span>\r\n </button>\r\n <div *ngIf=\"dropDown\" class=\"card py-1 w-100 position-absolute top-50px end-0\">\r\n <ul *ngFor=\"let item of dropdownItems\" class=\"list-unstyled\">\r\n <li [ngClass]=\"selectedItem === item ? 'active' : ''\"\r\n class=\"camera px-5 items fw-semibold cursor-pointer py-2\"\r\n (click)=\"selectItem(item)\">{{item}}\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"mt-5 cursor-pointer d-flex mb-5\">\r\n <div *ngFor=\"let data of standardData\" (click)=\"selectRadio(data)\" class=\"d-flex align-items-center me-20\">\r\n <input [checked]=\"selectedData === data\" type=\"radio\" class=\"radio\">\r\n <span class=\"ms-3 standard\">{{data}}</span>\r\n </div>\r\n </div>\r\n <div *ngIf=\"selectedData === 'To User'\" class=\"w-100 mb-5\">\r\n <label for=\"infraDownTime\" class=\"label mb-3\">Select User<span class=\"alert-required\"></span></label>\r\n <lib-select [items]=\"userList\" [multi]=\"false\" [searchField]=\"'userName'\" [idField]=\"'userId'\"\r\n (selected)=\"onReportSelect($event)\" [selectedValues]=\"[userId]\"></lib-select>\r\n </div>\r\n <div>\r\n <label class=\"label mb-3\">Comments</label>\r\n <textarea class=\"form-control\" [(ngModel)]=\"Comment\"></textarea>\r\n </div>\r\n <div class=\"d-flex mt-5\">\r\n <button class=\"btn btn-outline w-100 me-2\" (click)=\"activeModal.dismiss()\">Cancel</button>\r\n <button *ngIf=\"selectedData === 'To User'\" class=\"btn btn-primary w-100 ms-2\" [disabled]=\"!userId || !Comment\" (click)=\"closeModal()\">Submit</button>\r\n <button *ngIf=\"selectedData === 'To Queue'\" class=\"btn btn-primary w-100 ms-2\" [disabled]=\"!Comment\" (click)=\"closeModal()\">Submit</button>\r\n </div>\r\n </div>\r\n</div>", styles: [".label{color:var(--Gray-700, #344054);font-size:14px;font-weight:500;line-height:20px}.standard{color:var(--Gray-700, #344054);font-size:16px;font-weight:500;line-height:24px}.radio{width:16px!important;height:16px!important}\n"] }]
|
|
1216
|
-
}], ctorParameters: () => [{ type: i1$2.NgbActiveModal }, { type: TicketService }], propDecorators: { reTrigerData: [{
|
|
1217
|
-
type: Input
|
|
1218
|
-
}], onClick: [{
|
|
1219
|
-
type: HostListener,
|
|
1220
|
-
args: ['document:click', ['$event']]
|
|
1221
|
-
}] } });
|
|
1222
|
-
|
|
1223
|
-
class CountComponent {
|
|
1224
|
-
Service;
|
|
1225
|
-
toast;
|
|
1226
|
-
excel;
|
|
1227
|
-
cd;
|
|
1228
|
-
destroy$ = new Subject();
|
|
1229
|
-
data;
|
|
1230
|
-
loading = true;
|
|
1231
|
-
noData = false;
|
|
1232
|
-
auditImages;
|
|
1233
|
-
constructor(Service, toast, excel, cd) {
|
|
1234
|
-
this.Service = Service;
|
|
1235
|
-
this.toast = toast;
|
|
1236
|
-
this.excel = excel;
|
|
1237
|
-
this.cd = cd;
|
|
1238
|
-
}
|
|
1239
|
-
ngOnInit() {
|
|
1240
|
-
this.getAuditImages();
|
|
1241
|
-
}
|
|
1242
|
-
ngOnDestroy() {
|
|
1243
|
-
this.destroy$.next(true);
|
|
1244
|
-
this.destroy$.complete();
|
|
1245
|
-
}
|
|
1246
|
-
getAuditImages() {
|
|
1247
|
-
let params = {
|
|
1248
|
-
fileDate: this.data?.fileDate,
|
|
1249
|
-
storeId: this.data?.storeId,
|
|
1250
|
-
imageType: this.data?.imageType,
|
|
1251
|
-
export: false,
|
|
1252
|
-
moduleType: this.data?.selectedType,
|
|
1253
|
-
zoneName: this.data?.zoneName
|
|
1254
|
-
};
|
|
1255
|
-
this.Service.getAuditImages(params).pipe(takeUntil(this.destroy$)).subscribe({
|
|
1256
|
-
next: (res) => {
|
|
1257
|
-
if (res && res?.code === 200) {
|
|
1258
|
-
this.auditImages = res?.data?.result;
|
|
1259
|
-
this.loading = false;
|
|
1260
|
-
this.noData = false;
|
|
1261
|
-
}
|
|
1262
|
-
else {
|
|
1263
|
-
this.noData = true;
|
|
1264
|
-
this.loading = false;
|
|
1265
|
-
}
|
|
1266
|
-
this.cd.detectChanges();
|
|
1267
|
-
},
|
|
1268
|
-
error: (err) => {
|
|
1269
|
-
this.noData = true;
|
|
1270
|
-
this.loading = false;
|
|
1271
|
-
},
|
|
1272
|
-
});
|
|
1273
|
-
}
|
|
1274
|
-
exportTable() {
|
|
1275
|
-
let params = {
|
|
1276
|
-
fileDate: this.data?.fileDate,
|
|
1277
|
-
storeId: this.data?.storeId,
|
|
1278
|
-
imageType: this.data?.imageType,
|
|
1279
|
-
export: true,
|
|
1280
|
-
moduleType: this.data?.selectedType,
|
|
1281
|
-
zoneName: this.data?.zoneName
|
|
1282
|
-
};
|
|
1283
|
-
let type = this.data?.type === 'before' ? 'BeforeCount' : 'AfterCount';
|
|
1284
|
-
this.Service.ExportAuditImagesasxlsx(params).pipe(takeUntil(this.destroy$)).subscribe({
|
|
1285
|
-
next: (res) => {
|
|
1286
|
-
if (res) {
|
|
1287
|
-
this.excel.saveAsZipFile(res, type);
|
|
1288
|
-
}
|
|
1289
|
-
},
|
|
1290
|
-
error: (err) => {
|
|
1291
|
-
this.toast.getErrorToast(err?.error);
|
|
1292
|
-
},
|
|
1293
|
-
});
|
|
1294
|
-
}
|
|
1295
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CountComponent, deps: [{ token: TicketService }, { token: i4.ToastService }, { token: ExcelService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
1296
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CountComponent, selector: "lib-count", inputs: { data: "data" }, ngImport: i0, template: "<div class=\"card\">\r\n <div class=\"card-header\">\r\n <div class=\"card-title d-grid\">\r\n <div *ngIf=\"data?.type\" class=\"card-label\">{{data?.type | titlecase}} Count - {{data?.storeId}}</div>\r\n <div class=\"text-sub\">{{data?.fileDate | customDateFormat}}</div>\r\n </div>\r\n <div class=\"card-toolbar\">\r\n <button *ngIf=\"!noData\" type=\"button\" (click)=\"exportTable()\"\r\n class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\" stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n <span class=\"ms-2\">Export</span> </button>\r\n </div>\r\n </div>\r\n <div class=\"card-body\">\r\n <div class=\"row mx-3\">\r\n <div class=\"col-md-12 item scroll-y\">\r\n <div class=\"item\" *ngFor=\"let images of auditImages;let i=index\" style=\"padding: 10px;\">\r\n <img class=\"mx-3 my-3 img\" [src]=\"images?.imgPath\">\r\n <div class=\"text-center m-0 fs-7 fw-bold\">{{images?.imgName}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <ng-container *ngIf=\"loading\">\r\n <div 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 </ng-container>\r\n <ng-container *ngIf=\"noData\">\r\n <div class=\"row\">\r\n <div class=\"col-lg-12 mb-3\">\r\n <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n <img class=\"img-src w-25\" src=\"./assets/tango/Icons/Nodata.svg\" alt=\"\">\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n", styles: [".img{width:95px;height:200px}.item{position:relative;padding-top:20px;display:inline-block;max-height:595px}.scroll-y{overflow-y:auto!important;position:relative!important}\n"], dependencies: [{ kind: "directive", type: i6$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i6$1.TitleCasePipe, name: "titlecase" }, { kind: "pipe", type: i4.CustomDateFormatPipe, name: "customDateFormat" }] });
|
|
1297
|
-
}
|
|
1298
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CountComponent, decorators: [{
|
|
1299
|
-
type: Component,
|
|
1300
|
-
args: [{ selector: 'lib-count', template: "<div class=\"card\">\r\n <div class=\"card-header\">\r\n <div class=\"card-title d-grid\">\r\n <div *ngIf=\"data?.type\" class=\"card-label\">{{data?.type | titlecase}} Count - {{data?.storeId}}</div>\r\n <div class=\"text-sub\">{{data?.fileDate | customDateFormat}}</div>\r\n </div>\r\n <div class=\"card-toolbar\">\r\n <button *ngIf=\"!noData\" type=\"button\" (click)=\"exportTable()\"\r\n class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\" stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n <span class=\"ms-2\">Export</span> </button>\r\n </div>\r\n </div>\r\n <div class=\"card-body\">\r\n <div class=\"row mx-3\">\r\n <div class=\"col-md-12 item scroll-y\">\r\n <div class=\"item\" *ngFor=\"let images of auditImages;let i=index\" style=\"padding: 10px;\">\r\n <img class=\"mx-3 my-3 img\" [src]=\"images?.imgPath\">\r\n <div class=\"text-center m-0 fs-7 fw-bold\">{{images?.imgName}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <ng-container *ngIf=\"loading\">\r\n <div 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 </ng-container>\r\n <ng-container *ngIf=\"noData\">\r\n <div class=\"row\">\r\n <div class=\"col-lg-12 mb-3\">\r\n <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n <img class=\"img-src w-25\" src=\"./assets/tango/Icons/Nodata.svg\" alt=\"\">\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n", styles: [".img{width:95px;height:200px}.item{position:relative;padding-top:20px;display:inline-block;max-height:595px}.scroll-y{overflow-y:auto!important;position:relative!important}\n"] }]
|
|
1301
|
-
}], ctorParameters: () => [{ type: TicketService }, { type: i4.ToastService }, { type: ExcelService }, { type: i0.ChangeDetectorRef }], propDecorators: { data: [{
|
|
1302
|
-
type: Input
|
|
1303
|
-
}] } });
|
|
1304
|
-
|
|
1305
|
-
class AuditMetricsComponent {
|
|
1306
|
-
gs;
|
|
1307
|
-
modalService;
|
|
1308
|
-
service;
|
|
1309
|
-
toast;
|
|
1310
|
-
excel;
|
|
1311
|
-
noData = false;
|
|
1312
|
-
loading = true;
|
|
1313
|
-
storesData = [];
|
|
1314
|
-
activity = [
|
|
1315
|
-
{ type: 'Audit', FileDate: '28-11-2023', Time: '03:24 pm', beforeCout: '300', AfterCount: '100' },
|
|
1316
|
-
{ type: 'Re-Audit', FileDate: '28-10-2023', Time: '03:24 pm', beforeCout: '350', AfterCount: '120' },
|
|
1317
|
-
{ type: 'Audit', FileDate: '28-11-2023', Time: '03:24 pm', beforeCout: '300', AfterCount: '100' }
|
|
1318
|
-
];
|
|
1319
|
-
activitylog;
|
|
1320
|
-
destroy$ = new Subject();
|
|
1321
|
-
headerFilter;
|
|
1322
|
-
sortColumName = '';
|
|
1323
|
-
sortBy = 1;
|
|
1324
|
-
filterByClient = [];
|
|
1325
|
-
filterByStatus = [];
|
|
1326
|
-
pagination = [10, 20, 30];
|
|
1327
|
-
searchTerm;
|
|
1328
|
-
limit = 10;
|
|
1329
|
-
offset = 1;
|
|
1330
|
-
selectedValue;
|
|
1331
|
-
dayjs = dayjs;
|
|
1332
|
-
filterByStore = [];
|
|
1333
|
-
totalCount;
|
|
1334
|
-
selectedTab = '';
|
|
1335
|
-
dataObject = [
|
|
1336
|
-
{ Description: 'Module Type', type: 'single', Issues: [{ id: 'traffic', text: "Traffic" }, { id: 'zone', text: "Zone" }] },
|
|
1337
|
-
{ Description: 'Clients', Issues: [] },
|
|
1338
|
-
{ Description: 'Status', Issues: [{ id: 'closed', text: "Completed" }, { id: 'inprogress', text: "Inprogress" }, { id: 'drafted', text: "Draft" }, { id: 'assigned', text: "Assigned" }, { id: 'not_assign', text: "Not Assigened" }, { id: 'skipped', text: "Skip" },] }
|
|
1339
|
-
];
|
|
1340
|
-
clientList;
|
|
1341
|
-
selectedType = 'traffic';
|
|
1342
|
-
constructor(gs, modalService, service, toast, excel) {
|
|
1343
|
-
this.gs = gs;
|
|
1344
|
-
this.modalService = modalService;
|
|
1345
|
-
this.service = service;
|
|
1346
|
-
this.toast = toast;
|
|
1347
|
-
this.excel = excel;
|
|
1348
|
-
}
|
|
1349
|
-
ngOnInit() {
|
|
1350
|
-
this.gs.dataRangeValue.pipe(takeUntil(this.destroy$)).subscribe((data) => {
|
|
1351
|
-
if (data != null) {
|
|
1352
|
-
this.headerFilter = data;
|
|
1353
|
-
this.metricsList();
|
|
1354
|
-
}
|
|
1355
|
-
});
|
|
1356
|
-
}
|
|
1357
|
-
metricsList() {
|
|
1358
|
-
let data = {
|
|
1359
|
-
fromDate: this.dayjs(this.headerFilter?.date?.startDate).format('YYYY-MM-DD'),
|
|
1360
|
-
toDate: this.dayjs(this.headerFilter?.date?.endDate).format('YYYY-MM-DD'),
|
|
1361
|
-
filterByClientId: this.filterByClient,
|
|
1362
|
-
filterByStoreId: this.filterByStore,
|
|
1363
|
-
filterByStatus: this.filterByStatus,
|
|
1364
|
-
filterByAuditType: this.selectedTab === '' ? [] : [this.selectedTab],
|
|
1365
|
-
filterByModuleType: [this.selectedType],
|
|
1366
|
-
searchValue: this.searchTerm,
|
|
1367
|
-
sortBy: this.sortBy,
|
|
1368
|
-
limit: this.limit,
|
|
1369
|
-
offset: this.offset,
|
|
1370
|
-
isExport: false
|
|
1371
|
-
};
|
|
1372
|
-
if (this.sortColumName) {
|
|
1373
|
-
data.sortColumnName = this.sortColumName;
|
|
1374
|
-
}
|
|
1375
|
-
else if (this.searchTerm) {
|
|
1376
|
-
data.searchValue = this.searchTerm;
|
|
1377
|
-
}
|
|
1378
|
-
this.getclientList();
|
|
1379
|
-
this.service.getstoreMetrics(data).pipe(takeUntil(this.destroy$)).subscribe({
|
|
1380
|
-
next: (res) => {
|
|
1381
|
-
if (res && res?.code === 200) {
|
|
1382
|
-
this.storesData = res?.data?.result;
|
|
1383
|
-
this.totalCount = res?.data?.count;
|
|
1384
|
-
if (!this.storesData?.length) {
|
|
1385
|
-
this.noData = true;
|
|
1386
|
-
}
|
|
1387
|
-
if (this.totalCount < 10) {
|
|
1388
|
-
this.pagination = [this.totalCount];
|
|
1389
|
-
}
|
|
1390
|
-
else {
|
|
1391
|
-
this.pagination = [10, 20, 30];
|
|
1392
|
-
}
|
|
1393
|
-
this.loading = false;
|
|
1394
|
-
this.noData = false;
|
|
1395
|
-
}
|
|
1396
|
-
else {
|
|
1397
|
-
this.noData = true;
|
|
1398
|
-
this.loading = false;
|
|
1399
|
-
}
|
|
1400
|
-
},
|
|
1401
|
-
error: (err) => {
|
|
1402
|
-
this.noData = true;
|
|
1403
|
-
this.loading = false;
|
|
1404
|
-
this.toast.getErrorToast(err?.message);
|
|
1405
|
-
}
|
|
1406
|
-
});
|
|
1407
|
-
}
|
|
1408
|
-
setItemsperPage() {
|
|
1409
|
-
if (this.totalCount < 10) {
|
|
1410
|
-
return this.totalCount;
|
|
1411
|
-
}
|
|
1412
|
-
else {
|
|
1413
|
-
return this.limit;
|
|
1414
|
-
}
|
|
1415
|
-
}
|
|
1416
|
-
getclientList() {
|
|
1417
|
-
this.service.getclientList().pipe(takeUntil(this.destroy$)).subscribe({
|
|
1418
|
-
next: (res) => {
|
|
1419
|
-
if (res && res?.code === 200) {
|
|
1420
|
-
this.clientList = res?.data?.result;
|
|
1421
|
-
const issues = this.clientList.map((obj) => ({ text: obj.clientName, id: obj.clientId }));
|
|
1422
|
-
const uniqueIssues = [];
|
|
1423
|
-
const Clients = new Set();
|
|
1424
|
-
issues.forEach((issue) => {
|
|
1425
|
-
if (!Clients.has(issue.text)) {
|
|
1426
|
-
Clients.add(issue.text);
|
|
1427
|
-
uniqueIssues.push(issue);
|
|
1428
|
-
}
|
|
1429
|
-
});
|
|
1430
|
-
const filtredObject = (this.dataObject.find((obj) => obj.Description === "Clients"));
|
|
1431
|
-
filtredObject.Issues = uniqueIssues;
|
|
1432
|
-
}
|
|
1433
|
-
},
|
|
1434
|
-
error: (err) => {
|
|
1435
|
-
},
|
|
1436
|
-
});
|
|
1437
|
-
}
|
|
1438
|
-
ngOnDestroy() {
|
|
1439
|
-
this.destroy$.next(true);
|
|
1440
|
-
this.destroy$.complete();
|
|
1441
|
-
}
|
|
1442
|
-
receiveData(data) {
|
|
1443
|
-
this.filterByClient = data.find((obj) => obj.Description === "Clients")?.Issues.map((item) => item?.id);
|
|
1444
|
-
this.filterByStatus = data.find((obj) => obj.Description === "Status")?.Issues?.map((item) => item?.id);
|
|
1445
|
-
this.selectedType = data.find((obj) => obj.Description === 'Module Type')?.Issues?.id;
|
|
1446
|
-
this.metricsList();
|
|
1447
|
-
}
|
|
1448
|
-
onPageChange(pageOffset) {
|
|
1449
|
-
this.pagination.offset = pageOffset;
|
|
1450
|
-
this.metricsList();
|
|
1451
|
-
}
|
|
1452
|
-
onPageSizeChange(pageSize) {
|
|
1453
|
-
this.pagination.limit = pageSize;
|
|
1454
|
-
this.pagination.offset = 1;
|
|
1455
|
-
this.metricsList();
|
|
1456
|
-
}
|
|
1457
|
-
exportXLSX() {
|
|
1458
|
-
let data = {
|
|
1459
|
-
fromDate: this.dayjs(this.headerFilter?.date?.startDate).format('YYYY-MM-DD'),
|
|
1460
|
-
toDate: this.dayjs(this.headerFilter?.date?.endDate).format('YYYY-MM-DD'),
|
|
1461
|
-
filterByClientId: this.filterByClient,
|
|
1462
|
-
filterByStoreId: this.filterByStore,
|
|
1463
|
-
filterByStatus: this.filterByStatus,
|
|
1464
|
-
filterByAuditType: this.selectedTab === '' ? [] : [this.selectedTab],
|
|
1465
|
-
filterByModuleType: [this.selectedType],
|
|
1466
|
-
searchValue: this.searchTerm,
|
|
1467
|
-
sortBy: this.sortBy,
|
|
1468
|
-
limit: 10000,
|
|
1469
|
-
offset: this.offset,
|
|
1470
|
-
isExport: true
|
|
1471
|
-
};
|
|
1472
|
-
if (this.sortColumName) {
|
|
1473
|
-
data.sortColumnName = this.sortColumName;
|
|
1474
|
-
}
|
|
1475
|
-
else if (this.searchTerm) {
|
|
1476
|
-
data.searchValue = this.searchTerm;
|
|
1477
|
-
}
|
|
1478
|
-
this.service.getstoreMetricsExport(data).pipe(takeUntil(this.destroy$)).subscribe({
|
|
1479
|
-
next: (res) => {
|
|
1480
|
-
if (res) {
|
|
1481
|
-
this.excel.saveAsExcelFile(res, 'AuditMetrics');
|
|
1482
|
-
}
|
|
1483
|
-
},
|
|
1484
|
-
error: (err) => {
|
|
1485
|
-
this.toast.getErrorToast(err?.message);
|
|
1486
|
-
}
|
|
1487
|
-
});
|
|
1488
|
-
}
|
|
1489
|
-
selectedTabs(data) {
|
|
1490
|
-
if (data === 'all') {
|
|
1491
|
-
this.selectedTab = '';
|
|
1492
|
-
}
|
|
1493
|
-
else {
|
|
1494
|
-
this.selectedTab = data;
|
|
1495
|
-
}
|
|
1496
|
-
this.limit = 10;
|
|
1497
|
-
this.offset = 1;
|
|
1498
|
-
this.metricsList();
|
|
1499
|
-
}
|
|
1500
|
-
searchData() {
|
|
1501
|
-
this.searchTerm = this.searchTerm;
|
|
1502
|
-
this.metricsList();
|
|
1503
|
-
}
|
|
1504
|
-
openBeforecount(value) {
|
|
1505
|
-
const modalRef = this.modalService.open(CountComponent, {
|
|
1506
|
-
centered: true,
|
|
1507
|
-
size: 'xl'
|
|
1508
|
-
});
|
|
1509
|
-
modalRef.componentInstance.data = {
|
|
1510
|
-
type: 'before',
|
|
1511
|
-
fileDate: value?.fileDate,
|
|
1512
|
-
storeId: value?.storeId,
|
|
1513
|
-
selectedType: this.selectedType,
|
|
1514
|
-
zoneName: value?.zoneName,
|
|
1515
|
-
imageType: 'BC'
|
|
1516
|
-
};
|
|
1517
|
-
}
|
|
1518
|
-
openAftercount(value) {
|
|
1519
|
-
const modalRef = this.modalService.open(CountComponent, {
|
|
1520
|
-
centered: true,
|
|
1521
|
-
size: 'xl'
|
|
1522
|
-
});
|
|
1523
|
-
modalRef.componentInstance.data = {
|
|
1524
|
-
type: 'after',
|
|
1525
|
-
fileDate: value?.fileDate,
|
|
1526
|
-
storeId: value?.storeId,
|
|
1527
|
-
selectedType: this.selectedType,
|
|
1528
|
-
zoneName: value?.zoneName,
|
|
1529
|
-
imageType: 'AC'
|
|
1530
|
-
};
|
|
1531
|
-
}
|
|
1532
|
-
openView() {
|
|
1533
|
-
const modalRef = this.modalService.open(this.activitylog);
|
|
1534
|
-
}
|
|
1535
|
-
openreTrigger(value) {
|
|
1536
|
-
const modalRef = this.modalService.open(ReTriggerComponent, {
|
|
1537
|
-
centered: true,
|
|
1538
|
-
// size:''
|
|
1539
|
-
});
|
|
1540
|
-
modalRef.componentInstance.reTrigerData = {
|
|
1541
|
-
type: 'after',
|
|
1542
|
-
data: value,
|
|
1543
|
-
selectedType: this.selectedType
|
|
1544
|
-
};
|
|
1545
|
-
modalRef.closed.subscribe((res) => {
|
|
1546
|
-
if (res) {
|
|
1547
|
-
this.service.auditretrigger(res).pipe(takeUntil(this.destroy$)).subscribe({
|
|
1548
|
-
next: (res) => {
|
|
1549
|
-
if (res && res.code === 200) {
|
|
1550
|
-
this.toast.getSuccessToast(res?.data?.result);
|
|
1551
|
-
this.metricsList();
|
|
1552
|
-
}
|
|
1553
|
-
},
|
|
1554
|
-
error: (err) => {
|
|
1555
|
-
this.toast.getErrorToast(err?.message);
|
|
1556
|
-
}
|
|
1557
|
-
});
|
|
1558
|
-
}
|
|
1559
|
-
});
|
|
1560
|
-
}
|
|
1561
|
-
statusBadge(value) {
|
|
1562
|
-
let AccountStatus = value;
|
|
1563
|
-
if (AccountStatus === 'closed') {
|
|
1564
|
-
return 'badge-light-success';
|
|
1565
|
-
}
|
|
1566
|
-
else if (AccountStatus === 'assigned' || AccountStatus === 'not Assigned') {
|
|
1567
|
-
return 'badge-light-warning';
|
|
1568
|
-
}
|
|
1569
|
-
else {
|
|
1570
|
-
return 'badge-light-primary';
|
|
1571
|
-
}
|
|
1572
|
-
}
|
|
1573
|
-
sortData(value) {
|
|
1574
|
-
this.sortColumName = value;
|
|
1575
|
-
this.sortBy *= -1;
|
|
1576
|
-
this.metricsList();
|
|
1577
|
-
}
|
|
1578
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AuditMetricsComponent, deps: [{ token: i1$1.GlobalStateService }, { token: i1$2.NgbModal }, { token: TicketService }, { token: i4.ToastService }, { token: ExcelService }], target: i0.ɵɵFactoryTarget.Component });
|
|
1579
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AuditMetricsComponent, selector: "lib-audit-metrics", viewQueries: [{ propertyName: "activitylog", first: true, predicate: ["activitylog"], descendants: true }], ngImport: i0, template: "<div class=\"card\">\r\n <div class=\"card-header border-0 pt-3\">\r\n <h3 class=\"card-title align-items-start flex-column\">\r\n <span class=\"card-label mb-2\">Audit Metrics</span>\r\n <!-- <span class=\"text-sub mb-2\">Last updated 1 hour ago</span> -->\r\n </h3>\r\n <div class=\"card-toolbar\">\r\n <div class=\"d-flex\">\r\n <div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\" height=\"2\" rx=\"1\"\r\n transform=\"rotate(45 17.0365 15.1223)\" fill=\"currentColor\"></rect>\r\n <path\r\n d=\"M11 19C6.55556 19 3 15.4444 3 11C3 6.55556 6.55556 3 11 3C15.4444 3 19 6.55556 19 11C19 15.4444 15.4444 19 11 19ZM11 5C7.53333 5 5 7.53333 5 11C5 14.4667 7.53333 17 11 17C14.4667 17 17 14.4667 17 11C17 7.53333 14.4667 5 11 5Z\"\r\n fill=\"currentColor\"></path>\r\n </svg>\r\n </span>\r\n <input type=\"text\" class=\"form-control ps-14 me-2\" placeholder=\"Search\" autocomplete=\"off\"\r\n (change)=\"searchData()\" [(ngModel)]=\"searchTerm\" />\r\n \r\n <lib-filters *ngIf=\"clientList\" [dataObject]=\"dataObject\" (appliedFilters)=\"receiveData($event)\"></lib-filters>\r\n\r\n <button type=\"button\" *ngIf=\"!noData&&!loading\" (click)=\"exportXLSX()\"\r\n class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n <span class=\"ms-2\">Export</span>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"card-body\">\r\n <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap horizontal-scroll\">\r\n <li class=\"nav-item\" (click)=\"selectedTabs('all')\">\r\n <a [ngClass]=\"selectedTab === '' ? 'active' : ''\" class=\"nav-link cursor-pointer no-border me-2\">\r\n All <span class=\"mx-2\"\r\n [ngClass]=\"selectedTab === '' ? 'text-border-priamry' : 'text-border'\">{{totalCount?.totalauditCount ? totalCount?.totalauditCount : 0}}</span>\r\n </a>\r\n </li>\r\n <li class=\"nav-item\" (click)=\"selectedTabs('Audit')\">\r\n <a [ngClass]=\"selectedTab === 'Audit' ? 'active' :''\" class=\"nav-link cursor-pointer no-border me-2\">\r\n Audit <span class=\"mx-2\"\r\n [ngClass]=\"selectedTab === 'Audit' ? 'text-border-priamry' : 'text-border'\">{{totalCount?.auditCount ? totalCount?.auditCount : 0}}</span>\r\n </a>\r\n </li>\r\n <li class=\"nav-item\" (click)=\"selectedTabs('ReAudit')\">\r\n <a [ngClass]=\"selectedTab === 'ReAudit' ? 'active' : ''\" class=\"nav-link cursor-pointer no-border me-2\">\r\n Re Audit <span class=\"mx-2\"\r\n [ngClass]=\"selectedTab === 'ReAudit' ? 'text-border-priamry' : 'text-border'\">{{totalCount?.reauditCount ? totalCount?.reauditCount : 0}}</span>\r\n </a>\r\n </li>\r\n </ul>\r\n <div *ngIf=\"!loading && !noData\" class=\"mt-5\">\r\n <div class=\"table-responsive\">\r\n <table class=\"table bottom-border text-nowrap\">\r\n <thead>\r\n <tr>\r\n <th>File Date</th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('storeName')\">\r\n Store Name\r\n <span\r\n *ngIf=\"sortColumName === 'storeName' && sortBy !== 1 || sortColumName !== 'storeName'\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 1.33337V10.6667M6.00016 10.6667L10.6668 6.00004M6.00016 10.6667L1.3335 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span\r\n *ngIf=\"sortColumName === 'storeName' && sortBy !== -1\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 10.6667L6.00016 1.33337M6.00016 1.33337L1.3335 6.00004M6.00016 1.33337L10.6668 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n \r\n </div></th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('storeId')\">\r\n Store Id\r\n <span\r\n *ngIf=\"sortColumName === 'storeId' && sortBy !== 1 || sortColumName !== 'storeId'\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 1.33337V10.6667M6.00016 10.6667L10.6668 6.00004M6.00016 10.6667L1.3335 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"/>\r\n </svg>\r\n </span>\r\n <span\r\n *ngIf=\"sortColumName === 'storeId' && sortBy !== -1\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 10.6667L6.00016 1.33337M6.00016 1.33337L1.3335 6.00004M6.00016 1.33337L10.6668 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n \r\n </div></th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('userName')\">\r\n User Name\r\n <span\r\n *ngIf=\"sortColumName === 'userName' && sortBy !== 1 || sortColumName !== 'userName'\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 1.33337V10.6667M6.00016 10.6667L10.6668 6.00004M6.00016 10.6667L1.3335 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span\r\n *ngIf=\"sortColumName === 'userName' && sortBy !== -1\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 10.6667L6.00016 1.33337M6.00016 1.33337L1.3335 6.00004M6.00016 1.33337L10.6668 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"/>\r\n </svg>\r\n </span>\r\n \r\n </div></th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('userEmail')\">\r\n User Email\r\n <span\r\n *ngIf=\"sortColumName === 'userEmail' && sortBy !== 1 || sortColumName !== 'userEmail'\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 1.33337V10.6667M6.00016 10.6667L10.6668 6.00004M6.00016 10.6667L1.3335 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span\r\n *ngIf=\"sortColumName === 'userEmail' && sortBy !== -1\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 10.6667L6.00016 1.33337M6.00016 1.33337L1.3335 6.00004M6.00016 1.33337L10.6668 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n \r\n </div></th>\r\n <th>BC</th>\r\n <th>AC</th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('accuracy')\">\r\n Accuracy\r\n <span\r\n *ngIf=\"sortColumName === 'accuracy' && sortBy !== 1 || sortColumName !== 'accuracy'\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 1.33337V10.6667M6.00016 10.6667L10.6668 6.00004M6.00016 10.6667L1.3335 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span\r\n *ngIf=\"sortColumName === 'accuracy' && sortBy !== -1\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 10.6667L6.00016 1.33337M6.00016 1.33337L1.3335 6.00004M6.00016 1.33337L10.6668 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n \r\n </div></th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('timeSpent')\">\r\n TimeSpent\r\n <span\r\n *ngIf=\"sortColumName === 'timeSpent' && sortBy !== 1 || sortColumName !== 'timeSpent'\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 1.33337V10.6667M6.00016 10.6667L10.6668 6.00004M6.00016 10.6667L1.3335 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span\r\n *ngIf=\"sortColumName === 'timeSpent' && sortBy !== -1\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 10.6667L6.00016 1.33337M6.00016 1.33337L1.3335 6.00004M6.00016 1.33337L10.6668 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n \r\n </div></th>\r\n <th>Audit Type</th>\r\n <th>Status</th>\r\n <th><span>Actions</span></th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let item of storesData\">\r\n <td>\r\n <div>{{ item?.fileDate ? item?.fileDate :'NA' }}</div>\r\n </td>\r\n <td>\r\n <div>{{ item?.storeName ? item?.storeName :'NA' }}</div>\r\n </td>\r\n <td>\r\n <div>{{item?.storeId ? item?.storeId : 'NA'}}</div>\r\n </td>\r\n <td>\r\n <div>{{ item?.userName ? item?.userName :'NA' }}</div>\r\n </td>\r\n <td>\r\n <div>{{ item?.userEmail ? item?.userEmail :'NA' }}</div>\r\n </td>\r\n <td>\r\n <div class=\"d-flex align-items-center\">\r\n <div [ngClass]=\"item?.beforeCount ? 'text-decoration-underline':''\" class=\"text-title text-primary cursor-pointer mb-1\" (click)=\"openBeforecount(item)\">\r\n {{ item?.beforeCount ?? '--' }}</div>\r\n </div>\r\n </td>\r\n <td>\r\n <div class=\"d-flex align-items-center\">\r\n <div [ngClass]=\"item?.afterCount ? 'text-decoration-underline':''\" class=\"text-title text-primary cursor-pointer mb-1\" (click)=\"openAftercount(item)\">\r\n {{ item?.afterCount ?? '--' }}</div>\r\n </div>\r\n </td>\r\n <td>\r\n <div>{{ item?.accuracy ?? '--' }}</div>\r\n </td>\r\n <td>{{ item?.timeSpent ? item?.timeSpent :'NA'}}</td>\r\n <td><span *ngIf=\"item?.auditType\" [ngClass]=\"item?.auditType === 'Audit' ? 'badge-light-success':'badge-light-warning'\" class=\"badge\">{{ item?.auditType }}</span></td>\r\n <td><span *ngIf=\"item?.status\" [ngClass]=\"statusBadge(item?.status)\" class=\"badge\">{{ item?.status | titlecase}}</span></td>\r\n <td><button class=\"btn btn-default btn-outline\" (click)=\"openView()\">View-Log</button>\r\n <button class=\"btn btn-default btn-outline ms-3\" [disabled]=\"item?.status === 'not_assign' || item?.status === 'assigned'\" (click)=\"openreTrigger(item)\">Re-Trigger</button></td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n </div>\r\n <div *ngIf=\"!loading && !noData\" class=\"my-3\">\r\n <lib-pagination [itemsPerPage]=\"limit\" [currentPage]=\"offset\" [totalItems]=\"totalCount\"\r\n [paginationSizes]=\"pagination\" [pageSize]=\"setItemsperPage()\" (pageChange)=\"onPageChange($event)\"\r\n (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n </div>\r\n\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 <div class=\"col-lg-12 mb-3\">\r\n <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n <img class=\"img-src w-25\" src=\"./assets/tango/Icons/Nodata.svg\" alt=\"\">\r\n </div>\r\n </div>\r\n </div> \r\n\r\n </div>\r\n</div>\r\n\r\n<ng-template #activitylog let-modal>\r\n <div class=\"card\">\r\n <div class=\"card-header\">\r\n <div class=\"card-title\">\r\n <span class=\"card-label\">Activity Log</span>\r\n </div>\r\n <div class=\"card-toolbar\">\r\n <div class=\"cursor-pointer\" (click)=\"modal.dismiss()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path d=\"M15 5L5 15M5 5L15 15\" stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></div> \r\n </div>\r\n </div>\r\n <div class=\"card-body\">\r\n <div *ngFor=\"let log of activity\" class=\"d-flex mb-5 ms-5\">\r\n <div\r\n class=\"d-flex flex-column justify-content-center align-items-center pe-3\">\r\n <div class=\"d-flex align-items-centre justify-content-centre\">\r\n <!-- <img class=\"msgprofile\"\r\n src=\"./assets/tango/Images/userProfile.svg\"> -->\r\n <div class=\"symbol symbol-35px symbol-circle\">\r\n <span [ngClass]=\"log?.type === 'Audit' ? 'badge-light-success' : 'badge-light-primary'\" class=\"symbol-label badge-light-primary text-symbol\">\r\n <span [ngClass]=\"log?.type === 'Audit' ? 'text-success badge badge-light-success' : 'text-primary badge badge-light-primary'\" class=\"fs-4 fw-normal\">\r\n {{log?.type?.slice(0,1) | uppercase }}\r\n </span>\r\n </span>\r\n </div>\r\n </div>\r\n <div class=\"p-0 h-100 mt-1 border border-1 border-gray\" style=\"width:0px\"></div>\r\n </div>\r\n <div class=\"py-3 pt-0\">\r\n <div class=\"activity-title fw-semibold mt-2 d-flex mb-4\">\r\n <span>{{log?.type}} </span><span class=\"ms-5 list\"><li>Fasila</li></span>\r\n </div>\r\n <div class=\"date-time mb-4\">\r\n {{log?.FileDate}} | {{log?.Time}}\r\n </div>\r\n <div class=\"\"><span class=\"badge badge-light-default fw-semibold\">Before Count : {{log?.beforeCout}}</span>\r\n <span class=\"badge badge-light-default fw-semibold ms-3\">After Count : {{log?.AfterCount}}</span>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [".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}.text-border{border-radius:16px!important;background:var(--Gray-100, #F2F4F7)!important;color:var(--Gray-700, #344054);text-align:center;font-size:14px;font-weight:500;line-height:20px;padding:2px 10px!important}.text-border-priamry{border-radius:16px;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3);text-align:center;font-size:14px;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}tr{vertical-align:middle!important}\n"], dependencies: [{ kind: "directive", type: i6$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.PaginationComponent, selector: "lib-pagination", inputs: ["collection", "itemsPerPage", "currentPage", "totalItems", "directionLinks", "pageSize", "paginationSizes"], outputs: ["pageChange", "pageSizeChange"] }, { kind: "component", type: i4.FiltersComponent, selector: "lib-filters", inputs: ["dataObject"], outputs: ["appliedFilters"] }, { kind: "pipe", type: i6$1.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i6$1.TitleCasePipe, name: "titlecase" }] });
|
|
1580
|
-
}
|
|
1581
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AuditMetricsComponent, decorators: [{
|
|
1582
|
-
type: Component,
|
|
1583
|
-
args: [{ selector: 'lib-audit-metrics', template: "<div class=\"card\">\r\n <div class=\"card-header border-0 pt-3\">\r\n <h3 class=\"card-title align-items-start flex-column\">\r\n <span class=\"card-label mb-2\">Audit Metrics</span>\r\n <!-- <span class=\"text-sub mb-2\">Last updated 1 hour ago</span> -->\r\n </h3>\r\n <div class=\"card-toolbar\">\r\n <div class=\"d-flex\">\r\n <div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\" height=\"2\" rx=\"1\"\r\n transform=\"rotate(45 17.0365 15.1223)\" fill=\"currentColor\"></rect>\r\n <path\r\n d=\"M11 19C6.55556 19 3 15.4444 3 11C3 6.55556 6.55556 3 11 3C15.4444 3 19 6.55556 19 11C19 15.4444 15.4444 19 11 19ZM11 5C7.53333 5 5 7.53333 5 11C5 14.4667 7.53333 17 11 17C14.4667 17 17 14.4667 17 11C17 7.53333 14.4667 5 11 5Z\"\r\n fill=\"currentColor\"></path>\r\n </svg>\r\n </span>\r\n <input type=\"text\" class=\"form-control ps-14 me-2\" placeholder=\"Search\" autocomplete=\"off\"\r\n (change)=\"searchData()\" [(ngModel)]=\"searchTerm\" />\r\n \r\n <lib-filters *ngIf=\"clientList\" [dataObject]=\"dataObject\" (appliedFilters)=\"receiveData($event)\"></lib-filters>\r\n\r\n <button type=\"button\" *ngIf=\"!noData&&!loading\" (click)=\"exportXLSX()\"\r\n class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n <span class=\"ms-2\">Export</span>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"card-body\">\r\n <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap horizontal-scroll\">\r\n <li class=\"nav-item\" (click)=\"selectedTabs('all')\">\r\n <a [ngClass]=\"selectedTab === '' ? 'active' : ''\" class=\"nav-link cursor-pointer no-border me-2\">\r\n All <span class=\"mx-2\"\r\n [ngClass]=\"selectedTab === '' ? 'text-border-priamry' : 'text-border'\">{{totalCount?.totalauditCount ? totalCount?.totalauditCount : 0}}</span>\r\n </a>\r\n </li>\r\n <li class=\"nav-item\" (click)=\"selectedTabs('Audit')\">\r\n <a [ngClass]=\"selectedTab === 'Audit' ? 'active' :''\" class=\"nav-link cursor-pointer no-border me-2\">\r\n Audit <span class=\"mx-2\"\r\n [ngClass]=\"selectedTab === 'Audit' ? 'text-border-priamry' : 'text-border'\">{{totalCount?.auditCount ? totalCount?.auditCount : 0}}</span>\r\n </a>\r\n </li>\r\n <li class=\"nav-item\" (click)=\"selectedTabs('ReAudit')\">\r\n <a [ngClass]=\"selectedTab === 'ReAudit' ? 'active' : ''\" class=\"nav-link cursor-pointer no-border me-2\">\r\n Re Audit <span class=\"mx-2\"\r\n [ngClass]=\"selectedTab === 'ReAudit' ? 'text-border-priamry' : 'text-border'\">{{totalCount?.reauditCount ? totalCount?.reauditCount : 0}}</span>\r\n </a>\r\n </li>\r\n </ul>\r\n <div *ngIf=\"!loading && !noData\" class=\"mt-5\">\r\n <div class=\"table-responsive\">\r\n <table class=\"table bottom-border text-nowrap\">\r\n <thead>\r\n <tr>\r\n <th>File Date</th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('storeName')\">\r\n Store Name\r\n <span\r\n *ngIf=\"sortColumName === 'storeName' && sortBy !== 1 || sortColumName !== 'storeName'\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 1.33337V10.6667M6.00016 10.6667L10.6668 6.00004M6.00016 10.6667L1.3335 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span\r\n *ngIf=\"sortColumName === 'storeName' && sortBy !== -1\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 10.6667L6.00016 1.33337M6.00016 1.33337L1.3335 6.00004M6.00016 1.33337L10.6668 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n \r\n </div></th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('storeId')\">\r\n Store Id\r\n <span\r\n *ngIf=\"sortColumName === 'storeId' && sortBy !== 1 || sortColumName !== 'storeId'\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 1.33337V10.6667M6.00016 10.6667L10.6668 6.00004M6.00016 10.6667L1.3335 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"/>\r\n </svg>\r\n </span>\r\n <span\r\n *ngIf=\"sortColumName === 'storeId' && sortBy !== -1\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 10.6667L6.00016 1.33337M6.00016 1.33337L1.3335 6.00004M6.00016 1.33337L10.6668 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n \r\n </div></th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('userName')\">\r\n User Name\r\n <span\r\n *ngIf=\"sortColumName === 'userName' && sortBy !== 1 || sortColumName !== 'userName'\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 1.33337V10.6667M6.00016 10.6667L10.6668 6.00004M6.00016 10.6667L1.3335 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span\r\n *ngIf=\"sortColumName === 'userName' && sortBy !== -1\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 10.6667L6.00016 1.33337M6.00016 1.33337L1.3335 6.00004M6.00016 1.33337L10.6668 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"/>\r\n </svg>\r\n </span>\r\n \r\n </div></th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('userEmail')\">\r\n User Email\r\n <span\r\n *ngIf=\"sortColumName === 'userEmail' && sortBy !== 1 || sortColumName !== 'userEmail'\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 1.33337V10.6667M6.00016 10.6667L10.6668 6.00004M6.00016 10.6667L1.3335 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span\r\n *ngIf=\"sortColumName === 'userEmail' && sortBy !== -1\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 10.6667L6.00016 1.33337M6.00016 1.33337L1.3335 6.00004M6.00016 1.33337L10.6668 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n \r\n </div></th>\r\n <th>BC</th>\r\n <th>AC</th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('accuracy')\">\r\n Accuracy\r\n <span\r\n *ngIf=\"sortColumName === 'accuracy' && sortBy !== 1 || sortColumName !== 'accuracy'\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 1.33337V10.6667M6.00016 10.6667L10.6668 6.00004M6.00016 10.6667L1.3335 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span\r\n *ngIf=\"sortColumName === 'accuracy' && sortBy !== -1\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 10.6667L6.00016 1.33337M6.00016 1.33337L1.3335 6.00004M6.00016 1.33337L10.6668 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n \r\n </div></th>\r\n <th><div class=\"cursor-pointer\" (click)=\"sortData('timeSpent')\">\r\n TimeSpent\r\n <span\r\n *ngIf=\"sortColumName === 'timeSpent' && sortBy !== 1 || sortColumName !== 'timeSpent'\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 1.33337V10.6667M6.00016 10.6667L10.6668 6.00004M6.00016 10.6667L1.3335 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span\r\n *ngIf=\"sortColumName === 'timeSpent' && sortBy !== -1\">\r\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M6.00016 10.6667L6.00016 1.33337M6.00016 1.33337L1.3335 6.00004M6.00016 1.33337L10.6668 6.00004\"\r\n stroke=\"#667085\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n \r\n </div></th>\r\n <th>Audit Type</th>\r\n <th>Status</th>\r\n <th><span>Actions</span></th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let item of storesData\">\r\n <td>\r\n <div>{{ item?.fileDate ? item?.fileDate :'NA' }}</div>\r\n </td>\r\n <td>\r\n <div>{{ item?.storeName ? item?.storeName :'NA' }}</div>\r\n </td>\r\n <td>\r\n <div>{{item?.storeId ? item?.storeId : 'NA'}}</div>\r\n </td>\r\n <td>\r\n <div>{{ item?.userName ? item?.userName :'NA' }}</div>\r\n </td>\r\n <td>\r\n <div>{{ item?.userEmail ? item?.userEmail :'NA' }}</div>\r\n </td>\r\n <td>\r\n <div class=\"d-flex align-items-center\">\r\n <div [ngClass]=\"item?.beforeCount ? 'text-decoration-underline':''\" class=\"text-title text-primary cursor-pointer mb-1\" (click)=\"openBeforecount(item)\">\r\n {{ item?.beforeCount ?? '--' }}</div>\r\n </div>\r\n </td>\r\n <td>\r\n <div class=\"d-flex align-items-center\">\r\n <div [ngClass]=\"item?.afterCount ? 'text-decoration-underline':''\" class=\"text-title text-primary cursor-pointer mb-1\" (click)=\"openAftercount(item)\">\r\n {{ item?.afterCount ?? '--' }}</div>\r\n </div>\r\n </td>\r\n <td>\r\n <div>{{ item?.accuracy ?? '--' }}</div>\r\n </td>\r\n <td>{{ item?.timeSpent ? item?.timeSpent :'NA'}}</td>\r\n <td><span *ngIf=\"item?.auditType\" [ngClass]=\"item?.auditType === 'Audit' ? 'badge-light-success':'badge-light-warning'\" class=\"badge\">{{ item?.auditType }}</span></td>\r\n <td><span *ngIf=\"item?.status\" [ngClass]=\"statusBadge(item?.status)\" class=\"badge\">{{ item?.status | titlecase}}</span></td>\r\n <td><button class=\"btn btn-default btn-outline\" (click)=\"openView()\">View-Log</button>\r\n <button class=\"btn btn-default btn-outline ms-3\" [disabled]=\"item?.status === 'not_assign' || item?.status === 'assigned'\" (click)=\"openreTrigger(item)\">Re-Trigger</button></td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n </div>\r\n <div *ngIf=\"!loading && !noData\" class=\"my-3\">\r\n <lib-pagination [itemsPerPage]=\"limit\" [currentPage]=\"offset\" [totalItems]=\"totalCount\"\r\n [paginationSizes]=\"pagination\" [pageSize]=\"setItemsperPage()\" (pageChange)=\"onPageChange($event)\"\r\n (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n </div>\r\n\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 <div class=\"col-lg-12 mb-3\">\r\n <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n <img class=\"img-src w-25\" src=\"./assets/tango/Icons/Nodata.svg\" alt=\"\">\r\n </div>\r\n </div>\r\n </div> \r\n\r\n </div>\r\n</div>\r\n\r\n<ng-template #activitylog let-modal>\r\n <div class=\"card\">\r\n <div class=\"card-header\">\r\n <div class=\"card-title\">\r\n <span class=\"card-label\">Activity Log</span>\r\n </div>\r\n <div class=\"card-toolbar\">\r\n <div class=\"cursor-pointer\" (click)=\"modal.dismiss()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path d=\"M15 5L5 15M5 5L15 15\" stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></div> \r\n </div>\r\n </div>\r\n <div class=\"card-body\">\r\n <div *ngFor=\"let log of activity\" class=\"d-flex mb-5 ms-5\">\r\n <div\r\n class=\"d-flex flex-column justify-content-center align-items-center pe-3\">\r\n <div class=\"d-flex align-items-centre justify-content-centre\">\r\n <!-- <img class=\"msgprofile\"\r\n src=\"./assets/tango/Images/userProfile.svg\"> -->\r\n <div class=\"symbol symbol-35px symbol-circle\">\r\n <span [ngClass]=\"log?.type === 'Audit' ? 'badge-light-success' : 'badge-light-primary'\" class=\"symbol-label badge-light-primary text-symbol\">\r\n <span [ngClass]=\"log?.type === 'Audit' ? 'text-success badge badge-light-success' : 'text-primary badge badge-light-primary'\" class=\"fs-4 fw-normal\">\r\n {{log?.type?.slice(0,1) | uppercase }}\r\n </span>\r\n </span>\r\n </div>\r\n </div>\r\n <div class=\"p-0 h-100 mt-1 border border-1 border-gray\" style=\"width:0px\"></div>\r\n </div>\r\n <div class=\"py-3 pt-0\">\r\n <div class=\"activity-title fw-semibold mt-2 d-flex mb-4\">\r\n <span>{{log?.type}} </span><span class=\"ms-5 list\"><li>Fasila</li></span>\r\n </div>\r\n <div class=\"date-time mb-4\">\r\n {{log?.FileDate}} | {{log?.Time}}\r\n </div>\r\n <div class=\"\"><span class=\"badge badge-light-default fw-semibold\">Before Count : {{log?.beforeCout}}</span>\r\n <span class=\"badge badge-light-default fw-semibold ms-3\">After Count : {{log?.AfterCount}}</span>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [".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}.text-border{border-radius:16px!important;background:var(--Gray-100, #F2F4F7)!important;color:var(--Gray-700, #344054);text-align:center;font-size:14px;font-weight:500;line-height:20px;padding:2px 10px!important}.text-border-priamry{border-radius:16px;background:var(--Primary-50, #EAF8FF);color:var(--Primary-700, #009BF3);text-align:center;font-size:14px;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}tr{vertical-align:middle!important}\n"] }]
|
|
1584
|
-
}], ctorParameters: () => [{ type: i1$1.GlobalStateService }, { type: i1$2.NgbModal }, { type: TicketService }, { type: i4.ToastService }, { type: ExcelService }], propDecorators: { activitylog: [{
|
|
1585
|
-
type: ViewChild,
|
|
1586
|
-
args: ['activitylog']
|
|
1587
|
-
}] } });
|
|
1588
|
-
|
|
1589
|
-
const SELECT_CONTROL_VALUE_ACCESSOR = {
|
|
1590
|
-
provide: NG_VALUE_ACCESSOR,
|
|
1591
|
-
useExisting: forwardRef(() => ReactiveSelectComponent),
|
|
1592
|
-
multi: true,
|
|
1593
|
-
};
|
|
1594
|
-
class ReactiveSelectComponent {
|
|
1595
|
-
apiService;
|
|
1596
|
-
cd;
|
|
1597
|
-
onTouched;
|
|
1598
|
-
onChanged;
|
|
1599
|
-
isDisabled;
|
|
1600
|
-
idField;
|
|
1601
|
-
nameField;
|
|
1602
|
-
label;
|
|
1603
|
-
data;
|
|
1604
|
-
itemChange = new EventEmitter();
|
|
1605
|
-
isOpened = false;
|
|
1606
|
-
selected = null;
|
|
1607
|
-
selectedId;
|
|
1608
|
-
instanceId;
|
|
1609
|
-
constructor(apiService, cd) {
|
|
1610
|
-
this.apiService = apiService;
|
|
1611
|
-
this.cd = cd;
|
|
1612
|
-
}
|
|
1613
|
-
ngOnInit() {
|
|
1614
|
-
this.instanceId = crypto.randomUUID();
|
|
1615
|
-
this.apiService.dropDownTrigger.subscribe((e) => {
|
|
1616
|
-
if (e !== this.instanceId) {
|
|
1617
|
-
this.isOpened = false;
|
|
1618
|
-
this.cd.detectChanges();
|
|
1619
|
-
}
|
|
1620
|
-
});
|
|
1621
|
-
}
|
|
1622
|
-
writeValue(val) {
|
|
1623
|
-
this.selectedId = val;
|
|
1624
|
-
this.selected = this.data.filter((item) => item?.[this.idField] === val)[0];
|
|
1625
|
-
}
|
|
1626
|
-
registerOnChange(fn) {
|
|
1627
|
-
this.onChanged = fn;
|
|
1628
|
-
}
|
|
1629
|
-
registerOnTouched(fn) {
|
|
1630
|
-
this.onTouched = fn;
|
|
1631
|
-
}
|
|
1632
|
-
setDisabledState(isDisabled) {
|
|
1633
|
-
this.isDisabled = isDisabled;
|
|
1634
|
-
}
|
|
1635
|
-
onSelect(item) {
|
|
1636
|
-
this.onTouched();
|
|
1637
|
-
this.selected = item;
|
|
1638
|
-
this.selectedId = item?.[this.idField];
|
|
1639
|
-
this.isOpened = false;
|
|
1640
|
-
this.itemChange.next(this.selectedId);
|
|
1641
|
-
this.onChanged(this.selectedId);
|
|
1642
|
-
}
|
|
1643
|
-
onClick(event) {
|
|
1644
|
-
// console.log(this.isDisabled)
|
|
1645
|
-
if (!this.isDisabled) {
|
|
1646
|
-
const targetElement = event.target;
|
|
1647
|
-
if (!this.isComponentClicked(targetElement)) {
|
|
1648
|
-
this.isOpened = false;
|
|
1649
|
-
}
|
|
1650
|
-
}
|
|
1651
|
-
}
|
|
1652
|
-
isComponentClicked(targetElement) {
|
|
1653
|
-
const parentElement = targetElement.parentElement;
|
|
1654
|
-
if (parentElement) {
|
|
1655
|
-
const clickedOnComponent = parentElement.classList.contains('custom-select');
|
|
1656
|
-
if (clickedOnComponent) {
|
|
1657
|
-
return true;
|
|
1658
|
-
}
|
|
1659
|
-
else {
|
|
1660
|
-
return this.isComponentClicked(parentElement);
|
|
1661
|
-
}
|
|
1662
|
-
}
|
|
1663
|
-
return false;
|
|
1664
|
-
}
|
|
1665
|
-
openDropdown() {
|
|
1666
|
-
this.isOpened = !this.isOpened;
|
|
1667
|
-
this.apiService.dropDownTrigger.next(this.instanceId);
|
|
1668
|
-
}
|
|
1669
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ReactiveSelectComponent, deps: [{ token: TicketService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
1670
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ReactiveSelectComponent, selector: "lib-reactive-select", inputs: { isDisabled: "isDisabled", idField: "idField", nameField: "nameField", label: "label", data: "data" }, outputs: { itemChange: "itemChange" }, host: { listeners: { "document:click": "onClick($event)" } }, providers: [SELECT_CONTROL_VALUE_ACCESSOR], ngImport: i0, template: "<div class=\"custom-select\">\r\n <div class=\"form-group\">\r\n <label *ngIf=\"label\" class=\"form-label\">{{label}}</label>\r\n <div class=\"position-relative\">\r\n <div (click)=\"openDropdown()\" [ngClass]=\"isDisabled ? 'disable' : ''\" class=\"form-select dropselect ellipse1\">\r\n {{selected?.[nameField]}}</div>\r\n <div *ngIf=\"isOpened\" class=\"card py-2 w-100 position-absolute end-0 z-1 drop-list\">\r\n <ul class=\"list-unstyled mb-2\">\r\n <li *ngFor=\"let item of data\" (click)=\"onSelect(item)\"\r\n [ngClass]=\"item?.[idField] === selected?.[idField] ? 'active' : ''\"\r\n class=\"text px-5 items cursor-pointer py-4 \">\r\n {{item?.[nameField]}}\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".custom-select{min-width:200px}.custom-select .items:hover,.custom-select .tems.focus,.custom-select .items.active,.custom-select .camera.focus-visible{background:var(--Gray-50, #F9FAFB)}.custom-select .drop-list{max-height:300px;overflow-y:scroll}.custom-select .dropselect{color:var(--Gray-500, #667085);font-family:Inter;font-size:16px;font-style:normal;font-weight:400;line-height:24px;height:45px!important;cursor:default;white-space:nowrap;overflow:hidden}.custom-select .text{color:var(--Gray-700, #344054);font-size:14px;font-weight:500;line-height:20px}.custom-select .disable{pointer-events:none;background-color:#f9fafb!important}.ellipse1{min-width:auto;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.z-1{z-index:9!important}\n"], dependencies: [{ kind: "directive", type: i6$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
1671
|
-
}
|
|
1672
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ReactiveSelectComponent, decorators: [{
|
|
1673
|
-
type: Component,
|
|
1674
|
-
args: [{ selector: 'lib-reactive-select', providers: [SELECT_CONTROL_VALUE_ACCESSOR], template: "<div class=\"custom-select\">\r\n <div class=\"form-group\">\r\n <label *ngIf=\"label\" class=\"form-label\">{{label}}</label>\r\n <div class=\"position-relative\">\r\n <div (click)=\"openDropdown()\" [ngClass]=\"isDisabled ? 'disable' : ''\" class=\"form-select dropselect ellipse1\">\r\n {{selected?.[nameField]}}</div>\r\n <div *ngIf=\"isOpened\" class=\"card py-2 w-100 position-absolute end-0 z-1 drop-list\">\r\n <ul class=\"list-unstyled mb-2\">\r\n <li *ngFor=\"let item of data\" (click)=\"onSelect(item)\"\r\n [ngClass]=\"item?.[idField] === selected?.[idField] ? 'active' : ''\"\r\n class=\"text px-5 items cursor-pointer py-4 \">\r\n {{item?.[nameField]}}\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".custom-select{min-width:200px}.custom-select .items:hover,.custom-select .tems.focus,.custom-select .items.active,.custom-select .camera.focus-visible{background:var(--Gray-50, #F9FAFB)}.custom-select .drop-list{max-height:300px;overflow-y:scroll}.custom-select .dropselect{color:var(--Gray-500, #667085);font-family:Inter;font-size:16px;font-style:normal;font-weight:400;line-height:24px;height:45px!important;cursor:default;white-space:nowrap;overflow:hidden}.custom-select .text{color:var(--Gray-700, #344054);font-size:14px;font-weight:500;line-height:20px}.custom-select .disable{pointer-events:none;background-color:#f9fafb!important}.ellipse1{min-width:auto;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.z-1{z-index:9!important}\n"] }]
|
|
1675
|
-
}], ctorParameters: () => [{ type: TicketService }, { type: i0.ChangeDetectorRef }], propDecorators: { isDisabled: [{
|
|
1676
|
-
type: Input
|
|
1677
|
-
}], idField: [{
|
|
1678
|
-
type: Input
|
|
1679
|
-
}], nameField: [{
|
|
1680
|
-
type: Input
|
|
1681
|
-
}], label: [{
|
|
1682
|
-
type: Input
|
|
1683
|
-
}], data: [{
|
|
1684
|
-
type: Input
|
|
1685
|
-
}], itemChange: [{
|
|
1686
|
-
type: Output
|
|
1687
|
-
}], onClick: [{
|
|
1688
|
-
type: HostListener,
|
|
1689
|
-
args: ['document:click', ['$event']]
|
|
1690
|
-
}] } });
|
|
1691
|
-
|
|
1692
|
-
class GroupSelectComponent {
|
|
1693
|
-
cd;
|
|
1694
|
-
authService;
|
|
1695
|
-
onClick(event) {
|
|
1696
|
-
const target = event.target;
|
|
1697
|
-
if (!target.closest('.dropdown')) {
|
|
1698
|
-
this.showDropdown = false;
|
|
1699
|
-
}
|
|
1700
|
-
}
|
|
1701
|
-
items;
|
|
1702
|
-
searchField;
|
|
1703
|
-
multi;
|
|
1704
|
-
idField;
|
|
1705
|
-
selectedValues = [];
|
|
1706
|
-
disabled;
|
|
1707
|
-
label;
|
|
1708
|
-
selected = new EventEmitter();
|
|
1709
|
-
filteredValues = [];
|
|
1710
|
-
showDropdown;
|
|
1711
|
-
searchValue;
|
|
1712
|
-
instanceId;
|
|
1713
|
-
constructor(cd, authService) {
|
|
1714
|
-
this.cd = cd;
|
|
1715
|
-
this.authService = authService;
|
|
1716
|
-
}
|
|
1717
|
-
ngOnInit() {
|
|
1718
|
-
this.instanceId = crypto.randomUUID();
|
|
1719
|
-
this.authService.dropDownTrigger.subscribe((e) => {
|
|
1720
|
-
if (e !== this.instanceId) {
|
|
1721
|
-
this.showDropdown = false;
|
|
1722
|
-
this.cd.detectChanges();
|
|
1723
|
-
}
|
|
1724
|
-
});
|
|
1725
|
-
}
|
|
1726
|
-
ngOnChanges(changes) {
|
|
1727
|
-
if (changes['items'] && this.items?.length) {
|
|
1728
|
-
this.initializeItems();
|
|
1729
|
-
}
|
|
1730
|
-
if (changes['selectedValues'] && Array.isArray(changes['selectedValues']?.currentValue) && changes['selectedValues']?.currentValue?.length > 0 && changes['selectedValues']?.currentValue[0]) {
|
|
1731
|
-
this.updateSelectedValues();
|
|
1732
|
-
}
|
|
1733
|
-
}
|
|
1734
|
-
initializeItems() {
|
|
1735
|
-
this.filteredValues = this.items.map((item) => ({ ...item }));
|
|
1736
|
-
this.updateSelectedValues();
|
|
1737
|
-
}
|
|
1738
|
-
updateSelectedValues() {
|
|
1739
|
-
this.selectedValues?.forEach((selectedItem) => {
|
|
1740
|
-
const item = this.filteredValues?.find((filteredItem) => filteredItem?.[this.idField] === selectedItem?.[this.idField]);
|
|
1741
|
-
if (item) {
|
|
1742
|
-
item.isSelected = true;
|
|
1743
|
-
}
|
|
1744
|
-
});
|
|
1745
|
-
}
|
|
1746
|
-
openDropdown(event) {
|
|
1747
|
-
this.authService.dropDownTrigger.next(this.instanceId);
|
|
1748
|
-
event.stopPropagation();
|
|
1749
|
-
this.showDropdown = !this.showDropdown;
|
|
1750
|
-
}
|
|
1751
|
-
onInput(event) {
|
|
1752
|
-
if (!event.target.value) {
|
|
1753
|
-
this.filteredValues = [...this.items];
|
|
1754
|
-
}
|
|
1755
|
-
else {
|
|
1756
|
-
const searchTerm = event.target.value.toLowerCase();
|
|
1757
|
-
this.filteredValues = this.items.filter((item) => item[this.searchField].toLowerCase().includes(searchTerm));
|
|
1758
|
-
}
|
|
1759
|
-
this.updateSelectedValues();
|
|
1760
|
-
this.cd.detectChanges();
|
|
1761
|
-
}
|
|
1762
|
-
onSelect(event, item) {
|
|
1763
|
-
if (this.multi) {
|
|
1764
|
-
if (event.currentTarget.checked) {
|
|
1765
|
-
this.selectedValues.push(item);
|
|
1766
|
-
}
|
|
1767
|
-
else {
|
|
1768
|
-
this.selectedValues = this.selectedValues.filter((elem) => elem[this.idField] !== item[this.idField]);
|
|
1769
|
-
}
|
|
1770
|
-
}
|
|
1771
|
-
else {
|
|
1772
|
-
this.selectedValues = [{ ...item }];
|
|
1773
|
-
this.filteredValues.forEach((element) => {
|
|
1774
|
-
if (element[this.idField] !== item[this.idField]) {
|
|
1775
|
-
element.isSelected = false;
|
|
1776
|
-
}
|
|
1777
|
-
});
|
|
1778
|
-
this.showDropdown = false;
|
|
1779
|
-
}
|
|
1780
|
-
const valuesToEmit = this.selectedValues.map((value) => {
|
|
1781
|
-
const selectedItem = { ...value };
|
|
1782
|
-
delete selectedItem.isSelected;
|
|
1783
|
-
return selectedItem;
|
|
1784
|
-
});
|
|
1785
|
-
this.cd.detectChanges();
|
|
1786
|
-
this.emitSelectedValues(valuesToEmit);
|
|
1787
|
-
}
|
|
1788
|
-
onSelectAll(event) {
|
|
1789
|
-
const selectAll = event.currentTarget.checked;
|
|
1790
|
-
this.filteredValues.forEach((item) => item.isSelected = selectAll);
|
|
1791
|
-
if (selectAll) {
|
|
1792
|
-
this.selectedValues = [...this.filteredValues];
|
|
1793
|
-
}
|
|
1794
|
-
else {
|
|
1795
|
-
this.selectedValues = [];
|
|
1796
|
-
}
|
|
1797
|
-
const valuesToEmit = this.selectedValues.map((value) => {
|
|
1798
|
-
const { isSelected, ...selectedItem } = value;
|
|
1799
|
-
return selectedItem;
|
|
1800
|
-
});
|
|
1801
|
-
this.cd.detectChanges();
|
|
1802
|
-
this.emitSelectedValues(valuesToEmit);
|
|
1803
|
-
}
|
|
1804
|
-
emitSelectedValues(values) {
|
|
1805
|
-
if (this.multi) {
|
|
1806
|
-
this.selected.emit(values);
|
|
1807
|
-
}
|
|
1808
|
-
else {
|
|
1809
|
-
this.selected.emit(values[0]);
|
|
1810
|
-
}
|
|
1811
|
-
}
|
|
1812
|
-
checkIfAllSelected() {
|
|
1813
|
-
return this.filteredValues.every((item) => item.isSelected);
|
|
1814
|
-
}
|
|
1815
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GroupSelectComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: TicketService }], target: i0.ɵɵFactoryTarget.Component });
|
|
1816
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: GroupSelectComponent, selector: "lib-group-select", inputs: { items: "items", searchField: "searchField", multi: "multi", idField: "idField", selectedValues: "selectedValues", disabled: "disabled", label: "label" }, outputs: { selected: "selected" }, host: { listeners: { "document:click": "onClick($event)" } }, usesOnChanges: true, ngImport: i0, template: "<div class=\"outer-container\">\r\n <div [ngClass]=\"disabled ? 'disable-input':''\" (click)=\"openDropdown($event)\" class=\"form-select\">\r\n <ng-container *ngIf=\"multi\" >\r\n <span *ngIf=\"selectedValues?.length\" class=\"select-value mx-2\"> <img class=\"me-2\" alt=\"Pic\" src=\"./assets/tango/Image/users-teams.svg\">{{selectedValues?.[0]?.[searchField]}}</span> \r\n <!-- <span *ngIf=\"selectedValues?.length > 1\" class=\"select-value mx-2\"><img class=\"me-2\" alt=\"Pic\" src=\"./assets/tango/Image/users-teams.svg\">{{selectedValues?.[1]?.[searchField]}}</span> -->\r\n <span class=\"select-value mx-2\" *ngIf=\"selectedValues?.length > 1\">+{{selectedValues?.length -1}}</span> {{label}} \r\n </ng-container>\r\n <ng-container *ngIf=\"!multi\" >\r\n {{selectedValues?.[0]?.[searchField]}}\r\n </ng-container>\r\n </div>\r\n <div [ngClass]=\"showDropdown ? '' : 'd-none'\" class=\"input-container dropdown\" >\r\n <div class=\"w-100 input-wrapper\">\r\n <input [(ngModel)]=\"searchValue\" placeholder=\"Search\" (input)=\"onInput($event)\" type=\"text\"> \r\n <svg class=\"search-icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"17\" viewBox=\"0 0 16 17\" fill=\"none\">\r\n <path d=\"M14 14.5L11.1 11.6M12.6667 7.83333C12.6667 10.7789 10.2789 13.1667 7.33333 13.1667C4.38781 13.1667 2 10.7789 2 7.83333C2 4.88781 4.38781 2.5 7.33333 2.5C10.2789 2.5 12.6667 4.88781 12.6667 7.83333Z\" stroke=\"#667085\" stroke-width=\"1.3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg> \r\n </div>\r\n <ul>\r\n <li *ngIf=\"multi && filteredValues?.length\">\r\n <label class=\"form-check\" [for]=\"instanceId\" >\r\n <input (change)=\"onSelectAll($event)\" [checked]=\"checkIfAllSelected()\" class=\"form-check-input me-3\" type=\"checkbox\"\r\n [id]=\"instanceId\">\r\n <span class=\"form-check-label\" >\r\n Select All\r\n </span>\r\n </label>\r\n </li>\r\n <li *ngFor=\"let item of filteredValues\" [ngClass]=\"item.isSelected && !multi ? 'selected' : ''\" >\r\n <label [for]=\"item[idField] + instanceId\" [ngClass]=\"multi ? '': 'ps-0'\" class=\"form-check\">\r\n <input [ngClass]=\"multi ? '': 'd-none'\" (change)=\"onSelect($event, item)\" [(ngModel)]=\"item.isSelected\" class=\"form-check-input me-3\" type=\"checkbox\" value=\"\"\r\n [id]=\"item[idField] + instanceId\">\r\n <span class=\"form-check-label\" >\r\n {{item[searchField]}}\r\n </span>\r\n </label>\r\n </li>\r\n <li *ngIf=\"!filteredValues?.length\" >\r\n <span class=\"d-flex align-items-center justify-content-center\" >No data found</span>\r\n </li>\r\n </ul> \r\n </div> \r\n \r\n</div>", styles: [":host{width:100%;height:100%}.outer-container{position:relative;background-color:#fff}.outer-container .form-select{font-size:1.1rem;font-weight:600;border-radius:8px!important;color:var(--Gray-500, #344054);border:1px solid var(--Gray-300, #D0D5DD)!important;height:42.5px}.outer-container .disable-input{pointer-events:none;background-color:#f9fafb!important}.outer-container .input-container{position:absolute;width:100%;z-index:1}.outer-container .input-container .input-wrapper{padding:8px 10px;background-color:#fff;border-top-right-radius:8px;border-top-left-radius:8px;border-top:1px solid rgba(16,24,40,.08);border-right:1px solid rgba(16,24,40,.08);border-left:1px solid rgba(16,24,40,.08)}.outer-container .input-container .input-wrapper input{width:100%;border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);box-shadow:0 1px 2px #1018280d;padding:10px 14px 10px 30px;outline:none}.outer-container .input-container .input-wrapper input ::placeholder{color:var(--Gray-500, #667085);font-family:Inter;font-size:14px;font-weight:500;line-height:20px}.outer-container .input-container .input-wrapper .search-icon{position:absolute;left:20px;top:20px}.outer-container .input-container ul{position:relative;background-color:#fff;margin:0;padding:0;max-height:200px;min-height:auto;overflow-y:auto;border-bottom-right-radius:8px;border-bottom-left-radius:8px;border-bottom:1px solid rgba(16,24,40,.08);border-right:1px solid rgba(16,24,40,.08);border-left:1px solid rgba(16,24,40,.08)}.outer-container .input-container ul .selected{background:#f9fafb}.outer-container .input-container ul li{list-style:none;padding:10px 16px;cursor:pointer}.outer-container .input-container ul li label{cursor:pointer}.outer-container .input-container ul li:hover{background:#f9fafb}.form-check{display:flex;align-items:center}.form-check-input{height:16px;width:16px;border-radius:4px;border:1px solid var(--Primary-600, #00A3FF)}.form-check-input:checked{--bs-form-check-bg-image: url();background-color:#eaf8ff;border-color:#00a3ff}.form-check-label{color:var(--Gray-700, #344054);font-family:Inter;font-size:14px;font-style:normal;font-weight:500;line-height:20px}.select-value{border-radius:16px!important;background:var(--Gray-100, #F2F4F7)!important;mix-blend-mode:multiply;color:var(--Gray-700, #344054)!important;text-align:center;font-size:14px;font-style:normal;font-weight:500;line-height:20px;padding:4px 12px 4px 6px}\n"], dependencies: [{ kind: "directive", type: i6$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
1817
|
-
}
|
|
1818
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GroupSelectComponent, decorators: [{
|
|
1819
|
-
type: Component,
|
|
1820
|
-
args: [{ selector: 'lib-group-select', template: "<div class=\"outer-container\">\r\n <div [ngClass]=\"disabled ? 'disable-input':''\" (click)=\"openDropdown($event)\" class=\"form-select\">\r\n <ng-container *ngIf=\"multi\" >\r\n <span *ngIf=\"selectedValues?.length\" class=\"select-value mx-2\"> <img class=\"me-2\" alt=\"Pic\" src=\"./assets/tango/Image/users-teams.svg\">{{selectedValues?.[0]?.[searchField]}}</span> \r\n <!-- <span *ngIf=\"selectedValues?.length > 1\" class=\"select-value mx-2\"><img class=\"me-2\" alt=\"Pic\" src=\"./assets/tango/Image/users-teams.svg\">{{selectedValues?.[1]?.[searchField]}}</span> -->\r\n <span class=\"select-value mx-2\" *ngIf=\"selectedValues?.length > 1\">+{{selectedValues?.length -1}}</span> {{label}} \r\n </ng-container>\r\n <ng-container *ngIf=\"!multi\" >\r\n {{selectedValues?.[0]?.[searchField]}}\r\n </ng-container>\r\n </div>\r\n <div [ngClass]=\"showDropdown ? '' : 'd-none'\" class=\"input-container dropdown\" >\r\n <div class=\"w-100 input-wrapper\">\r\n <input [(ngModel)]=\"searchValue\" placeholder=\"Search\" (input)=\"onInput($event)\" type=\"text\"> \r\n <svg class=\"search-icon\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"17\" viewBox=\"0 0 16 17\" fill=\"none\">\r\n <path d=\"M14 14.5L11.1 11.6M12.6667 7.83333C12.6667 10.7789 10.2789 13.1667 7.33333 13.1667C4.38781 13.1667 2 10.7789 2 7.83333C2 4.88781 4.38781 2.5 7.33333 2.5C10.2789 2.5 12.6667 4.88781 12.6667 7.83333Z\" stroke=\"#667085\" stroke-width=\"1.3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg> \r\n </div>\r\n <ul>\r\n <li *ngIf=\"multi && filteredValues?.length\">\r\n <label class=\"form-check\" [for]=\"instanceId\" >\r\n <input (change)=\"onSelectAll($event)\" [checked]=\"checkIfAllSelected()\" class=\"form-check-input me-3\" type=\"checkbox\"\r\n [id]=\"instanceId\">\r\n <span class=\"form-check-label\" >\r\n Select All\r\n </span>\r\n </label>\r\n </li>\r\n <li *ngFor=\"let item of filteredValues\" [ngClass]=\"item.isSelected && !multi ? 'selected' : ''\" >\r\n <label [for]=\"item[idField] + instanceId\" [ngClass]=\"multi ? '': 'ps-0'\" class=\"form-check\">\r\n <input [ngClass]=\"multi ? '': 'd-none'\" (change)=\"onSelect($event, item)\" [(ngModel)]=\"item.isSelected\" class=\"form-check-input me-3\" type=\"checkbox\" value=\"\"\r\n [id]=\"item[idField] + instanceId\">\r\n <span class=\"form-check-label\" >\r\n {{item[searchField]}}\r\n </span>\r\n </label>\r\n </li>\r\n <li *ngIf=\"!filteredValues?.length\" >\r\n <span class=\"d-flex align-items-center justify-content-center\" >No data found</span>\r\n </li>\r\n </ul> \r\n </div> \r\n \r\n</div>", styles: [":host{width:100%;height:100%}.outer-container{position:relative;background-color:#fff}.outer-container .form-select{font-size:1.1rem;font-weight:600;border-radius:8px!important;color:var(--Gray-500, #344054);border:1px solid var(--Gray-300, #D0D5DD)!important;height:42.5px}.outer-container .disable-input{pointer-events:none;background-color:#f9fafb!important}.outer-container .input-container{position:absolute;width:100%;z-index:1}.outer-container .input-container .input-wrapper{padding:8px 10px;background-color:#fff;border-top-right-radius:8px;border-top-left-radius:8px;border-top:1px solid rgba(16,24,40,.08);border-right:1px solid rgba(16,24,40,.08);border-left:1px solid rgba(16,24,40,.08)}.outer-container .input-container .input-wrapper input{width:100%;border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);box-shadow:0 1px 2px #1018280d;padding:10px 14px 10px 30px;outline:none}.outer-container .input-container .input-wrapper input ::placeholder{color:var(--Gray-500, #667085);font-family:Inter;font-size:14px;font-weight:500;line-height:20px}.outer-container .input-container .input-wrapper .search-icon{position:absolute;left:20px;top:20px}.outer-container .input-container ul{position:relative;background-color:#fff;margin:0;padding:0;max-height:200px;min-height:auto;overflow-y:auto;border-bottom-right-radius:8px;border-bottom-left-radius:8px;border-bottom:1px solid rgba(16,24,40,.08);border-right:1px solid rgba(16,24,40,.08);border-left:1px solid rgba(16,24,40,.08)}.outer-container .input-container ul .selected{background:#f9fafb}.outer-container .input-container ul li{list-style:none;padding:10px 16px;cursor:pointer}.outer-container .input-container ul li label{cursor:pointer}.outer-container .input-container ul li:hover{background:#f9fafb}.form-check{display:flex;align-items:center}.form-check-input{height:16px;width:16px;border-radius:4px;border:1px solid var(--Primary-600, #00A3FF)}.form-check-input:checked{--bs-form-check-bg-image: url();background-color:#eaf8ff;border-color:#00a3ff}.form-check-label{color:var(--Gray-700, #344054);font-family:Inter;font-size:14px;font-style:normal;font-weight:500;line-height:20px}.select-value{border-radius:16px!important;background:var(--Gray-100, #F2F4F7)!important;mix-blend-mode:multiply;color:var(--Gray-700, #344054)!important;text-align:center;font-size:14px;font-style:normal;font-weight:500;line-height:20px;padding:4px 12px 4px 6px}\n"] }]
|
|
1821
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: TicketService }], propDecorators: { onClick: [{
|
|
1822
|
-
type: HostListener,
|
|
1823
|
-
args: ['document:click', ['$event']]
|
|
1824
|
-
}], items: [{
|
|
1825
|
-
type: Input
|
|
1826
|
-
}], searchField: [{
|
|
1827
|
-
type: Input
|
|
1828
|
-
}], multi: [{
|
|
1829
|
-
type: Input
|
|
1830
|
-
}], idField: [{
|
|
1831
|
-
type: Input
|
|
1832
|
-
}], selectedValues: [{
|
|
1833
|
-
type: Input
|
|
1834
|
-
}], disabled: [{
|
|
1835
|
-
type: Input
|
|
1836
|
-
}], label: [{
|
|
1837
|
-
type: Input
|
|
1838
|
-
}], selected: [{
|
|
1839
|
-
type: Output
|
|
1840
|
-
}] } });
|
|
1841
|
-
|
|
1842
|
-
class FootfallDicComponent {
|
|
1843
|
-
gs;
|
|
1844
|
-
ticketService;
|
|
1845
|
-
cd;
|
|
1846
|
-
toast;
|
|
1847
|
-
modalService;
|
|
1848
|
-
excelservice;
|
|
1849
|
-
fb;
|
|
1850
|
-
searchValue;
|
|
1851
|
-
loading = false;
|
|
1852
|
-
noData = false;
|
|
1853
|
-
sortedColumn = '';
|
|
1854
|
-
sortDirection = 1;
|
|
1855
|
-
footfallView = true;
|
|
1856
|
-
headerFilters;
|
|
1857
|
-
footfallList_req;
|
|
1858
|
-
form;
|
|
1859
|
-
selectedRevopsType;
|
|
1860
|
-
revopsTypeArray = [
|
|
1861
|
-
{ value: "", label: "All" },
|
|
1862
|
-
{ value: "duplicateImages", label: "Duplicates" },
|
|
1863
|
-
{ value: "employee", label: "Employee/Staff" },
|
|
1864
|
-
{ value: "houseKeeping", label: "House Keeping" },
|
|
1865
|
-
];
|
|
1866
|
-
type = [
|
|
1867
|
-
{ value: "open", label: "Open" },
|
|
1868
|
-
{ value: "closed", label: "Closed" },
|
|
1869
|
-
];
|
|
1870
|
-
// selectedStatus: FormControl;
|
|
1871
|
-
pendingArray = [
|
|
1872
|
-
// { value: "", label: "All" },
|
|
1873
|
-
{ value: "pending", label: "Pending" },
|
|
1874
|
-
{ value: "approved", label: "Approved" },
|
|
1875
|
-
{ value: "rejected", label: "Rejected" },
|
|
1876
|
-
];
|
|
1877
|
-
actionStatus;
|
|
1878
|
-
filterForm;
|
|
1879
|
-
ticketData = {
|
|
1880
|
-
ticketName: "Footfall Directory",
|
|
1881
|
-
ticketId: "TE_INF_F5645G4534A24",
|
|
1882
|
-
storeName: "LKST98 | RK Salai, Mylapore, Chennai, Tamil Nadu, India",
|
|
1883
|
-
status: "Open",
|
|
1884
|
-
date: "04 Sep 2023",
|
|
1885
|
-
footfall: {
|
|
1886
|
-
total: 100,
|
|
1887
|
-
duplicates: 10,
|
|
1888
|
-
employee: 2,
|
|
1889
|
-
houseKeeping: 1,
|
|
1890
|
-
},
|
|
1891
|
-
duplicates: [
|
|
1892
|
-
{ url: "assets/img1.jpg" },
|
|
1893
|
-
{ url: "assets/img2.jpg" },
|
|
1894
|
-
{ url: "assets/img3.jpg" },
|
|
1895
|
-
],
|
|
1896
|
-
};
|
|
1897
|
-
selectedStores = [];
|
|
1898
|
-
allSelected = false;
|
|
1899
|
-
stores = [];
|
|
1900
|
-
destroy$ = new Subject();
|
|
1901
|
-
constructor(gs, ticketService, cd, toast, modalService, excelservice, fb) {
|
|
1902
|
-
this.gs = gs;
|
|
1903
|
-
this.ticketService = ticketService;
|
|
1904
|
-
this.cd = cd;
|
|
1905
|
-
this.toast = toast;
|
|
1906
|
-
this.modalService = modalService;
|
|
1907
|
-
this.excelservice = excelservice;
|
|
1908
|
-
this.fb = fb;
|
|
1909
|
-
}
|
|
1910
|
-
ngOnDestroy() {
|
|
1911
|
-
this.destroy$.next(true);
|
|
1912
|
-
this.destroy$.complete();
|
|
1913
|
-
}
|
|
1914
|
-
ngOnInit() {
|
|
1915
|
-
this.footfallView = true;
|
|
1916
|
-
this.selectedRevopsType = new FormControl('');
|
|
1917
|
-
this.filterForm = this.fb.group({
|
|
1918
|
-
selectedStatus: new FormControl('open'),
|
|
1919
|
-
actionStatus: new FormControl('pending'),
|
|
1920
|
-
ClusterList: new FormControl([]),
|
|
1921
|
-
});
|
|
1922
|
-
this.form = this.fb.group({
|
|
1923
|
-
selectedRevopsType: this.selectedRevopsType,
|
|
1924
|
-
});
|
|
1925
|
-
this.gs.dataRangeValue?.pipe(takeUntil(this.destroy$))?.subscribe({
|
|
1926
|
-
next: (data) => {
|
|
1927
|
-
if (data) {
|
|
1928
|
-
this.headerFilters = data;
|
|
1929
|
-
this.footfallList_req = {
|
|
1930
|
-
client: this.headerFilters.clients.toString(),
|
|
1931
|
-
fromDate: this.headerFilters?.date?.startDate,
|
|
1932
|
-
toDate: this.headerFilters?.date?.endDate,
|
|
1933
|
-
};
|
|
1934
|
-
this.getTicketSummary();
|
|
1935
|
-
this.getTicketList();
|
|
1936
|
-
this.getAllGroups();
|
|
1937
|
-
}
|
|
1938
|
-
},
|
|
1939
|
-
});
|
|
1940
|
-
}
|
|
1941
|
-
getFootfallSummaryData;
|
|
1942
|
-
getTicketSummary() {
|
|
1943
|
-
this.ticketService
|
|
1944
|
-
.getTicketSummaryApi(this.footfallList_req.client, this.footfallList_req.fromDate, this.footfallList_req.toDate)
|
|
1945
|
-
.pipe(takeUntil(this.destroy$))
|
|
1946
|
-
.subscribe({
|
|
1947
|
-
next: (res) => {
|
|
1948
|
-
if (res && res?.data && res?.data?.result) {
|
|
1949
|
-
this.getFootfallSummaryData = res?.data?.result;
|
|
1950
|
-
}
|
|
1951
|
-
else {
|
|
1952
|
-
this.getFootfallSummaryData = [];
|
|
1953
|
-
}
|
|
1954
|
-
},
|
|
1955
|
-
error: (err) => {
|
|
1956
|
-
this.getFootfallSummaryData = [];
|
|
1957
|
-
},
|
|
1958
|
-
complete: () => {
|
|
1959
|
-
this.getFootfallSummaryData.length === 0;
|
|
1960
|
-
},
|
|
1961
|
-
});
|
|
1962
|
-
this.cd.detectChanges();
|
|
1963
|
-
}
|
|
1964
|
-
offset = 0;
|
|
1965
|
-
limit = 10;
|
|
1966
|
-
isExport = false;
|
|
1967
|
-
footfallListData;
|
|
1968
|
-
totalItems;
|
|
1969
|
-
paginationSizes = [10, 20, 30];
|
|
1970
|
-
getTicketList() {
|
|
1971
|
-
this.loading = true;
|
|
1972
|
-
this.searchValue = this.searchValue?.trim() || '';
|
|
1973
|
-
this.offset = this.offset || 1;
|
|
1974
|
-
this.limit = this.limit || 10;
|
|
1975
|
-
this.isExport = false;
|
|
1976
|
-
this.ticketService
|
|
1977
|
-
.getTicketListApi(this.footfallList_req.client, this.footfallList_req.fromDate, this.footfallList_req.toDate, this.searchValue, this.limit, this.offset, this.isExport, this.sortedColumn, this.sortDirection)
|
|
1978
|
-
.pipe(takeUntil(this.destroy$))
|
|
1979
|
-
.subscribe({
|
|
1980
|
-
next: (res) => {
|
|
1981
|
-
if (res && res.code === 200) {
|
|
1982
|
-
this.noData = false;
|
|
1983
|
-
this.loading = false;
|
|
1984
|
-
this.footfallListData = res?.data?.result;
|
|
1985
|
-
this.totalItems = res?.data?.count;
|
|
1986
|
-
if (this.totalItems < 10) {
|
|
1987
|
-
this.paginationSizes = [this.totalItems];
|
|
1988
|
-
}
|
|
1989
|
-
else {
|
|
1990
|
-
this.paginationSizes = [10, 20, 30];
|
|
1991
|
-
}
|
|
1992
|
-
}
|
|
1993
|
-
else {
|
|
1994
|
-
this.noData = true;
|
|
1995
|
-
this.loading = false;
|
|
1996
|
-
this.footfallListData = [];
|
|
1997
|
-
}
|
|
1998
|
-
this.cd.detectChanges();
|
|
1999
|
-
},
|
|
2000
|
-
error: (err) => {
|
|
2001
|
-
this.noData = true;
|
|
2002
|
-
this.loading = false;
|
|
2003
|
-
},
|
|
2004
|
-
complete: () => {
|
|
2005
|
-
this.loading = false;
|
|
2006
|
-
},
|
|
2007
|
-
});
|
|
2008
|
-
}
|
|
2009
|
-
currentPage = 1;
|
|
2010
|
-
pageSize = 10;
|
|
2011
|
-
onPageChange(pageOffset) {
|
|
2012
|
-
this.currentPage = Number(pageOffset);
|
|
2013
|
-
this.offset = Number(pageOffset);
|
|
2014
|
-
this.limit = 10;
|
|
2015
|
-
this.getTicketList();
|
|
2016
|
-
}
|
|
2017
|
-
onPageSizeChange(pageSize) {
|
|
2018
|
-
this.pageSize = Number(pageSize);
|
|
2019
|
-
this.limit = Number(pageSize);
|
|
2020
|
-
this.currentPage = 1;
|
|
2021
|
-
this.offset = 1;
|
|
2022
|
-
this.getTicketList();
|
|
2023
|
-
}
|
|
2024
|
-
setpageSize() {
|
|
2025
|
-
if (this.totalItems < 10) {
|
|
2026
|
-
return this.totalItems;
|
|
2027
|
-
}
|
|
2028
|
-
else {
|
|
2029
|
-
return this.pageSize;
|
|
2030
|
-
}
|
|
2031
|
-
}
|
|
2032
|
-
searchData() {
|
|
2033
|
-
this.currentPage = 1;
|
|
2034
|
-
this.offset = 1;
|
|
2035
|
-
this.limit = 10;
|
|
2036
|
-
this.getTicketList();
|
|
2037
|
-
}
|
|
2038
|
-
exportXLSX() {
|
|
2039
|
-
this.searchValue = this.searchValue?.trim() || '';
|
|
2040
|
-
this.offset = 1;
|
|
2041
|
-
this.limit = 10000;
|
|
2042
|
-
this.isExport = true;
|
|
2043
|
-
this.ticketService
|
|
2044
|
-
.getTicketListExportApi(this.footfallList_req.client, this.footfallList_req.fromDate, this.footfallList_req.toDate, this.searchValue, this.limit, this.offset, this.isExport, this.sortedColumn, this.sortDirection)
|
|
2045
|
-
.pipe(takeUntil(this.destroy$))
|
|
2046
|
-
.subscribe({
|
|
2047
|
-
next: (res) => {
|
|
2048
|
-
this.excelservice.saveAsExcelFile(res, 'footfall directory ticket ');
|
|
2049
|
-
},
|
|
2050
|
-
error: (err) => {
|
|
2051
|
-
this.toast.getErrorToast('Error exporting data:' + err.error ? err.error : err.message);
|
|
2052
|
-
}
|
|
2053
|
-
});
|
|
2054
|
-
}
|
|
2055
|
-
onSort(column) {
|
|
2056
|
-
if (this.sortedColumn === column) {
|
|
2057
|
-
this.sortDirection = this.sortDirection === 1 ? -1 : 1;
|
|
2058
|
-
}
|
|
2059
|
-
else {
|
|
2060
|
-
this.sortedColumn = column;
|
|
2061
|
-
this.sortDirection = 1;
|
|
2062
|
-
}
|
|
2063
|
-
this.getTicketList();
|
|
2064
|
-
}
|
|
2065
|
-
storeCount;
|
|
2066
|
-
searchStoresData() {
|
|
2067
|
-
this.getStores();
|
|
2068
|
-
}
|
|
2069
|
-
StoresSearchValue = '';
|
|
2070
|
-
getStores() {
|
|
2071
|
-
this.ticketService.getTaggedStoresApi(this.footfallList_req.client, this.footfallList_req.fromDate, this.footfallList_req.toDate, this.StoresSearchValue, this.groups).pipe(takeUntil(this.destroy$))
|
|
2072
|
-
.subscribe({
|
|
2073
|
-
next: (res) => {
|
|
2074
|
-
if (res && res.code === 200) {
|
|
2075
|
-
this.stores = res?.data?.result;
|
|
2076
|
-
this.storeCount = res.data?.count || 0;
|
|
2077
|
-
}
|
|
2078
|
-
else {
|
|
2079
|
-
this.stores = [];
|
|
2080
|
-
this.storeCount = 0;
|
|
2081
|
-
}
|
|
2082
|
-
this.cd.detectChanges();
|
|
2083
|
-
},
|
|
2084
|
-
error: (err) => {
|
|
2085
|
-
this.stores = [];
|
|
2086
|
-
this.storeCount = 0;
|
|
2087
|
-
},
|
|
2088
|
-
complete: () => { },
|
|
2089
|
-
});
|
|
2090
|
-
}
|
|
2091
|
-
getTaggedStoresData;
|
|
2092
|
-
typeChange(event) {
|
|
2093
|
-
this.filterForm.get('selectedStatus')?.setValue(event || null);
|
|
2094
|
-
}
|
|
2095
|
-
pendingChange(event) {
|
|
2096
|
-
this.filterForm.get('actionStatus')?.setValue(event || null);
|
|
2097
|
-
}
|
|
2098
|
-
RevopsTypeChange(event) {
|
|
2099
|
-
const selectedType = event ?? '';
|
|
2100
|
-
this.footfalloffset = 1;
|
|
2101
|
-
if (selectedType === '')
|
|
2102
|
-
this.footfalllimit = 1;
|
|
2103
|
-
else
|
|
2104
|
-
this.footfalllimit = 250;
|
|
2105
|
-
this.form.get('selectedRevopsType')?.setValue(selectedType);
|
|
2106
|
-
this.allSelectValue = false;
|
|
2107
|
-
// Clear selected lists
|
|
2108
|
-
this.selectedEmployeeImagesList = [];
|
|
2109
|
-
this.selectedHousekeepingImagesList = [];
|
|
2110
|
-
this.selectedDuplicateImagesList = [];
|
|
2111
|
-
this.cd.detectChanges();
|
|
2112
|
-
// Reset counts
|
|
2113
|
-
this.employeeACCount = '';
|
|
2114
|
-
this.houseKeepingACCount = '';
|
|
2115
|
-
this.duplicateACCount = '';
|
|
2116
|
-
this.dataStoreView();
|
|
2117
|
-
}
|
|
2118
|
-
footfalloffset = 1;
|
|
2119
|
-
footfalllimit = 1;
|
|
2120
|
-
footfallTicketsData = [];
|
|
2121
|
-
storeIdValue;
|
|
2122
|
-
dataReset() {
|
|
2123
|
-
this.selectedStores = [];
|
|
2124
|
-
this.allSelected = false;
|
|
2125
|
-
this.form.get('selectedRevopsType')?.setValue('');
|
|
2126
|
-
this.filterForm.get('selectedStatus')?.setValue('open');
|
|
2127
|
-
this.filterForm.get('actionStatus')?.setValue('pending');
|
|
2128
|
-
this.dataStoreView();
|
|
2129
|
-
}
|
|
2130
|
-
dataApply() {
|
|
2131
|
-
if (this.selectedRevopsType.value === '')
|
|
2132
|
-
this.footfalllimit = 1;
|
|
2133
|
-
else
|
|
2134
|
-
this.footfalllimit = 250;
|
|
2135
|
-
this.allSelectValue = false;
|
|
2136
|
-
this.dataStoreView();
|
|
2137
|
-
}
|
|
2138
|
-
imageUrl;
|
|
2139
|
-
dataIndexId;
|
|
2140
|
-
dateString;
|
|
2141
|
-
footfallNoData = false;
|
|
2142
|
-
footfallLoading = true;
|
|
2143
|
-
lastSelectedTicket = null;
|
|
2144
|
-
hasInitialStoreSynced = false;
|
|
2145
|
-
addStoreIfNotExists(store) {
|
|
2146
|
-
if (this.hasInitialStoreSynced)
|
|
2147
|
-
return;
|
|
2148
|
-
const storeId = store?.storeId;
|
|
2149
|
-
if (storeId && !this.selectedStores.includes(storeId)) {
|
|
2150
|
-
this.selectedStores.push(storeId);
|
|
2151
|
-
}
|
|
2152
|
-
this.hasInitialStoreSynced = true;
|
|
2153
|
-
this.allSelected = this.selectedStores.length === this.stores.length;
|
|
2154
|
-
}
|
|
2155
|
-
selecteValues;
|
|
2156
|
-
dataStoreView(data) {
|
|
2157
|
-
this.footfallTicketsData = [];
|
|
2158
|
-
this.footfallNoData = false;
|
|
2159
|
-
this.footfallLoading = true;
|
|
2160
|
-
const ticket = data?._source ? data : this.lastSelectedTicket;
|
|
2161
|
-
if (!ticket || !ticket._source) {
|
|
2162
|
-
this.footfallLoading = false;
|
|
2163
|
-
this.footfallNoData = true;
|
|
2164
|
-
this.toast.getErrorToast('No ticket data available');
|
|
2165
|
-
return;
|
|
2166
|
-
}
|
|
2167
|
-
this.lastSelectedTicket = ticket;
|
|
2168
|
-
this.addStoreIfNotExists(ticket._source);
|
|
2169
|
-
this.dataIndexId = ticket._id || '';
|
|
2170
|
-
this.dateString = ticket._source.dateString || '';
|
|
2171
|
-
this.imageUrl = this.ticketService?.footfallCDN;
|
|
2172
|
-
this.storeIdValue = this.selectedStores;
|
|
2173
|
-
const revopsType = this.form.get('selectedRevopsType')?.value;
|
|
2174
|
-
const selectedStatus = this.filterForm.get('selectedStatus')?.value;
|
|
2175
|
-
const actionStatus = this.selecteValues = this.filterForm.get('actionStatus')?.value;
|
|
2176
|
-
const storeId = this.storeIdValue;
|
|
2177
|
-
const fromDate = this.footfallList_req.fromDate;
|
|
2178
|
-
const toDate = this.footfallList_req.toDate;
|
|
2179
|
-
const offset = this.footfalloffset;
|
|
2180
|
-
const limit = revopsType === '' ? this.footfalllimit : this.footfalllimit = 250;
|
|
2181
|
-
this.ticketService
|
|
2182
|
-
.getTicketsApi(storeId, fromDate, toDate, revopsType, selectedStatus, actionStatus, offset, limit)
|
|
2183
|
-
.pipe(takeUntil(this.destroy$))
|
|
2184
|
-
.subscribe({
|
|
2185
|
-
next: (res) => {
|
|
2186
|
-
if (res && res.code === 200) {
|
|
2187
|
-
if (res?.data?.result?.length === 0) {
|
|
2188
|
-
this.footfallTicketsData = [];
|
|
2189
|
-
this.footfallView = true;
|
|
2190
|
-
this.footfallNoData = true;
|
|
2191
|
-
this.footfallLoading = false;
|
|
2192
|
-
this.toast.getErrorToast('No data found for the selected filters');
|
|
2193
|
-
}
|
|
2194
|
-
else {
|
|
2195
|
-
this.footfallTicketsData = res?.data?.result ?? [];
|
|
2196
|
-
this.totalItemsFootfall = res?.data?.count;
|
|
2197
|
-
this.paginationSizes = this.totalItemsFootfall < 1
|
|
2198
|
-
? [this.totalItemsFootfall]
|
|
2199
|
-
: [1];
|
|
2200
|
-
this.footfallView = false;
|
|
2201
|
-
this.footfallNoData = false;
|
|
2202
|
-
this.footfallLoading = false;
|
|
2203
|
-
}
|
|
2204
|
-
}
|
|
2205
|
-
else {
|
|
2206
|
-
this.footfallTicketsData = [];
|
|
2207
|
-
this.footfallView = false;
|
|
2208
|
-
this.footfallNoData = true;
|
|
2209
|
-
this.footfallLoading = false;
|
|
2210
|
-
}
|
|
2211
|
-
},
|
|
2212
|
-
error: () => {
|
|
2213
|
-
this.footfallTicketsData = [];
|
|
2214
|
-
this.footfallView = false;
|
|
2215
|
-
this.footfallNoData = true;
|
|
2216
|
-
this.footfallLoading = false;
|
|
2217
|
-
},
|
|
2218
|
-
complete: () => {
|
|
2219
|
-
this.cd.detectChanges();
|
|
2220
|
-
},
|
|
2221
|
-
});
|
|
2222
|
-
}
|
|
2223
|
-
isCollapsed = false;
|
|
2224
|
-
toggleSidebar() {
|
|
2225
|
-
this.isCollapsed = !this.isCollapsed;
|
|
2226
|
-
}
|
|
2227
|
-
matchedType;
|
|
2228
|
-
matchedArray = [{ value: "all", label: "matched: All" }];
|
|
2229
|
-
onFilterApply() {
|
|
2230
|
-
if (this.selectedRevopsType.value === '')
|
|
2231
|
-
this.footfalllimit = 1;
|
|
2232
|
-
else
|
|
2233
|
-
this.footfalllimit = 250;
|
|
2234
|
-
this.dataStoreView();
|
|
2235
|
-
}
|
|
2236
|
-
pageSizeFootfall = 1;
|
|
2237
|
-
footfallcurrentPage = 1;
|
|
2238
|
-
onFootfallPageChange(pageOffset) {
|
|
2239
|
-
this.footfallcurrentPage = Number(pageOffset);
|
|
2240
|
-
this.footfalloffset = Number(pageOffset);
|
|
2241
|
-
this.footfalllimit = 1;
|
|
2242
|
-
this.dataStoreView();
|
|
2243
|
-
}
|
|
2244
|
-
onFootfallPageSizeChange(pageSize) {
|
|
2245
|
-
this.footfalllimit = Number(pageSize);
|
|
2246
|
-
this.pageSizeFootfall = Number(pageSize);
|
|
2247
|
-
this.footfallcurrentPage = 1;
|
|
2248
|
-
this.footfalloffset = 1;
|
|
2249
|
-
this.dataStoreView();
|
|
2250
|
-
}
|
|
2251
|
-
totalItemsFootfall;
|
|
2252
|
-
setFootfallpageSize() {
|
|
2253
|
-
if (this.totalItemsFootfall < 1) {
|
|
2254
|
-
return this.totalItemsFootfall;
|
|
2255
|
-
}
|
|
2256
|
-
else {
|
|
2257
|
-
return this.pageSizeFootfall;
|
|
2258
|
-
}
|
|
2259
|
-
}
|
|
2260
|
-
toggleStoreSelection(store) {
|
|
2261
|
-
const storeId = store?.storeId;
|
|
2262
|
-
if (!storeId)
|
|
2263
|
-
return;
|
|
2264
|
-
const index = this.selectedStores.indexOf(storeId);
|
|
2265
|
-
if (index > -1) {
|
|
2266
|
-
this.selectedStores.splice(index, 1);
|
|
2267
|
-
}
|
|
2268
|
-
else {
|
|
2269
|
-
this.selectedStores.push(storeId);
|
|
2270
|
-
}
|
|
2271
|
-
this.allSelected = this.selectedStores.length === this.stores.length;
|
|
2272
|
-
}
|
|
2273
|
-
toggleSelectAll() {
|
|
2274
|
-
const visibleStoreIds = this.filteredStores.map((s) => s.storeId);
|
|
2275
|
-
if (this.allSelected) {
|
|
2276
|
-
// Remove only the visible ones
|
|
2277
|
-
this.selectedStores = this.selectedStores.filter(id => !visibleStoreIds.includes(id));
|
|
2278
|
-
}
|
|
2279
|
-
else {
|
|
2280
|
-
// Add only those that are not already selected
|
|
2281
|
-
const newIds = visibleStoreIds.filter(id => !this.selectedStores.includes(id));
|
|
2282
|
-
this.selectedStores = [...this.selectedStores, ...newIds];
|
|
2283
|
-
}
|
|
2284
|
-
this.allSelected = this.selectedStores.length === this.stores.length;
|
|
2285
|
-
}
|
|
2286
|
-
isSelected(store) {
|
|
2287
|
-
return this.selectedStores.includes(store.storeId);
|
|
2288
|
-
}
|
|
2289
|
-
imgtoggleSelectAll() {
|
|
2290
|
-
this.allSelected = !this.allSelected;
|
|
2291
|
-
this.ticketData.duplicates.forEach((img) => {
|
|
2292
|
-
img.selected = this.allSelected;
|
|
2293
|
-
});
|
|
2294
|
-
}
|
|
2295
|
-
selectedImagesList = [];
|
|
2296
|
-
selectedDuplicateImagesList = [];
|
|
2297
|
-
selectedHousekeepingImagesList = [];
|
|
2298
|
-
selectedEmployeeImagesList = [];
|
|
2299
|
-
houseKeepingACCount;
|
|
2300
|
-
employeeACCount;
|
|
2301
|
-
duplicateACCount;
|
|
2302
|
-
cloneWithoutSelected(obj) {
|
|
2303
|
-
const { ...rest } = obj;
|
|
2304
|
-
return rest;
|
|
2305
|
-
}
|
|
2306
|
-
allSelectValue = false;
|
|
2307
|
-
cloneWithoutSelected1(data) {
|
|
2308
|
-
const { __parent, ...rest } = data;
|
|
2309
|
-
return { ...rest };
|
|
2310
|
-
}
|
|
2311
|
-
onImageCheckboxChange1(data, category, parentOriginal) {
|
|
2312
|
-
let selectedList;
|
|
2313
|
-
if (category === 'duplicate') {
|
|
2314
|
-
parentOriginal = parentOriginal || data.__parent;
|
|
2315
|
-
const existingOriginal = this.selectedDuplicateImagesList.find((item) => item.tempId === parentOriginal?.tempId);
|
|
2316
|
-
if (data.selected) {
|
|
2317
|
-
if (existingOriginal) {
|
|
2318
|
-
const alreadyExists = existingOriginal.data?.some((dup) => dup.tempId === data.tempId);
|
|
2319
|
-
if (!alreadyExists) {
|
|
2320
|
-
existingOriginal.data.push(this.cloneWithoutSelected1(data));
|
|
2321
|
-
}
|
|
2322
|
-
}
|
|
2323
|
-
else {
|
|
2324
|
-
this.selectedDuplicateImagesList.push({
|
|
2325
|
-
tempId: parentOriginal?.tempId,
|
|
2326
|
-
filePath: parentOriginal?.filePath,
|
|
2327
|
-
entryTime: parentOriginal?.entryTime,
|
|
2328
|
-
exitTime: parentOriginal?.exitTime,
|
|
2329
|
-
timeRange: parentOriginal?.timeRange,
|
|
2330
|
-
data: [this.cloneWithoutSelected1(data)],
|
|
2331
|
-
});
|
|
2332
|
-
}
|
|
2333
|
-
}
|
|
2334
|
-
else {
|
|
2335
|
-
if (existingOriginal) {
|
|
2336
|
-
existingOriginal.data = existingOriginal.data.filter((d) => d.tempId !== data.tempId);
|
|
2337
|
-
if (existingOriginal.data.length === 0) {
|
|
2338
|
-
this.selectedDuplicateImagesList = this.selectedDuplicateImagesList.filter((o) => o.tempId !== parentOriginal?.tempId);
|
|
2339
|
-
}
|
|
2340
|
-
}
|
|
2341
|
-
}
|
|
2342
|
-
this.duplicateACCount = this.selectedDuplicateImagesList.reduce((sum, orig) => sum + orig.data.length, 0);
|
|
2343
|
-
}
|
|
2344
|
-
if (category === 'employee') {
|
|
2345
|
-
selectedList = this.selectedEmployeeImagesList;
|
|
2346
|
-
}
|
|
2347
|
-
else if (category === 'housekeeping') {
|
|
2348
|
-
selectedList = this.selectedHousekeepingImagesList;
|
|
2349
|
-
}
|
|
2350
|
-
if (category !== 'duplicate') {
|
|
2351
|
-
if (data.selected) {
|
|
2352
|
-
const alreadyExists = selectedList.some((item) => item.tempId === data.tempId);
|
|
2353
|
-
if (!alreadyExists) {
|
|
2354
|
-
selectedList.push(data);
|
|
2355
|
-
}
|
|
2356
|
-
}
|
|
2357
|
-
else {
|
|
2358
|
-
const index = selectedList.findIndex((item) => item.tempId === data.tempId);
|
|
2359
|
-
if (index !== -1) {
|
|
2360
|
-
selectedList.splice(index, 1);
|
|
2361
|
-
}
|
|
2362
|
-
}
|
|
2363
|
-
this.employeeACCount = this.selectedEmployeeImagesList.length;
|
|
2364
|
-
this.houseKeepingACCount = this.selectedHousekeepingImagesList.length;
|
|
2365
|
-
}
|
|
2366
|
-
// 🔒 Disable other checkboxes if one type is selected
|
|
2367
|
-
const totalSelected = this.duplicateACCount + this.employeeACCount + this.houseKeepingACCount;
|
|
2368
|
-
if (totalSelected > 0) {
|
|
2369
|
-
this.checkedValue = false;
|
|
2370
|
-
}
|
|
2371
|
-
else {
|
|
2372
|
-
this.checkedValue = true;
|
|
2373
|
-
}
|
|
2374
|
-
this.cd.detectChanges(); // To update the template
|
|
2375
|
-
this.allSelectValue = this.areAllCheckboxesSelected();
|
|
2376
|
-
// console.log('✅ Counts:', {
|
|
2377
|
-
// duplicateACCount: this.duplicateACCount,
|
|
2378
|
-
// employeeACCount: this.employeeACCount,
|
|
2379
|
-
// houseKeepingACCount: this.houseKeepingACCount,
|
|
2380
|
-
// checkedValue: this.checkedValue,
|
|
2381
|
-
// });
|
|
2382
|
-
}
|
|
2383
|
-
selectAllValue() {
|
|
2384
|
-
this.allSelectValue = !this.allSelectValue;
|
|
2385
|
-
this.checkedValue = !this.allSelectValue;
|
|
2386
|
-
this.selectedEmployeeImagesList = [];
|
|
2387
|
-
this.selectedHousekeepingImagesList = [];
|
|
2388
|
-
this.selectedDuplicateImagesList = [];
|
|
2389
|
-
for (const ticket of this.footfallTicketsData) {
|
|
2390
|
-
const source = ticket._source;
|
|
2391
|
-
// ✅ Employee
|
|
2392
|
-
if (Array.isArray(source.employee)) {
|
|
2393
|
-
source.employee.forEach((img) => {
|
|
2394
|
-
img.selected = this.allSelectValue;
|
|
2395
|
-
if (this.allSelectValue && !this.selectedEmployeeImagesList.some(e => e.tempId === img.tempId)) {
|
|
2396
|
-
this.selectedEmployeeImagesList.push(img);
|
|
2397
|
-
}
|
|
2398
|
-
});
|
|
2399
|
-
}
|
|
2400
|
-
// ✅ Housekeeping
|
|
2401
|
-
if (Array.isArray(source.houseKeeping)) {
|
|
2402
|
-
source.houseKeeping.forEach((emp) => {
|
|
2403
|
-
emp.selected = this.allSelectValue;
|
|
2404
|
-
if (this.allSelectValue && !this.selectedHousekeepingImagesList.some(e => e.tempId === emp.tempId)) {
|
|
2405
|
-
this.selectedHousekeepingImagesList.push(emp);
|
|
2406
|
-
}
|
|
2407
|
-
});
|
|
2408
|
-
}
|
|
2409
|
-
// ✅ Duplicate
|
|
2410
|
-
if (Array.isArray(source.duplicateImages)) {
|
|
2411
|
-
source.duplicateImages.forEach((original) => {
|
|
2412
|
-
if (Array.isArray(original.data)) {
|
|
2413
|
-
original.data.forEach((dup) => {
|
|
2414
|
-
dup.selected = this.allSelectValue;
|
|
2415
|
-
dup.__parent = original; // ✅ Needed for uncheck
|
|
2416
|
-
});
|
|
2417
|
-
if (this.allSelectValue && original.data.length > 0) {
|
|
2418
|
-
const existing = this.selectedDuplicateImagesList.find((o) => o.tempId === original.tempId);
|
|
2419
|
-
if (!existing) {
|
|
2420
|
-
this.selectedDuplicateImagesList.push({
|
|
2421
|
-
tempId: original.tempId,
|
|
2422
|
-
filePath: original.filePath,
|
|
2423
|
-
entryTime: original.entryTime,
|
|
2424
|
-
exitTime: original.exitTime,
|
|
2425
|
-
timeRange: original.timeRange,
|
|
2426
|
-
data: original.data.map((d) => this.cloneWithoutSelected1(d)),
|
|
2427
|
-
});
|
|
2428
|
-
}
|
|
2429
|
-
}
|
|
2430
|
-
}
|
|
2431
|
-
});
|
|
2432
|
-
}
|
|
2433
|
-
}
|
|
2434
|
-
console.log('✅ All selected:', this.selectedDuplicateImagesList);
|
|
2435
|
-
this.houseKeepingACCount = this.selectedHousekeepingImagesList.length;
|
|
2436
|
-
this.employeeACCount = this.selectedEmployeeImagesList.length;
|
|
2437
|
-
this.duplicateACCount = this.selectedDuplicateImagesList.reduce((sum, orig) => sum + orig.data.length, 0);
|
|
2438
|
-
}
|
|
2439
|
-
areAllCheckboxesSelected() {
|
|
2440
|
-
for (const ticket of this.footfallTicketsData) {
|
|
2441
|
-
const source = ticket._source;
|
|
2442
|
-
if (source.employee?.some((img) => !img.selected))
|
|
2443
|
-
return false;
|
|
2444
|
-
if (source.houseKeeping?.some((img) => !img.selected))
|
|
2445
|
-
return false;
|
|
2446
|
-
if (source.duplicateImages?.some((original) => original.data?.some((dup) => !dup.selected)))
|
|
2447
|
-
return false;
|
|
2448
|
-
}
|
|
2449
|
-
return true;
|
|
2450
|
-
}
|
|
2451
|
-
checkedValue = true;
|
|
2452
|
-
onImageCheckboxChange(data, category, parentOriginal) {
|
|
2453
|
-
let selectedList;
|
|
2454
|
-
switch (category) {
|
|
2455
|
-
case 'duplicate':
|
|
2456
|
-
// Ensure selectedDuplicateImagesList is an array of ORIGINALS with selected children
|
|
2457
|
-
const existingOriginal = this.selectedDuplicateImagesList.find((item) => item.tempId === parentOriginal?.tempId);
|
|
2458
|
-
if (data.selected) {
|
|
2459
|
-
if (existingOriginal) {
|
|
2460
|
-
const alreadyExists = existingOriginal.data?.some((dup) => dup.tempId === data.tempId);
|
|
2461
|
-
if (!alreadyExists) {
|
|
2462
|
-
existingOriginal.data.push(this.cloneWithoutSelected(data)); // ✅ no 'selected' key
|
|
2463
|
-
}
|
|
2464
|
-
}
|
|
2465
|
-
else {
|
|
2466
|
-
this.selectedDuplicateImagesList.push({
|
|
2467
|
-
tempId: parentOriginal?.tempId,
|
|
2468
|
-
filePath: parentOriginal?.filePath,
|
|
2469
|
-
entryTime: parentOriginal?.entryTime,
|
|
2470
|
-
exitTime: parentOriginal?.exitTime,
|
|
2471
|
-
timeRange: parentOriginal?.timeRange,
|
|
2472
|
-
data: [this.cloneWithoutSelected(data)], // ✅
|
|
2473
|
-
});
|
|
2474
|
-
}
|
|
2475
|
-
}
|
|
2476
|
-
else {
|
|
2477
|
-
// Remove from selected duplicates
|
|
2478
|
-
if (existingOriginal) {
|
|
2479
|
-
existingOriginal.data = existingOriginal.data.filter((d) => d.tempId !== data.tempId);
|
|
2480
|
-
// Remove the whole original if no duplicates are left
|
|
2481
|
-
if (existingOriginal.data.length === 0) {
|
|
2482
|
-
this.selectedDuplicateImagesList = this.selectedDuplicateImagesList.filter((o) => o.tempId !== parentOriginal?.tempId);
|
|
2483
|
-
}
|
|
2484
|
-
}
|
|
2485
|
-
}
|
|
2486
|
-
// Count only from selected duplicates
|
|
2487
|
-
this.duplicateACCount = this.selectedDuplicateImagesList.reduce((sum, orig) => sum + orig.data.length, 0);
|
|
2488
|
-
return;
|
|
2489
|
-
case 'housekeeping':
|
|
2490
|
-
selectedList = this.selectedHousekeepingImagesList;
|
|
2491
|
-
break;
|
|
2492
|
-
case 'employee':
|
|
2493
|
-
selectedList = this.selectedEmployeeImagesList;
|
|
2494
|
-
break;
|
|
2495
|
-
default:
|
|
2496
|
-
return;
|
|
2497
|
-
}
|
|
2498
|
-
// Unchanged logic for employee and housekeeping
|
|
2499
|
-
selectedList = selectedList || [];
|
|
2500
|
-
if (data.selected) {
|
|
2501
|
-
const alreadyExists = Array.isArray(selectedList) && selectedList.some((item) => item.tempId === data.tempId);
|
|
2502
|
-
if (!alreadyExists) {
|
|
2503
|
-
selectedList.push(data);
|
|
2504
|
-
}
|
|
2505
|
-
}
|
|
2506
|
-
else {
|
|
2507
|
-
const updated = Array.isArray(selectedList) ? selectedList.filter((item) => item.tempId !== data.tempId) : [];
|
|
2508
|
-
if (category === 'housekeeping') {
|
|
2509
|
-
this.selectedHousekeepingImagesList = updated;
|
|
2510
|
-
}
|
|
2511
|
-
else if (category === 'employee') {
|
|
2512
|
-
this.selectedEmployeeImagesList = updated;
|
|
2513
|
-
}
|
|
2514
|
-
}
|
|
2515
|
-
this.houseKeepingACCount = this.selectedHousekeepingImagesList?.length || 0;
|
|
2516
|
-
this.employeeACCount = this.selectedEmployeeImagesList.length || 0;
|
|
2517
|
-
}
|
|
2518
|
-
commentText;
|
|
2519
|
-
submitValue(status = 'approved', category = 'duplicate') {
|
|
2520
|
-
// Step 1: Validate based on current category
|
|
2521
|
-
let selectedList;
|
|
2522
|
-
switch (category) {
|
|
2523
|
-
case 'duplicate':
|
|
2524
|
-
selectedList = this.selectedDuplicateImagesList;
|
|
2525
|
-
break;
|
|
2526
|
-
case 'housekeeping':
|
|
2527
|
-
selectedList = this.selectedHousekeepingImagesList;
|
|
2528
|
-
break;
|
|
2529
|
-
case 'employee':
|
|
2530
|
-
selectedList = this.selectedEmployeeImagesList;
|
|
2531
|
-
break;
|
|
2532
|
-
default:
|
|
2533
|
-
return;
|
|
2534
|
-
}
|
|
2535
|
-
if (selectedList.length === 0) {
|
|
2536
|
-
this.toast.getErrorToast('Please select at least one image');
|
|
2537
|
-
return;
|
|
2538
|
-
}
|
|
2539
|
-
// Replace selected → isChecked before sending
|
|
2540
|
-
const transformedList = selectedList.map(item => {
|
|
2541
|
-
const { selected, ...rest } = item;
|
|
2542
|
-
return { ...rest, isChecked: true };
|
|
2543
|
-
});
|
|
2544
|
-
// Step 2: Build full payload
|
|
2545
|
-
const payload = [];
|
|
2546
|
-
for (const ticket of this.footfallTicketsData) {
|
|
2547
|
-
const source = ticket._source;
|
|
2548
|
-
const singlePayload = {
|
|
2549
|
-
_id: ticket._id,
|
|
2550
|
-
comments: this.commentText || '',
|
|
2551
|
-
dateString: source.dateString || this.dateString,
|
|
2552
|
-
employeeStatus: category === 'employee' ? status : source.employeeStatus,
|
|
2553
|
-
houseKeepingStatus: category === 'housekeeping' ? status : source.houseKeepingStatus,
|
|
2554
|
-
duplicateStatus: category === 'duplicate' ? status : source.duplicateStatus,
|
|
2555
|
-
};
|
|
2556
|
-
if (category === 'employee') {
|
|
2557
|
-
singlePayload.employee = transformedList;
|
|
2558
|
-
singlePayload.employeeACCount = this.employeeACCount ? this.employeeACCount : 0;
|
|
2559
|
-
}
|
|
2560
|
-
if (category === 'housekeeping') {
|
|
2561
|
-
singlePayload.houseKeeping = transformedList;
|
|
2562
|
-
singlePayload.houseKeepingACCount = this.houseKeepingACCount ? this.houseKeepingACCount : 0;
|
|
2563
|
-
}
|
|
2564
|
-
if (category === 'duplicate') {
|
|
2565
|
-
singlePayload.duplicateImages = transformedList;
|
|
2566
|
-
singlePayload.duplicateACCount = this.duplicateACCount ? this.duplicateACCount : 0;
|
|
2567
|
-
}
|
|
2568
|
-
payload.push(singlePayload);
|
|
2569
|
-
}
|
|
2570
|
-
// console.log('Payload to submit:', payload);
|
|
2571
|
-
// return
|
|
2572
|
-
// Step 3: Set status based on current category
|
|
2573
|
-
switch (category) {
|
|
2574
|
-
case 'duplicate':
|
|
2575
|
-
payload.forEach(item => item.duplicateStatus = status);
|
|
2576
|
-
break;
|
|
2577
|
-
case 'housekeeping':
|
|
2578
|
-
payload.forEach(item => item.houseKeepingStatus = status);
|
|
2579
|
-
break;
|
|
2580
|
-
case 'employee':
|
|
2581
|
-
payload.forEach(item => item.employeeStatus = status);
|
|
2582
|
-
break;
|
|
2583
|
-
}
|
|
2584
|
-
// Step 4: Submit the payload
|
|
2585
|
-
this.ticketService.getUpdateStatusApi({ data: payload })
|
|
2586
|
-
.pipe(takeUntil(this.destroy$))
|
|
2587
|
-
.subscribe({
|
|
2588
|
-
next: (res) => {
|
|
2589
|
-
if (res && res.code === 200) {
|
|
2590
|
-
this.toast.getSuccessToast(res?.message || 'Ticket updated successfully');
|
|
2591
|
-
this.selectedStores = [];
|
|
2592
|
-
this.allSelected = false;
|
|
2593
|
-
this.allSelectValue = false;
|
|
2594
|
-
this.dataStoreView();
|
|
2595
|
-
this.cancel();
|
|
2596
|
-
}
|
|
2597
|
-
else {
|
|
2598
|
-
this.toast.getErrorToast('Failed to update ticket');
|
|
2599
|
-
}
|
|
2600
|
-
},
|
|
2601
|
-
error: (err) => {
|
|
2602
|
-
const msg = err.error.error || err.error || err?.error?.message || err.message || 'Unknown error';
|
|
2603
|
-
this.toast.getErrorToast('Error updating ticket: ' + msg);
|
|
2604
|
-
this.allSelected = false;
|
|
2605
|
-
this.allSelectValue = false;
|
|
2606
|
-
}
|
|
2607
|
-
});
|
|
2608
|
-
}
|
|
2609
|
-
searchTerm = '';
|
|
2610
|
-
get filteredStores() {
|
|
2611
|
-
if (!this.searchTerm?.trim())
|
|
2612
|
-
return this.stores;
|
|
2613
|
-
const term = this.searchTerm.toLowerCase();
|
|
2614
|
-
return this.stores.filter(store => store?.storeName?.toLowerCase().includes(term));
|
|
2615
|
-
}
|
|
2616
|
-
onImageError(event) {
|
|
2617
|
-
event.target.src = 'assets/images/fallback-image.png'; // or any default image path
|
|
2618
|
-
}
|
|
2619
|
-
backToNavigation() {
|
|
2620
|
-
this.selectedStores = [];
|
|
2621
|
-
this.allSelected = false;
|
|
2622
|
-
this.allSelectValue = false;
|
|
2623
|
-
this.hasInitialStoreSynced = false;
|
|
2624
|
-
this.footfallView = true;
|
|
2625
|
-
this.getTicketSummary();
|
|
2626
|
-
this.getTicketList();
|
|
2627
|
-
}
|
|
2628
|
-
zoomPopup;
|
|
2629
|
-
popupvalue;
|
|
2630
|
-
popupType;
|
|
2631
|
-
popupOpen(type, value) {
|
|
2632
|
-
const modalRef = this.modalService.open(this.zoomPopup, { centered: true, size: 'md' });
|
|
2633
|
-
this.popupType = type;
|
|
2634
|
-
if (value === 'duplicateImages') {
|
|
2635
|
-
this.popupvalue = 'duplicate';
|
|
2636
|
-
}
|
|
2637
|
-
else {
|
|
2638
|
-
this.popupvalue = value;
|
|
2639
|
-
}
|
|
2640
|
-
}
|
|
2641
|
-
cancel() {
|
|
2642
|
-
this.modalService.dismissAll();
|
|
2643
|
-
this.allSelected = false;
|
|
2644
|
-
this.allSelectValue = false;
|
|
2645
|
-
// Clear all selected flags from the data
|
|
2646
|
-
for (const ticket of this.footfallTicketsData) {
|
|
2647
|
-
const source = ticket._source;
|
|
2648
|
-
source.employee?.forEach((img) => (img.selected = false));
|
|
2649
|
-
source.houseKeeping?.forEach((img) => (img.selected = false));
|
|
2650
|
-
source.duplicateImages?.forEach((original) => {
|
|
2651
|
-
original.data?.forEach((dup) => (dup.selected = false));
|
|
2652
|
-
});
|
|
2653
|
-
}
|
|
2654
|
-
// Clear selected lists
|
|
2655
|
-
this.selectedEmployeeImagesList = [];
|
|
2656
|
-
this.selectedHousekeepingImagesList = [];
|
|
2657
|
-
this.selectedDuplicateImagesList = [];
|
|
2658
|
-
// Reset counts
|
|
2659
|
-
this.employeeACCount = '';
|
|
2660
|
-
this.houseKeepingACCount = '';
|
|
2661
|
-
this.duplicateACCount = '';
|
|
2662
|
-
this.checkedValue = true;
|
|
2663
|
-
}
|
|
2664
|
-
ClusterList = [];
|
|
2665
|
-
getAllGroups() {
|
|
2666
|
-
this.ticketService.getclusters({ clientId: this.headerFilters.client, group: [], city: [] }).subscribe({
|
|
2667
|
-
next: (res) => {
|
|
2668
|
-
if (res && res.code == 200) {
|
|
2669
|
-
this.ClusterList = res?.data?.groupData;
|
|
2670
|
-
this.getStores();
|
|
2671
|
-
}
|
|
2672
|
-
else {
|
|
2673
|
-
this.ClusterList = [];
|
|
2674
|
-
}
|
|
2675
|
-
}
|
|
2676
|
-
});
|
|
2677
|
-
}
|
|
2678
|
-
groups = [];
|
|
2679
|
-
ongroupSelect(event) {
|
|
2680
|
-
this.filterForm.get('ClusterList')?.setValue(event);
|
|
2681
|
-
this.groups = event.map((el) => el.groupName);
|
|
2682
|
-
this.getStores();
|
|
2683
|
-
}
|
|
2684
|
-
// isSubmitDisabled(): boolean {
|
|
2685
|
-
// switch (this.selectedRevopsType?.value) {
|
|
2686
|
-
// case 'employee':
|
|
2687
|
-
// return this.employeeACCount === 0;
|
|
2688
|
-
// case 'houseKeeping':
|
|
2689
|
-
// return this.houseKeepingACCount === 0;
|
|
2690
|
-
// case 'duplicate':
|
|
2691
|
-
// return this.duplicateACCount === 0;
|
|
2692
|
-
// default:
|
|
2693
|
-
// return true;
|
|
2694
|
-
// }
|
|
2695
|
-
// }
|
|
2696
|
-
getFormattedEntryTime(entryTime) {
|
|
2697
|
-
if (!entryTime)
|
|
2698
|
-
return '-';
|
|
2699
|
-
const [hours, minutes, seconds] = entryTime.split(':').map(Number);
|
|
2700
|
-
const date = new Date();
|
|
2701
|
-
date.setHours(hours, minutes, seconds);
|
|
2702
|
-
return date.toLocaleTimeString('en-US', {
|
|
2703
|
-
hour: '2-digit',
|
|
2704
|
-
minute: '2-digit',
|
|
2705
|
-
// second: '2-digit',
|
|
2706
|
-
hour12: true
|
|
2707
|
-
});
|
|
2708
|
-
}
|
|
2709
|
-
showSelectAllBox() {
|
|
2710
|
-
this.filterForm.get('actionStatus')?.setValue('pending');
|
|
2711
|
-
}
|
|
2712
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FootfallDicComponent, deps: [{ token: i1$1.GlobalStateService }, { token: TicketService }, { token: i0.ChangeDetectorRef }, { token: i4.ToastService }, { token: i1$2.NgbModal }, { token: ExcelService }, { token: i6.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
|
|
2713
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FootfallDicComponent, selector: "lib-footfall-dic", viewQueries: [{ propertyName: "zoomPopup", first: true, predicate: ["zoomPopup"], descendants: true }], ngImport: i0, template: "<div *ngIf=\"footfallView\" class=\"row\">\r\n <div class=\"col-md-3 mb-3\">\r\n <div class=\"card\">\r\n <div class=\"card-header ellipse1 py-1 px-5\">\r\n <div class=\"my-0\">\r\n <h5 class=\"card-title my-0\">{{ getFootfallSummaryData?.totalTickets !== null ?\r\n getFootfallSummaryData?.totalTickets : '--' }}</h5>\r\n <span class=\"sub-header\">Total tickets</span>\r\n </div>\r\n </div>\r\n <div class=\"card-body py-2 px-5\">\r\n <div class=\"row\">\r\n <div class=\"col-lg-6 col-xl-9 col-md-6 my-3\">\r\n <h5 class=\"card-title\">{{ getFootfallSummaryData?.openTickets !== null ?\r\n getFootfallSummaryData?.openTickets : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">Open</span>\r\n </div>\r\n <div class=\"col-lg-6 col-xl-3 col-md-6 my-3\">\r\n <h5 class=\"card-title\">{{ getFootfallSummaryData?.closedTickets !== null ?\r\n getFootfallSummaryData?.closedTickets : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">Closed</span>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"col-md-9 mb-3\">\r\n <div class=\"card\">\r\n <div class=\"card-header ellipse1 py-1 px-5\">\r\n <div class=\"my-0\">\r\n <h5 class=\"card-title mt-0\">{{ getFootfallSummaryData?.noShopper !== null ?\r\n getFootfallSummaryData?.noShopper : '--' }}</h5>\r\n <div class=\"sub-header\">Non-Shoppers</div>\r\n </div>\r\n </div>\r\n <div class=\"card-body py-2 px-5\">\r\n <div class=\"row\">\r\n <div class=\"col-lg-4 col-xl-5 col-md-4 my-3\">\r\n <h5 class=\"card-title\">{{ getFootfallSummaryData?.duplicateCount !== null ?\r\n getFootfallSummaryData?.duplicateCount : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">Duplicates</span>\r\n </div>\r\n <div class=\"col-lg-4 col-xl-5 col-md-4 my-3 \">\r\n <h5 class=\"card-title \">{{ getFootfallSummaryData?.employeeCount !== null ?\r\n getFootfallSummaryData?.employeeCount : '--' }}</h5>\r\n <span class=\"card-title-sub-header \">Employee/Staff</span>\r\n </div>\r\n <div class=\"col-lg-4 col-xl-2 col-md-4 my-3\">\r\n <h5 class=\"card-title \">{{ getFootfallSummaryData?.houseKeepingCount !== null ?\r\n getFootfallSummaryData?.houseKeepingCount : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">Housekeeping</span>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<div *ngIf=\"footfallView\" class=\"card\">\r\n <div class=\"card-header border-0 pt-3\">\r\n <h3 class=\"card-title align-items-start flex-column\">\r\n <span class=\"card-label mb-2\">Ticket Info <span *ngIf=\"totalItems\" class=\"ms-2 px-3 badge badge-light-primary\">{{totalItems ? totalItems :'--'}} Total</span></span>\r\n <span class=\"text-sub mb-2\">Based on {{footfallList_req?.fromDate | date: 'dd MMM, yyyy'}} \u2013 {{footfallList_req?.toDate | date: 'dd MMM, yyyy'}} </span>\r\n </h3>\r\n <div class=\"card-toolbar\">\r\n <div class=\"d-flex\">\r\n <div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\" height=\"2\" rx=\"1\"\r\n transform=\"rotate(45 17.0365 15.1223)\" fill=\"currentColor\"></rect>\r\n <path\r\n d=\"M11 19C6.55556 19 3 15.4444 3 11C3 6.55556 6.55556 3 11 3C15.4444 3 19 6.55556 19 11C19 15.4444 15.4444 19 11 19ZM11 5C7.53333 5 5 7.53333 5 11C5 14.4667 7.53333 17 11 17C14.4667 17 17 14.4667 17 11C17 7.53333 14.4667 5 11 5Z\"\r\n fill=\"currentColor\"></path>\r\n </svg>\r\n </span>\r\n <input type=\"text\" class=\"form-control ps-14 me-2\" placeholder=\"Search by store\" autocomplete=\"off\"\r\n (change)=\"searchData()\" [(ngModel)]=\"searchValue\" />\r\n <!-- <lib-filters [dataObject]=\"dataObject\"\r\n (appliedFilters)=\"applyFilters($event)\"></lib-filters> -->\r\n\r\n <button type=\"button\" (click)=\"exportXLSX()\"\r\n class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n <span class=\"ms-2\">Export</span>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n <div class=\"card-body mt-3 py-0 px-0\">\r\n\r\n\r\n\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 <div class=\"col-lg-12 mb-3\">\r\n <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n <img class=\"img-src\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n <div class=\"nodata-title\">No data found</div>\r\n <div class=\"nodata-sub\">There is no result for this Date</div>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"!loading && !noData\" class=\"table-responsive\">\r\n <table class=\"table bottom-border text-nowrap \">\r\n <thead>\r\n <tr>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('storeName')\">Store Info<svg\r\n [ngClass]=\"sortedColumn === 'storeName' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'storeName' ? '#00A3FF' : '#667085'\"\r\n stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('ticketId')\">Ticket ID<svg\r\n [ngClass]=\"sortedColumn === 'ticketId' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'ticketId' ? '#00A3FF' : '#667085'\"\r\n stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('dateString')\">Ticket raised on\r\n <svg [ngClass]=\"sortedColumn === 'dateString' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'dateString' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('footfallCount')\">Total footfalls\r\n <svg [ngClass]=\"sortedColumn === 'footfallCount' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'footfallCount' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('duplicateCount')\">Duplicates\r\n <svg [ngClass]=\"sortedColumn === 'duplicateCount' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'duplicateCount' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('employeeCount')\">Employee/Staff\r\n <svg [ngClass]=\"sortedColumn === 'employeeCount' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'employeeCount' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('houseKeepingCount')\">Housekeeping\r\n <svg [ngClass]=\"sortedColumn === 'houseKeepingCount' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'houseKeepingCount' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n\r\n <th>Revised footfalls\r\n \r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('status')\">Status<svg\r\n [ngClass]=\"sortedColumn === 'status' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\"\r\n height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'status' ? '#00A3FF' : '#667085'\"\r\n stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <!-- <th >Actions</th> -->\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let ticket of footfallListData\">\r\n <ng-container *ngIf=\"ticket?._source as source\">\r\n <td (click)=\"dataStoreView(ticket)\">\r\n <div class=\"text-primary cursor-pointer\">{{ source.storeName }}</div>\r\n <div class=\"text-gray-500 fs-7 mt-2\">ID : {{ source.storeId }}</div>\r\n </td>\r\n \r\n <td class=\"py-7\">{{ source.ticketId }}</td>\r\n <td class=\"py-7\">{{ source.dateString | date: 'dd MMM, yyyy' }}</td>\r\n <td class=\"py-7\">{{ source.footfallCount }}</td>\r\n <td class=\"py-7\">{{ source.duplicateCount }}</td>\r\n <td class=\"py-7\">{{ source.employeeCount }}</td>\r\n <td class=\"py-7\">{{ source.houseKeepingCount }}</td>\r\n <td class=\"py-7\">\r\n {{ source.footfallCount - (source.houseKeepingCount + source.employeeCount +\r\n source.duplicateCount) }}\r\n </td>\r\n \r\n <td class=\"py-7\">\r\n <span *ngIf=\"source.status === 'open' || source.status === 'closed'\" class=\"badge mx-2\" [ngClass]=\"{\r\n 'badge-light-primary': source.status === 'open',\r\n 'badge-light-default': source.status === 'closed'\r\n }\">\r\n {{ source.status | titlecase }}\r\n </span>\r\n </td>\r\n </ng-container>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n <div *ngIf=\"!loading && !noData\" class=\"my-3\">\r\n <lib-pagination [itemsPerPage]=\"pageSize\" [currentPage]=\"currentPage\" [totalItems]=\"totalItems\"\r\n [paginationSizes]=\"paginationSizes\" [pageSize]=\"setpageSize()\" (pageChange)=\"onPageChange($event)\"\r\n (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n </div>\r\n </div>\r\n\r\n</div>\r\n\r\n\r\n<div *ngIf=\"!footfallView\" class=\"card mt-2\">\r\n <form [formGroup]=\"filterForm\">\r\n <div class=\"row my-0\">\r\n <div class=\"col-lg-3 my-3\">\r\n <span class=\"ms-2 cursor-pointer\" (click)=\"backToNavigation()\" ><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"56\" height=\"44\" viewBox=\"0 0 56 44\"\r\n fill=\"none\">\r\n <g filter=\"url(#filter0_d_887_4505)\">\r\n <rect x=\"2\" y=\"1\" width=\"52\" height=\"40\" rx=\"8\" fill=\"white\" />\r\n <rect x=\"2.5\" y=\"1.5\" width=\"51\" height=\"39\" rx=\"7.5\" stroke=\"#D0D5DD\" />\r\n <path d=\"M30.5 26L25.5 21L30.5 16\" 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_887_4505\" x=\"0\" y=\"0\" width=\"56\" height=\"44\" filterUnits=\"userSpaceOnUse\"\r\n 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\" result=\"effect1_dropShadow_887_4505\" />\r\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_887_4505\"\r\n result=\"shape\" />\r\n </filter>\r\n </defs>\r\n </svg></span>\r\n <span class=\"card-title-foot ms-3\">Footfall Directory</span>\r\n </div>\r\n <div class=\"col-md-2 my-3\">\r\n \r\n <lib-reactive-select formControlName=\"selectedStatus\" [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"type\"\r\n (itemChange)=\"typeChange($event)\"></lib-reactive-select>\r\n \r\n\r\n </div>\r\n <div class=\"col-md-2 my-3\">\r\n \r\n <lib-reactive-select formControlName=\"actionStatus\" [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"pendingArray\"\r\n (itemChange)=\"pendingChange($event)\"></lib-reactive-select>\r\n \r\n </div>\r\n <div class=\"col-md-3 my-4\" >\r\n <div class=\"select-wrapper\">\r\n <div class=\"placeholder-overlay\" *ngIf=\"!(filterForm.get('ClusterList')?.value?.length)\">\r\n Select cluster\r\n </div>\r\n <lib-group-select [items]=\"ClusterList\" [disabled]=\"false\" [multi]=\"true\"\r\n [searchField]=\"'groupName'\" [idField]=\"'groupName'\" (selected)=\"ongroupSelect($event)\"\r\n [selectedValues]=\"filterForm.get('ClusterList')?.value\">\r\n </lib-group-select>\r\n </div>\r\n\r\n </div>\r\n <div class=\"col-md-2 my-4\">\r\n <div class=\"d-flex me-3\">\r\n <a (click)=\"onFilterApply()\" type=\"submit\" class=\"btn btn-sm btn-primary px-4 \"><span>Apply</span></a>\r\n </div>\r\n </div>\r\n </div>\r\n</form>\r\n</div>\r\n<div *ngIf=\"!footfallView\" class=\"row mt-3\">\r\n <div class=\"position-relative\" \r\n [ngClass]=\"isCollapsed ? 'd-none' : 'col-md-3 h-auto'\" >\r\n <div class=\"card h-100\">\r\n <div class=\"card-header border-0 pt-3 px-5\">\r\n <h3 class=\"card-title align-items-start flex-column\">\r\n <span class=\"card-label mb-2\">Footfall Directory</span>\r\n <span class=\"text-sub mb-2\">Based on {{footfallList_req.fromDate | date: 'dd MMM, yyyy'}} \u2013 {{footfallList_req.toDate | date: 'dd MMM, yyyy'}} </span>\r\n </h3>\r\n </div>\r\n <span class=\"cursor-pointer\" (click)=\"toggleSidebar()\" style=\"position: absolute; top: 15px; right: -25px;\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"68\" height=\"68\" viewBox=\"0 0 68 68\" fill=\"none\">\r\n<g filter=\"url(#filter0_dd_778_34282)\">\r\n<rect x=\"12\" width=\"44\" height=\"44\" rx=\"22\" fill=\"white\"/>\r\n<path d=\"M33 27L28 22L33 17M40 27L35 22L40 17\" stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</g>\r\n<defs>\r\n<filter id=\"filter0_dd_778_34282\" x=\"0\" y=\"0\" width=\"68\" height=\"68\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n<feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\r\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\" result=\"hardAlpha\"/>\r\n<feMorphology radius=\"2\" operator=\"erode\" in=\"SourceAlpha\" result=\"effect1_dropShadow_778_34282\"/>\r\n<feOffset dy=\"4\"/>\r\n<feGaussianBlur stdDeviation=\"3\"/>\r\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.03 0\"/>\r\n<feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_778_34282\"/>\r\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\" result=\"hardAlpha\"/>\r\n<feMorphology radius=\"4\" operator=\"erode\" in=\"SourceAlpha\" result=\"effect2_dropShadow_778_34282\"/>\r\n<feOffset dy=\"12\"/>\r\n<feGaussianBlur stdDeviation=\"8\"/>\r\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.08 0\"/>\r\n<feBlend mode=\"normal\" in2=\"effect1_dropShadow_778_34282\" result=\"effect2_dropShadow_778_34282\"/>\r\n<feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect2_dropShadow_778_34282\" result=\"shape\"/>\r\n</filter>\r\n</defs>\r\n</svg>\r\n</span>\r\n <div class=\"text-end mt-10\">\r\n <button class=\"btn btn-outline w-25 me-3 btn-resize\" (click)=\"dataReset()\"> Reset </button>\r\n <button class=\"btn btn-primary w-25 me-5 btn-resize\" (click)=\"dataApply()\">Apply</button>\r\n </div>\r\n <div class=\"p-4 w-100 overflow-auto\">\r\n <input\r\n class=\"form-control form-control-sm mb-2 px-2 py-1 w-100\"\r\n type=\"text\"\r\n placeholder=\"Search\"\r\n [(ngModel)]=\"StoresSearchValue\"\r\n (change)=\"searchStoresData()\"\r\n/>\r\n\r\n <div class=\"mb-2 border-selectall\">\r\n <input type=\"checkbox\" [checked]=\"allSelected\" (change)=\"toggleSelectAll()\" />\r\n <label class=\"mt-2 font-semibold ms-2\">Select All {{storeCount}} Stores</label>\r\n </div>\r\n <ul class=\"list-unstyled ps-0\">\r\n <li *ngFor=\"let store of stores\" class=\"mb-5\">\r\n <input type=\"checkbox\" [checked]=\"isSelected(store)\" (change)=\"toggleStoreSelection(store)\" />\r\n {{ store?.storeName }}\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n <div [ngClass]=\"isCollapsed ? 'col-12' : 'col-md-9'\" >\r\n <div class=\"card h-100\">\r\n\r\n <div class=\"card-header min-h-35px border-0 pt-3\">\r\n <h3 class=\"card-title align-items-start flex-column\">\r\n \r\n </h3>\r\n <div class=\"card-toolbar\">\r\n <form class=\"mx-4\" [formGroup]=\"form\">\r\n <lib-reactive-select formControlName=\"selectedRevopsType\" [idField]=\"'value'\" [nameField]=\"'label'\"\r\n [data]=\"revopsTypeArray\" (itemChange)=\"RevopsTypeChange($event)\"></lib-reactive-select>\r\n </form>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"selectedRevopsType?.value !== '' && selecteValues ==='pending'\" class=\"card-header min-h-35px border-0\">\r\n <h3 class=\"align-items-start flex-column\">\r\n \r\n <div *ngIf=\"selectedRevopsType?.value !== ''\" class=\"mt-12 mb-2 font-semibold\">\r\n \r\n <input *ngIf=\"!footfallLoading && !footfallNoData\"\r\n type=\"checkbox\"\r\n [checked]=\"allSelectValue\"\r\n (change)=\"selectAllValue()\" />\r\n <label *ngIf=\"!footfallLoading && !footfallNoData\" class=\"mt-2 fs-6 font-semibold ms-2\">\r\n Select All (\r\n {{\r\n houseKeepingACCount > 0\r\n ? houseKeepingACCount\r\n : employeeACCount > 0\r\n ? employeeACCount\r\n : duplicateACCount > 0\r\n ? duplicateACCount\r\n : 0\r\n }}\r\n )\r\n </label>\r\n </div>\r\n <!-- -->\r\n \r\n </h3>\r\n <div class=\"card-toolbar\">\r\n <div *ngIf=\"selectedRevopsType?.value !== ''\" class=\"my-7 d-flex justify-content-end me-5\" role=\"group\">\r\n <button *ngIf=\"!footfallLoading && !footfallNoData\" [disabled]=\"checkedValue\" class=\"btn btn-outline me-1\" (click)=\"popupOpen('rejected',this.selectedRevopsType.value)\">Reject selection</button>\r\n <button *ngIf=\"!footfallLoading && !footfallNoData\" [disabled]=\"checkedValue\" class=\"btn btn-primary ms-1\" (click)=\"popupOpen('approved',this.selectedRevopsType.value)\">Approve selection</button>\r\n </div>\r\n \r\n </div>\r\n </div>\r\n <section *ngIf=\"selectedRevopsType?.value === ''\">\r\n <div *ngIf=\"!footfallLoading && !footfallNoData\" class=\"card-body mt-3 py-0\">\r\n\r\n <span class=\"cursor-pointer\" *ngIf=\"isCollapsed\" (click)=\"toggleSidebar()\" style=\"position: absolute; top: 15px; left: 0;\">\r\n <svg class=\"mt-2 ms-2\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 24 24\"\r\n fill=\"none\">\r\n <path\r\n d=\"M9.72714 12.6365L13.3635 9.00013L9.72714 5.36377M4.63623 12.6365L8.27259 9.00013L4.63623 5.36377\"\r\n stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <div class=\"col-md-12 text-center my-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"240\" height=\"86\" viewBox=\"0 0 240 86\" fill=\"none\">\r\n <rect width=\"240\" height=\"86\" fill=\"#FAFAFA\"/>\r\n <rect x=\"31\" width=\"178\" height=\"86\" fill=\"url(#pattern0_778_33543)\"/>\r\n <defs>\r\n <pattern id=\"pattern0_778_33543\" patternContentUnits=\"objectBoundingBox\" width=\"1\" height=\"1\">\r\n <use xlink:href=\"#image0_778_33543\" transform=\"matrix(0.000333333 0 0 0.000689922 0 -0.0822946)\"/>\r\n </pattern>\r\n <image id=\"image0_778_33543\" width=\"3000\" height=\"1688\" preserveAspectRatio=\"none\" xlink:href=\"\"/>\r\n </defs>\r\n </svg>\r\n </div>\r\n\r\n <ng-container *ngFor=\"let ticket of footfallTicketsData\">\r\n <div *ngIf=\"ticket?._source as source\" class=\"row mb-6\">\r\n <div class=\"col-2 card-title-label my-2\">Ticket Name</div>\r\n <div class=\"col-1 font-bold my-2\">:</div>\r\n <div class=\"col-9 card-title-value my-2\">{{ source.ticketName ? (source.ticketName | titlecase) : '-' }}</div>\r\n <div class=\"col-2 card-title-label my-2\">Ticket ID</div>\r\n <div class=\"col-1 font-bold my-2\">:</div>\r\n <div class=\"col-9 card-title-value my-2\">{{ source.ticketId ? source.ticketId:'-' }}</div>\r\n <div class=\"col-2 card-title-label my-2\">Store Name</div>\r\n <div class=\"col-1 font-bold my-2\">:</div>\r\n <div class=\"col-9 card-title-value my-2\">{{ source.storeName ? source.storeName:'-' }}</div>\r\n <div class=\"col-2 card-title-label my-2\">Status</div>\r\n <div class=\"col-1 font-bold my-2\">:</div>\r\n <div class=\"col-3 my-2\"><span \r\n class=\"badge\" \r\n [ngClass]=\"{\r\n 'badge-light-primary': source.status === 'open',\r\n 'badge-secondary': source.status === 'closed',\r\n 'badge-light-warning': source.status === 'pending',\r\n 'badge-light-danger': source.status === 'rejected'\r\n }\">\r\n {{ source.status ? (source.status | titlecase) : '-' }}\r\n</span></div>\r\n \r\n <div class=\"col-2 card-title-label my-2\">Date</div>\r\n <div class=\"col-1 font-bold my-2\">:</div>\r\n <div class=\"col-3 card-title-value my-2\">{{ source.dateString ? (source.dateString | date: 'dd MMM, yyyy') :'- ' }}</div>\r\n </div>\r\n \r\n <div *ngIf=\"ticket?._source as source\" class=\"border-totalfootfall\">\r\n <div class=\"card-header ellipse1 min-h-45px py-1 px-5\">\r\n <div class=\"my-0\">\r\n <h5 class=\"card-title\">{{ source?.footfallCount !== null ?\r\n source?.footfallCount : '--' }} <span class=\"sub-header ms-2\">Total Footfall</span></h5>\r\n \r\n </div>\r\n </div>\r\n <div class=\"card-body py-2 px-5\">\r\n <div class=\"row\">\r\n <div class=\"col-lg-3 col-xl-3 col-md-3 my-3\">\r\n <h5 class=\"card-title\">{{ source?.duplicateCount !== null ?\r\n source?.duplicateCount : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">Duplicates</span>\r\n </div>\r\n <div class=\"col-lg-3 col-xl-3 col-md-3 my-3\">\r\n <h5 class=\"card-title\">{{ source?.employeeCount !== null ?\r\n source?.employeeCount : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">Employee/Staff</span>\r\n </div>\r\n \r\n <div class=\"col-lg-3 col-xl-3 col-md-3 my-3\">\r\n <h5 class=\"card-title\">{{ source?.houseKeepingCount !== null ?\r\n source?.houseKeepingCount : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">House Keeping</span>\r\n </div>\r\n <div class=\"col-lg-3 col-xl-3 col-md-3 my-3\">\r\n <h5 class=\"card-title\"> {{ \r\n (source.footfallCount || 0) - \r\n ((source.houseKeepingCount || 0) + \r\n (source.employeeCount || 0) + \r\n (source.duplicateCount || 0)) \r\n }}</h5>\r\n <span class=\"card-title-sub-header\">Actual footfall</span>\r\n </div>\r\n </div>\r\n \r\n </div>\r\n </div>\r\n \r\n \r\n <div *ngIf=\"ticket?._source as source\" class=\"my-5\">\r\n <h3 *ngIf=\"source?.duplicateImages?.length\" class=\"text-lg font-semibold mb-4\"> <span class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\"\r\n width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_730_76157)\">\r\n <path\r\n d=\"M3.75 11.25H3C2.60218 11.25 2.22064 11.092 1.93934 10.8107C1.65804 10.5294 1.5 10.1478 1.5 9.75V3C1.5 2.60218 1.65804 2.22064 1.93934 1.93934C2.22064 1.65804 2.60218 1.5 3 1.5H9.75C10.1478 1.5 10.5294 1.65804 10.8107 1.93934C11.092 2.22064 11.25 2.60218 11.25 3V3.75M8.25 6.75H15C15.8284 6.75 16.5 7.42157 16.5 8.25V15C16.5 15.8284 15.8284 16.5 15 16.5H8.25C7.42157 16.5 6.75 15.8284 6.75 15V8.25C6.75 7.42157 7.42157 6.75 8.25 6.75Z\"\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_730_76157\">\r\n <rect width=\"18\" height=\"18\" fill=\"white\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>Duplicates</h3>\r\n \r\n \r\n <div *ngFor=\"let original of source.duplicateImages\" class=\"mb-4\">\r\n <div *ngIf=\"source?.duplicateImages?.length\" class=\"duplicate-head my-3\">Original image</div>\r\n <div class=\"row\">\r\n <div class=\"col-md-3 relative\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3\">\r\n \r\n <img [src]=\"imageUrl + original.filePath\" alt=\"\" class=\"w-100 rounded border\" />\r\n <div class=\"desc-title ms-2 mt-2\">Temp ID: {{ original.tempId }}</div>\r\n <div class=\"desc-value ms-2\">Entry Time: {{ getFormattedEntryTime(original?.entryTime) }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <div class=\"duplicate-head text-lg my-3\">Duplicates<span class=\"badge ms-2\" \r\n [ngClass]=\"{\r\n 'badge-light-primary': source?.duplicateStatus === 'pending',\r\n 'badge-light-success': source?.duplicateStatus === 'approved',\r\n 'badge-light-danger': source?.duplicateStatus === 'rejected'\r\n }\">{{source?.duplicateStatus | titlecase}}</span></div>\r\n <div class=\"row\">\r\n <div class=\"col-md-3 position-relative\" *ngFor=\"let img of original.data\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3 position-relative\">\r\n <input *ngIf=\"source?.duplicateStatus ==='pending'\"\r\n type=\"checkbox\"\r\n [(ngModel)]=\"img.selected\"\r\n class=\"position-absolute absolute form-check-input\"\r\n(change)=\"onImageCheckboxChange(img, 'duplicate', original)\"\r\n />\r\n <img [src]=\"imageUrl + img.filePath\" alt=\"\" class=\"w-100 mb-2 rounded border\" />\r\n <div class=\"desc-title ms-2 mt-2\">Temp ID: {{ img.tempId }}</div>\r\n <div class=\"desc-value ms-2\">Entry Time: {{ getFormattedEntryTime(img?.entryTime) }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n \r\n <div *ngIf=\"source?.duplicateImages?.length\" class=\"my-7 d-flex justify-content-end\" role=\"group\">\r\n <button [disabled]=\"!duplicateACCount\" class=\"btn btn-outline me-1\" (click)=\"popupOpen('rejected','duplicate')\" >Reject</button>\r\n <button [disabled]=\"!duplicateACCount\" class=\"btn btn-primary ms-1\" (click)=\"popupOpen('approved','duplicate')\">Approve</button>\r\n </div>\r\n \r\n <div *ngIf=\"source?.employee?.length\" class=\"duplicate-head text-lg my-3\"><span class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"18\" height=\"16\" viewBox=\"0 0 18 16\" fill=\"none\">\r\n<path d=\"M12.75 14.75V13.25C12.75 12.4544 12.4339 11.6913 11.8713 11.1287C11.3087 10.5661 10.5456 10.25 9.75 10.25H3.75C2.95435 10.25 2.19129 10.5661 1.62868 11.1287C1.06607 11.6913 0.75 12.4544 0.75 13.25V14.75M17.25 14.75V13.25C17.2495 12.5853 17.0283 11.9396 16.621 11.4142C16.2138 10.8889 15.6436 10.5137 15 10.3475M12 1.3475C12.6453 1.51273 13.2173 1.88803 13.6257 2.41423C14.0342 2.94044 14.2559 3.58762 14.2559 4.25375C14.2559 4.91988 14.0342 5.56706 13.6257 6.09327C13.2173 6.61947 12.6453 6.99477 12 7.16M9.75 4.25C9.75 5.90685 8.40685 7.25 6.75 7.25C5.09315 7.25 3.75 5.90685 3.75 4.25C3.75 2.59315 5.09315 1.25 6.75 1.25C8.40685 1.25 9.75 2.59315 9.75 4.25Z\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg></span>Employee/Staff <span class=\"badge ms-2\" \r\n [ngClass]=\"{\r\n 'badge-light-primary': source?.employeeStatus === 'pending',\r\n 'badge-light-success': source?.employeeStatus === 'approved',\r\n 'badge-light-danger': source?.employeeStatus === 'rejected'\r\n }\">{{source?.employeeStatus | titlecase}}</span></div>\r\n <div class=\"row\">\r\n <div class=\"col-md-3 position-relative\" *ngFor=\"let img of source.employee\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3 position-relative\">\r\n \r\n <!-- Top-right Checkbox -->\r\n <input *ngIf=\"source?.employeeStatus ==='pending'\" type=\"checkbox\" [(ngModel)]=\"img.selected\"\r\n class=\"position-absolute absolute form-check-input\"\r\n (change)=\"onImageCheckboxChange(img, 'employee')\" />\r\n \r\n \r\n <!-- Image -->\r\n <img [src]=\"imageUrl + img.filePath\" alt=\"\" class=\"w-100 mb-2 rounded border\" />\r\n \r\n <!-- Details -->\r\n <div class=\"desc-title ms-2 mt-2\">Temp ID: {{img.tempId}}</div>\r\n <div class=\"desc-value ms-2\">Entry Time: {{getFormattedEntryTime(img?.entryTime)}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <div *ngIf=\"source?.employee?.length\" class=\"my-7 d-flex justify-content-end\" role=\"group\">\r\n <button [disabled]=\"!employeeACCount\" class=\"btn btn-outline me-1\" (click)=\"popupOpen('rejected','employee')\" >Reject</button>\r\n <button [disabled]=\"!employeeACCount\" class=\"btn btn-primary ms-1\" (click)=\"popupOpen('approved','employee')\">Approve</button>\r\n </div>\r\n \r\n \r\n <div *ngIf=\"source?.houseKeeping?.length\" class=\"duplicate-head text-lg my-3\"><span class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n<path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M7.51995 0.613065C8.33739 -0.204355 9.66267 -0.204355 10.4801 0.613065L17.387 7.51995C18.2043 8.33739 18.2043 9.66267 17.387 10.4801L10.4801 17.387C9.66267 18.2043 8.33739 18.2043 7.51995 17.387L5.54626 15.4133L3.73708 17.2224C2.91966 18.0399 1.59436 18.0399 0.776944 17.2224C-0.0404767 16.4051 -0.0404767 15.0797 0.776944 14.2624L2.58612 12.4531L0.613065 10.4801C-0.204355 9.66267 -0.204355 8.33739 0.613065 7.51995L7.51995 0.613065ZM9.49336 1.59978C9.22088 1.32731 8.77909 1.32731 8.50661 1.59978L3.57286 6.53357L11.4665 14.4272L16.4002 9.49336C16.6727 9.22088 16.6727 8.77909 16.4002 8.5067L12.9465 5.05286L11.7952 6.20403C11.5228 6.4765 11.0811 6.4765 10.8086 6.20403C10.5361 5.93155 10.5361 5.48978 10.8086 5.21731L11.9597 4.06614L10.9732 3.07964L8.17757 5.87533C7.90509 6.1478 7.46329 6.1478 7.19081 5.87533C6.91833 5.60286 6.91833 5.16109 7.19081 4.88862L9.9865 2.09293L9.49336 1.59978ZM10.4797 15.4139L2.58615 7.52028L1.59978 8.5067C1.3273 8.77909 1.3273 9.22088 1.59978 9.49336L8.50661 16.4002C8.77909 16.6727 9.22088 16.6727 9.49336 16.4002L10.4797 15.4139ZM3.57275 13.4399L1.76366 15.249C1.49119 15.5215 1.49119 15.9633 1.76366 16.2358C2.03613 16.5082 2.4779 16.5082 2.75037 16.2358L4.55946 14.4266L3.57275 13.4399Z\" fill=\"#475467\"/>\r\n</svg></span> House Keeping <span class=\"badge ms-2\" \r\n [ngClass]=\"{\r\n 'badge-light-primary': source?.houseKeepingStatus === 'pending',\r\n 'badge-light-success': source?.houseKeepingStatus === 'approved',\r\n 'badge-light-danger': source?.houseKeepingStatus === 'rejected'\r\n }\">{{source?.houseKeepingStatus | titlecase}}</span></div>\r\n <div class=\"row\">\r\n <div class=\"col-md-3 position-relative\" *ngFor=\"let img of source.houseKeeping\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3 position-relative\">\r\n \r\n <!-- Top-right Checkbox -->\r\n <input *ngIf=\"source?.houseKeepingStatus ==='pending'\" type=\"checkbox\" [(ngModel)]=\"img.selected\" \r\n class=\"position-absolute absolute form-check-input\"\r\n (change)=\"onImageCheckboxChange(img, 'housekeeping')\" />\r\n \r\n \r\n <!-- Image -->\r\n <img [src]=\"imageUrl + img.filePath\" alt=\"\" class=\"w-100 mb-2 rounded border\" />\r\n \r\n <!-- Details -->\r\n <div class=\"desc-title ms-2 mt-2\">Temp ID: {{img.tempId}}</div>\r\n <div class=\"desc-value ms-2\">Entry Time: {{getFormattedEntryTime(img?.entryTime)}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <div *ngIf=\"source?.houseKeeping?.length\" class=\"my-7 d-flex justify-content-end\" role=\"group\">\r\n <button [disabled]=\"!houseKeepingACCount\" class=\"btn btn-outline me-1\" (click)=\"popupOpen('rejected','housekeeping')\" >Reject</button>\r\n <button [disabled]=\"!houseKeepingACCount\" class=\"btn btn-primary ms-1\" (click)=\"popupOpen('approved','housekeeping')\">Approve</button>\r\n </div>\r\n </div>\r\n \r\n </ng-container>\r\n <div *ngIf=\"!footfallLoading && !footfallNoData\" class=\"my-3\">\r\n <lib-pagination [itemsPerPage]=\"pageSizeFootfall\" [currentPage]=\"footfallcurrentPage\" [totalItems]=\"totalItemsFootfall\"\r\n [paginationSizes]=\"paginationSizes\" [pageSize]=\"setFootfallpageSize()\" (pageChange)=\"onFootfallPageChange($event)\"\r\n (pageSizeChange)=\"onFootfallPageSizeChange($event)\"></lib-pagination>\r\n </div>\r\n \r\n </div>\r\n \r\n </section>\r\n <div *ngIf=\"footfallLoading\" 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=\"footfallNoData\" class=\"row\">\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 class=\"my-5\" xmlns=\"http://www.w3.org/2000/svg\" width=\"94\" height=\"94\" viewBox=\"0 0 94 94\" fill=\"none\">\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\" stroke-width=\"13.3333\" />\r\n <g clip-path=\"url(#clip0_730_75095)\">\r\n <path\r\n d=\"M55.3327 62V58.6667C55.3327 56.8986 54.6303 55.2029 53.3801 53.9526C52.1298 52.7024 50.4341 52 48.666 52H35.3327C33.5646 52 31.8689 52.7024 30.6186 53.9526C29.3684 55.2029 28.666 56.8986 28.666 58.6667V62M65.3327 62V58.6667C65.3316 57.1895 64.8399 55.7546 63.935 54.5872C63.03 53.4198 61.7629 52.5859 60.3327 52.2167M53.666 32.2167C55.1 32.5838 56.3711 33.4178 57.2787 34.5872C58.1864 35.7565 58.6791 37.1947 58.6791 38.675C58.6791 40.1553 58.1864 41.5935 57.2787 42.7628C56.3711 43.9322 55.1 44.7662 53.666 45.1333M48.666 38.6667C48.666 42.3486 45.6812 45.3333 41.9993 45.3333C38.3174 45.3333 35.3327 42.3486 35.3327 38.6667C35.3327 34.9848 38.3174 32 41.9993 32C45.6812 32 48.666 34.9848 48.666 38.6667Z\"\r\n stroke=\"#00A3FF\" stroke-width=\"4\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_730_75095\">\r\n <rect width=\"40\" height=\"40\" fill=\"white\" transform=\"translate(27 27)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n <div class=\"nodata-title my-3\">No pending items</div>\r\n <div class=\"nodata-sub mb-3\">Looks like there is no action item required for <span\r\n *ngIf=\"selectedRevopsType?.value==='duplicateImages'\">duplicates</span><span\r\n *ngIf=\"selectedRevopsType?.value==='employee'\">employee/staff</span> <span\r\n *ngIf=\"selectedRevopsType?.value==='houseKeeping'\">houseKeeping</span>\r\n <span\r\n *ngIf=\"!selectedRevopsType?.value\">items</span></div>\r\n </div>\r\n </div>\r\n </div>\r\n <!-- Card Body -->\r\n <div *ngIf=\"selectedRevopsType?.value !== ''\" class=\"card-body mt-3 py-0\">\r\n <span class=\"cursor-pointer\" *ngIf=\"isCollapsed\" (click)=\"toggleSidebar()\" style=\"position: absolute; top: 15px; left: 0;\">\r\n <svg class=\"mt-2 ms-2\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 24 24\"\r\n fill=\"none\">\r\n <path\r\n d=\"M9.72714 12.6365L13.3635 9.00013L9.72714 5.36377M4.63623 12.6365L8.27259 9.00013L4.63623 5.36377\"\r\n stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <ng-container *ngFor=\"let ticket of footfallTicketsData\">\r\n <div *ngIf=\"ticket?._source as source\" class=\"my-4\">\r\n <div *ngFor=\"let original of source.duplicateImages\" class=\"mb-4\">\r\n <div *ngIf=\"source?.duplicateImages?.length\" class=\"duplicate-head my-2\">Original image</div>\r\n <div class=\"row\">\r\n <!-- \u2705 Original Image -->\r\n <div class=\"col-md-3 relative\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3\">\r\n \r\n <img [src]=\"imageUrl + original.filePath\" alt=\"\" class=\"w-100 rounded border\" />\r\n <div class=\"desc-title ms-2 mt-2\">{{source.storeName}}</div>\r\n <div class=\"desc-value ms-2\">Footfall date : {{source.dateString | date:'dd/MM/yyyy'}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <!-- \uD83D\uDFE8 Duplicate Images (for this original) -->\r\n <div class=\"duplicate-head my-3\">Duplicates <span class=\"badge ms-2\" \r\n [ngClass]=\"{\r\n 'badge-light-primary': source?.duplicateStatus === 'pending',\r\n 'badge-light-success': source?.duplicateStatus === 'approved',\r\n 'badge-light-danger': source?.duplicateStatus === 'rejected'\r\n }\">{{source?.duplicateStatus | titlecase}}</span></div>\r\n <div class=\"row\">\r\n <div class=\"col-md-3 position-relative\" *ngFor=\"let img of original.data\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3 position-relative\">\r\n <input *ngIf=\"source?.duplicateStatus ==='pending'\" type=\"checkbox\" [(ngModel)]=\"img.selected\"\r\n class=\"position-absolute absolute form-check-input\"\r\n (change)=\"onImageCheckboxChange1(img, 'duplicate')\" />\r\n <img [src]=\"imageUrl + img.filePath\" alt=\"\" class=\"w-100 mb-2 rounded border\" />\r\n <div class=\"desc-title ms-2 mt-2\">{{source.storeName}}</div>\r\n <div class=\"desc-value ms-2\">Footfall date : {{source.dateString | date:'dd/MM/yyyy'}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"source?.employee?.length\" class=\"row\">\r\n <div class=\"col-md-3 position-relative\" *ngFor=\"let img of source.employee\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3 position-relative\">\r\n \r\n <!-- Top-right Checkbox -->\r\n <input *ngIf=\"source?.employeeStatus ==='pending'\" type=\"checkbox\" [(ngModel)]=\"img.selected\"\r\n class=\"position-absolute absolute form-check-input\"\r\n (change)=\"onImageCheckboxChange1(img, 'employee')\" />\r\n \r\n \r\n <!-- Image -->\r\n <img [src]=\"imageUrl + img.filePath\" alt=\"\" class=\"w-100 mb-2 rounded border\" />\r\n \r\n <!-- Details -->\r\n <div class=\"desc-title ms-2 mt-2\">{{source.storeName}}</div>\r\n <div class=\"desc-value ms-2\">Footfall date : {{source.dateString | date:'dd/MM/yyyy'}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"source?.houseKeeping?.length\" class=\"row\">\r\n <div class=\"col-md-3 position-relative\" *ngFor=\"let img of source.houseKeeping\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3 position-relative\">\r\n \r\n <!-- Top-right Checkbox -->\r\n <input *ngIf=\"source?.houseKeepingStatus ==='pending'\" type=\"checkbox\" [(ngModel)]=\"img.selected\"\r\n class=\"position-absolute absolute form-check-input\"\r\n (change)=\"onImageCheckboxChange1(img, 'housekeeping')\" />\r\n \r\n \r\n <!-- Image -->\r\n <img [src]=\"imageUrl + img.filePath\" alt=\"\" class=\"w-100 mb-2 rounded border\" />\r\n \r\n <!-- Details -->\r\n <div class=\"desc-title ms-2 mt-2\">{{source.storeName}}</div>\r\n <div class=\"desc-value ms-2\">Footfall date : {{source.dateString | date:'dd/MM/yyyy'}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <!-- <div *ngIf=\"!footfallLoading && !footfallNoData\" class=\"my-3\">\r\n <lib-pagination [itemsPerPage]=\"pageSizeFootfall\" [currentPage]=\"footfallcurrentPage\"\r\n [totalItems]=\"totalItemsFootfall\" [paginationSizes]=\"paginationSizes\" [pageSize]=\"setFootfallpageSize()\"\r\n (pageChange)=\"onFootfallPageChange($event)\"\r\n (pageSizeChange)=\"onFootfallPageSizeChange($event)\"></lib-pagination>\r\n </div> -->\r\n </div>\r\n </div>\r\n \r\n </div>\r\n</div>\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 \r\n <!-- Heading -->\r\n <h5 class=\"modal-title mb-2\">\r\n {{ popupType === 'approved' ? 'Approve' : 'Reject' }} Selected Images\r\n </h5>\r\n\r\n <!-- Description -->\r\n <p class=\"mb-3\">\r\n You're about to {{ popupType === 'approved' ? 'approve' : 'reject' }} the following number of selected images.\r\n </p>\r\n\r\n <!-- Count Box -->\r\n <div class=\"border border-1 rounded p-3 w-50 mb-4\">\r\n <div *ngIf=\"popupvalue === 'employee'\" class=\"fw-semibold fs-5 mb-2\">\r\n {{ employeeACCount || '--' }}\r\n </div>\r\n <div *ngIf=\"popupvalue === 'housekeeping'\" class=\"fw-semibold fs-5 mb-2\">\r\n {{ houseKeepingACCount || '--' }}\r\n </div>\r\n <div *ngIf=\"popupvalue === 'duplicate'\" class=\"fw-semibold fs-5 mb-2\">\r\n {{ duplicateACCount || '--' }}\r\n </div>\r\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n {{ popupvalue | titlecase }}s\r\n </div>\r\n </div>\r\n\r\n <!-- Action Buttons -->\r\n <div class=\"w-100 d-flex justify-content-end\">\r\n <button class=\"btn btn-outline me-2\" (click)=\"cancel()\">Cancel</button>\r\n <button class=\"btn btn-primary\" (click)=\"submitValue(popupType, popupvalue)\">\r\n {{ popupType === 'approved' ? 'Approve' : 'Reject' }}\r\n </button>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n", styles: [".card-header,.header{color:var(--Gray-900, #101828);font-size:20px!important;font-style:normal;font-weight:700;line-height:30px}.sub-header{color:var(--Gray-700, #344054);font-size:14px!important;font-style:normal;font-weight:600;line-height:20px}.ellipse1{border-radius:6px;border-bottom:2px solid var(--Gray-200, #EAECF0);background:radial-gradient(206.89% 107.47% at 16.16% 32.77%,#fff6,#45bbfe33),#f2f4f7;box-shadow:0 4px 10px #0000000d}.card-title-foot{color:var(--Gray-800, #1D2939)!important;font-size:18px;font-weight:600;line-height:28px}.card-title-label{color:var(--Gray-800, #1D2939)!important;font-size:16px;font-weight:600;line-height:28px}.card-title-value{color:var(--Gray-800, #1D2939)!important;font-size:16px;font-weight:400;line-height:28px}input[type=checkbox]{width:16px!important;height:16px!important;margin:7px 5px -2px;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}.rotate{rotate:180deg;transition:1s}.border-selectall{border-radius:6px!important;border-bottom:1px solid var(--Gray-200, #EAECF0)!important;background:var(--White, #FFF)!important;padding:8px 2px}.border-selectall1{border-radius:6px!important;background:var(--White, #FFF)!important;padding:8px 2px}.border-totalfootfall{border-radius:12px;padding:4px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF)}.vl{border-left:2px solid #000;height:50px}.duplicate-head{color:var(--Gray-700, #344054);font-size:16px;font-weight:600;line-height:20px}.img-border{border-radius:5px!important;border:2px solid var(--Gray-300, #D0D5DD)}.desc-title{color:var(--Gray-900, #101828);font-size:12px;font-weight:500;line-height:20px}.desc-value{color:var(--Gray-900, #475467);font-size:10px;font-weight:500;line-height:20px}.img-border{overflow:hidden;position:relative}.btn-resize{font-size:13px!important;height:29px!important;line-height:11px!important;padding:1px!important}.absolute{top:5px;right:5px;z-index:2}.img-src{width:25%;height:20%}.backButtonright{border-radius:1000px!important;background:var(--text-primary, #FFF)!important;padding:12px!important;box-shadow:0 12px 16px -4px #10182814,0 4px 6px -2px #10182808!important;box-shadow:0 8.727px 11.636px -2.909px #10182814,0 2.909px 4.364px -1.455px #10182808!important;position:absolute;top:30px;right:-10px;z-index:0}.backButtonleft{border-radius:1000px!important;background:#fff;padding:14px!important;border:var(--Gray-300, #D0D5DD);box-shadow:0 8.727px 11.636px -2.909px #10182814,0 2.909px 4.364px -1.455px #10182808;position:absolute;top:30px;left:-20px;z-index:5}.select-wrapper{position:relative;display:inline-block;width:100%}.placeholder-overlay{position:absolute;color:var(--Gray-500, #667085);font-family:Inter;font-size:16px!important;font-style:normal;font-weight:400;top:10px;left:15px;pointer-events:none;font-size:1.1rem;z-index:1}.card-title{color:var(--Black, #101828)!important;font-size:20px!important;font-weight:700!important;line-height:30px}.card-title-sub-header{color:var(--Black, #101828);font-size:14px;font-weight:500;line-height:30px}\n"], dependencies: [{ kind: "directive", type: i6$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i6.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i6.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i4.PaginationComponent, selector: "lib-pagination", inputs: ["collection", "itemsPerPage", "currentPage", "totalItems", "directionLinks", "pageSize", "paginationSizes"], outputs: ["pageChange", "pageSizeChange"] }, { kind: "component", type: ReactiveSelectComponent, selector: "lib-reactive-select", inputs: ["isDisabled", "idField", "nameField", "label", "data"], outputs: ["itemChange"] }, { kind: "component", type: GroupSelectComponent, selector: "lib-group-select", inputs: ["items", "searchField", "multi", "idField", "selectedValues", "disabled", "label"], outputs: ["selected"] }, { kind: "pipe", type: i6$1.TitleCasePipe, name: "titlecase" }, { kind: "pipe", type: i6$1.DatePipe, name: "date" }] });
|
|
2714
|
-
}
|
|
2715
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FootfallDicComponent, decorators: [{
|
|
2716
|
-
type: Component,
|
|
2717
|
-
args: [{ selector: "lib-footfall-dic", template: "<div *ngIf=\"footfallView\" class=\"row\">\r\n <div class=\"col-md-3 mb-3\">\r\n <div class=\"card\">\r\n <div class=\"card-header ellipse1 py-1 px-5\">\r\n <div class=\"my-0\">\r\n <h5 class=\"card-title my-0\">{{ getFootfallSummaryData?.totalTickets !== null ?\r\n getFootfallSummaryData?.totalTickets : '--' }}</h5>\r\n <span class=\"sub-header\">Total tickets</span>\r\n </div>\r\n </div>\r\n <div class=\"card-body py-2 px-5\">\r\n <div class=\"row\">\r\n <div class=\"col-lg-6 col-xl-9 col-md-6 my-3\">\r\n <h5 class=\"card-title\">{{ getFootfallSummaryData?.openTickets !== null ?\r\n getFootfallSummaryData?.openTickets : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">Open</span>\r\n </div>\r\n <div class=\"col-lg-6 col-xl-3 col-md-6 my-3\">\r\n <h5 class=\"card-title\">{{ getFootfallSummaryData?.closedTickets !== null ?\r\n getFootfallSummaryData?.closedTickets : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">Closed</span>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"col-md-9 mb-3\">\r\n <div class=\"card\">\r\n <div class=\"card-header ellipse1 py-1 px-5\">\r\n <div class=\"my-0\">\r\n <h5 class=\"card-title mt-0\">{{ getFootfallSummaryData?.noShopper !== null ?\r\n getFootfallSummaryData?.noShopper : '--' }}</h5>\r\n <div class=\"sub-header\">Non-Shoppers</div>\r\n </div>\r\n </div>\r\n <div class=\"card-body py-2 px-5\">\r\n <div class=\"row\">\r\n <div class=\"col-lg-4 col-xl-5 col-md-4 my-3\">\r\n <h5 class=\"card-title\">{{ getFootfallSummaryData?.duplicateCount !== null ?\r\n getFootfallSummaryData?.duplicateCount : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">Duplicates</span>\r\n </div>\r\n <div class=\"col-lg-4 col-xl-5 col-md-4 my-3 \">\r\n <h5 class=\"card-title \">{{ getFootfallSummaryData?.employeeCount !== null ?\r\n getFootfallSummaryData?.employeeCount : '--' }}</h5>\r\n <span class=\"card-title-sub-header \">Employee/Staff</span>\r\n </div>\r\n <div class=\"col-lg-4 col-xl-2 col-md-4 my-3\">\r\n <h5 class=\"card-title \">{{ getFootfallSummaryData?.houseKeepingCount !== null ?\r\n getFootfallSummaryData?.houseKeepingCount : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">Housekeeping</span>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<div *ngIf=\"footfallView\" class=\"card\">\r\n <div class=\"card-header border-0 pt-3\">\r\n <h3 class=\"card-title align-items-start flex-column\">\r\n <span class=\"card-label mb-2\">Ticket Info <span *ngIf=\"totalItems\" class=\"ms-2 px-3 badge badge-light-primary\">{{totalItems ? totalItems :'--'}} Total</span></span>\r\n <span class=\"text-sub mb-2\">Based on {{footfallList_req?.fromDate | date: 'dd MMM, yyyy'}} \u2013 {{footfallList_req?.toDate | date: 'dd MMM, yyyy'}} </span>\r\n </h3>\r\n <div class=\"card-toolbar\">\r\n <div class=\"d-flex\">\r\n <div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\r\n <rect opacity=\"0.5\" x=\"17.0365\" y=\"15.1223\" width=\"8.15546\" height=\"2\" rx=\"1\"\r\n transform=\"rotate(45 17.0365 15.1223)\" fill=\"currentColor\"></rect>\r\n <path\r\n d=\"M11 19C6.55556 19 3 15.4444 3 11C3 6.55556 6.55556 3 11 3C15.4444 3 19 6.55556 19 11C19 15.4444 15.4444 19 11 19ZM11 5C7.53333 5 5 7.53333 5 11C5 14.4667 7.53333 17 11 17C14.4667 17 17 14.4667 17 11C17 7.53333 14.4667 5 11 5Z\"\r\n fill=\"currentColor\"></path>\r\n </svg>\r\n </span>\r\n <input type=\"text\" class=\"form-control ps-14 me-2\" placeholder=\"Search by store\" autocomplete=\"off\"\r\n (change)=\"searchData()\" [(ngModel)]=\"searchValue\" />\r\n <!-- <lib-filters [dataObject]=\"dataObject\"\r\n (appliedFilters)=\"applyFilters($event)\"></lib-filters> -->\r\n\r\n <button type=\"button\" (click)=\"exportXLSX()\"\r\n class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n <span class=\"ms-2\">Export</span>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n <div class=\"card-body mt-3 py-0 px-0\">\r\n\r\n\r\n\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 <div class=\"col-lg-12 mb-3\">\r\n <div class=\"card-body d-flex justify-content-center align-items-center flex-column\">\r\n <img class=\"img-src\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\">\r\n <div class=\"nodata-title\">No data found</div>\r\n <div class=\"nodata-sub\">There is no result for this Date</div>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"!loading && !noData\" class=\"table-responsive\">\r\n <table class=\"table bottom-border text-nowrap \">\r\n <thead>\r\n <tr>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('storeName')\">Store Info<svg\r\n [ngClass]=\"sortedColumn === 'storeName' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'storeName' ? '#00A3FF' : '#667085'\"\r\n stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('ticketId')\">Ticket ID<svg\r\n [ngClass]=\"sortedColumn === 'ticketId' && sortDirection === 1 ? 'rotate' : ''\"\r\n width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'ticketId' ? '#00A3FF' : '#667085'\"\r\n stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('dateString')\">Ticket raised on\r\n <svg [ngClass]=\"sortedColumn === 'dateString' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'dateString' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('footfallCount')\">Total footfalls\r\n <svg [ngClass]=\"sortedColumn === 'footfallCount' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'footfallCount' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('duplicateCount')\">Duplicates\r\n <svg [ngClass]=\"sortedColumn === 'duplicateCount' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'duplicateCount' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('employeeCount')\">Employee/Staff\r\n <svg [ngClass]=\"sortedColumn === 'employeeCount' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'employeeCount' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('houseKeepingCount')\">Housekeeping\r\n <svg [ngClass]=\"sortedColumn === 'houseKeepingCount' && sortDirection === 1 ? 'rotate' : ''\"\r\n xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\r\n fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'houseKeepingCount' ? '#00A3FF' : '#667085'\" stroke-width=\"1.33333\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </th>\r\n\r\n <th>Revised footfalls\r\n \r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('status')\">Status<svg\r\n [ngClass]=\"sortedColumn === 'status' && sortDirection === 1 ? 'rotate' : ''\" width=\"16\"\r\n height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M8.00016 3.33337V12.6667M8.00016 12.6667L12.6668 8.00004M8.00016 12.6667L3.3335 8.00004\"\r\n [attr.stroke]=\"sortedColumn === 'status' ? '#00A3FF' : '#667085'\"\r\n stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg></th>\r\n <!-- <th >Actions</th> -->\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let ticket of footfallListData\">\r\n <ng-container *ngIf=\"ticket?._source as source\">\r\n <td (click)=\"dataStoreView(ticket)\">\r\n <div class=\"text-primary cursor-pointer\">{{ source.storeName }}</div>\r\n <div class=\"text-gray-500 fs-7 mt-2\">ID : {{ source.storeId }}</div>\r\n </td>\r\n \r\n <td class=\"py-7\">{{ source.ticketId }}</td>\r\n <td class=\"py-7\">{{ source.dateString | date: 'dd MMM, yyyy' }}</td>\r\n <td class=\"py-7\">{{ source.footfallCount }}</td>\r\n <td class=\"py-7\">{{ source.duplicateCount }}</td>\r\n <td class=\"py-7\">{{ source.employeeCount }}</td>\r\n <td class=\"py-7\">{{ source.houseKeepingCount }}</td>\r\n <td class=\"py-7\">\r\n {{ source.footfallCount - (source.houseKeepingCount + source.employeeCount +\r\n source.duplicateCount) }}\r\n </td>\r\n \r\n <td class=\"py-7\">\r\n <span *ngIf=\"source.status === 'open' || source.status === 'closed'\" class=\"badge mx-2\" [ngClass]=\"{\r\n 'badge-light-primary': source.status === 'open',\r\n 'badge-light-default': source.status === 'closed'\r\n }\">\r\n {{ source.status | titlecase }}\r\n </span>\r\n </td>\r\n </ng-container>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n <div *ngIf=\"!loading && !noData\" class=\"my-3\">\r\n <lib-pagination [itemsPerPage]=\"pageSize\" [currentPage]=\"currentPage\" [totalItems]=\"totalItems\"\r\n [paginationSizes]=\"paginationSizes\" [pageSize]=\"setpageSize()\" (pageChange)=\"onPageChange($event)\"\r\n (pageSizeChange)=\"onPageSizeChange($event)\"></lib-pagination>\r\n </div>\r\n </div>\r\n\r\n</div>\r\n\r\n\r\n<div *ngIf=\"!footfallView\" class=\"card mt-2\">\r\n <form [formGroup]=\"filterForm\">\r\n <div class=\"row my-0\">\r\n <div class=\"col-lg-3 my-3\">\r\n <span class=\"ms-2 cursor-pointer\" (click)=\"backToNavigation()\" ><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"56\" height=\"44\" viewBox=\"0 0 56 44\"\r\n fill=\"none\">\r\n <g filter=\"url(#filter0_d_887_4505)\">\r\n <rect x=\"2\" y=\"1\" width=\"52\" height=\"40\" rx=\"8\" fill=\"white\" />\r\n <rect x=\"2.5\" y=\"1.5\" width=\"51\" height=\"39\" rx=\"7.5\" stroke=\"#D0D5DD\" />\r\n <path d=\"M30.5 26L25.5 21L30.5 16\" 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_887_4505\" x=\"0\" y=\"0\" width=\"56\" height=\"44\" filterUnits=\"userSpaceOnUse\"\r\n 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\" result=\"effect1_dropShadow_887_4505\" />\r\n <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_887_4505\"\r\n result=\"shape\" />\r\n </filter>\r\n </defs>\r\n </svg></span>\r\n <span class=\"card-title-foot ms-3\">Footfall Directory</span>\r\n </div>\r\n <div class=\"col-md-2 my-3\">\r\n \r\n <lib-reactive-select formControlName=\"selectedStatus\" [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"type\"\r\n (itemChange)=\"typeChange($event)\"></lib-reactive-select>\r\n \r\n\r\n </div>\r\n <div class=\"col-md-2 my-3\">\r\n \r\n <lib-reactive-select formControlName=\"actionStatus\" [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"pendingArray\"\r\n (itemChange)=\"pendingChange($event)\"></lib-reactive-select>\r\n \r\n </div>\r\n <div class=\"col-md-3 my-4\" >\r\n <div class=\"select-wrapper\">\r\n <div class=\"placeholder-overlay\" *ngIf=\"!(filterForm.get('ClusterList')?.value?.length)\">\r\n Select cluster\r\n </div>\r\n <lib-group-select [items]=\"ClusterList\" [disabled]=\"false\" [multi]=\"true\"\r\n [searchField]=\"'groupName'\" [idField]=\"'groupName'\" (selected)=\"ongroupSelect($event)\"\r\n [selectedValues]=\"filterForm.get('ClusterList')?.value\">\r\n </lib-group-select>\r\n </div>\r\n\r\n </div>\r\n <div class=\"col-md-2 my-4\">\r\n <div class=\"d-flex me-3\">\r\n <a (click)=\"onFilterApply()\" type=\"submit\" class=\"btn btn-sm btn-primary px-4 \"><span>Apply</span></a>\r\n </div>\r\n </div>\r\n </div>\r\n</form>\r\n</div>\r\n<div *ngIf=\"!footfallView\" class=\"row mt-3\">\r\n <div class=\"position-relative\" \r\n [ngClass]=\"isCollapsed ? 'd-none' : 'col-md-3 h-auto'\" >\r\n <div class=\"card h-100\">\r\n <div class=\"card-header border-0 pt-3 px-5\">\r\n <h3 class=\"card-title align-items-start flex-column\">\r\n <span class=\"card-label mb-2\">Footfall Directory</span>\r\n <span class=\"text-sub mb-2\">Based on {{footfallList_req.fromDate | date: 'dd MMM, yyyy'}} \u2013 {{footfallList_req.toDate | date: 'dd MMM, yyyy'}} </span>\r\n </h3>\r\n </div>\r\n <span class=\"cursor-pointer\" (click)=\"toggleSidebar()\" style=\"position: absolute; top: 15px; right: -25px;\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"68\" height=\"68\" viewBox=\"0 0 68 68\" fill=\"none\">\r\n<g filter=\"url(#filter0_dd_778_34282)\">\r\n<rect x=\"12\" width=\"44\" height=\"44\" rx=\"22\" fill=\"white\"/>\r\n<path d=\"M33 27L28 22L33 17M40 27L35 22L40 17\" stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</g>\r\n<defs>\r\n<filter id=\"filter0_dd_778_34282\" x=\"0\" y=\"0\" width=\"68\" height=\"68\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\r\n<feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\r\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\" result=\"hardAlpha\"/>\r\n<feMorphology radius=\"2\" operator=\"erode\" in=\"SourceAlpha\" result=\"effect1_dropShadow_778_34282\"/>\r\n<feOffset dy=\"4\"/>\r\n<feGaussianBlur stdDeviation=\"3\"/>\r\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.03 0\"/>\r\n<feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_778_34282\"/>\r\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\" result=\"hardAlpha\"/>\r\n<feMorphology radius=\"4\" operator=\"erode\" in=\"SourceAlpha\" result=\"effect2_dropShadow_778_34282\"/>\r\n<feOffset dy=\"12\"/>\r\n<feGaussianBlur stdDeviation=\"8\"/>\r\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.08 0\"/>\r\n<feBlend mode=\"normal\" in2=\"effect1_dropShadow_778_34282\" result=\"effect2_dropShadow_778_34282\"/>\r\n<feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect2_dropShadow_778_34282\" result=\"shape\"/>\r\n</filter>\r\n</defs>\r\n</svg>\r\n</span>\r\n <div class=\"text-end mt-10\">\r\n <button class=\"btn btn-outline w-25 me-3 btn-resize\" (click)=\"dataReset()\"> Reset </button>\r\n <button class=\"btn btn-primary w-25 me-5 btn-resize\" (click)=\"dataApply()\">Apply</button>\r\n </div>\r\n <div class=\"p-4 w-100 overflow-auto\">\r\n <input\r\n class=\"form-control form-control-sm mb-2 px-2 py-1 w-100\"\r\n type=\"text\"\r\n placeholder=\"Search\"\r\n [(ngModel)]=\"StoresSearchValue\"\r\n (change)=\"searchStoresData()\"\r\n/>\r\n\r\n <div class=\"mb-2 border-selectall\">\r\n <input type=\"checkbox\" [checked]=\"allSelected\" (change)=\"toggleSelectAll()\" />\r\n <label class=\"mt-2 font-semibold ms-2\">Select All {{storeCount}} Stores</label>\r\n </div>\r\n <ul class=\"list-unstyled ps-0\">\r\n <li *ngFor=\"let store of stores\" class=\"mb-5\">\r\n <input type=\"checkbox\" [checked]=\"isSelected(store)\" (change)=\"toggleStoreSelection(store)\" />\r\n {{ store?.storeName }}\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n <div [ngClass]=\"isCollapsed ? 'col-12' : 'col-md-9'\" >\r\n <div class=\"card h-100\">\r\n\r\n <div class=\"card-header min-h-35px border-0 pt-3\">\r\n <h3 class=\"card-title align-items-start flex-column\">\r\n \r\n </h3>\r\n <div class=\"card-toolbar\">\r\n <form class=\"mx-4\" [formGroup]=\"form\">\r\n <lib-reactive-select formControlName=\"selectedRevopsType\" [idField]=\"'value'\" [nameField]=\"'label'\"\r\n [data]=\"revopsTypeArray\" (itemChange)=\"RevopsTypeChange($event)\"></lib-reactive-select>\r\n </form>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"selectedRevopsType?.value !== '' && selecteValues ==='pending'\" class=\"card-header min-h-35px border-0\">\r\n <h3 class=\"align-items-start flex-column\">\r\n \r\n <div *ngIf=\"selectedRevopsType?.value !== ''\" class=\"mt-12 mb-2 font-semibold\">\r\n \r\n <input *ngIf=\"!footfallLoading && !footfallNoData\"\r\n type=\"checkbox\"\r\n [checked]=\"allSelectValue\"\r\n (change)=\"selectAllValue()\" />\r\n <label *ngIf=\"!footfallLoading && !footfallNoData\" class=\"mt-2 fs-6 font-semibold ms-2\">\r\n Select All (\r\n {{\r\n houseKeepingACCount > 0\r\n ? houseKeepingACCount\r\n : employeeACCount > 0\r\n ? employeeACCount\r\n : duplicateACCount > 0\r\n ? duplicateACCount\r\n : 0\r\n }}\r\n )\r\n </label>\r\n </div>\r\n <!-- -->\r\n \r\n </h3>\r\n <div class=\"card-toolbar\">\r\n <div *ngIf=\"selectedRevopsType?.value !== ''\" class=\"my-7 d-flex justify-content-end me-5\" role=\"group\">\r\n <button *ngIf=\"!footfallLoading && !footfallNoData\" [disabled]=\"checkedValue\" class=\"btn btn-outline me-1\" (click)=\"popupOpen('rejected',this.selectedRevopsType.value)\">Reject selection</button>\r\n <button *ngIf=\"!footfallLoading && !footfallNoData\" [disabled]=\"checkedValue\" class=\"btn btn-primary ms-1\" (click)=\"popupOpen('approved',this.selectedRevopsType.value)\">Approve selection</button>\r\n </div>\r\n \r\n </div>\r\n </div>\r\n <section *ngIf=\"selectedRevopsType?.value === ''\">\r\n <div *ngIf=\"!footfallLoading && !footfallNoData\" class=\"card-body mt-3 py-0\">\r\n\r\n <span class=\"cursor-pointer\" *ngIf=\"isCollapsed\" (click)=\"toggleSidebar()\" style=\"position: absolute; top: 15px; left: 0;\">\r\n <svg class=\"mt-2 ms-2\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 24 24\"\r\n fill=\"none\">\r\n <path\r\n d=\"M9.72714 12.6365L13.3635 9.00013L9.72714 5.36377M4.63623 12.6365L8.27259 9.00013L4.63623 5.36377\"\r\n stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <div class=\"col-md-12 text-center my-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"240\" height=\"86\" viewBox=\"0 0 240 86\" fill=\"none\">\r\n <rect width=\"240\" height=\"86\" fill=\"#FAFAFA\"/>\r\n <rect x=\"31\" width=\"178\" height=\"86\" fill=\"url(#pattern0_778_33543)\"/>\r\n <defs>\r\n <pattern id=\"pattern0_778_33543\" patternContentUnits=\"objectBoundingBox\" width=\"1\" height=\"1\">\r\n <use xlink:href=\"#image0_778_33543\" transform=\"matrix(0.000333333 0 0 0.000689922 0 -0.0822946)\"/>\r\n </pattern>\r\n <image id=\"image0_778_33543\" width=\"3000\" height=\"1688\" preserveAspectRatio=\"none\" xlink:href=\"\"/>\r\n </defs>\r\n </svg>\r\n </div>\r\n\r\n <ng-container *ngFor=\"let ticket of footfallTicketsData\">\r\n <div *ngIf=\"ticket?._source as source\" class=\"row mb-6\">\r\n <div class=\"col-2 card-title-label my-2\">Ticket Name</div>\r\n <div class=\"col-1 font-bold my-2\">:</div>\r\n <div class=\"col-9 card-title-value my-2\">{{ source.ticketName ? (source.ticketName | titlecase) : '-' }}</div>\r\n <div class=\"col-2 card-title-label my-2\">Ticket ID</div>\r\n <div class=\"col-1 font-bold my-2\">:</div>\r\n <div class=\"col-9 card-title-value my-2\">{{ source.ticketId ? source.ticketId:'-' }}</div>\r\n <div class=\"col-2 card-title-label my-2\">Store Name</div>\r\n <div class=\"col-1 font-bold my-2\">:</div>\r\n <div class=\"col-9 card-title-value my-2\">{{ source.storeName ? source.storeName:'-' }}</div>\r\n <div class=\"col-2 card-title-label my-2\">Status</div>\r\n <div class=\"col-1 font-bold my-2\">:</div>\r\n <div class=\"col-3 my-2\"><span \r\n class=\"badge\" \r\n [ngClass]=\"{\r\n 'badge-light-primary': source.status === 'open',\r\n 'badge-secondary': source.status === 'closed',\r\n 'badge-light-warning': source.status === 'pending',\r\n 'badge-light-danger': source.status === 'rejected'\r\n }\">\r\n {{ source.status ? (source.status | titlecase) : '-' }}\r\n</span></div>\r\n \r\n <div class=\"col-2 card-title-label my-2\">Date</div>\r\n <div class=\"col-1 font-bold my-2\">:</div>\r\n <div class=\"col-3 card-title-value my-2\">{{ source.dateString ? (source.dateString | date: 'dd MMM, yyyy') :'- ' }}</div>\r\n </div>\r\n \r\n <div *ngIf=\"ticket?._source as source\" class=\"border-totalfootfall\">\r\n <div class=\"card-header ellipse1 min-h-45px py-1 px-5\">\r\n <div class=\"my-0\">\r\n <h5 class=\"card-title\">{{ source?.footfallCount !== null ?\r\n source?.footfallCount : '--' }} <span class=\"sub-header ms-2\">Total Footfall</span></h5>\r\n \r\n </div>\r\n </div>\r\n <div class=\"card-body py-2 px-5\">\r\n <div class=\"row\">\r\n <div class=\"col-lg-3 col-xl-3 col-md-3 my-3\">\r\n <h5 class=\"card-title\">{{ source?.duplicateCount !== null ?\r\n source?.duplicateCount : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">Duplicates</span>\r\n </div>\r\n <div class=\"col-lg-3 col-xl-3 col-md-3 my-3\">\r\n <h5 class=\"card-title\">{{ source?.employeeCount !== null ?\r\n source?.employeeCount : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">Employee/Staff</span>\r\n </div>\r\n \r\n <div class=\"col-lg-3 col-xl-3 col-md-3 my-3\">\r\n <h5 class=\"card-title\">{{ source?.houseKeepingCount !== null ?\r\n source?.houseKeepingCount : '--' }}</h5>\r\n <span class=\"card-title-sub-header\">House Keeping</span>\r\n </div>\r\n <div class=\"col-lg-3 col-xl-3 col-md-3 my-3\">\r\n <h5 class=\"card-title\"> {{ \r\n (source.footfallCount || 0) - \r\n ((source.houseKeepingCount || 0) + \r\n (source.employeeCount || 0) + \r\n (source.duplicateCount || 0)) \r\n }}</h5>\r\n <span class=\"card-title-sub-header\">Actual footfall</span>\r\n </div>\r\n </div>\r\n \r\n </div>\r\n </div>\r\n \r\n \r\n <div *ngIf=\"ticket?._source as source\" class=\"my-5\">\r\n <h3 *ngIf=\"source?.duplicateImages?.length\" class=\"text-lg font-semibold mb-4\"> <span class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\"\r\n width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n <g clip-path=\"url(#clip0_730_76157)\">\r\n <path\r\n d=\"M3.75 11.25H3C2.60218 11.25 2.22064 11.092 1.93934 10.8107C1.65804 10.5294 1.5 10.1478 1.5 9.75V3C1.5 2.60218 1.65804 2.22064 1.93934 1.93934C2.22064 1.65804 2.60218 1.5 3 1.5H9.75C10.1478 1.5 10.5294 1.65804 10.8107 1.93934C11.092 2.22064 11.25 2.60218 11.25 3V3.75M8.25 6.75H15C15.8284 6.75 16.5 7.42157 16.5 8.25V15C16.5 15.8284 15.8284 16.5 15 16.5H8.25C7.42157 16.5 6.75 15.8284 6.75 15V8.25C6.75 7.42157 7.42157 6.75 8.25 6.75Z\"\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_730_76157\">\r\n <rect width=\"18\" height=\"18\" fill=\"white\" />\r\n </clipPath>\r\n </defs>\r\n </svg></span>Duplicates</h3>\r\n \r\n \r\n <div *ngFor=\"let original of source.duplicateImages\" class=\"mb-4\">\r\n <div *ngIf=\"source?.duplicateImages?.length\" class=\"duplicate-head my-3\">Original image</div>\r\n <div class=\"row\">\r\n <div class=\"col-md-3 relative\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3\">\r\n \r\n <img [src]=\"imageUrl + original.filePath\" alt=\"\" class=\"w-100 rounded border\" />\r\n <div class=\"desc-title ms-2 mt-2\">Temp ID: {{ original.tempId }}</div>\r\n <div class=\"desc-value ms-2\">Entry Time: {{ getFormattedEntryTime(original?.entryTime) }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <div class=\"duplicate-head text-lg my-3\">Duplicates<span class=\"badge ms-2\" \r\n [ngClass]=\"{\r\n 'badge-light-primary': source?.duplicateStatus === 'pending',\r\n 'badge-light-success': source?.duplicateStatus === 'approved',\r\n 'badge-light-danger': source?.duplicateStatus === 'rejected'\r\n }\">{{source?.duplicateStatus | titlecase}}</span></div>\r\n <div class=\"row\">\r\n <div class=\"col-md-3 position-relative\" *ngFor=\"let img of original.data\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3 position-relative\">\r\n <input *ngIf=\"source?.duplicateStatus ==='pending'\"\r\n type=\"checkbox\"\r\n [(ngModel)]=\"img.selected\"\r\n class=\"position-absolute absolute form-check-input\"\r\n(change)=\"onImageCheckboxChange(img, 'duplicate', original)\"\r\n />\r\n <img [src]=\"imageUrl + img.filePath\" alt=\"\" class=\"w-100 mb-2 rounded border\" />\r\n <div class=\"desc-title ms-2 mt-2\">Temp ID: {{ img.tempId }}</div>\r\n <div class=\"desc-value ms-2\">Entry Time: {{ getFormattedEntryTime(img?.entryTime) }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n \r\n <div *ngIf=\"source?.duplicateImages?.length\" class=\"my-7 d-flex justify-content-end\" role=\"group\">\r\n <button [disabled]=\"!duplicateACCount\" class=\"btn btn-outline me-1\" (click)=\"popupOpen('rejected','duplicate')\" >Reject</button>\r\n <button [disabled]=\"!duplicateACCount\" class=\"btn btn-primary ms-1\" (click)=\"popupOpen('approved','duplicate')\">Approve</button>\r\n </div>\r\n \r\n <div *ngIf=\"source?.employee?.length\" class=\"duplicate-head text-lg my-3\"><span class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"18\" height=\"16\" viewBox=\"0 0 18 16\" fill=\"none\">\r\n<path d=\"M12.75 14.75V13.25C12.75 12.4544 12.4339 11.6913 11.8713 11.1287C11.3087 10.5661 10.5456 10.25 9.75 10.25H3.75C2.95435 10.25 2.19129 10.5661 1.62868 11.1287C1.06607 11.6913 0.75 12.4544 0.75 13.25V14.75M17.25 14.75V13.25C17.2495 12.5853 17.0283 11.9396 16.621 11.4142C16.2138 10.8889 15.6436 10.5137 15 10.3475M12 1.3475C12.6453 1.51273 13.2173 1.88803 13.6257 2.41423C14.0342 2.94044 14.2559 3.58762 14.2559 4.25375C14.2559 4.91988 14.0342 5.56706 13.6257 6.09327C13.2173 6.61947 12.6453 6.99477 12 7.16M9.75 4.25C9.75 5.90685 8.40685 7.25 6.75 7.25C5.09315 7.25 3.75 5.90685 3.75 4.25C3.75 2.59315 5.09315 1.25 6.75 1.25C8.40685 1.25 9.75 2.59315 9.75 4.25Z\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg></span>Employee/Staff <span class=\"badge ms-2\" \r\n [ngClass]=\"{\r\n 'badge-light-primary': source?.employeeStatus === 'pending',\r\n 'badge-light-success': source?.employeeStatus === 'approved',\r\n 'badge-light-danger': source?.employeeStatus === 'rejected'\r\n }\">{{source?.employeeStatus | titlecase}}</span></div>\r\n <div class=\"row\">\r\n <div class=\"col-md-3 position-relative\" *ngFor=\"let img of source.employee\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3 position-relative\">\r\n \r\n <!-- Top-right Checkbox -->\r\n <input *ngIf=\"source?.employeeStatus ==='pending'\" type=\"checkbox\" [(ngModel)]=\"img.selected\"\r\n class=\"position-absolute absolute form-check-input\"\r\n (change)=\"onImageCheckboxChange(img, 'employee')\" />\r\n \r\n \r\n <!-- Image -->\r\n <img [src]=\"imageUrl + img.filePath\" alt=\"\" class=\"w-100 mb-2 rounded border\" />\r\n \r\n <!-- Details -->\r\n <div class=\"desc-title ms-2 mt-2\">Temp ID: {{img.tempId}}</div>\r\n <div class=\"desc-value ms-2\">Entry Time: {{getFormattedEntryTime(img?.entryTime)}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <div *ngIf=\"source?.employee?.length\" class=\"my-7 d-flex justify-content-end\" role=\"group\">\r\n <button [disabled]=\"!employeeACCount\" class=\"btn btn-outline me-1\" (click)=\"popupOpen('rejected','employee')\" >Reject</button>\r\n <button [disabled]=\"!employeeACCount\" class=\"btn btn-primary ms-1\" (click)=\"popupOpen('approved','employee')\">Approve</button>\r\n </div>\r\n \r\n \r\n <div *ngIf=\"source?.houseKeeping?.length\" class=\"duplicate-head text-lg my-3\"><span class=\"me-2\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n<path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M7.51995 0.613065C8.33739 -0.204355 9.66267 -0.204355 10.4801 0.613065L17.387 7.51995C18.2043 8.33739 18.2043 9.66267 17.387 10.4801L10.4801 17.387C9.66267 18.2043 8.33739 18.2043 7.51995 17.387L5.54626 15.4133L3.73708 17.2224C2.91966 18.0399 1.59436 18.0399 0.776944 17.2224C-0.0404767 16.4051 -0.0404767 15.0797 0.776944 14.2624L2.58612 12.4531L0.613065 10.4801C-0.204355 9.66267 -0.204355 8.33739 0.613065 7.51995L7.51995 0.613065ZM9.49336 1.59978C9.22088 1.32731 8.77909 1.32731 8.50661 1.59978L3.57286 6.53357L11.4665 14.4272L16.4002 9.49336C16.6727 9.22088 16.6727 8.77909 16.4002 8.5067L12.9465 5.05286L11.7952 6.20403C11.5228 6.4765 11.0811 6.4765 10.8086 6.20403C10.5361 5.93155 10.5361 5.48978 10.8086 5.21731L11.9597 4.06614L10.9732 3.07964L8.17757 5.87533C7.90509 6.1478 7.46329 6.1478 7.19081 5.87533C6.91833 5.60286 6.91833 5.16109 7.19081 4.88862L9.9865 2.09293L9.49336 1.59978ZM10.4797 15.4139L2.58615 7.52028L1.59978 8.5067C1.3273 8.77909 1.3273 9.22088 1.59978 9.49336L8.50661 16.4002C8.77909 16.6727 9.22088 16.6727 9.49336 16.4002L10.4797 15.4139ZM3.57275 13.4399L1.76366 15.249C1.49119 15.5215 1.49119 15.9633 1.76366 16.2358C2.03613 16.5082 2.4779 16.5082 2.75037 16.2358L4.55946 14.4266L3.57275 13.4399Z\" fill=\"#475467\"/>\r\n</svg></span> House Keeping <span class=\"badge ms-2\" \r\n [ngClass]=\"{\r\n 'badge-light-primary': source?.houseKeepingStatus === 'pending',\r\n 'badge-light-success': source?.houseKeepingStatus === 'approved',\r\n 'badge-light-danger': source?.houseKeepingStatus === 'rejected'\r\n }\">{{source?.houseKeepingStatus | titlecase}}</span></div>\r\n <div class=\"row\">\r\n <div class=\"col-md-3 position-relative\" *ngFor=\"let img of source.houseKeeping\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3 position-relative\">\r\n \r\n <!-- Top-right Checkbox -->\r\n <input *ngIf=\"source?.houseKeepingStatus ==='pending'\" type=\"checkbox\" [(ngModel)]=\"img.selected\" \r\n class=\"position-absolute absolute form-check-input\"\r\n (change)=\"onImageCheckboxChange(img, 'housekeeping')\" />\r\n \r\n \r\n <!-- Image -->\r\n <img [src]=\"imageUrl + img.filePath\" alt=\"\" class=\"w-100 mb-2 rounded border\" />\r\n \r\n <!-- Details -->\r\n <div class=\"desc-title ms-2 mt-2\">Temp ID: {{img.tempId}}</div>\r\n <div class=\"desc-value ms-2\">Entry Time: {{getFormattedEntryTime(img?.entryTime)}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <div *ngIf=\"source?.houseKeeping?.length\" class=\"my-7 d-flex justify-content-end\" role=\"group\">\r\n <button [disabled]=\"!houseKeepingACCount\" class=\"btn btn-outline me-1\" (click)=\"popupOpen('rejected','housekeeping')\" >Reject</button>\r\n <button [disabled]=\"!houseKeepingACCount\" class=\"btn btn-primary ms-1\" (click)=\"popupOpen('approved','housekeeping')\">Approve</button>\r\n </div>\r\n </div>\r\n \r\n </ng-container>\r\n <div *ngIf=\"!footfallLoading && !footfallNoData\" class=\"my-3\">\r\n <lib-pagination [itemsPerPage]=\"pageSizeFootfall\" [currentPage]=\"footfallcurrentPage\" [totalItems]=\"totalItemsFootfall\"\r\n [paginationSizes]=\"paginationSizes\" [pageSize]=\"setFootfallpageSize()\" (pageChange)=\"onFootfallPageChange($event)\"\r\n (pageSizeChange)=\"onFootfallPageSizeChange($event)\"></lib-pagination>\r\n </div>\r\n \r\n </div>\r\n \r\n </section>\r\n <div *ngIf=\"footfallLoading\" 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=\"footfallNoData\" class=\"row\">\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 class=\"my-5\" xmlns=\"http://www.w3.org/2000/svg\" width=\"94\" height=\"94\" viewBox=\"0 0 94 94\" fill=\"none\">\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\" stroke-width=\"13.3333\" />\r\n <g clip-path=\"url(#clip0_730_75095)\">\r\n <path\r\n d=\"M55.3327 62V58.6667C55.3327 56.8986 54.6303 55.2029 53.3801 53.9526C52.1298 52.7024 50.4341 52 48.666 52H35.3327C33.5646 52 31.8689 52.7024 30.6186 53.9526C29.3684 55.2029 28.666 56.8986 28.666 58.6667V62M65.3327 62V58.6667C65.3316 57.1895 64.8399 55.7546 63.935 54.5872C63.03 53.4198 61.7629 52.5859 60.3327 52.2167M53.666 32.2167C55.1 32.5838 56.3711 33.4178 57.2787 34.5872C58.1864 35.7565 58.6791 37.1947 58.6791 38.675C58.6791 40.1553 58.1864 41.5935 57.2787 42.7628C56.3711 43.9322 55.1 44.7662 53.666 45.1333M48.666 38.6667C48.666 42.3486 45.6812 45.3333 41.9993 45.3333C38.3174 45.3333 35.3327 42.3486 35.3327 38.6667C35.3327 34.9848 38.3174 32 41.9993 32C45.6812 32 48.666 34.9848 48.666 38.6667Z\"\r\n stroke=\"#00A3FF\" stroke-width=\"4\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_730_75095\">\r\n <rect width=\"40\" height=\"40\" fill=\"white\" transform=\"translate(27 27)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n <div class=\"nodata-title my-3\">No pending items</div>\r\n <div class=\"nodata-sub mb-3\">Looks like there is no action item required for <span\r\n *ngIf=\"selectedRevopsType?.value==='duplicateImages'\">duplicates</span><span\r\n *ngIf=\"selectedRevopsType?.value==='employee'\">employee/staff</span> <span\r\n *ngIf=\"selectedRevopsType?.value==='houseKeeping'\">houseKeeping</span>\r\n <span\r\n *ngIf=\"!selectedRevopsType?.value\">items</span></div>\r\n </div>\r\n </div>\r\n </div>\r\n <!-- Card Body -->\r\n <div *ngIf=\"selectedRevopsType?.value !== ''\" class=\"card-body mt-3 py-0\">\r\n <span class=\"cursor-pointer\" *ngIf=\"isCollapsed\" (click)=\"toggleSidebar()\" style=\"position: absolute; top: 15px; left: 0;\">\r\n <svg class=\"mt-2 ms-2\" xmlns=\"http://www.w3.org/2000/svg\" width=\"32\" height=\"32\" viewBox=\"0 0 24 24\"\r\n fill=\"none\">\r\n <path\r\n d=\"M9.72714 12.6365L13.3635 9.00013L9.72714 5.36377M4.63623 12.6365L8.27259 9.00013L4.63623 5.36377\"\r\n stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <ng-container *ngFor=\"let ticket of footfallTicketsData\">\r\n <div *ngIf=\"ticket?._source as source\" class=\"my-4\">\r\n <div *ngFor=\"let original of source.duplicateImages\" class=\"mb-4\">\r\n <div *ngIf=\"source?.duplicateImages?.length\" class=\"duplicate-head my-2\">Original image</div>\r\n <div class=\"row\">\r\n <!-- \u2705 Original Image -->\r\n <div class=\"col-md-3 relative\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3\">\r\n \r\n <img [src]=\"imageUrl + original.filePath\" alt=\"\" class=\"w-100 rounded border\" />\r\n <div class=\"desc-title ms-2 mt-2\">{{source.storeName}}</div>\r\n <div class=\"desc-value ms-2\">Footfall date : {{source.dateString | date:'dd/MM/yyyy'}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <!-- \uD83D\uDFE8 Duplicate Images (for this original) -->\r\n <div class=\"duplicate-head my-3\">Duplicates <span class=\"badge ms-2\" \r\n [ngClass]=\"{\r\n 'badge-light-primary': source?.duplicateStatus === 'pending',\r\n 'badge-light-success': source?.duplicateStatus === 'approved',\r\n 'badge-light-danger': source?.duplicateStatus === 'rejected'\r\n }\">{{source?.duplicateStatus | titlecase}}</span></div>\r\n <div class=\"row\">\r\n <div class=\"col-md-3 position-relative\" *ngFor=\"let img of original.data\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3 position-relative\">\r\n <input *ngIf=\"source?.duplicateStatus ==='pending'\" type=\"checkbox\" [(ngModel)]=\"img.selected\"\r\n class=\"position-absolute absolute form-check-input\"\r\n (change)=\"onImageCheckboxChange1(img, 'duplicate')\" />\r\n <img [src]=\"imageUrl + img.filePath\" alt=\"\" class=\"w-100 mb-2 rounded border\" />\r\n <div class=\"desc-title ms-2 mt-2\">{{source.storeName}}</div>\r\n <div class=\"desc-value ms-2\">Footfall date : {{source.dateString | date:'dd/MM/yyyy'}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"source?.employee?.length\" class=\"row\">\r\n <div class=\"col-md-3 position-relative\" *ngFor=\"let img of source.employee\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3 position-relative\">\r\n \r\n <!-- Top-right Checkbox -->\r\n <input *ngIf=\"source?.employeeStatus ==='pending'\" type=\"checkbox\" [(ngModel)]=\"img.selected\"\r\n class=\"position-absolute absolute form-check-input\"\r\n (change)=\"onImageCheckboxChange1(img, 'employee')\" />\r\n \r\n \r\n <!-- Image -->\r\n <img [src]=\"imageUrl + img.filePath\" alt=\"\" class=\"w-100 mb-2 rounded border\" />\r\n \r\n <!-- Details -->\r\n <div class=\"desc-title ms-2 mt-2\">{{source.storeName}}</div>\r\n <div class=\"desc-value ms-2\">Footfall date : {{source.dateString | date:'dd/MM/yyyy'}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"source?.houseKeeping?.length\" class=\"row\">\r\n <div class=\"col-md-3 position-relative\" *ngFor=\"let img of source.houseKeeping\">\r\n <div class=\"pb-3 img-border border border-1 h-100 rounded-3 position-relative\">\r\n \r\n <!-- Top-right Checkbox -->\r\n <input *ngIf=\"source?.houseKeepingStatus ==='pending'\" type=\"checkbox\" [(ngModel)]=\"img.selected\"\r\n class=\"position-absolute absolute form-check-input\"\r\n (change)=\"onImageCheckboxChange1(img, 'housekeeping')\" />\r\n \r\n \r\n <!-- Image -->\r\n <img [src]=\"imageUrl + img.filePath\" alt=\"\" class=\"w-100 mb-2 rounded border\" />\r\n \r\n <!-- Details -->\r\n <div class=\"desc-title ms-2 mt-2\">{{source.storeName}}</div>\r\n <div class=\"desc-value ms-2\">Footfall date : {{source.dateString | date:'dd/MM/yyyy'}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <!-- <div *ngIf=\"!footfallLoading && !footfallNoData\" class=\"my-3\">\r\n <lib-pagination [itemsPerPage]=\"pageSizeFootfall\" [currentPage]=\"footfallcurrentPage\"\r\n [totalItems]=\"totalItemsFootfall\" [paginationSizes]=\"paginationSizes\" [pageSize]=\"setFootfallpageSize()\"\r\n (pageChange)=\"onFootfallPageChange($event)\"\r\n (pageSizeChange)=\"onFootfallPageSizeChange($event)\"></lib-pagination>\r\n </div> -->\r\n </div>\r\n </div>\r\n \r\n </div>\r\n</div>\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 \r\n <!-- Heading -->\r\n <h5 class=\"modal-title mb-2\">\r\n {{ popupType === 'approved' ? 'Approve' : 'Reject' }} Selected Images\r\n </h5>\r\n\r\n <!-- Description -->\r\n <p class=\"mb-3\">\r\n You're about to {{ popupType === 'approved' ? 'approve' : 'reject' }} the following number of selected images.\r\n </p>\r\n\r\n <!-- Count Box -->\r\n <div class=\"border border-1 rounded p-3 w-50 mb-4\">\r\n <div *ngIf=\"popupvalue === 'employee'\" class=\"fw-semibold fs-5 mb-2\">\r\n {{ employeeACCount || '--' }}\r\n </div>\r\n <div *ngIf=\"popupvalue === 'housekeeping'\" class=\"fw-semibold fs-5 mb-2\">\r\n {{ houseKeepingACCount || '--' }}\r\n </div>\r\n <div *ngIf=\"popupvalue === 'duplicate'\" class=\"fw-semibold fs-5 mb-2\">\r\n {{ duplicateACCount || '--' }}\r\n </div>\r\n <div class=\"fw-semibold text-muted fs-6 mt-2\">\r\n {{ popupvalue | titlecase }}s\r\n </div>\r\n </div>\r\n\r\n <!-- Action Buttons -->\r\n <div class=\"w-100 d-flex justify-content-end\">\r\n <button class=\"btn btn-outline me-2\" (click)=\"cancel()\">Cancel</button>\r\n <button class=\"btn btn-primary\" (click)=\"submitValue(popupType, popupvalue)\">\r\n {{ popupType === 'approved' ? 'Approve' : 'Reject' }}\r\n </button>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n", styles: [".card-header,.header{color:var(--Gray-900, #101828);font-size:20px!important;font-style:normal;font-weight:700;line-height:30px}.sub-header{color:var(--Gray-700, #344054);font-size:14px!important;font-style:normal;font-weight:600;line-height:20px}.ellipse1{border-radius:6px;border-bottom:2px solid var(--Gray-200, #EAECF0);background:radial-gradient(206.89% 107.47% at 16.16% 32.77%,#fff6,#45bbfe33),#f2f4f7;box-shadow:0 4px 10px #0000000d}.card-title-foot{color:var(--Gray-800, #1D2939)!important;font-size:18px;font-weight:600;line-height:28px}.card-title-label{color:var(--Gray-800, #1D2939)!important;font-size:16px;font-weight:600;line-height:28px}.card-title-value{color:var(--Gray-800, #1D2939)!important;font-size:16px;font-weight:400;line-height:28px}input[type=checkbox]{width:16px!important;height:16px!important;margin:7px 5px -2px;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}.rotate{rotate:180deg;transition:1s}.border-selectall{border-radius:6px!important;border-bottom:1px solid var(--Gray-200, #EAECF0)!important;background:var(--White, #FFF)!important;padding:8px 2px}.border-selectall1{border-radius:6px!important;background:var(--White, #FFF)!important;padding:8px 2px}.border-totalfootfall{border-radius:12px;padding:4px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF)}.vl{border-left:2px solid #000;height:50px}.duplicate-head{color:var(--Gray-700, #344054);font-size:16px;font-weight:600;line-height:20px}.img-border{border-radius:5px!important;border:2px solid var(--Gray-300, #D0D5DD)}.desc-title{color:var(--Gray-900, #101828);font-size:12px;font-weight:500;line-height:20px}.desc-value{color:var(--Gray-900, #475467);font-size:10px;font-weight:500;line-height:20px}.img-border{overflow:hidden;position:relative}.btn-resize{font-size:13px!important;height:29px!important;line-height:11px!important;padding:1px!important}.absolute{top:5px;right:5px;z-index:2}.img-src{width:25%;height:20%}.backButtonright{border-radius:1000px!important;background:var(--text-primary, #FFF)!important;padding:12px!important;box-shadow:0 12px 16px -4px #10182814,0 4px 6px -2px #10182808!important;box-shadow:0 8.727px 11.636px -2.909px #10182814,0 2.909px 4.364px -1.455px #10182808!important;position:absolute;top:30px;right:-10px;z-index:0}.backButtonleft{border-radius:1000px!important;background:#fff;padding:14px!important;border:var(--Gray-300, #D0D5DD);box-shadow:0 8.727px 11.636px -2.909px #10182814,0 2.909px 4.364px -1.455px #10182808;position:absolute;top:30px;left:-20px;z-index:5}.select-wrapper{position:relative;display:inline-block;width:100%}.placeholder-overlay{position:absolute;color:var(--Gray-500, #667085);font-family:Inter;font-size:16px!important;font-style:normal;font-weight:400;top:10px;left:15px;pointer-events:none;font-size:1.1rem;z-index:1}.card-title{color:var(--Black, #101828)!important;font-size:20px!important;font-weight:700!important;line-height:30px}.card-title-sub-header{color:var(--Black, #101828);font-size:14px;font-weight:500;line-height:30px}\n"] }]
|
|
2718
|
-
}], ctorParameters: () => [{ type: i1$1.GlobalStateService }, { type: TicketService }, { type: i0.ChangeDetectorRef }, { type: i4.ToastService }, { type: i1$2.NgbModal }, { type: ExcelService }, { type: i6.FormBuilder }], propDecorators: { zoomPopup: [{
|
|
2719
|
-
type: ViewChild,
|
|
2720
|
-
args: ['zoomPopup']
|
|
2721
|
-
}] } });
|
|
2722
|
-
|
|
2723
|
-
class TangoManageTicketsComponent {
|
|
2724
|
-
pageInfo;
|
|
2725
|
-
route;
|
|
2726
|
-
router;
|
|
2727
|
-
gs;
|
|
2728
|
-
service;
|
|
2729
|
-
SelectedTab = 'installation';
|
|
2730
|
-
destroy$ = new Subject();
|
|
2731
|
-
headerFilters;
|
|
2732
|
-
ticketAllCount;
|
|
2733
|
-
users;
|
|
2734
|
-
constructor(pageInfo, route, router, gs, service) {
|
|
2735
|
-
this.pageInfo = pageInfo;
|
|
2736
|
-
this.route = route;
|
|
2737
|
-
this.router = router;
|
|
2738
|
-
this.gs = gs;
|
|
2739
|
-
this.service = service;
|
|
2740
|
-
}
|
|
2741
|
-
ngOnInit() {
|
|
2742
|
-
const userData = JSON.parse(localStorage.getItem("user-info") || "{}");
|
|
2743
|
-
this.users = userData;
|
|
2744
|
-
this.route?.queryParams?.pipe(takeUntil(this.destroy$)).subscribe(params => {
|
|
2745
|
-
if (params.hasOwnProperty('type')) {
|
|
2746
|
-
const type = params['type'];
|
|
2747
|
-
this.Selectedtabs(type);
|
|
2748
|
-
}
|
|
2749
|
-
else {
|
|
2750
|
-
this.updateStoreIdQueryParam();
|
|
2751
|
-
}
|
|
2752
|
-
});
|
|
2753
|
-
this.onLoad();
|
|
2754
|
-
this.setPageData();
|
|
2755
|
-
}
|
|
2756
|
-
updateStoreIdQueryParam() {
|
|
2757
|
-
const queryParams = { ...this.route?.snapshot?.queryParams };
|
|
2758
|
-
// Update storeId in queryParams
|
|
2759
|
-
queryParams.type = this.SelectedTab.toLocaleLowerCase();
|
|
2760
|
-
// Navigate to the same route with updated queryParams
|
|
2761
|
-
this.router.navigate([], { queryParams: queryParams, queryParamsHandling: 'merge' });
|
|
2762
|
-
}
|
|
2763
|
-
setPageData() {
|
|
2764
|
-
this.pageInfo.setTitle('Tickets');
|
|
2765
|
-
this.pageInfo.setDescription('Summary of queries raised,addresed & resolved');
|
|
2766
|
-
let breadcrumbs = [];
|
|
2767
|
-
if (this.gs.userAccess.value?.userType === "tango") {
|
|
2768
|
-
breadcrumbs = [
|
|
2769
|
-
{
|
|
2770
|
-
title: "Manage",
|
|
2771
|
-
path: "/manage/brands",
|
|
2772
|
-
isActive: false,
|
|
2773
|
-
isSeparator: false,
|
|
2774
|
-
},
|
|
2775
|
-
{
|
|
2776
|
-
title: "Manage",
|
|
2777
|
-
path: "/manage/brands",
|
|
2778
|
-
isActive: false,
|
|
2779
|
-
isSeparator: true,
|
|
2780
|
-
},
|
|
2781
|
-
];
|
|
2782
|
-
}
|
|
2783
|
-
else if (this.gs.userAccess.value?.userType === "client") {
|
|
2784
|
-
breadcrumbs = [
|
|
2785
|
-
{
|
|
2786
|
-
title: "Manage",
|
|
2787
|
-
path: "/manage/summary",
|
|
2788
|
-
isActive: false,
|
|
2789
|
-
isSeparator: false,
|
|
2790
|
-
},
|
|
2791
|
-
{
|
|
2792
|
-
title: "Manage",
|
|
2793
|
-
path: "/manage/summary",
|
|
2794
|
-
isActive: false,
|
|
2795
|
-
isSeparator: true,
|
|
2796
|
-
},
|
|
2797
|
-
];
|
|
2798
|
-
}
|
|
2799
|
-
this.pageInfo.setBreadcrumbs(breadcrumbs);
|
|
2800
|
-
}
|
|
2801
|
-
Selectedtabs(value) {
|
|
2802
|
-
this.SelectedTab = value;
|
|
2803
|
-
}
|
|
2804
|
-
ngOnDestroy() {
|
|
2805
|
-
this.destroy$.next(true);
|
|
2806
|
-
this.destroy$.complete();
|
|
2807
|
-
}
|
|
2808
|
-
onLoad() {
|
|
2809
|
-
this.gs.dataRangeValue?.pipe(takeUntil(this.destroy$))?.subscribe({
|
|
2810
|
-
next: (data) => {
|
|
2811
|
-
if (data) {
|
|
2812
|
-
this.headerFilters = data;
|
|
2813
|
-
this.getAllCount();
|
|
2814
|
-
}
|
|
2815
|
-
}
|
|
2816
|
-
});
|
|
2817
|
-
}
|
|
2818
|
-
getAllCount() {
|
|
2819
|
-
let obj = {
|
|
2820
|
-
clientId: this.headerFilters?.clients,
|
|
2821
|
-
fromDate: this.headerFilters?.date?.startDate,
|
|
2822
|
-
toDate: this.headerFilters?.date?.endDate
|
|
2823
|
-
};
|
|
2824
|
-
this.service.getAllCounts(obj)?.pipe(takeUntil(this.destroy$))?.subscribe({
|
|
2825
|
-
next: (res) => {
|
|
2826
|
-
if (res.code === 200) {
|
|
2827
|
-
this.ticketAllCount = res?.data[0];
|
|
2828
|
-
}
|
|
2829
|
-
}
|
|
2830
|
-
});
|
|
2831
|
-
}
|
|
2832
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TangoManageTicketsComponent, deps: [{ token: i1$1.PageInfoService }, { token: i2.ActivatedRoute }, { token: i2.Router }, { token: i1$1.GlobalStateService }, { token: TicketService }], target: i0.ɵɵFactoryTarget.Component });
|
|
2833
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TangoManageTicketsComponent, selector: "lib-tango-manage-tickets", ngImport: i0, template: "<div class=\"card mb-5 py-3 px-5\">\r\n <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\r\n <li class=\"nav-item\">\r\n <a [routerLink]=\"['/manage/tickets']\" [queryParams]=\"{ type: 'installation' }\" (click)=\"Selectedtabs('installation')\"\r\n [ngClass]=\"SelectedTab === 'installation' ? 'active' : ''\" class=\"nav-link cursor-pointer no-border me-3\">\r\n Installation<span class=\"mx-2 \" [ngClass]=\"SelectedTab ==='installation' ? 'badge-num-primary' :'badge-num-muted'\">{{ticketAllCount?.installationCount?ticketAllCount?.installationCount:0}}</span>\r\n </a>\r\n </li>\r\n <li class=\"nav-item\" >\r\n <a [routerLink]=\"['/manage/tickets']\" [queryParams]=\"{ type: 'infra' }\" (click)=\"Selectedtabs('infra')\"\r\n [ngClass]=\"SelectedTab === 'infra' ? 'active' : ''\" class=\"nav-link cursor-pointer no-border me-3\">\r\n Infra<span class=\"mx-2\" [ngClass]=\"SelectedTab ==='infra' ? 'badge-num-primary' :'badge-num-muted'\">{{ticketAllCount?.infraCount?ticketAllCount?.infraCount:0}}</span>\r\n </a>\r\n </li> \r\n <li class=\"nav-item\" [routerLink]=\"['/manage/tickets']\" [queryParams]=\"{ type: 'dataMismatch' }\" (click)=\"Selectedtabs('dataMismatch')\">\r\n <a [ngClass]=\"SelectedTab ==='dataMismatch' ? 'active' :''\" class=\"nav-link cursor-pointer me-3\">Data Mismatch\r\n <span class=\"mx-2\" [ngClass]=\"SelectedTab ==='dataMismatch' ? 'badge-num-primary' :'badge-num-muted'\">{{ticketAllCount?.datamismatchCount? ticketAllCount?.datamismatchCount:0}}</span></a>\r\n </li>\r\n <!-- <li *ngIf=\"this.users.userType ==='tango'\" class=\"nav-item\" [routerLink]=\"['/manage/tickets']\" [queryParams]=\"{ type: 'audit' }\" (click)=\"Selectedtabs('audit')\"><a [ngClass]=\"SelectedTab ==='audit' ? 'active' :''\"\r\n class=\"nav-link cursor-pointer no-border me-3\">Audit</a>\r\n </li> -->\r\n <li *ngIf=\"this.users.userType ==='tango'\" class=\"nav-item\" (click)=\"Selectedtabs('mat')\"><a [routerLink]=\"['/manage/tickets']\" [queryParams]=\"{ type: 'mat' }\" [ngClass]=\"SelectedTab ==='mat' ? 'active' :''\"\r\n class=\"nav-link cursor-pointer no-border me-3\">Employee Mat\r\n <span class=\"mx-2 \" [ngClass]=\"SelectedTab ==='mat' ? 'badge-num-primary' :'badge-num-muted'\">{{ticketAllCount?.matCount ?ticketAllCount?.matCount:0}}</span></a>\r\n </li>\r\n<li *ngIf=\"(gs.userAccess | async)?.userType === 'tango' || headerFilters?.client ==='11'\" class=\"nav-item\" (click)=\"Selectedtabs('footfall')\"><a [routerLink]=\"['/manage/tickets']\" [queryParams]=\"{ type: 'footfall' }\" [ngClass]=\"SelectedTab ==='footfall' ? 'active' :''\"\r\n class=\"nav-link cursor-pointer no-border me-3\">Footfall Directory\r\n </a>\r\n <!-- <span class=\"mx-2 \" [ngClass]=\"SelectedTab ==='footfall' ? 'badge-num-primary' :'badge-num-muted'\">{{ticketAllCount?.matCount ?ticketAllCount?.matCount:0}}</span> -->\r\n </li>\r\n \r\n </ul>\r\n</div>\r\n<lib-footfall-dic *ngIf=\"SelectedTab ==='footfall'\"></lib-footfall-dic>\r\n<lib-tickets *ngIf=\"SelectedTab !=='audit' && SelectedTab !=='footfall'\"></lib-tickets>\r\n<lib-audit-metrics *ngIf=\"SelectedTab ==='audit'\"></lib-audit-metrics>\r\n<router-outlet></router-outlet>", styles: [".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-style:normal;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-style:normal;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}\n"], dependencies: [{ kind: "directive", type: i6$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: TicketsComponent, selector: "lib-tickets" }, { kind: "component", type: AuditMetricsComponent, selector: "lib-audit-metrics" }, { kind: "component", type: FootfallDicComponent, selector: "lib-footfall-dic" }, { kind: "pipe", type: i6$1.AsyncPipe, name: "async" }] });
|
|
2834
|
-
}
|
|
2835
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TangoManageTicketsComponent, decorators: [{
|
|
2836
|
-
type: Component,
|
|
2837
|
-
args: [{ selector: 'lib-tango-manage-tickets', template: "<div class=\"card mb-5 py-3 px-5\">\r\n <ul class=\"nav nav-stretch nav-line-tabs1 nav-line-tabs border-transparent flex-nowrap\">\r\n <li class=\"nav-item\">\r\n <a [routerLink]=\"['/manage/tickets']\" [queryParams]=\"{ type: 'installation' }\" (click)=\"Selectedtabs('installation')\"\r\n [ngClass]=\"SelectedTab === 'installation' ? 'active' : ''\" class=\"nav-link cursor-pointer no-border me-3\">\r\n Installation<span class=\"mx-2 \" [ngClass]=\"SelectedTab ==='installation' ? 'badge-num-primary' :'badge-num-muted'\">{{ticketAllCount?.installationCount?ticketAllCount?.installationCount:0}}</span>\r\n </a>\r\n </li>\r\n <li class=\"nav-item\" >\r\n <a [routerLink]=\"['/manage/tickets']\" [queryParams]=\"{ type: 'infra' }\" (click)=\"Selectedtabs('infra')\"\r\n [ngClass]=\"SelectedTab === 'infra' ? 'active' : ''\" class=\"nav-link cursor-pointer no-border me-3\">\r\n Infra<span class=\"mx-2\" [ngClass]=\"SelectedTab ==='infra' ? 'badge-num-primary' :'badge-num-muted'\">{{ticketAllCount?.infraCount?ticketAllCount?.infraCount:0}}</span>\r\n </a>\r\n </li> \r\n <li class=\"nav-item\" [routerLink]=\"['/manage/tickets']\" [queryParams]=\"{ type: 'dataMismatch' }\" (click)=\"Selectedtabs('dataMismatch')\">\r\n <a [ngClass]=\"SelectedTab ==='dataMismatch' ? 'active' :''\" class=\"nav-link cursor-pointer me-3\">Data Mismatch\r\n <span class=\"mx-2\" [ngClass]=\"SelectedTab ==='dataMismatch' ? 'badge-num-primary' :'badge-num-muted'\">{{ticketAllCount?.datamismatchCount? ticketAllCount?.datamismatchCount:0}}</span></a>\r\n </li>\r\n <!-- <li *ngIf=\"this.users.userType ==='tango'\" class=\"nav-item\" [routerLink]=\"['/manage/tickets']\" [queryParams]=\"{ type: 'audit' }\" (click)=\"Selectedtabs('audit')\"><a [ngClass]=\"SelectedTab ==='audit' ? 'active' :''\"\r\n class=\"nav-link cursor-pointer no-border me-3\">Audit</a>\r\n </li> -->\r\n <li *ngIf=\"this.users.userType ==='tango'\" class=\"nav-item\" (click)=\"Selectedtabs('mat')\"><a [routerLink]=\"['/manage/tickets']\" [queryParams]=\"{ type: 'mat' }\" [ngClass]=\"SelectedTab ==='mat' ? 'active' :''\"\r\n class=\"nav-link cursor-pointer no-border me-3\">Employee Mat\r\n <span class=\"mx-2 \" [ngClass]=\"SelectedTab ==='mat' ? 'badge-num-primary' :'badge-num-muted'\">{{ticketAllCount?.matCount ?ticketAllCount?.matCount:0}}</span></a>\r\n </li>\r\n<li *ngIf=\"(gs.userAccess | async)?.userType === 'tango' || headerFilters?.client ==='11'\" class=\"nav-item\" (click)=\"Selectedtabs('footfall')\"><a [routerLink]=\"['/manage/tickets']\" [queryParams]=\"{ type: 'footfall' }\" [ngClass]=\"SelectedTab ==='footfall' ? 'active' :''\"\r\n class=\"nav-link cursor-pointer no-border me-3\">Footfall Directory\r\n </a>\r\n <!-- <span class=\"mx-2 \" [ngClass]=\"SelectedTab ==='footfall' ? 'badge-num-primary' :'badge-num-muted'\">{{ticketAllCount?.matCount ?ticketAllCount?.matCount:0}}</span> -->\r\n </li>\r\n \r\n </ul>\r\n</div>\r\n<lib-footfall-dic *ngIf=\"SelectedTab ==='footfall'\"></lib-footfall-dic>\r\n<lib-tickets *ngIf=\"SelectedTab !=='audit' && SelectedTab !=='footfall'\"></lib-tickets>\r\n<lib-audit-metrics *ngIf=\"SelectedTab ==='audit'\"></lib-audit-metrics>\r\n<router-outlet></router-outlet>", styles: [".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-style:normal;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-style:normal;font-weight:500;line-height:20px;padding:2px 10px!important;mix-blend-mode:multiply!important}\n"] }]
|
|
2838
|
-
}], ctorParameters: () => [{ type: i1$1.PageInfoService }, { type: i2.ActivatedRoute }, { type: i2.Router }, { type: i1$1.GlobalStateService }, { type: TicketService }] });
|
|
2839
|
-
|
|
2840
|
-
const routes = [
|
|
2841
|
-
{
|
|
2842
|
-
path: '',
|
|
2843
|
-
component: TangoManageTicketsComponent
|
|
2844
|
-
}
|
|
2845
|
-
];
|
|
2846
|
-
class TangoManageTicketsRoutingModule {
|
|
2847
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TangoManageTicketsRoutingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
2848
|
-
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: TangoManageTicketsRoutingModule, imports: [i2.RouterModule], exports: [RouterModule] });
|
|
2849
|
-
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TangoManageTicketsRoutingModule, imports: [RouterModule.forChild(routes), RouterModule] });
|
|
2850
|
-
}
|
|
2851
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TangoManageTicketsRoutingModule, decorators: [{
|
|
2852
|
-
type: NgModule,
|
|
2853
|
-
args: [{
|
|
2854
|
-
imports: [RouterModule.forChild(routes)],
|
|
2855
|
-
exports: [RouterModule]
|
|
2856
|
-
}]
|
|
2857
|
-
}] });
|
|
2858
|
-
|
|
2859
|
-
class AuditLogComponent {
|
|
2860
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AuditLogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
2861
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AuditLogComponent, selector: "lib-audit-log", ngImport: i0, template: "<p>audit-log works!</p>\r\n", styles: [""] });
|
|
2862
|
-
}
|
|
2863
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AuditLogComponent, decorators: [{
|
|
2864
|
-
type: Component,
|
|
2865
|
-
args: [{ selector: 'lib-audit-log', template: "<p>audit-log works!</p>\r\n" }]
|
|
2866
|
-
}] });
|
|
2867
|
-
|
|
2868
|
-
class TangoManageTicketsModule {
|
|
2869
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TangoManageTicketsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
2870
|
-
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: TangoManageTicketsModule, declarations: [TangoManageTicketsComponent,
|
|
2871
|
-
TicketsComponent, AddCsmModalComponent, CommentModelComponent, AuditMetricsComponent,
|
|
2872
|
-
ReTriggerComponent, AuditLogComponent, CountComponent, FootfallDicComponent,
|
|
2873
|
-
ReactiveSelectComponent,
|
|
2874
|
-
GroupSelectComponent], imports: [CommonModule,
|
|
2875
|
-
TangoManageTicketsRoutingModule,
|
|
2876
|
-
FormsModule,
|
|
2877
|
-
ReactiveFormsModule,
|
|
2878
|
-
CommonSharedModule] });
|
|
2879
|
-
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TangoManageTicketsModule, imports: [CommonModule,
|
|
2880
|
-
TangoManageTicketsRoutingModule,
|
|
2881
|
-
FormsModule,
|
|
2882
|
-
ReactiveFormsModule,
|
|
2883
|
-
CommonSharedModule] });
|
|
2884
|
-
}
|
|
2885
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TangoManageTicketsModule, decorators: [{
|
|
2886
|
-
type: NgModule,
|
|
2887
|
-
args: [{
|
|
2888
|
-
declarations: [
|
|
2889
|
-
TangoManageTicketsComponent,
|
|
2890
|
-
TicketsComponent, AddCsmModalComponent, CommentModelComponent, AuditMetricsComponent,
|
|
2891
|
-
ReTriggerComponent, AuditLogComponent, CountComponent, FootfallDicComponent,
|
|
2892
|
-
ReactiveSelectComponent,
|
|
2893
|
-
GroupSelectComponent,
|
|
2894
|
-
],
|
|
2895
|
-
imports: [
|
|
2896
|
-
CommonModule,
|
|
2897
|
-
TangoManageTicketsRoutingModule,
|
|
2898
|
-
FormsModule,
|
|
2899
|
-
ReactiveFormsModule,
|
|
2900
|
-
CommonSharedModule
|
|
2901
|
-
]
|
|
2902
|
-
}]
|
|
2903
|
-
}] });
|
|
2904
|
-
|
|
2905
|
-
/*
|
|
2906
|
-
* Public API Surface of tango-manage-tickets
|
|
2907
|
-
*/
|
|
2908
|
-
|
|
2909
|
-
/**
|
|
2910
|
-
* Generated bundle index. Do not edit.
|
|
2911
|
-
*/
|
|
2912
|
-
|
|
2913
|
-
export { TangoManageTicketsComponent, TangoManageTicketsModule };
|
|
2914
|
-
//# sourceMappingURL=tango-app-ui-manage-tickets.mjs.map
|