tango-app-ui-analyse-traffic 3.8.0-alpha.6 → 3.8.0-alpha.61
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/add-nob/add-nob.component.mjs +266 -71
- package/esm2022/lib/components/explore-view/explore-view.component.mjs +3 -3
- package/esm2022/lib/components/img-rvps/img-rvps.component.mjs +2221 -281
- package/esm2022/lib/components/nob-upload/nob-upload.component.mjs +187 -54
- package/esm2022/lib/components/traffic-analysis/traffic-analysis.component.mjs +11 -7
- package/esm2022/lib/directive/magnifier.directive.mjs +23 -15
- package/esm2022/lib/services/traffic-rvps.service.mjs +4 -1
- package/esm2022/lib/services/traffic.service.mjs +12 -1
- package/esm2022/lib/tango-analyse-traffic.module.mjs +3 -3
- package/fesm2022/tango-app-ui-analyse-traffic.mjs +2708 -414
- package/fesm2022/tango-app-ui-analyse-traffic.mjs.map +1 -1
- package/lib/components/add-nob/add-nob.component.d.ts +18 -2
- package/lib/components/img-rvps/img-rvps.component.d.ts +169 -30
- package/lib/components/nob-upload/nob-upload.component.d.ts +4 -0
- package/lib/components/traffic-analysis/traffic-analysis.component.d.ts +3 -0
- package/lib/directive/magnifier.directive.d.ts +6 -3
- package/lib/services/traffic-rvps.service.d.ts +1 -0
- package/lib/services/traffic.service.d.ts +4 -0
- package/package.json +1 -1
|
@@ -5,23 +5,27 @@ import { DatePipe } from '@angular/common';
|
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/forms";
|
|
7
7
|
import * as i2 from "../../services/traffic.service";
|
|
8
|
-
import * as i3 from "
|
|
9
|
-
import * as i4 from "
|
|
10
|
-
import * as i5 from "
|
|
11
|
-
import * as i6 from "
|
|
8
|
+
import * as i3 from "../../services/excel.service";
|
|
9
|
+
import * as i4 from "@ng-bootstrap/ng-bootstrap";
|
|
10
|
+
import * as i5 from "tango-app-ui-shared";
|
|
11
|
+
import * as i6 from "@angular/common";
|
|
12
|
+
import * as i7 from "../custom-select/custom-select.component";
|
|
12
13
|
export class AddNobComponent {
|
|
13
14
|
fb;
|
|
14
15
|
service;
|
|
16
|
+
excelService;
|
|
15
17
|
activeModal;
|
|
16
18
|
ts;
|
|
17
19
|
cd;
|
|
18
20
|
datePipe;
|
|
19
21
|
type;
|
|
22
|
+
viewData;
|
|
20
23
|
nobForm;
|
|
21
24
|
destroy$ = new Subject();
|
|
22
|
-
constructor(fb, service, activeModal, ts, cd, datePipe) {
|
|
25
|
+
constructor(fb, service, excelService, activeModal, ts, cd, datePipe) {
|
|
23
26
|
this.fb = fb;
|
|
24
27
|
this.service = service;
|
|
28
|
+
this.excelService = excelService;
|
|
25
29
|
this.activeModal = activeModal;
|
|
26
30
|
this.ts = ts;
|
|
27
31
|
this.cd = cd;
|
|
@@ -33,11 +37,41 @@ export class AddNobComponent {
|
|
|
33
37
|
}
|
|
34
38
|
clientId;
|
|
35
39
|
maxDate = '';
|
|
40
|
+
isEditEnabled = false;
|
|
41
|
+
clientData;
|
|
36
42
|
ngOnInit() {
|
|
37
43
|
let data = JSON.parse(localStorage.getItem("header-filters") || "");
|
|
38
44
|
this.clientId = data.client;
|
|
45
|
+
let client = JSON.parse(localStorage.getItem("client-details") || "");
|
|
46
|
+
this.clientData = client;
|
|
39
47
|
this.getNobStoreList(data.client);
|
|
40
48
|
this.setMaxDate();
|
|
49
|
+
if (this.type === 'editView' || this.type === 'view') {
|
|
50
|
+
this.storeName = this.viewData.storeName;
|
|
51
|
+
this.storeId = this.viewData.storeId;
|
|
52
|
+
this.storeCode = this.viewData.storeCode;
|
|
53
|
+
this.dateValue = this.viewData.nobDate
|
|
54
|
+
? new Date(this.viewData.nobDate).toISOString().split('T')[0]
|
|
55
|
+
: null;
|
|
56
|
+
this.nobCount = this.viewData.nobCount;
|
|
57
|
+
this.zoneList = this.viewData.zonewisenob; // keep values
|
|
58
|
+
if (this.type === 'editView') {
|
|
59
|
+
this.isEditEnabled = true;
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
this.isEditEnabled = false;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
cancelEdit() {
|
|
67
|
+
this.isEditEnabled = false;
|
|
68
|
+
if (this.viewData?.zoneList) {
|
|
69
|
+
this.zoneList = JSON.parse(JSON.stringify(this.viewData.zoneList));
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
this.zoneList = [];
|
|
73
|
+
}
|
|
74
|
+
this.cancel();
|
|
41
75
|
}
|
|
42
76
|
storeList = [];
|
|
43
77
|
getNobStoreList(client) {
|
|
@@ -57,6 +91,7 @@ export class AddNobComponent {
|
|
|
57
91
|
dateValue;
|
|
58
92
|
storeCode;
|
|
59
93
|
nobCount;
|
|
94
|
+
zoneShow = false;
|
|
60
95
|
onNOBStoreSelect(event, type) {
|
|
61
96
|
if (!event) {
|
|
62
97
|
this.ts.getErrorToast('storeName or storeId is undefined or invalid');
|
|
@@ -86,6 +121,11 @@ export class AddNobComponent {
|
|
|
86
121
|
this.storeCode = '';
|
|
87
122
|
}
|
|
88
123
|
}
|
|
124
|
+
this.zoneShow = true;
|
|
125
|
+
if (this.isEnabled) {
|
|
126
|
+
this.getZoneList(this.storeId);
|
|
127
|
+
}
|
|
128
|
+
// console.log('storeName',this.storeId);
|
|
89
129
|
}
|
|
90
130
|
omit_special_char(event) {
|
|
91
131
|
var k;
|
|
@@ -109,31 +149,38 @@ export class AddNobComponent {
|
|
|
109
149
|
cancel() {
|
|
110
150
|
this.activeModal.close('close');
|
|
111
151
|
}
|
|
152
|
+
erroShow = '';
|
|
153
|
+
isSubmitting = false;
|
|
112
154
|
onSubmit() {
|
|
113
|
-
|
|
155
|
+
// ⛔ STOP if already submitting
|
|
156
|
+
if (this.isSubmitting) {
|
|
157
|
+
return;
|
|
158
|
+
}
|
|
159
|
+
const overallNob = Number(this.nobCount) || 0;
|
|
160
|
+
const zoneTotal = this.zonewisenob.reduce((sum, z) => sum + (Number(z.nobCount) || 0), 0);
|
|
161
|
+
if (zoneTotal > overallNob) {
|
|
162
|
+
this.erroShow = 'Zone-wise NoB cannot exceed overall NoB count';
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
// ✅ LOCK BUTTON
|
|
166
|
+
this.isSubmitting = true;
|
|
167
|
+
const obj = {
|
|
114
168
|
bills: [
|
|
115
169
|
{
|
|
116
|
-
// storeId: this.storeId,
|
|
117
170
|
storeCode: this.storeCode ? this.storeCode : this.storeId,
|
|
118
|
-
// storeName: this.storeName,
|
|
119
171
|
nobDate: this.dateValue,
|
|
120
|
-
nobCount: Number(this.nobCount)
|
|
172
|
+
nobCount: Number(this.nobCount),
|
|
173
|
+
zonewisenob: this.zonewisenob
|
|
121
174
|
}
|
|
122
175
|
],
|
|
123
176
|
clientId: this.clientId
|
|
124
177
|
};
|
|
125
|
-
this.service.getNOBDataList(obj)
|
|
178
|
+
this.service.getNOBDataList(obj)
|
|
179
|
+
?.pipe(takeUntil(this.destroy$))
|
|
126
180
|
.subscribe({
|
|
127
181
|
next: (res) => {
|
|
128
|
-
if (res
|
|
129
|
-
|
|
130
|
-
// .map((item:any) => {
|
|
131
|
-
// const status = item.code === 200 ? '✅' : '❌';
|
|
132
|
-
// const storeInfo = item.storeId ? `${item.storeId}` : '';
|
|
133
|
-
// return `${status} ${storeInfo}: ${item.message}`;
|
|
134
|
-
// })
|
|
135
|
-
// .join('<br>');
|
|
136
|
-
this.ts.getSuccessToast(allMessages);
|
|
182
|
+
if (res?.code === 200) {
|
|
183
|
+
this.ts.getSuccessToast(res.message);
|
|
137
184
|
this.activeModal.close('submit');
|
|
138
185
|
}
|
|
139
186
|
else {
|
|
@@ -141,8 +188,12 @@ export class AddNobComponent {
|
|
|
141
188
|
}
|
|
142
189
|
},
|
|
143
190
|
error: (err) => {
|
|
144
|
-
this.ts.getErrorToast(err
|
|
191
|
+
this.ts.getErrorToast(err?.error?.error || 'Something went wrong');
|
|
145
192
|
},
|
|
193
|
+
complete: () => {
|
|
194
|
+
// 🔓 UNLOCK BUTTON
|
|
195
|
+
this.isSubmitting = false;
|
|
196
|
+
}
|
|
146
197
|
});
|
|
147
198
|
}
|
|
148
199
|
typeNOB = 'single';
|
|
@@ -155,66 +206,152 @@ export class AddNobComponent {
|
|
|
155
206
|
convertedData;
|
|
156
207
|
inputFile;
|
|
157
208
|
onUpload(event) {
|
|
158
|
-
const file = event.target.files[0];
|
|
209
|
+
const file = event.target.files?.[0];
|
|
210
|
+
if (!file)
|
|
211
|
+
return;
|
|
159
212
|
const reader = new FileReader();
|
|
160
213
|
reader.onload = (e) => {
|
|
161
|
-
const binaryData = e.target.result;
|
|
162
214
|
try {
|
|
163
|
-
const
|
|
215
|
+
const binaryData = e.target.result;
|
|
216
|
+
const workbook = XLSX.read(binaryData, {
|
|
217
|
+
type: 'binary'
|
|
218
|
+
});
|
|
164
219
|
const sheetName = workbook.SheetNames[0];
|
|
165
|
-
if (sheetName !== 'NOB') {
|
|
166
|
-
this.ts.getErrorToast("Please upload a valid file.");
|
|
167
|
-
this.resetFileInput();
|
|
168
|
-
return;
|
|
169
|
-
}
|
|
170
220
|
const sheet = workbook.Sheets[sheetName];
|
|
171
|
-
const
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
this.
|
|
221
|
+
const sheetData = XLSX.utils.sheet_to_json(sheet, {
|
|
222
|
+
header: 1,
|
|
223
|
+
defval: null
|
|
224
|
+
});
|
|
225
|
+
if (!sheetData || sheetData.length < 2) {
|
|
226
|
+
this.ts.getErrorToast('Excel file is empty');
|
|
177
227
|
return;
|
|
178
228
|
}
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
229
|
+
const STORE_ID_HEADERS = ['storeid', 'store id', 'StoreId'];
|
|
230
|
+
const DATE_HEADERS = ['date', 'nobdate', 'nob date', 'NOBDate'];
|
|
231
|
+
const NOB_HEADERS = ['nobcount', 'overallnobcount', 'overall nob count', 'NOBCount'];
|
|
232
|
+
const normalize = (h) => String(h ?? '')
|
|
233
|
+
.toLowerCase()
|
|
234
|
+
.replace(/\s+/g, '');
|
|
235
|
+
const rawHeaders = sheetData[0];
|
|
236
|
+
const headers = rawHeaders.map(h => normalize(h));
|
|
237
|
+
const isStoreValid = STORE_ID_HEADERS.includes(headers[0]);
|
|
238
|
+
const isDateValid = DATE_HEADERS.includes(headers[1]);
|
|
239
|
+
const isNobValid = NOB_HEADERS.includes(headers[2]);
|
|
240
|
+
if (!isStoreValid || !isDateValid || !isNobValid) {
|
|
241
|
+
this.ts.getErrorToast('Invalid Excel file. First columns must be Store Id, NoB Date, Overall NoB Count');
|
|
242
|
+
return;
|
|
182
243
|
}
|
|
183
|
-
const
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
244
|
+
const rows = sheetData.slice(1);
|
|
245
|
+
// ===============================
|
|
246
|
+
// 2️⃣ PROCESS ROWS
|
|
247
|
+
// ===============================
|
|
248
|
+
const bills = rows
|
|
249
|
+
.map((row, rowIndex) => {
|
|
250
|
+
// 🔹 SKIP COMPLETELY EMPTY ROWS (SAFE)
|
|
251
|
+
const isEmptyRow = row.every(cell => cell === null ||
|
|
252
|
+
cell === undefined ||
|
|
253
|
+
(typeof cell === 'string' && cell.trim() === ''));
|
|
254
|
+
if (isEmptyRow)
|
|
255
|
+
return null;
|
|
256
|
+
// ===============================
|
|
257
|
+
// 3️⃣ STORE CODE
|
|
258
|
+
// ===============================
|
|
259
|
+
const storeId = String(row[0] ?? '').trim();
|
|
260
|
+
if (!storeId) {
|
|
261
|
+
throw new Error(`Missing Store Code at row ${rowIndex + 2}`);
|
|
262
|
+
}
|
|
263
|
+
// ===============================
|
|
264
|
+
// 4️⃣ DATE
|
|
265
|
+
// ===============================
|
|
266
|
+
let nobDate = row[1];
|
|
267
|
+
if (nobDate === null || nobDate === undefined || nobDate === '') {
|
|
268
|
+
throw new Error(`Missing Date at row ${rowIndex + 2}`);
|
|
269
|
+
}
|
|
270
|
+
if (typeof nobDate === 'number') {
|
|
271
|
+
nobDate = this.convertExcelDate(nobDate);
|
|
272
|
+
}
|
|
273
|
+
else if (nobDate instanceof Date) {
|
|
274
|
+
// ok
|
|
275
|
+
}
|
|
276
|
+
else if (typeof nobDate === 'string') {
|
|
277
|
+
const parsed = new Date(nobDate);
|
|
278
|
+
if (isNaN(parsed.getTime())) {
|
|
279
|
+
throw new Error(`Invalid Date format at row ${rowIndex + 2}`);
|
|
280
|
+
}
|
|
281
|
+
nobDate = parsed;
|
|
282
|
+
}
|
|
283
|
+
else {
|
|
284
|
+
throw new Error(`Invalid Date format at row ${rowIndex + 2}`);
|
|
285
|
+
}
|
|
286
|
+
// ===============================
|
|
287
|
+
// 5️⃣ NoB COUNT
|
|
288
|
+
// ===============================
|
|
289
|
+
let nobCount = row[2];
|
|
290
|
+
if (nobCount === null || nobCount === undefined || nobCount === '') {
|
|
291
|
+
throw new Error(`Missing NoB count at row ${rowIndex + 2}`);
|
|
292
|
+
}
|
|
293
|
+
nobCount = Number(nobCount);
|
|
294
|
+
if (isNaN(nobCount)) {
|
|
295
|
+
throw new Error(`Invalid NoB count at row ${rowIndex + 2}`);
|
|
296
|
+
}
|
|
297
|
+
// ===============================
|
|
298
|
+
// 6️⃣ ZONE WISE NoB
|
|
299
|
+
// ===============================
|
|
300
|
+
const zonewisenob = headers.slice(3)
|
|
301
|
+
.map((zoneName, index) => {
|
|
302
|
+
const raw = row[index + 3];
|
|
303
|
+
if (raw === null ||
|
|
304
|
+
raw === undefined ||
|
|
305
|
+
(typeof raw === 'string' && raw.trim() === '')) {
|
|
306
|
+
return null;
|
|
307
|
+
}
|
|
308
|
+
const value = Number(raw);
|
|
309
|
+
if (isNaN(value)) {
|
|
310
|
+
throw new Error(`Invalid Zone NoB at row ${rowIndex + 2} (${zoneName})`);
|
|
311
|
+
}
|
|
202
312
|
return {
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
nobCount: Number(obj["NOBCount"]),
|
|
313
|
+
zoneName,
|
|
314
|
+
nobCount: value
|
|
206
315
|
};
|
|
207
316
|
})
|
|
208
|
-
.filter(
|
|
209
|
-
|
|
317
|
+
.filter(Boolean);
|
|
318
|
+
const zoneTotal = zonewisenob.reduce((sum, z) => sum + z.nobCount, 0);
|
|
319
|
+
if (zoneTotal > nobCount) {
|
|
320
|
+
throw new Error(`Zone-wise NoB cannot exceed overall NoB (Row ${rowIndex + 2})`);
|
|
321
|
+
}
|
|
322
|
+
// ===============================
|
|
323
|
+
// 7️⃣ FINAL OBJECT
|
|
324
|
+
// ===============================
|
|
325
|
+
return {
|
|
326
|
+
storeCode: storeId,
|
|
327
|
+
nobDate: this.datePipe.transform(nobDate, 'yyyy-MM-dd'),
|
|
328
|
+
nobCount,
|
|
329
|
+
zonewisenob
|
|
330
|
+
};
|
|
331
|
+
})
|
|
332
|
+
.filter(Boolean);
|
|
333
|
+
if (!bills.length) {
|
|
334
|
+
this.ts.getErrorToast('No valid rows found in Excel');
|
|
335
|
+
return;
|
|
336
|
+
}
|
|
337
|
+
// ===============================
|
|
338
|
+
// 8️⃣ FINAL PAYLOAD
|
|
339
|
+
// ===============================
|
|
340
|
+
this.convertedData = {
|
|
341
|
+
clientId: this.clientId,
|
|
342
|
+
bills
|
|
210
343
|
};
|
|
211
|
-
this.
|
|
212
|
-
this.
|
|
344
|
+
this.dataTableShow = true;
|
|
345
|
+
this.ts.getSuccessToast('File uploaded successfully');
|
|
346
|
+
}
|
|
347
|
+
catch (err) {
|
|
348
|
+
console.error(err);
|
|
349
|
+
this.ts.getErrorToast(err.message || 'Invalid Excel file');
|
|
213
350
|
}
|
|
214
|
-
|
|
215
|
-
this.
|
|
351
|
+
finally {
|
|
352
|
+
this.resetFileInput();
|
|
353
|
+
this.cd.detectChanges();
|
|
216
354
|
}
|
|
217
|
-
this.resetFileInput();
|
|
218
355
|
};
|
|
219
356
|
reader.readAsBinaryString(file);
|
|
220
357
|
}
|
|
@@ -246,16 +383,74 @@ export class AddNobComponent {
|
|
|
246
383
|
},
|
|
247
384
|
});
|
|
248
385
|
}
|
|
249
|
-
|
|
250
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AddNobComponent, selector: "lib-add-nob", inputs: { type: "type" }, providers: [DatePipe], viewQueries: [{ propertyName: "inputFile", first: true, predicate: ["inputFile"], descendants: true }], ngImport: i0, template: "<div class=\"card pt-0 pb-3 scroll\">\r\n <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n <div class=\"my-5 d-flex\">\r\n <div *ngIf=\"type ==='add'\" class=\"symbol symbol-75px symbol-circle\">\r\n <img alt=\"Pic\" src=\"./assets/tango/Icons/add-store-icon.svg\">\r\n </div>\r\n <div *ngIf=\"type ==='reupload'\" 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 31V35C37 35.5304 36.7893 36.0391 36.4142 36.4142C36.0391 36.7893 35.5304 37 35 37H21C20.4696 37 19.9609 36.7893 19.5858 36.4142C19.2107 36.0391 19 35.5304 19 35V31M33 24L28 19M28 19L23 24M28 19V31\" stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n \r\n </div>\r\n </div>\r\n <div class=\"row w-100\">\r\n <div *ngIf=\"type ==='add'\" class=\"col-md-12\">\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Add Single NoB</a>\r\n </div>\r\n <div *ngIf=\"type ==='reupload'\" class=\"col-md-12\">\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Upload NoB for</a>\r\n </div>\r\n<div *ngIf=\"type ==='reupload'\" class=\"d-flex align-items-center mt-5\">\r\n <div class=\"form-check w-50 cursor-pointer ps-5\" (click)=\"nobStore('single')\" [ngClass]=\"typeNOB ==='single' ? 'form-check-inline':'form-check-inline-none'\" >\r\n <svg *ngIf=\"typeNOB ==='single'\" style=\"margin-top: -5px !important;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"#EAF8FF\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#00A3FF\"/>\r\n <circle cx=\"8\" cy=\"8\" r=\"3\" fill=\"#00A3FF\"/>\r\n </svg>\r\n\r\n <svg *ngIf=\"typeNOB !=='single'\" style=\"margin-top: -5px !important;\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"white\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#D0D5DD\"/>\r\n </svg>\r\n <!-- <input class=\"form-check-input ms-10\" type=\"radio\" name=\"inlineRadioOptions\" id=\"inlineRadio1\" value=\"option1\"> -->\r\n <span class=\"ms-3 pt-12\" [ngClass]=\"typeNOB ==='single' ? 'form-text-primary ':'form-defult'\">Single Store</span>\r\n </div>\r\n <div class=\"form-check w-50 cursor-pointer ps-5\" (click)=\"nobStore('multiple')\" [ngClass]=\"typeNOB ==='multiple' ? 'form-check-inline':'form-check-inline-none'\">\r\n <svg *ngIf=\"typeNOB ==='multiple'\" style=\"margin-top: -5px !important;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"#EAF8FF\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#00A3FF\"/>\r\n <circle cx=\"8\" cy=\"8\" r=\"3\" fill=\"#00A3FF\"/>\r\n </svg>\r\n\r\n <svg *ngIf=\"typeNOB !=='multiple'\" style=\"margin-top: -5px !important;\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"white\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#D0D5DD\"/>\r\n </svg>\r\n <span class=\"ms-3 pt-12\" [ngClass]=\"typeNOB ==='multiple' ? 'form-text-primary':'form-defult'\">Multiple Stores</span>\r\n \r\n </div>\r\n </div>\r\n <div *ngIf=\"typeNOB ==='single'\" class=\"w-100 h-0px scroll\">\r\n <div class=\"mt-5\">\r\n <div class=\"row px-0 me-3\">\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"storeName\" class=\"form-label\">Store Name<span\r\n class=\"alert-required text-danger\"> *</span></label>\r\n <lib-custom-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeName'\"\r\n [idField]=\"'storeName'\" (selected)=\"onNOBStoreSelect($event, 'storeName')\"\r\n [selectedValues]=\"[{ storeName: storeName }]\">\r\n </lib-custom-select>\r\n </div>\r\n\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"storeID\" class=\"form-label\">Store ID /<span *ngIf=\"type !=='add'\"> Store Code</span><span *ngIf=\"type ==='add'\"> Reference Code</span> <span\r\n class=\"alert-required text-danger\"> *</span></label>\r\n <lib-custom-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeId'\"\r\n [idField]=\"'storeId'\" (selected)=\"onNOBStoreSelect($event, 'storeId')\"\r\n [selectedValues]=\"[{ storeId: storeId }]\">\r\n </lib-custom-select>\r\n </div>\r\n\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"Date\" class=\"form-label\">Select Date <span\r\n class=\"alert-required text-danger\">*</span></label>\r\n <input type=\"date\" class=\"form-control\" id=\"myDate\" [(ngModel)]=\"dateValue\"\r\n (change)=\"onDateChange($event)\" [max]=\"maxDate\">\r\n </div>\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"count\" class=\"form-label\">NOB Count <span\r\n class=\"alert-required text-danger\">*</span></label>\r\n <input type=\"text\" class=\"form-control\" [(ngModel)]=\"nobCount\"\r\n (keypress)=\"omit_special_char($event)\">\r\n </div>\r\n <div class=\"d-flex mt-3 mb-10\" 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\" id=\"alert-toast\" (click)=\"onSubmit()\"\r\n [disabled]=\"!dateValue || !nobCount || !storeId || !storeName\"><span *ngIf=\"type !=='add'\">Proceed</span><span *ngIf=\"type ==='add'\">Add</span></button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div *ngIf=\"typeNOB ==='multiple'\" class=\"d-flex justify-content\">\r\n <div class=\"fw-bold text-gray-500 my-6\">\r\n <ul class=\"text-gray-400 fw-bold fs-6\">\r\n <li class=\"user-text\">Use the template to upload multiple NoB\u2019s at once.</li>\r\n <li class=\"user-text \">Download the template here - <a href=\"../../assets/files/nobUploadTemplate.xlsx\" download><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\r\n <path d=\"M17.5 13V16.3333C17.5 16.7754 17.3244 17.1993 17.0118 17.5118C16.6993 17.8244 16.2754 18 15.8333 18H4.16667C3.72464 18 3.30072 17.8244 2.98816 17.5118C2.67559 17.1993 2.5 16.7754 2.5 16.3333V13M5.83333 8.83333L10 13M10 13L14.1667 8.83333M10 13V3\" stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg><span class=\"ms-2 text-download\">Download Template</span></a></li>\r\n <li class=\"user-text \">Add your data to the Template File</li>\r\n <li class=\"user-text\">Upload it below for processing</li>\r\n \r\n </ul>\r\n </div>\r\n </div>\r\n <div *ngIf=\"typeNOB ==='multiple'\"\r\n class=\"mt-3 ms-3 right-bar py-10 d-flex justify-content-center align-items-center flex-column\">\r\n <input name=\"accountType\" type=\"radio\" id=\"kt_create_account_form_account_type_personal\"\r\n value=\"personal\" class=\"btn-check\" ng-reflect-name=\"accountType\"\r\n ng-reflect-form-control-name=\"accountType\" (change)=\"onUpload($event)\"\r\n ng-reflect-value=\"personal\" type=\"file\" #inputFile />\r\n <label for=\"kt_create_account_form_account_type_personal\" class=\" w-50 p-4 mt-5\"><span\r\n class=\"fw-bold text-center w-100 fs-4\">\r\n<div class=\"d-flex justify-content-center align-items-center w-100\">\r\n <svg width=\"46\" height=\"46\" viewBox=\"0 0 46 46\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"3\" y=\"3\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#F2F4F7\" />\r\n <rect x=\"3\" y=\"3\" width=\"40\" height=\"40\" rx=\"20\" stroke=\"#F9FAFB\"\r\n stroke-width=\"6\" />\r\n <g clip-path=\"url(#clip0_4047_40566)\">\r\n <path\r\n d=\"M26.3333 26.3334L23 23M23 23L19.6666 26.3334M23 23V30.5M29.9916 28.325C30.8044 27.8819 31.4465 27.1808 31.8165 26.3322C32.1866 25.4837 32.2635 24.5361 32.0351 23.6389C31.8068 22.7418 31.2862 21.9463 30.5555 21.3779C29.8248 20.8095 28.9257 20.5006 28 20.5H26.95C26.6977 19.5244 26.2276 18.6186 25.5749 17.8509C24.9222 17.0831 24.104 16.4732 23.1817 16.0672C22.2594 15.6612 21.2571 15.4695 20.2501 15.5066C19.243 15.5437 18.2575 15.8086 17.3676 16.2814C16.4777 16.7542 15.7066 17.4226 15.1122 18.2363C14.5177 19.0501 14.1155 19.988 13.9358 20.9795C13.756 21.9711 13.8034 22.9905 14.0743 23.9611C14.3452 24.9317 14.8327 25.8282 15.5 26.5834\"\r\n stroke=\"#475467\" stroke-width=\"1.66667\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_4047_40566\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(13 13)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </div>\r\n <div class=\"nodata-title\"><span class=\"click-upload cursor-pointer\">Click to\r\n upload </span>\r\n <!-- <span class=\"drag-drop\"> or drag and drop the template</span> -->\r\n </div>\r\n \r\n </span>\r\n </label>\r\n </div>\r\n\r\n <div *ngIf=\"typeNOB ==='multiple'\" class=\"d-flex mt-3 mb-10\" 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\" id=\"alert-toast\" (click)=\"proceed()\"\r\n >Proceed</button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n</div>", styles: [".scroll{overflow-y:auto;overflow-x:hidden}.title{color:var(--Gray-900, #101828)!important;font-size:18px!important;font-weight:600;line-height:28px}.sub-title{color:var(--Gray-500, #667085)!important;font-size:14px!important;font-weight:400!important;line-height:20px}.teams-title{color:var(--Black, #101828)!important;font-size:18px!important;font-weight:600!important;line-height:28px}.title-header{border-radius:6px!important;border-bottom:2px solid var(--Gray-200, #EAECF0)!important;background:#f2f4f7!important;box-shadow:0 4px 10px #0000000d!important;color:var(--Black, #101828)!important;font-size:20px!important;font-weight:600;line-height:30px;padding:8px 16px}input[type=checkbox]{width:18px!important;height:18px!important;margin: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:.5em;padding-left:0;padding-top:12px;padding-right:6px}.global-label{color:var(--Gray-700, #344054)!important;font-size:16px!important;font-weight:500;line-height:24px}.w-25{width:40%!important}td{color:var(--Black, #101828)!important;font-size:16px!important;font-weight:500!important;line-height:24px}tr,.add-team{border-bottom:1px solid var(--Gray-200, #EAECF0)!important}input[disabled]{pointer-events:none;opacity:.5}input.form-control{margin-bottom:10px}.dropdown-menu{max-height:200px;overflow-y:auto}.dropdown-item{cursor:pointer}.btn-outline-primary{width:100%;text-align:left}.form-check-inline{border-radius:8px;border:1px solid var(--Primary-700, #009BF3);background:var(--Primary-25, #F6FCFF);padding:16px}.form-check-label{color:var(--Gray-900, #101828)!important;font-size:16px!important;font-weight:600;line-height:24px}.form-check-inline-none{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);padding:16px;margin-right:1rem}.right-bar{border-radius:8px!important;border:1px solid var(--Gray-200, #EAECF0)!important;background:var(--White, #FFF);padding:16px 24px!important}.drag-drop{color:var(--Gray-500, #667085)!important;font-size:14px!important;font-weight:400;line-height:20px}.click-upload{color:var(--Primary-700, #009BF3);font-family:Inter;font-size:14px;font-style:normal;font-weight:600;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font;text-transform:capitalize}.user-text{color:var(--Gray-500, #344054)!important;font-size:14px!important;font-weight:400!important;line-height:28px;list-style:decimal!important}.form-text-primary{color:var(--Primary-700, #009BF3)!important;font-size:16px!important;font-weight:600;line-height:24px}.form-defult{color:var(--Gray-900, #101828)!important;font-size:16px!important;font-weight:600;line-height:24px}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.CustomSelectComponent, selector: "lib-custom-select", inputs: ["items", "searchField", "multi", "idField", "selectedValues", "disabled", "label"], outputs: ["selected"] }] });
|
|
386
|
+
isEnabled = false;
|
|
387
|
+
zoneList = [];
|
|
388
|
+
onCheckboxChange(event) {
|
|
389
|
+
this.isEnabled = event.target.checked;
|
|
390
|
+
if (this.isEnabled) {
|
|
391
|
+
this.getZoneList(this.storeId);
|
|
392
|
+
}
|
|
393
|
+
else {
|
|
394
|
+
this.zoneList = [];
|
|
395
|
+
}
|
|
396
|
+
}
|
|
397
|
+
getZoneList(store) {
|
|
398
|
+
this.service.getZoneList({ "storeId": [store] })?.pipe(takeUntil(this.destroy$))
|
|
399
|
+
.subscribe({
|
|
400
|
+
next: (res) => {
|
|
401
|
+
if (res && res.code === 200) {
|
|
402
|
+
this.zoneList = res?.data;
|
|
403
|
+
}
|
|
404
|
+
else {
|
|
405
|
+
this.zoneList = [];
|
|
406
|
+
}
|
|
407
|
+
},
|
|
408
|
+
error: (err) => {
|
|
409
|
+
this.zoneList = [];
|
|
410
|
+
}
|
|
411
|
+
});
|
|
412
|
+
}
|
|
413
|
+
zonewisenob = [];
|
|
414
|
+
onNobChange() {
|
|
415
|
+
this.zonewisenob = this.zoneList.map((zone) => ({
|
|
416
|
+
zoneName: zone.tagName ? zone.tagName : zone.zoneName,
|
|
417
|
+
nobCount: Number(zone.nobCount) || 0
|
|
418
|
+
}));
|
|
419
|
+
console.log('Updated zonewisenob:', this.zonewisenob);
|
|
420
|
+
}
|
|
421
|
+
download() {
|
|
422
|
+
this.service
|
|
423
|
+
.getZoneTemplate({ clientId: this.clientId || '' })
|
|
424
|
+
.pipe(takeUntil(this.destroy$))
|
|
425
|
+
.subscribe({
|
|
426
|
+
next: (res) => {
|
|
427
|
+
if (res) {
|
|
428
|
+
this.excelService.saveAsExcelFile(res, 'NOB Upload Template');
|
|
429
|
+
}
|
|
430
|
+
else {
|
|
431
|
+
this.ts.getErrorToast('File is empty');
|
|
432
|
+
}
|
|
433
|
+
},
|
|
434
|
+
error: (err) => {
|
|
435
|
+
const errorMsg = err.error?.error ||
|
|
436
|
+
err.error?.message || err.message || err.error;
|
|
437
|
+
'An error occurred while downloading file';
|
|
438
|
+
this.ts.getErrorToast(errorMsg);
|
|
439
|
+
}
|
|
440
|
+
});
|
|
441
|
+
}
|
|
442
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AddNobComponent, deps: [{ token: i1.FormBuilder }, { token: i2.TrafficService }, { token: i3.ExcelService }, { token: i4.NgbActiveModal }, { token: i5.ToastService }, { token: i0.ChangeDetectorRef }, { token: i6.DatePipe }], target: i0.ɵɵFactoryTarget.Component });
|
|
443
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AddNobComponent, selector: "lib-add-nob", inputs: { type: "type", viewData: "viewData" }, providers: [DatePipe], viewQueries: [{ propertyName: "inputFile", first: true, predicate: ["inputFile"], descendants: true }], ngImport: i0, template: "<div *ngIf=\"type !=='editView' && type !== 'view'\" class=\"card pt-0 pb-3 scroll\">\r\n <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n <div class=\"my-5 d-flex\">\r\n <div *ngIf=\"type ==='add'\" class=\"symbol symbol-75px symbol-circle\">\r\n <img alt=\"Pic\" src=\"./assets/tango/Icons/add-store-icon.svg\">\r\n </div>\r\n <div *ngIf=\"type ==='reupload'\" 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 31V35C37 35.5304 36.7893 36.0391 36.4142 36.4142C36.0391 36.7893 35.5304 37 35 37H21C20.4696 37 19.9609 36.7893 19.5858 36.4142C19.2107 36.0391 19 35.5304 19 35V31M33 24L28 19M28 19L23 24M28 19V31\" stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n \r\n </div>\r\n </div>\r\n <div class=\"row w-100\">\r\n <div *ngIf=\"type ==='add'\" class=\"col-md-12\">\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Add Single NoB</a>\r\n </div>\r\n <div *ngIf=\"type ==='reupload'\" class=\"col-md-12\">\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Upload NoB for</a>\r\n </div>\r\n<div *ngIf=\"type ==='reupload'\" class=\"d-flex align-items-center mt-5\">\r\n <div class=\"form-check w-50 cursor-pointer ps-5\" (click)=\"nobStore('single')\" [ngClass]=\"typeNOB ==='single' ? 'form-check-inline':'form-check-inline-none'\" >\r\n <svg *ngIf=\"typeNOB ==='single'\" style=\"margin-top: -5px !important;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"#EAF8FF\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#00A3FF\"/>\r\n <circle cx=\"8\" cy=\"8\" r=\"3\" fill=\"#00A3FF\"/>\r\n </svg>\r\n\r\n <svg *ngIf=\"typeNOB !=='single'\" style=\"margin-top: -5px !important;\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"white\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#D0D5DD\"/>\r\n </svg>\r\n <!-- <input class=\"form-check-input ms-10\" type=\"radio\" name=\"inlineRadioOptions\" id=\"inlineRadio1\" value=\"option1\"> -->\r\n <span class=\"ms-3 pt-12\" [ngClass]=\"typeNOB ==='single' ? 'form-text-primary ':'form-defult'\">Single Store</span>\r\n </div>\r\n <div class=\"form-check w-50 cursor-pointer ps-5\" (click)=\"nobStore('multiple')\" [ngClass]=\"typeNOB ==='multiple' ? 'form-check-inline':'form-check-inline-none'\">\r\n <svg *ngIf=\"typeNOB ==='multiple'\" style=\"margin-top: -5px !important;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"#EAF8FF\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#00A3FF\"/>\r\n <circle cx=\"8\" cy=\"8\" r=\"3\" fill=\"#00A3FF\"/>\r\n </svg>\r\n\r\n <svg *ngIf=\"typeNOB !=='multiple'\" style=\"margin-top: -5px !important;\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"white\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#D0D5DD\"/>\r\n </svg>\r\n <span class=\"ms-3 pt-12\" [ngClass]=\"typeNOB ==='multiple' ? 'form-text-primary':'form-defult'\">Multiple Stores</span>\r\n \r\n </div>\r\n </div>\r\n <div *ngIf=\"typeNOB ==='single'\" class=\"w-100 h-0px scroll\">\r\n <div class=\"mt-5\">\r\n <div class=\"row px-0 me-3\">\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"storeName\" class=\"form-label\">Store Name<span\r\n class=\"alert-required text-danger\"> *</span></label>\r\n <lib-custom-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeName'\"\r\n [idField]=\"'storeName'\" (selected)=\"onNOBStoreSelect($event, 'storeName')\"\r\n [selectedValues]=\"[{ storeName: storeName }]\">\r\n </lib-custom-select>\r\n </div>\r\n\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"storeID\" class=\"form-label\">Store ID /<span *ngIf=\"type !=='add'\"> Store Code</span><span *ngIf=\"type ==='add'\"> Reference Code</span> <span\r\n class=\"alert-required text-danger\"> *</span></label>\r\n <lib-custom-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeId'\"\r\n [idField]=\"'storeId'\" (selected)=\"onNOBStoreSelect($event, 'storeId')\"\r\n [selectedValues]=\"[{ storeId: storeId }]\">\r\n </lib-custom-select>\r\n </div>\r\n\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"Date\" class=\"form-label\">Select Date <span\r\n class=\"alert-required text-danger\">*</span></label>\r\n <input type=\"date\" class=\"form-control\" id=\"myDate\" [(ngModel)]=\"dateValue\"\r\n (change)=\"onDateChange($event)\" [max]=\"maxDate\">\r\n </div>\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"count\" class=\"form-label\">NOB Count <span\r\n class=\"alert-required text-danger\">*</span></label>\r\n <input type=\"text\" class=\"form-control\" [(ngModel)]=\"nobCount\"\r\n (keypress)=\"omit_special_char($event)\">\r\n </div>\r\n <div *ngIf=\"zoneShow\" class=\"col-12\">\r\n <div *ngIf=\"clientData?.isZonewiseNOB\" class=\"toggle-wrapper\">\r\n <label class=\"switch\">\r\n <input type=\"checkbox\" [(ngModel)]=\"isEnabled\" (change)=\"onCheckboxChange($event)\" />\r\n <span class=\"slider\"></span>\r\n </label>\r\n\r\n <span class=\"toggle-label\">\r\n Add Zone-wise NoB Count\r\n </span>\r\n</div>\r\n\r\n </div>\r\n <div *ngIf=\"isEnabled\" class=\"table-responsive\">\r\n <table class=\"table bottom-border text-nowrap mt-5\">\r\n <thead>\r\n <tr>\r\n <th scope=\"col\">Zone Name</th>\r\n <th scope=\"col\">NoB Count</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let zone of zoneList\">\r\n <td class=\"py-3 mt-10\">{{zone.tagName}}</td>\r\n <td class=\"py-2\"><input type=\"text\" class=\"form-control form-control-sm mb-0 py-0\" [(ngModel)]=\"zone.nobCount\" (ngModelChange)=\"onNobChange()\" \r\n (keypress)=\"omit_special_char($event)\"></td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n <div *ngIf=\"erroShow\" class=\"text-danger mt-2\"><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<g clip-path=\"url(#clip0_15055_156438)\">\r\n<path d=\"M9 6V9M9 12H9.0075M16.5 9C16.5 13.1421 13.1421 16.5 9 16.5C4.85786 16.5 1.5 13.1421 1.5 9C1.5 4.85786 4.85786 1.5 9 1.5C13.1421 1.5 16.5 4.85786 16.5 9Z\" stroke=\"#B42318\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</g>\r\n<defs>\r\n<clipPath id=\"clip0_15055_156438\">\r\n<rect width=\"18\" height=\"18\" fill=\"white\"/>\r\n</clipPath>\r\n</defs>\r\n</svg></span>{{ erroShow }}</div>\r\n\r\n <div class=\"d-flex mt-3 mb-10\" role=\"group\">\r\n <button class=\"btn btn-outline w-100 me-3\" (click)=\"cancel()\">Cancel</button>\r\n <button\r\n class=\"btn btn-primary w-100 ms-3\"\r\n id=\"alert-toast\"\r\n (click)=\"onSubmit()\"\r\n [disabled]=\"\r\n !dateValue ||\r\n !nobCount ||\r\n !storeId ||\r\n !storeName ||\r\n isSubmitting\r\n \"\r\n>\r\n <span *ngIf=\"!isSubmitting && type !== 'add'\">Proceed</span>\r\n <span *ngIf=\"!isSubmitting && type === 'add'\">Add</span>\r\n <span *ngIf=\"isSubmitting\">Please wait...</span>\r\n</button>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div *ngIf=\"typeNOB ==='multiple'\" class=\"d-flex justify-content\">\r\n <div class=\"fw-bold text-gray-500 my-6\">\r\n <ul class=\"text-gray-400 fw-bold fs-6\">\r\n <li class=\"user-text\">Use the template to upload multiple NoB\u2019s at once.</li>\r\n <li class=\"user-text \">Download the template here - <a *ngIf=\"!clientData?.isZonewiseNOB\" href=\"../../assets/files/nobUploadTemplate.xlsx\" download><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\r\n <path d=\"M17.5 13V16.3333C17.5 16.7754 17.3244 17.1993 17.0118 17.5118C16.6993 17.8244 16.2754 18 15.8333 18H4.16667C3.72464 18 3.30072 17.8244 2.98816 17.5118C2.67559 17.1993 2.5 16.7754 2.5 16.3333V13M5.83333 8.83333L10 13M10 13L14.1667 8.83333M10 13V3\" stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg><span class=\"ms-2 text-download text-primary\">Download Template</span></a> <span *ngIf=\"clientData?.isZonewiseNOB\" class=\" text-active-primary\" (click)=\"download()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\r\n <path d=\"M17.5 13V16.3333C17.5 16.7754 17.3244 17.1993 17.0118 17.5118C16.6993 17.8244 16.2754 18 15.8333 18H4.16667C3.72464 18 3.30072 17.8244 2.98816 17.5118C2.67559 17.1993 2.5 16.7754 2.5 16.3333V13M5.83333 8.83333L10 13M10 13L14.1667 8.83333M10 13V3\" stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg><span class=\"ms-2 text-download text-primary cursor-pointer\">Download Template</span></span></li>\r\n <li class=\"user-text \">Add your data to the Template File</li>\r\n <li class=\"user-text\">Upload it below for processing</li>\r\n \r\n </ul>\r\n </div>\r\n </div>\r\n <div *ngIf=\"typeNOB ==='multiple'\"\r\n class=\"mt-3 ms-3 right-bar py-10 d-flex justify-content-center align-items-center flex-column\">\r\n <input name=\"accountType\" type=\"radio\" id=\"kt_create_account_form_account_type_personal\"\r\n value=\"personal\" class=\"btn-check\" ng-reflect-name=\"accountType\"\r\n ng-reflect-form-control-name=\"accountType\" (change)=\"onUpload($event)\"\r\n ng-reflect-value=\"personal\" type=\"file\" #inputFile />\r\n <label for=\"kt_create_account_form_account_type_personal\" class=\" w-50 p-4 mt-5\"><span\r\n class=\"fw-bold text-center w-100 fs-4\">\r\n<div class=\"d-flex justify-content-center align-items-center w-100\">\r\n <svg width=\"46\" height=\"46\" viewBox=\"0 0 46 46\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"3\" y=\"3\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#F2F4F7\" />\r\n <rect x=\"3\" y=\"3\" width=\"40\" height=\"40\" rx=\"20\" stroke=\"#F9FAFB\"\r\n stroke-width=\"6\" />\r\n <g clip-path=\"url(#clip0_4047_40566)\">\r\n <path\r\n d=\"M26.3333 26.3334L23 23M23 23L19.6666 26.3334M23 23V30.5M29.9916 28.325C30.8044 27.8819 31.4465 27.1808 31.8165 26.3322C32.1866 25.4837 32.2635 24.5361 32.0351 23.6389C31.8068 22.7418 31.2862 21.9463 30.5555 21.3779C29.8248 20.8095 28.9257 20.5006 28 20.5H26.95C26.6977 19.5244 26.2276 18.6186 25.5749 17.8509C24.9222 17.0831 24.104 16.4732 23.1817 16.0672C22.2594 15.6612 21.2571 15.4695 20.2501 15.5066C19.243 15.5437 18.2575 15.8086 17.3676 16.2814C16.4777 16.7542 15.7066 17.4226 15.1122 18.2363C14.5177 19.0501 14.1155 19.988 13.9358 20.9795C13.756 21.9711 13.8034 22.9905 14.0743 23.9611C14.3452 24.9317 14.8327 25.8282 15.5 26.5834\"\r\n stroke=\"#475467\" stroke-width=\"1.66667\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_4047_40566\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(13 13)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </div>\r\n <div class=\"nodata-title\"><span class=\"click-upload cursor-pointer\">Click to\r\n upload </span>\r\n <!-- <span class=\"drag-drop\"> or drag and drop the template</span> -->\r\n </div>\r\n \r\n </span>\r\n </label>\r\n </div>\r\n\r\n <div *ngIf=\"typeNOB ==='multiple'\" class=\"d-flex mt-3 mb-10\" 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\" id=\"alert-toast\" (click)=\"proceed()\"\r\n >Proceed</button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n</div>\r\n<div *ngIf=\"type ==='editView' || type === 'view'\" class=\"card pt-0 pb-3 \">\r\n <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n \r\n <div class=\"row w-100 mt-5\">\r\n \r\n <div class=\"col-md-6\">\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Zone-wise NoB\r\n Count</a>\r\n </div>\r\n <div *ngIf=\"type === 'view'\" class=\"col-md-6 text-end\">\r\n <span class=\"cursor-pointer\" (click)=\"cancel()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\">\r\n<path d=\"M13 1L1 13M1 1L13 13\" stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg></span>\r\n </div>\r\n \r\n <div *ngIf=\"zoneList?.length\" class=\"table-responsive max-h-500\">\r\n <table class=\"table bottom-border text-nowrap mt-5\">\r\n <thead>\r\n <tr>\r\n <th scope=\"col\">Zone Name</th>\r\n <th scope=\"col\">NoB Count</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let zone of zoneList;let i = index\">\r\n <td class=\"py-3 mt-10\">{{zone.zoneName}}</td>\r\n <td class=\"py-2\"><span *ngIf=\"type === 'view' || !isEditEnabled\">\r\n {{ zone.nobCount }}\r\n </span>\r\n\r\n <!-- EDIT MODE -->\r\n <input *ngIf=\"type === 'editView' && isEditEnabled\" type=\"text\" class=\"form-control form-control-sm\"\r\n [(ngModel)]=\"zone.nobCount\" (ngModelChange)=\"onNobChange()\"\r\n (keypress)=\"omit_special_char($event)\" />\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n <div *ngIf=\"!zoneList?.length\" 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-nodata-table\" 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 Zone-wise NoB count</div>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"erroShow\" class=\"text-danger mt-2\"><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<g clip-path=\"url(#clip0_15055_156438)\">\r\n<path d=\"M9 6V9M9 12H9.0075M16.5 9C16.5 13.1421 13.1421 16.5 9 16.5C4.85786 16.5 1.5 13.1421 1.5 9C1.5 4.85786 4.85786 1.5 9 1.5C13.1421 1.5 16.5 4.85786 16.5 9Z\" stroke=\"#B42318\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</g>\r\n<defs>\r\n<clipPath id=\"clip0_15055_156438\">\r\n<rect width=\"18\" height=\"18\" fill=\"white\"/>\r\n</clipPath>\r\n</defs>\r\n</svg></span>{{ erroShow }}</div>\r\n\r\n <div *ngIf=\"type ==='editView' && isEditEnabled\" class=\"d-flex mt-3 mb-10\" role=\"group\">\r\n <button class=\"btn btn-outline w-100 me-3\" (click)=\"cancelEdit()\">Cancel</button>\r\n <button class=\"btn btn-primary w-100 ms-3\" id=\"alert-toast\" (click)=\"onSubmit()\"\r\n [disabled]=\"!dateValue || !nobCount || !storeId || !storeName\"><span\r\n *ngIf=\"type !=='add'\">Save</span><span *ngIf=\"type ==='add'\">Add</span></button>\r\n </div>\r\n \r\n </div>\r\n </div>\r\n</div>", styles: [".scroll{overflow-y:auto;overflow-x:hidden}.title{color:var(--Gray-900, #101828)!important;font-size:18px!important;font-weight:600;line-height:28px}.sub-title{color:var(--Gray-500, #667085)!important;font-size:14px!important;font-weight:400!important;line-height:20px}.teams-title{color:var(--Black, #101828)!important;font-size:18px!important;font-weight:600!important;line-height:28px}.title-header{border-radius:6px!important;border-bottom:2px solid var(--Gray-200, #EAECF0)!important;background:#f2f4f7!important;box-shadow:0 4px 10px #0000000d!important;color:var(--Black, #101828)!important;font-size:20px!important;font-weight:600;line-height:30px;padding:8px 16px}input[type=checkbox]{width:18px!important;height:18px!important;margin: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:.5em;padding-left:0;padding-top:12px;padding-right:6px}.global-label{color:var(--Gray-700, #344054)!important;font-size:16px!important;font-weight:500;line-height:24px}.w-25{width:40%!important}td{color:var(--Black, #101828)!important;font-size:16px!important;font-weight:500!important;line-height:24px}tr,.add-team{border-bottom:1px solid var(--Gray-200, #EAECF0)!important}input[disabled]{pointer-events:none;opacity:.5}input.form-control{margin-bottom:10px}.dropdown-menu{max-height:200px;overflow-y:auto}.dropdown-item{cursor:pointer}.btn-outline-primary{width:100%;text-align:left}.form-check-inline{border-radius:8px;border:1px solid var(--Primary-700, #009BF3);background:var(--Primary-25, #F6FCFF);padding:16px}.form-check-label{color:var(--Gray-900, #101828)!important;font-size:16px!important;font-weight:600;line-height:24px}.form-check-inline-none{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);padding:16px;margin-right:1rem}.right-bar{border-radius:8px!important;border:1px solid var(--Gray-200, #EAECF0)!important;background:var(--White, #FFF);padding:16px 24px!important}.drag-drop{color:var(--Gray-500, #667085)!important;font-size:14px!important;font-weight:400;line-height:20px}.click-upload{color:var(--Primary-700, #009BF3);font-family:Inter;font-size:14px;font-style:normal;font-weight:600;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font;text-transform:capitalize}.user-text{color:var(--Gray-500, #344054)!important;font-size:14px!important;font-weight:400!important;line-height:28px;list-style:decimal!important}.form-text-primary{color:var(--Primary-700, #009BF3)!important;font-size:16px!important;font-weight:600;line-height:24px}.form-defult{color:var(--Gray-900, #101828)!important;font-size:16px!important;font-weight:600;line-height:24px}table td{height:24px!important;align-items:center}.toggle-wrapper{display:flex;align-items:center;gap:12px}.switch{position:relative;display:inline-block;width:46px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#f2f4f7;transition:.3s;border-radius:24px}.slider:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.switch input:checked+.slider{background-color:#0d6efd}.switch input:checked+.slider:before{transform:translate(22px)}.text-danger{color:#b42318!important}.max-h-500{max-height:500px;overflow-y:auto}\n"], dependencies: [{ kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.CustomSelectComponent, selector: "lib-custom-select", inputs: ["items", "searchField", "multi", "idField", "selectedValues", "disabled", "label"], outputs: ["selected"] }] });
|
|
251
444
|
}
|
|
252
445
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AddNobComponent, decorators: [{
|
|
253
446
|
type: Component,
|
|
254
|
-
args: [{ selector: 'lib-add-nob', providers: [DatePipe], template: "<div class=\"card pt-0 pb-3 scroll\">\r\n <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n <div class=\"my-5 d-flex\">\r\n <div *ngIf=\"type ==='add'\" class=\"symbol symbol-75px symbol-circle\">\r\n <img alt=\"Pic\" src=\"./assets/tango/Icons/add-store-icon.svg\">\r\n </div>\r\n <div *ngIf=\"type ==='reupload'\" 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 31V35C37 35.5304 36.7893 36.0391 36.4142 36.4142C36.0391 36.7893 35.5304 37 35 37H21C20.4696 37 19.9609 36.7893 19.5858 36.4142C19.2107 36.0391 19 35.5304 19 35V31M33 24L28 19M28 19L23 24M28 19V31\" stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n \r\n </div>\r\n </div>\r\n <div class=\"row w-100\">\r\n <div *ngIf=\"type ==='add'\" class=\"col-md-12\">\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Add Single NoB</a>\r\n </div>\r\n <div *ngIf=\"type ==='reupload'\" class=\"col-md-12\">\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Upload NoB for</a>\r\n </div>\r\n<div *ngIf=\"type ==='reupload'\" class=\"d-flex align-items-center mt-5\">\r\n <div class=\"form-check w-50 cursor-pointer ps-5\" (click)=\"nobStore('single')\" [ngClass]=\"typeNOB ==='single' ? 'form-check-inline':'form-check-inline-none'\" >\r\n <svg *ngIf=\"typeNOB ==='single'\" style=\"margin-top: -5px !important;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"#EAF8FF\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#00A3FF\"/>\r\n <circle cx=\"8\" cy=\"8\" r=\"3\" fill=\"#00A3FF\"/>\r\n </svg>\r\n\r\n <svg *ngIf=\"typeNOB !=='single'\" style=\"margin-top: -5px !important;\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"white\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#D0D5DD\"/>\r\n </svg>\r\n <!-- <input class=\"form-check-input ms-10\" type=\"radio\" name=\"inlineRadioOptions\" id=\"inlineRadio1\" value=\"option1\"> -->\r\n <span class=\"ms-3 pt-12\" [ngClass]=\"typeNOB ==='single' ? 'form-text-primary ':'form-defult'\">Single Store</span>\r\n </div>\r\n <div class=\"form-check w-50 cursor-pointer ps-5\" (click)=\"nobStore('multiple')\" [ngClass]=\"typeNOB ==='multiple' ? 'form-check-inline':'form-check-inline-none'\">\r\n <svg *ngIf=\"typeNOB ==='multiple'\" style=\"margin-top: -5px !important;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"#EAF8FF\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#00A3FF\"/>\r\n <circle cx=\"8\" cy=\"8\" r=\"3\" fill=\"#00A3FF\"/>\r\n </svg>\r\n\r\n <svg *ngIf=\"typeNOB !=='multiple'\" style=\"margin-top: -5px !important;\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"white\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#D0D5DD\"/>\r\n </svg>\r\n <span class=\"ms-3 pt-12\" [ngClass]=\"typeNOB ==='multiple' ? 'form-text-primary':'form-defult'\">Multiple Stores</span>\r\n \r\n </div>\r\n </div>\r\n <div *ngIf=\"typeNOB ==='single'\" class=\"w-100 h-0px scroll\">\r\n <div class=\"mt-5\">\r\n <div class=\"row px-0 me-3\">\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"storeName\" class=\"form-label\">Store Name<span\r\n class=\"alert-required text-danger\"> *</span></label>\r\n <lib-custom-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeName'\"\r\n [idField]=\"'storeName'\" (selected)=\"onNOBStoreSelect($event, 'storeName')\"\r\n [selectedValues]=\"[{ storeName: storeName }]\">\r\n </lib-custom-select>\r\n </div>\r\n\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"storeID\" class=\"form-label\">Store ID /<span *ngIf=\"type !=='add'\"> Store Code</span><span *ngIf=\"type ==='add'\"> Reference Code</span> <span\r\n class=\"alert-required text-danger\"> *</span></label>\r\n <lib-custom-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeId'\"\r\n [idField]=\"'storeId'\" (selected)=\"onNOBStoreSelect($event, 'storeId')\"\r\n [selectedValues]=\"[{ storeId: storeId }]\">\r\n </lib-custom-select>\r\n </div>\r\n\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"Date\" class=\"form-label\">Select Date <span\r\n class=\"alert-required text-danger\">*</span></label>\r\n <input type=\"date\" class=\"form-control\" id=\"myDate\" [(ngModel)]=\"dateValue\"\r\n (change)=\"onDateChange($event)\" [max]=\"maxDate\">\r\n </div>\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"count\" class=\"form-label\">NOB Count <span\r\n class=\"alert-required text-danger\">*</span></label>\r\n <input type=\"text\" class=\"form-control\" [(ngModel)]=\"nobCount\"\r\n (keypress)=\"omit_special_char($event)\">\r\n </div>\r\n <div class=\"d-flex mt-3 mb-10\" 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\" id=\"alert-toast\" (click)=\"onSubmit()\"\r\n [disabled]=\"!dateValue || !nobCount || !storeId || !storeName\"><span *ngIf=\"type !=='add'\">Proceed</span><span *ngIf=\"type ==='add'\">Add</span></button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div *ngIf=\"typeNOB ==='multiple'\" class=\"d-flex justify-content\">\r\n <div class=\"fw-bold text-gray-500 my-6\">\r\n <ul class=\"text-gray-400 fw-bold fs-6\">\r\n <li class=\"user-text\">Use the template to upload multiple NoB\u2019s at once.</li>\r\n <li class=\"user-text \">Download the template here - <a href=\"../../assets/files/nobUploadTemplate.xlsx\" download><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\r\n <path d=\"M17.5 13V16.3333C17.5 16.7754 17.3244 17.1993 17.0118 17.5118C16.6993 17.8244 16.2754 18 15.8333 18H4.16667C3.72464 18 3.30072 17.8244 2.98816 17.5118C2.67559 17.1993 2.5 16.7754 2.5 16.3333V13M5.83333 8.83333L10 13M10 13L14.1667 8.83333M10 13V3\" stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg><span class=\"ms-2 text-download\">Download Template</span></a></li>\r\n <li class=\"user-text \">Add your data to the Template File</li>\r\n <li class=\"user-text\">Upload it below for processing</li>\r\n \r\n </ul>\r\n </div>\r\n </div>\r\n <div *ngIf=\"typeNOB ==='multiple'\"\r\n class=\"mt-3 ms-3 right-bar py-10 d-flex justify-content-center align-items-center flex-column\">\r\n <input name=\"accountType\" type=\"radio\" id=\"kt_create_account_form_account_type_personal\"\r\n value=\"personal\" class=\"btn-check\" ng-reflect-name=\"accountType\"\r\n ng-reflect-form-control-name=\"accountType\" (change)=\"onUpload($event)\"\r\n ng-reflect-value=\"personal\" type=\"file\" #inputFile />\r\n <label for=\"kt_create_account_form_account_type_personal\" class=\" w-50 p-4 mt-5\"><span\r\n class=\"fw-bold text-center w-100 fs-4\">\r\n<div class=\"d-flex justify-content-center align-items-center w-100\">\r\n <svg width=\"46\" height=\"46\" viewBox=\"0 0 46 46\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"3\" y=\"3\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#F2F4F7\" />\r\n <rect x=\"3\" y=\"3\" width=\"40\" height=\"40\" rx=\"20\" stroke=\"#F9FAFB\"\r\n stroke-width=\"6\" />\r\n <g clip-path=\"url(#clip0_4047_40566)\">\r\n <path\r\n d=\"M26.3333 26.3334L23 23M23 23L19.6666 26.3334M23 23V30.5M29.9916 28.325C30.8044 27.8819 31.4465 27.1808 31.8165 26.3322C32.1866 25.4837 32.2635 24.5361 32.0351 23.6389C31.8068 22.7418 31.2862 21.9463 30.5555 21.3779C29.8248 20.8095 28.9257 20.5006 28 20.5H26.95C26.6977 19.5244 26.2276 18.6186 25.5749 17.8509C24.9222 17.0831 24.104 16.4732 23.1817 16.0672C22.2594 15.6612 21.2571 15.4695 20.2501 15.5066C19.243 15.5437 18.2575 15.8086 17.3676 16.2814C16.4777 16.7542 15.7066 17.4226 15.1122 18.2363C14.5177 19.0501 14.1155 19.988 13.9358 20.9795C13.756 21.9711 13.8034 22.9905 14.0743 23.9611C14.3452 24.9317 14.8327 25.8282 15.5 26.5834\"\r\n stroke=\"#475467\" stroke-width=\"1.66667\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_4047_40566\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(13 13)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </div>\r\n <div class=\"nodata-title\"><span class=\"click-upload cursor-pointer\">Click to\r\n upload </span>\r\n <!-- <span class=\"drag-drop\"> or drag and drop the template</span> -->\r\n </div>\r\n \r\n </span>\r\n </label>\r\n </div>\r\n\r\n <div *ngIf=\"typeNOB ==='multiple'\" class=\"d-flex mt-3 mb-10\" 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\" id=\"alert-toast\" (click)=\"proceed()\"\r\n >Proceed</button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n</div>", styles: [".scroll{overflow-y:auto;overflow-x:hidden}.title{color:var(--Gray-900, #101828)!important;font-size:18px!important;font-weight:600;line-height:28px}.sub-title{color:var(--Gray-500, #667085)!important;font-size:14px!important;font-weight:400!important;line-height:20px}.teams-title{color:var(--Black, #101828)!important;font-size:18px!important;font-weight:600!important;line-height:28px}.title-header{border-radius:6px!important;border-bottom:2px solid var(--Gray-200, #EAECF0)!important;background:#f2f4f7!important;box-shadow:0 4px 10px #0000000d!important;color:var(--Black, #101828)!important;font-size:20px!important;font-weight:600;line-height:30px;padding:8px 16px}input[type=checkbox]{width:18px!important;height:18px!important;margin: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:.5em;padding-left:0;padding-top:12px;padding-right:6px}.global-label{color:var(--Gray-700, #344054)!important;font-size:16px!important;font-weight:500;line-height:24px}.w-25{width:40%!important}td{color:var(--Black, #101828)!important;font-size:16px!important;font-weight:500!important;line-height:24px}tr,.add-team{border-bottom:1px solid var(--Gray-200, #EAECF0)!important}input[disabled]{pointer-events:none;opacity:.5}input.form-control{margin-bottom:10px}.dropdown-menu{max-height:200px;overflow-y:auto}.dropdown-item{cursor:pointer}.btn-outline-primary{width:100%;text-align:left}.form-check-inline{border-radius:8px;border:1px solid var(--Primary-700, #009BF3);background:var(--Primary-25, #F6FCFF);padding:16px}.form-check-label{color:var(--Gray-900, #101828)!important;font-size:16px!important;font-weight:600;line-height:24px}.form-check-inline-none{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);padding:16px;margin-right:1rem}.right-bar{border-radius:8px!important;border:1px solid var(--Gray-200, #EAECF0)!important;background:var(--White, #FFF);padding:16px 24px!important}.drag-drop{color:var(--Gray-500, #667085)!important;font-size:14px!important;font-weight:400;line-height:20px}.click-upload{color:var(--Primary-700, #009BF3);font-family:Inter;font-size:14px;font-style:normal;font-weight:600;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font;text-transform:capitalize}.user-text{color:var(--Gray-500, #344054)!important;font-size:14px!important;font-weight:400!important;line-height:28px;list-style:decimal!important}.form-text-primary{color:var(--Primary-700, #009BF3)!important;font-size:16px!important;font-weight:600;line-height:24px}.form-defult{color:var(--Gray-900, #101828)!important;font-size:16px!important;font-weight:600;line-height:24px}\n"] }]
|
|
255
|
-
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.TrafficService }, { type: i3.
|
|
447
|
+
args: [{ selector: 'lib-add-nob', providers: [DatePipe], template: "<div *ngIf=\"type !=='editView' && type !== 'view'\" class=\"card pt-0 pb-3 scroll\">\r\n <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n <div class=\"my-5 d-flex\">\r\n <div *ngIf=\"type ==='add'\" class=\"symbol symbol-75px symbol-circle\">\r\n <img alt=\"Pic\" src=\"./assets/tango/Icons/add-store-icon.svg\">\r\n </div>\r\n <div *ngIf=\"type ==='reupload'\" 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 31V35C37 35.5304 36.7893 36.0391 36.4142 36.4142C36.0391 36.7893 35.5304 37 35 37H21C20.4696 37 19.9609 36.7893 19.5858 36.4142C19.2107 36.0391 19 35.5304 19 35V31M33 24L28 19M28 19L23 24M28 19V31\" stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n \r\n </div>\r\n </div>\r\n <div class=\"row w-100\">\r\n <div *ngIf=\"type ==='add'\" class=\"col-md-12\">\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Add Single NoB</a>\r\n </div>\r\n <div *ngIf=\"type ==='reupload'\" class=\"col-md-12\">\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Upload NoB for</a>\r\n </div>\r\n<div *ngIf=\"type ==='reupload'\" class=\"d-flex align-items-center mt-5\">\r\n <div class=\"form-check w-50 cursor-pointer ps-5\" (click)=\"nobStore('single')\" [ngClass]=\"typeNOB ==='single' ? 'form-check-inline':'form-check-inline-none'\" >\r\n <svg *ngIf=\"typeNOB ==='single'\" style=\"margin-top: -5px !important;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"#EAF8FF\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#00A3FF\"/>\r\n <circle cx=\"8\" cy=\"8\" r=\"3\" fill=\"#00A3FF\"/>\r\n </svg>\r\n\r\n <svg *ngIf=\"typeNOB !=='single'\" style=\"margin-top: -5px !important;\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"white\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#D0D5DD\"/>\r\n </svg>\r\n <!-- <input class=\"form-check-input ms-10\" type=\"radio\" name=\"inlineRadioOptions\" id=\"inlineRadio1\" value=\"option1\"> -->\r\n <span class=\"ms-3 pt-12\" [ngClass]=\"typeNOB ==='single' ? 'form-text-primary ':'form-defult'\">Single Store</span>\r\n </div>\r\n <div class=\"form-check w-50 cursor-pointer ps-5\" (click)=\"nobStore('multiple')\" [ngClass]=\"typeNOB ==='multiple' ? 'form-check-inline':'form-check-inline-none'\">\r\n <svg *ngIf=\"typeNOB ==='multiple'\" style=\"margin-top: -5px !important;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"#EAF8FF\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#00A3FF\"/>\r\n <circle cx=\"8\" cy=\"8\" r=\"3\" fill=\"#00A3FF\"/>\r\n </svg>\r\n\r\n <svg *ngIf=\"typeNOB !=='multiple'\" style=\"margin-top: -5px !important;\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"white\"/>\r\n <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#D0D5DD\"/>\r\n </svg>\r\n <span class=\"ms-3 pt-12\" [ngClass]=\"typeNOB ==='multiple' ? 'form-text-primary':'form-defult'\">Multiple Stores</span>\r\n \r\n </div>\r\n </div>\r\n <div *ngIf=\"typeNOB ==='single'\" class=\"w-100 h-0px scroll\">\r\n <div class=\"mt-5\">\r\n <div class=\"row px-0 me-3\">\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"storeName\" class=\"form-label\">Store Name<span\r\n class=\"alert-required text-danger\"> *</span></label>\r\n <lib-custom-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeName'\"\r\n [idField]=\"'storeName'\" (selected)=\"onNOBStoreSelect($event, 'storeName')\"\r\n [selectedValues]=\"[{ storeName: storeName }]\">\r\n </lib-custom-select>\r\n </div>\r\n\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"storeID\" class=\"form-label\">Store ID /<span *ngIf=\"type !=='add'\"> Store Code</span><span *ngIf=\"type ==='add'\"> Reference Code</span> <span\r\n class=\"alert-required text-danger\"> *</span></label>\r\n <lib-custom-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeId'\"\r\n [idField]=\"'storeId'\" (selected)=\"onNOBStoreSelect($event, 'storeId')\"\r\n [selectedValues]=\"[{ storeId: storeId }]\">\r\n </lib-custom-select>\r\n </div>\r\n\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"Date\" class=\"form-label\">Select Date <span\r\n class=\"alert-required text-danger\">*</span></label>\r\n <input type=\"date\" class=\"form-control\" id=\"myDate\" [(ngModel)]=\"dateValue\"\r\n (change)=\"onDateChange($event)\" [max]=\"maxDate\">\r\n </div>\r\n <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n <label for=\"count\" class=\"form-label\">NOB Count <span\r\n class=\"alert-required text-danger\">*</span></label>\r\n <input type=\"text\" class=\"form-control\" [(ngModel)]=\"nobCount\"\r\n (keypress)=\"omit_special_char($event)\">\r\n </div>\r\n <div *ngIf=\"zoneShow\" class=\"col-12\">\r\n <div *ngIf=\"clientData?.isZonewiseNOB\" class=\"toggle-wrapper\">\r\n <label class=\"switch\">\r\n <input type=\"checkbox\" [(ngModel)]=\"isEnabled\" (change)=\"onCheckboxChange($event)\" />\r\n <span class=\"slider\"></span>\r\n </label>\r\n\r\n <span class=\"toggle-label\">\r\n Add Zone-wise NoB Count\r\n </span>\r\n</div>\r\n\r\n </div>\r\n <div *ngIf=\"isEnabled\" class=\"table-responsive\">\r\n <table class=\"table bottom-border text-nowrap mt-5\">\r\n <thead>\r\n <tr>\r\n <th scope=\"col\">Zone Name</th>\r\n <th scope=\"col\">NoB Count</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let zone of zoneList\">\r\n <td class=\"py-3 mt-10\">{{zone.tagName}}</td>\r\n <td class=\"py-2\"><input type=\"text\" class=\"form-control form-control-sm mb-0 py-0\" [(ngModel)]=\"zone.nobCount\" (ngModelChange)=\"onNobChange()\" \r\n (keypress)=\"omit_special_char($event)\"></td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n <div *ngIf=\"erroShow\" class=\"text-danger mt-2\"><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<g clip-path=\"url(#clip0_15055_156438)\">\r\n<path d=\"M9 6V9M9 12H9.0075M16.5 9C16.5 13.1421 13.1421 16.5 9 16.5C4.85786 16.5 1.5 13.1421 1.5 9C1.5 4.85786 4.85786 1.5 9 1.5C13.1421 1.5 16.5 4.85786 16.5 9Z\" stroke=\"#B42318\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</g>\r\n<defs>\r\n<clipPath id=\"clip0_15055_156438\">\r\n<rect width=\"18\" height=\"18\" fill=\"white\"/>\r\n</clipPath>\r\n</defs>\r\n</svg></span>{{ erroShow }}</div>\r\n\r\n <div class=\"d-flex mt-3 mb-10\" role=\"group\">\r\n <button class=\"btn btn-outline w-100 me-3\" (click)=\"cancel()\">Cancel</button>\r\n <button\r\n class=\"btn btn-primary w-100 ms-3\"\r\n id=\"alert-toast\"\r\n (click)=\"onSubmit()\"\r\n [disabled]=\"\r\n !dateValue ||\r\n !nobCount ||\r\n !storeId ||\r\n !storeName ||\r\n isSubmitting\r\n \"\r\n>\r\n <span *ngIf=\"!isSubmitting && type !== 'add'\">Proceed</span>\r\n <span *ngIf=\"!isSubmitting && type === 'add'\">Add</span>\r\n <span *ngIf=\"isSubmitting\">Please wait...</span>\r\n</button>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div *ngIf=\"typeNOB ==='multiple'\" class=\"d-flex justify-content\">\r\n <div class=\"fw-bold text-gray-500 my-6\">\r\n <ul class=\"text-gray-400 fw-bold fs-6\">\r\n <li class=\"user-text\">Use the template to upload multiple NoB\u2019s at once.</li>\r\n <li class=\"user-text \">Download the template here - <a *ngIf=\"!clientData?.isZonewiseNOB\" href=\"../../assets/files/nobUploadTemplate.xlsx\" download><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\r\n <path d=\"M17.5 13V16.3333C17.5 16.7754 17.3244 17.1993 17.0118 17.5118C16.6993 17.8244 16.2754 18 15.8333 18H4.16667C3.72464 18 3.30072 17.8244 2.98816 17.5118C2.67559 17.1993 2.5 16.7754 2.5 16.3333V13M5.83333 8.83333L10 13M10 13L14.1667 8.83333M10 13V3\" stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg><span class=\"ms-2 text-download text-primary\">Download Template</span></a> <span *ngIf=\"clientData?.isZonewiseNOB\" class=\" text-active-primary\" (click)=\"download()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\r\n <path d=\"M17.5 13V16.3333C17.5 16.7754 17.3244 17.1993 17.0118 17.5118C16.6993 17.8244 16.2754 18 15.8333 18H4.16667C3.72464 18 3.30072 17.8244 2.98816 17.5118C2.67559 17.1993 2.5 16.7754 2.5 16.3333V13M5.83333 8.83333L10 13M10 13L14.1667 8.83333M10 13V3\" stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg><span class=\"ms-2 text-download text-primary cursor-pointer\">Download Template</span></span></li>\r\n <li class=\"user-text \">Add your data to the Template File</li>\r\n <li class=\"user-text\">Upload it below for processing</li>\r\n \r\n </ul>\r\n </div>\r\n </div>\r\n <div *ngIf=\"typeNOB ==='multiple'\"\r\n class=\"mt-3 ms-3 right-bar py-10 d-flex justify-content-center align-items-center flex-column\">\r\n <input name=\"accountType\" type=\"radio\" id=\"kt_create_account_form_account_type_personal\"\r\n value=\"personal\" class=\"btn-check\" ng-reflect-name=\"accountType\"\r\n ng-reflect-form-control-name=\"accountType\" (change)=\"onUpload($event)\"\r\n ng-reflect-value=\"personal\" type=\"file\" #inputFile />\r\n <label for=\"kt_create_account_form_account_type_personal\" class=\" w-50 p-4 mt-5\"><span\r\n class=\"fw-bold text-center w-100 fs-4\">\r\n<div class=\"d-flex justify-content-center align-items-center w-100\">\r\n <svg width=\"46\" height=\"46\" viewBox=\"0 0 46 46\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <rect x=\"3\" y=\"3\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#F2F4F7\" />\r\n <rect x=\"3\" y=\"3\" width=\"40\" height=\"40\" rx=\"20\" stroke=\"#F9FAFB\"\r\n stroke-width=\"6\" />\r\n <g clip-path=\"url(#clip0_4047_40566)\">\r\n <path\r\n d=\"M26.3333 26.3334L23 23M23 23L19.6666 26.3334M23 23V30.5M29.9916 28.325C30.8044 27.8819 31.4465 27.1808 31.8165 26.3322C32.1866 25.4837 32.2635 24.5361 32.0351 23.6389C31.8068 22.7418 31.2862 21.9463 30.5555 21.3779C29.8248 20.8095 28.9257 20.5006 28 20.5H26.95C26.6977 19.5244 26.2276 18.6186 25.5749 17.8509C24.9222 17.0831 24.104 16.4732 23.1817 16.0672C22.2594 15.6612 21.2571 15.4695 20.2501 15.5066C19.243 15.5437 18.2575 15.8086 17.3676 16.2814C16.4777 16.7542 15.7066 17.4226 15.1122 18.2363C14.5177 19.0501 14.1155 19.988 13.9358 20.9795C13.756 21.9711 13.8034 22.9905 14.0743 23.9611C14.3452 24.9317 14.8327 25.8282 15.5 26.5834\"\r\n stroke=\"#475467\" stroke-width=\"1.66667\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </g>\r\n <defs>\r\n <clipPath id=\"clip0_4047_40566\">\r\n <rect width=\"20\" height=\"20\" fill=\"white\"\r\n transform=\"translate(13 13)\" />\r\n </clipPath>\r\n </defs>\r\n </svg>\r\n </div>\r\n <div class=\"nodata-title\"><span class=\"click-upload cursor-pointer\">Click to\r\n upload </span>\r\n <!-- <span class=\"drag-drop\"> or drag and drop the template</span> -->\r\n </div>\r\n \r\n </span>\r\n </label>\r\n </div>\r\n\r\n <div *ngIf=\"typeNOB ==='multiple'\" class=\"d-flex mt-3 mb-10\" 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\" id=\"alert-toast\" (click)=\"proceed()\"\r\n >Proceed</button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n</div>\r\n<div *ngIf=\"type ==='editView' || type === 'view'\" class=\"card pt-0 pb-3 \">\r\n <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n \r\n <div class=\"row w-100 mt-5\">\r\n \r\n <div class=\"col-md-6\">\r\n <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Zone-wise NoB\r\n Count</a>\r\n </div>\r\n <div *ngIf=\"type === 'view'\" class=\"col-md-6 text-end\">\r\n <span class=\"cursor-pointer\" (click)=\"cancel()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\">\r\n<path d=\"M13 1L1 13M1 1L13 13\" stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg></span>\r\n </div>\r\n \r\n <div *ngIf=\"zoneList?.length\" class=\"table-responsive max-h-500\">\r\n <table class=\"table bottom-border text-nowrap mt-5\">\r\n <thead>\r\n <tr>\r\n <th scope=\"col\">Zone Name</th>\r\n <th scope=\"col\">NoB Count</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let zone of zoneList;let i = index\">\r\n <td class=\"py-3 mt-10\">{{zone.zoneName}}</td>\r\n <td class=\"py-2\"><span *ngIf=\"type === 'view' || !isEditEnabled\">\r\n {{ zone.nobCount }}\r\n </span>\r\n\r\n <!-- EDIT MODE -->\r\n <input *ngIf=\"type === 'editView' && isEditEnabled\" type=\"text\" class=\"form-control form-control-sm\"\r\n [(ngModel)]=\"zone.nobCount\" (ngModelChange)=\"onNobChange()\"\r\n (keypress)=\"omit_special_char($event)\" />\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n <div *ngIf=\"!zoneList?.length\" 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-nodata-table\" 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 Zone-wise NoB count</div>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"erroShow\" class=\"text-danger mt-2\"><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<g clip-path=\"url(#clip0_15055_156438)\">\r\n<path d=\"M9 6V9M9 12H9.0075M16.5 9C16.5 13.1421 13.1421 16.5 9 16.5C4.85786 16.5 1.5 13.1421 1.5 9C1.5 4.85786 4.85786 1.5 9 1.5C13.1421 1.5 16.5 4.85786 16.5 9Z\" stroke=\"#B42318\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</g>\r\n<defs>\r\n<clipPath id=\"clip0_15055_156438\">\r\n<rect width=\"18\" height=\"18\" fill=\"white\"/>\r\n</clipPath>\r\n</defs>\r\n</svg></span>{{ erroShow }}</div>\r\n\r\n <div *ngIf=\"type ==='editView' && isEditEnabled\" class=\"d-flex mt-3 mb-10\" role=\"group\">\r\n <button class=\"btn btn-outline w-100 me-3\" (click)=\"cancelEdit()\">Cancel</button>\r\n <button class=\"btn btn-primary w-100 ms-3\" id=\"alert-toast\" (click)=\"onSubmit()\"\r\n [disabled]=\"!dateValue || !nobCount || !storeId || !storeName\"><span\r\n *ngIf=\"type !=='add'\">Save</span><span *ngIf=\"type ==='add'\">Add</span></button>\r\n </div>\r\n \r\n </div>\r\n </div>\r\n</div>", styles: [".scroll{overflow-y:auto;overflow-x:hidden}.title{color:var(--Gray-900, #101828)!important;font-size:18px!important;font-weight:600;line-height:28px}.sub-title{color:var(--Gray-500, #667085)!important;font-size:14px!important;font-weight:400!important;line-height:20px}.teams-title{color:var(--Black, #101828)!important;font-size:18px!important;font-weight:600!important;line-height:28px}.title-header{border-radius:6px!important;border-bottom:2px solid var(--Gray-200, #EAECF0)!important;background:#f2f4f7!important;box-shadow:0 4px 10px #0000000d!important;color:var(--Black, #101828)!important;font-size:20px!important;font-weight:600;line-height:30px;padding:8px 16px}input[type=checkbox]{width:18px!important;height:18px!important;margin: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:.5em;padding-left:0;padding-top:12px;padding-right:6px}.global-label{color:var(--Gray-700, #344054)!important;font-size:16px!important;font-weight:500;line-height:24px}.w-25{width:40%!important}td{color:var(--Black, #101828)!important;font-size:16px!important;font-weight:500!important;line-height:24px}tr,.add-team{border-bottom:1px solid var(--Gray-200, #EAECF0)!important}input[disabled]{pointer-events:none;opacity:.5}input.form-control{margin-bottom:10px}.dropdown-menu{max-height:200px;overflow-y:auto}.dropdown-item{cursor:pointer}.btn-outline-primary{width:100%;text-align:left}.form-check-inline{border-radius:8px;border:1px solid var(--Primary-700, #009BF3);background:var(--Primary-25, #F6FCFF);padding:16px}.form-check-label{color:var(--Gray-900, #101828)!important;font-size:16px!important;font-weight:600;line-height:24px}.form-check-inline-none{border-radius:8px;border:1px solid var(--Gray-300, #D0D5DD);background:var(--White, #FFF);padding:16px;margin-right:1rem}.right-bar{border-radius:8px!important;border:1px solid var(--Gray-200, #EAECF0)!important;background:var(--White, #FFF);padding:16px 24px!important}.drag-drop{color:var(--Gray-500, #667085)!important;font-size:14px!important;font-weight:400;line-height:20px}.click-upload{color:var(--Primary-700, #009BF3);font-family:Inter;font-size:14px;font-style:normal;font-weight:600;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font;text-transform:capitalize}.user-text{color:var(--Gray-500, #344054)!important;font-size:14px!important;font-weight:400!important;line-height:28px;list-style:decimal!important}.form-text-primary{color:var(--Primary-700, #009BF3)!important;font-size:16px!important;font-weight:600;line-height:24px}.form-defult{color:var(--Gray-900, #101828)!important;font-size:16px!important;font-weight:600;line-height:24px}table td{height:24px!important;align-items:center}.toggle-wrapper{display:flex;align-items:center;gap:12px}.switch{position:relative;display:inline-block;width:46px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#f2f4f7;transition:.3s;border-radius:24px}.slider:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.switch input:checked+.slider{background-color:#0d6efd}.switch input:checked+.slider:before{transform:translate(22px)}.text-danger{color:#b42318!important}.max-h-500{max-height:500px;overflow-y:auto}\n"] }]
|
|
448
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.TrafficService }, { type: i3.ExcelService }, { type: i4.NgbActiveModal }, { type: i5.ToastService }, { type: i0.ChangeDetectorRef }, { type: i6.DatePipe }], propDecorators: { type: [{
|
|
449
|
+
type: Input
|
|
450
|
+
}], viewData: [{
|
|
256
451
|
type: Input
|
|
257
452
|
}], inputFile: [{
|
|
258
453
|
type: ViewChild,
|
|
259
454
|
args: ["inputFile"]
|
|
260
455
|
}] } });
|
|
261
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-nob.component.js","sourceRoot":"","sources":["../../../../../../projects/tango-analyse-traffic/src/lib/components/add-nob/add-nob.component.ts","../../../../../../projects/tango-analyse-traffic/src/lib/components/add-nob/add-nob.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { TrafficService } from '../../services/traffic.service';\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';\r\nimport { ToastService } from 'tango-app-ui-shared';\r\nimport * as XLSX from 'xlsx';\r\nimport { DatePipe } from '@angular/common';\r\n@Component({\r\n  selector: 'lib-add-nob',\r\n  templateUrl: './add-nob.component.html',\r\n  styleUrl: './add-nob.component.scss',\r\n  providers: [DatePipe]\r\n})\r\nexport class AddNobComponent implements OnInit,OnDestroy {\r\n@Input() type:any;\r\n\r\nnobForm: FormGroup;\r\nprivate readonly destroy$ = new Subject();\r\nconstructor(private fb:FormBuilder,private service:TrafficService,private activeModal :NgbActiveModal,private ts: ToastService,private cd:ChangeDetectorRef,private datePipe: DatePipe){\r\n\r\n}\r\nngOnDestroy(): void {\r\n  this.destroy$.next(true);\r\n  this.destroy$.complete();\r\n}\r\nclientId:any;\r\nmaxDate: string = '';\r\nngOnInit(): void {\r\nlet data: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"\");\r\nthis.clientId =data.client\r\nthis.getNobStoreList(data.client);\r\nthis.setMaxDate();\r\n}\r\n\r\n\r\nstoreList:any[]=[];\r\ngetNobStoreList(client:any){\r\n  this.service.getNOBStoreList(client)?.pipe(takeUntil(this.destroy$))\r\n  .subscribe({\r\n    next: (res: any) => {\r\n      if(res && res.code === 200){\r\n        this.storeList =res.data.result\r\n      }\r\n    },\r\n    error: (err) => {\r\n      \r\n    }\r\n  })\r\n}\r\n\r\nstoreName:any;\r\nstoreId:any;\r\ndateValue:any;\r\nstoreCode:any;\r\nnobCount:any;\r\nonNOBStoreSelect(event: any, type: 'storeName' | 'storeId'): void {\r\n  if (!event) {\r\n    this.ts.getErrorToast('storeName or storeId is undefined or invalid');\r\n    return;\r\n  }\r\n  if (type === 'storeName') {\r\n    this.storeName = event.storeName;\r\n    const store = this.storeList.find(store => store.storeName === event.storeName);\r\n    if (store) {\r\n      this.storeId = store.storeId;\r\n      this.storeCode = store.storeCode; \r\n    } else {\r\n      this.storeId = '';\r\n      this.storeCode = '';\r\n    }\r\n  }\r\n\r\n  else if (type === 'storeId') {\r\n    this.storeId = event.storeId;\r\n    const store = this.storeList.find(store => store.storeId === event.storeId);\r\n    if (store) {\r\n      this.storeName = store.storeName;\r\n      this.storeCode = store.storeCode; \r\n    } else {\r\n      this.storeName = '';\r\n      this.storeCode = ''; \r\n    }\r\n  }\r\n\r\n  \r\n}\r\nomit_special_char(event: any) {\r\n  var k;\r\n  k = event.charCode; //         k = event.keyCode;  (Both can be used)\r\n  return k == 8 || k == 32 || (k >= 48 && k <= 57);\r\n}\r\nsetMaxDate(): void {\r\n  const today = new Date();\r\n  const yesterday = new Date(today);\r\n  yesterday.setDate(today.getDate() - 1); // Set the max date to yesterday\r\n  this.dateValue = yesterday.toISOString().split('T')[0];\r\n  // Format the date as yyyy-MM-dd\r\n  this.maxDate = yesterday.toISOString().split('T')[0];\r\n}\r\nonDateChange(event: any): void {\r\n  const selectedDate = event.target.value;\r\n  if (selectedDate > this.maxDate) {\r\n    this.ts.getErrorToast('Invalid date selected!');\r\n  }\r\n}\r\ncancel(){\r\n  this.activeModal.close('close');\r\n}\r\nonSubmit(){\r\n  let obj ={\r\n    bills: [\r\n      {\r\n        // storeId: this.storeId,\r\n        storeCode: this.storeCode ? this.storeCode : this.storeId,\r\n        // storeName: this.storeName,\r\n        nobDate: this.dateValue,\r\n        nobCount: Number(this.nobCount)\r\n      }\r\n    ],\r\n    clientId: this.clientId\r\n  }\r\nthis.service.getNOBDataList(obj)?.pipe(takeUntil(this.destroy$))\r\n.subscribe({\r\n  next: (res: any) => {\r\n      if (res.code === 200 && res) {\r\n        const allMessages = res.message\r\n          // .map((item:any) => {\r\n          //   const status = item.code === 200 ? '✅' : '❌'; \r\n          //   const storeInfo = item.storeId ? `${item.storeId}` : '';\r\n          //   return `${status} ${storeInfo}: ${item.message}`;\r\n          // })\r\n          // .join('<br>'); \r\n        this.ts.getSuccessToast(allMessages);\r\n        this.activeModal.close('submit');\r\n      } else {\r\n        this.ts.getErrorToast('Unexpected response format');\r\n      }\r\n    },\r\n    error: (err: any) => {\r\n      this.ts.getErrorToast(err.error.error ? err.error.error:err.error.error);\r\n    },\r\n\r\n})\r\n}\r\n\r\n\r\ntypeNOB ='single'\r\nnobStore(type:any){\r\n  this.typeNOB =type\r\n}\r\ndataTableShow =false;\r\ndataTableShow1 =false;\r\ntableHeaders:any;\r\nconvertedData:any;\r\n@ViewChild(\"inputFile\") inputFile: ElementRef;\r\nonUpload(event: any): void {\r\n  const file = event.target.files[0];\r\n  const reader = new FileReader();\r\n  reader.onload = (e: any) => {\r\n    const binaryData: string = e.target.result;\r\n    try {\r\n      const workbook: XLSX.WorkBook = XLSX.read(binaryData, { type: 'binary' });\r\n      const sheetName: string = workbook.SheetNames[0];\r\n\r\n      if (sheetName !== 'NOB') {\r\n        this.ts.getErrorToast(\"Please upload a valid file.\");\r\n        this.resetFileInput();\r\n        return;\r\n      }\r\n\r\n      const sheet: XLSX.WorkSheet = workbook.Sheets[sheetName];\r\n      const jsonData = XLSX.utils.sheet_to_json(sheet, { header: 1 });\r\n      if (jsonData.length > 100) { \r\n        this.ts.getErrorToast(\"File contains too many rows. Please limit to 100 rows.\");\r\n        this.resetFileInput();\r\n        this.dataTableShow1 = true; \r\n        this.cd.detectChanges();\r\n        return;\r\n      } else {\r\n        this.dataTableShow = true;\r\n        this.dataTableShow1 = false; \r\n      }\r\n      const headers: any = jsonData[0];\r\n      this.tableHeaders = headers;\r\n      const dataRows = jsonData.slice(1);\r\n      this.convertedData = {\r\n        bills: dataRows.map((row: any) => {\r\n          const obj: any = {};\r\n          headers.forEach((header: any, index: any) => {\r\n            let cellValue = row[index];\r\n            if (header === \"NOBDate\" && typeof cellValue === \"number\") {\r\n              cellValue = this.convertExcelDate(cellValue); \r\n            } else {\r\n              this.ts.getErrorToast(`Please upload a valid NOB Date Format`);\r\n            }\r\n            if (header === \"StoreId\" && cellValue != null) {\r\n              cellValue = cellValue.toString();\r\n            }\r\n            obj[header] = cellValue;\r\n          });\r\n          return {\r\n            storeCode: obj[\"StoreId\"],\r\n            nobDate: this.datePipe.transform(obj[\"NOBDate\"], \"yyyy-MM-dd\"),\r\n            nobCount: Number(obj[\"NOBCount\"]),\r\n          };\r\n        })\r\n        .filter((bill: any) => bill.nobDate !== null && bill.nobCount !== null), \r\n        clientId: this.clientId\r\n      };\r\n      this.ts.getSuccessToast(`File has been uploaded`);\r\n      this.cd.detectChanges();\r\n    } catch (error) {\r\n      this.ts.getErrorToast(`Please upload a valid file: ${error}`);\r\n    }\r\n    this.resetFileInput();\r\n  };\r\n  reader.readAsBinaryString(file);\r\n}\r\nresetFileInput(): void {\r\n  if (this.inputFile && this.inputFile.nativeElement) {\r\n    this.inputFile.nativeElement.value = '';\r\n  }\r\n}\r\n\r\nconvertExcelDate(excelDate: number): string {\r\n  const baseDate = new Date(1900, 0, 1); \r\n  const correctedDate = new Date(baseDate.getTime() + (excelDate - 1) * 86400000);\r\n  return correctedDate.toISOString().split(\"T\")[0]; \r\n}\r\n\r\nproceed(){\r\n  this.service.getNOBDataList(this.convertedData)?.pipe(takeUntil(this.destroy$))\r\n  .subscribe({\r\n    next: (res: any) => {\r\n        if (res.code === 200 && res) {\r\n          const allMessages = res.message\r\n          this.ts.getSuccessToast(allMessages);\r\n    this.activeModal.close('submit')\r\n        } else {\r\n          this.ts.getErrorToast('Unexpected response format');\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.ts.getErrorToast(err.error.error);\r\n      },\r\n  \r\n  })\r\n}\r\n}\r\n","<div class=\"card pt-0 pb-3 scroll\">\r\n    <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n        <div class=\"my-5 d-flex\">\r\n            <div *ngIf=\"type ==='add'\" class=\"symbol symbol-75px symbol-circle\">\r\n                <img alt=\"Pic\" src=\"./assets/tango/Icons/add-store-icon.svg\">\r\n            </div>\r\n            <div *ngIf=\"type ==='reupload'\" 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 31V35C37 35.5304 36.7893 36.0391 36.4142 36.4142C36.0391 36.7893 35.5304 37 35 37H21C20.4696 37 19.9609 36.7893 19.5858 36.4142C19.2107 36.0391 19 35.5304 19 35V31M33 24L28 19M28 19L23 24M28 19V31\" stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                    </svg>\r\n                    \r\n            </div>\r\n        </div>\r\n        <div class=\"row w-100\">\r\n            <div *ngIf=\"type ==='add'\" class=\"col-md-12\">\r\n                <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Add Single NoB</a>\r\n            </div>\r\n            <div *ngIf=\"type ==='reupload'\" class=\"col-md-12\">\r\n                <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Upload NoB for</a>\r\n            </div>\r\n<div  *ngIf=\"type ==='reupload'\" class=\"d-flex align-items-center mt-5\">\r\n            <div class=\"form-check w-50 cursor-pointer ps-5\" (click)=\"nobStore('single')\" [ngClass]=\"typeNOB ==='single' ? 'form-check-inline':'form-check-inline-none'\" >\r\n                <svg *ngIf=\"typeNOB ==='single'\" style=\"margin-top: -5px !important;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"#EAF8FF\"/>\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#00A3FF\"/>\r\n                    <circle cx=\"8\" cy=\"8\" r=\"3\" fill=\"#00A3FF\"/>\r\n                  </svg>\r\n\r\n                  <svg *ngIf=\"typeNOB !=='single'\" style=\"margin-top: -5px !important;\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"white\"/>\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#D0D5DD\"/>\r\n                    </svg>\r\n                <!-- <input class=\"form-check-input ms-10\" type=\"radio\" name=\"inlineRadioOptions\" id=\"inlineRadio1\" value=\"option1\"> -->\r\n                <span class=\"ms-3 pt-12\" [ngClass]=\"typeNOB ==='single' ? 'form-text-primary ':'form-defult'\">Single Store</span>\r\n            </div>\r\n            <div class=\"form-check  w-50 cursor-pointer ps-5\" (click)=\"nobStore('multiple')\" [ngClass]=\"typeNOB ==='multiple' ? 'form-check-inline':'form-check-inline-none'\">\r\n                <svg *ngIf=\"typeNOB ==='multiple'\" style=\"margin-top: -5px !important;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"#EAF8FF\"/>\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#00A3FF\"/>\r\n                    <circle cx=\"8\" cy=\"8\" r=\"3\" fill=\"#00A3FF\"/>\r\n                  </svg>\r\n\r\n                  <svg *ngIf=\"typeNOB !=='multiple'\" style=\"margin-top: -5px !important;\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"white\"/>\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#D0D5DD\"/>\r\n                    </svg>\r\n                    <span class=\"ms-3 pt-12\" [ngClass]=\"typeNOB ==='multiple' ? 'form-text-primary':'form-defult'\">Multiple Stores</span>\r\n              \r\n            </div>\r\n            </div>\r\n            <div *ngIf=\"typeNOB ==='single'\" class=\"w-100 h-0px scroll\">\r\n                <div class=\"mt-5\">\r\n                    <div class=\"row px-0 me-3\">\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"storeName\" class=\"form-label\">Store Name<span\r\n                                    class=\"alert-required text-danger\"> *</span></label>\r\n                            <lib-custom-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeName'\"\r\n                                [idField]=\"'storeName'\" (selected)=\"onNOBStoreSelect($event, 'storeName')\"\r\n                                [selectedValues]=\"[{ storeName: storeName }]\">\r\n                            </lib-custom-select>\r\n                        </div>\r\n\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"storeID\" class=\"form-label\">Store ID /<span *ngIf=\"type !=='add'\"> Store Code</span><span *ngIf=\"type ==='add'\"> Reference Code</span>  <span\r\n                                    class=\"alert-required text-danger\"> *</span></label>\r\n                            <lib-custom-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeId'\"\r\n                                [idField]=\"'storeId'\" (selected)=\"onNOBStoreSelect($event, 'storeId')\"\r\n                                [selectedValues]=\"[{ storeId: storeId }]\">\r\n                            </lib-custom-select>\r\n                        </div>\r\n\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"Date\" class=\"form-label\">Select Date <span\r\n                                    class=\"alert-required text-danger\">*</span></label>\r\n                            <input type=\"date\" class=\"form-control\" id=\"myDate\" [(ngModel)]=\"dateValue\"\r\n                                (change)=\"onDateChange($event)\"  [max]=\"maxDate\">\r\n                        </div>\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"count\" class=\"form-label\">NOB Count <span\r\n                                    class=\"alert-required text-danger\">*</span></label>\r\n                            <input type=\"text\" class=\"form-control\" [(ngModel)]=\"nobCount\"\r\n                                (keypress)=\"omit_special_char($event)\">\r\n                        </div>\r\n                        <div class=\"d-flex mt-3 mb-10\" 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\" id=\"alert-toast\" (click)=\"onSubmit()\"\r\n                                [disabled]=\"!dateValue || !nobCount || !storeId || !storeName\"><span *ngIf=\"type !=='add'\">Proceed</span><span *ngIf=\"type ==='add'\">Add</span></button>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n            <div *ngIf=\"typeNOB ==='multiple'\" class=\"d-flex justify-content\">\r\n                <div class=\"fw-bold text-gray-500 my-6\">\r\n                    <ul class=\"text-gray-400 fw-bold fs-6\">\r\n                        <li class=\"user-text\">Use the template to upload multiple NoB’s at once.</li>\r\n                        <li class=\"user-text \">Download the template here -   <a href=\"../../assets/files/nobUploadTemplate.xlsx\" download><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\r\n                            <path d=\"M17.5 13V16.3333C17.5 16.7754 17.3244 17.1993 17.0118 17.5118C16.6993 17.8244 16.2754 18 15.8333 18H4.16667C3.72464 18 3.30072 17.8244 2.98816 17.5118C2.67559 17.1993 2.5 16.7754 2.5 16.3333V13M5.83333 8.83333L10 13M10 13L14.1667 8.83333M10 13V3\" stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                          </svg><span class=\"ms-2 text-download\">Download Template</span></a></li>\r\n                        <li class=\"user-text \">Add your data to the Template File</li>\r\n                        <li class=\"user-text\">Upload it below for processing</li>\r\n                    \r\n                    </ul>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"typeNOB ==='multiple'\"\r\n                class=\"mt-3 ms-3 right-bar py-10 d-flex justify-content-center align-items-center flex-column\">\r\n                <input name=\"accountType\" type=\"radio\" id=\"kt_create_account_form_account_type_personal\"\r\n                    value=\"personal\" class=\"btn-check\" ng-reflect-name=\"accountType\"\r\n                    ng-reflect-form-control-name=\"accountType\"   (change)=\"onUpload($event)\"\r\n                    ng-reflect-value=\"personal\" type=\"file\" #inputFile />\r\n                <label for=\"kt_create_account_form_account_type_personal\" class=\" w-50 p-4 mt-5\"><span\r\n                        class=\"fw-bold text-center w-100 fs-4\">\r\n<div class=\"d-flex justify-content-center align-items-center w-100\">\r\n                        <svg width=\"46\" height=\"46\" viewBox=\"0 0 46 46\" fill=\"none\"\r\n                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                            <rect x=\"3\" y=\"3\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#F2F4F7\" />\r\n                            <rect x=\"3\" y=\"3\" width=\"40\" height=\"40\" rx=\"20\" stroke=\"#F9FAFB\"\r\n                                stroke-width=\"6\" />\r\n                            <g clip-path=\"url(#clip0_4047_40566)\">\r\n                                <path\r\n                                    d=\"M26.3333 26.3334L23 23M23 23L19.6666 26.3334M23 23V30.5M29.9916 28.325C30.8044 27.8819 31.4465 27.1808 31.8165 26.3322C32.1866 25.4837 32.2635 24.5361 32.0351 23.6389C31.8068 22.7418 31.2862 21.9463 30.5555 21.3779C29.8248 20.8095 28.9257 20.5006 28 20.5H26.95C26.6977 19.5244 26.2276 18.6186 25.5749 17.8509C24.9222 17.0831 24.104 16.4732 23.1817 16.0672C22.2594 15.6612 21.2571 15.4695 20.2501 15.5066C19.243 15.5437 18.2575 15.8086 17.3676 16.2814C16.4777 16.7542 15.7066 17.4226 15.1122 18.2363C14.5177 19.0501 14.1155 19.988 13.9358 20.9795C13.756 21.9711 13.8034 22.9905 14.0743 23.9611C14.3452 24.9317 14.8327 25.8282 15.5 26.5834\"\r\n                                    stroke=\"#475467\" stroke-width=\"1.66667\" stroke-linecap=\"round\"\r\n                                    stroke-linejoin=\"round\" />\r\n                            </g>\r\n                            <defs>\r\n                                <clipPath id=\"clip0_4047_40566\">\r\n                                    <rect width=\"20\" height=\"20\" fill=\"white\"\r\n                                        transform=\"translate(13 13)\" />\r\n                                </clipPath>\r\n                            </defs>\r\n                        </svg>\r\n                    </div>\r\n                        <div class=\"nodata-title\"><span class=\"click-upload cursor-pointer\">Click to\r\n                                upload </span>\r\n                                <!-- <span class=\"drag-drop\"> or drag and drop the template</span> -->\r\n                            </div>\r\n                       \r\n                    </span>\r\n                </label>\r\n            </div>\r\n\r\n            <div  *ngIf=\"typeNOB ==='multiple'\" class=\"d-flex mt-3 mb-10\" 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\" id=\"alert-toast\" (click)=\"proceed()\"\r\n                  >Proceed</button>\r\n            </div>\r\n        </div>\r\n\r\n    </div>\r\n</div>"]}
|
|
456
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-nob.component.js","sourceRoot":"","sources":["../../../../../../projects/tango-analyse-traffic/src/lib/components/add-nob/add-nob.component.ts","../../../../../../projects/tango-analyse-traffic/src/lib/components/add-nob/add-nob.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { TrafficService } from '../../services/traffic.service';\r\nimport { Subject, takeUntil } from \"rxjs\";\r\nimport { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';\r\nimport { ToastService } from 'tango-app-ui-shared';\r\nimport * as XLSX from 'xlsx';\r\nimport { DatePipe } from '@angular/common';\r\nimport { ExcelService } from '../../services/excel.service';\r\n\r\n@Component({\r\n  selector: 'lib-add-nob',\r\n  templateUrl: './add-nob.component.html',\r\n  styleUrl: './add-nob.component.scss',\r\n  providers: [DatePipe]\r\n})\r\nexport class AddNobComponent implements OnInit,OnDestroy {\r\n@Input() type:any;\r\n@Input() viewData:any;\r\nnobForm: FormGroup;\r\nprivate readonly destroy$ = new Subject();\r\nconstructor(private fb:FormBuilder,private service:TrafficService,private excelService:ExcelService,\r\n  private activeModal :NgbActiveModal,private ts: ToastService,private cd:ChangeDetectorRef,private datePipe: DatePipe){\r\n\r\n}\r\nngOnDestroy(): void {\r\n  this.destroy$.next(true);\r\n  this.destroy$.complete();\r\n}\r\nclientId:any;\r\nmaxDate: string = '';\r\nisEditEnabled = false;\r\nclientData:any;\r\nngOnInit(): void {\r\nlet data: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"\");\r\nthis.clientId =data.client\r\nlet client: any = JSON.parse(localStorage.getItem(\"client-details\") || \"\");\r\nthis.clientData = client\r\nthis.getNobStoreList(data.client);\r\nthis.setMaxDate();\r\nif (this.type === 'editView' || this.type === 'view') {\r\n  this.storeName = this.viewData.storeName;\r\n  this.storeId = this.viewData.storeId;\r\n  this.storeCode = this.viewData.storeCode;\r\n this.dateValue = this.viewData.nobDate\r\n  ? new Date(this.viewData.nobDate).toISOString().split('T')[0]\r\n  : null;\r\n\r\n  this.nobCount = this.viewData.nobCount;\r\n\r\n  this.zoneList = this.viewData.zonewisenob; // keep values\r\n  if(this.type === 'editView'){\r\n    this.isEditEnabled = true;\r\n  } else {\r\n    this.isEditEnabled = false;\r\n  }\r\n}\r\n\r\n}\r\n\r\ncancelEdit() {\r\n  this.isEditEnabled = false;\r\n\r\n  if (this.viewData?.zoneList) {\r\n    this.zoneList = JSON.parse(JSON.stringify(this.viewData.zoneList));\r\n  } else {\r\n    this.zoneList = [];\r\n  }\r\n\r\n  this.cancel();\r\n}\r\n\r\nstoreList:any[]=[];\r\ngetNobStoreList(client:any){\r\n  this.service.getNOBStoreList(client)?.pipe(takeUntil(this.destroy$))\r\n  .subscribe({\r\n    next: (res: any) => {\r\n      if(res && res.code === 200){\r\n        this.storeList =res.data.result\r\n      }\r\n    },\r\n    error: (err) => {\r\n      \r\n    }\r\n  })\r\n}\r\n\r\nstoreName:any;\r\nstoreId:any;\r\ndateValue:any;\r\nstoreCode:any;\r\nnobCount:any;\r\nzoneShow =false;\r\nonNOBStoreSelect(event: any, type: 'storeName' | 'storeId'): void {\r\n  if (!event) {\r\n    this.ts.getErrorToast('storeName or storeId is undefined or invalid');\r\n    return;\r\n  }\r\n  if (type === 'storeName') {\r\n    this.storeName = event.storeName;\r\n    const store = this.storeList.find(store => store.storeName === event.storeName);\r\n    if (store) {\r\n      this.storeId = store.storeId;\r\n      this.storeCode = store.storeCode; \r\n    } else {\r\n      this.storeId = '';\r\n      this.storeCode = '';\r\n    }\r\n  }\r\n  else if (type === 'storeId') {\r\n    this.storeId = event.storeId;\r\n    const store = this.storeList.find(store => store.storeId === event.storeId);\r\n    if (store) {\r\n      this.storeName = store.storeName;\r\n      this.storeCode = store.storeCode; \r\n    } else {\r\n      this.storeName = '';\r\n      this.storeCode = ''; \r\n    }\r\n  }\r\n  this.zoneShow = true;\r\n  if(this.isEnabled){\r\n   this.getZoneList(this.storeId);\r\n  }\r\n  // console.log('storeName',this.storeId);\r\n\r\n  \r\n}\r\nomit_special_char(event: any) {\r\n  var k;\r\n  k = event.charCode; //         k = event.keyCode;  (Both can be used)\r\n  return k == 8 || k == 32 || (k >= 48 && k <= 57);\r\n}\r\nsetMaxDate(): void {\r\n  const today = new Date();\r\n  const yesterday = new Date(today);\r\n  yesterday.setDate(today.getDate() - 1); // Set the max date to yesterday\r\n  this.dateValue = yesterday.toISOString().split('T')[0];\r\n  // Format the date as yyyy-MM-dd\r\n  this.maxDate = yesterday.toISOString().split('T')[0];\r\n}\r\nonDateChange(event: any): void {\r\n  const selectedDate = event.target.value;\r\n  if (selectedDate > this.maxDate) {\r\n    this.ts.getErrorToast('Invalid date selected!');\r\n  }\r\n}\r\ncancel(){\r\n  this.activeModal.close('close');\r\n}\r\nerroShow:any ='';\r\nisSubmitting = false;\r\nonSubmit() {\r\n\r\n  // ⛔ STOP if already submitting\r\n  if (this.isSubmitting) {\r\n    return;\r\n  }\r\n\r\n  const overallNob = Number(this.nobCount) || 0;\r\n\r\n  const zoneTotal = this.zonewisenob.reduce(\r\n    (sum: number, z: any) => sum + (Number(z.nobCount) || 0),\r\n    0\r\n  );\r\n\r\n  if (zoneTotal > overallNob) {\r\n    this.erroShow = 'Zone-wise NoB cannot exceed overall NoB count';\r\n    return;\r\n  }\r\n\r\n  // ✅ LOCK BUTTON\r\n  this.isSubmitting = true;\r\n\r\n  const obj = {\r\n    bills: [\r\n      {\r\n        storeCode: this.storeCode ? this.storeCode : this.storeId,\r\n        nobDate: this.dateValue,\r\n        nobCount: Number(this.nobCount),\r\n        zonewisenob: this.zonewisenob\r\n      }\r\n    ],\r\n    clientId: this.clientId\r\n  };\r\n\r\n  this.service.getNOBDataList(obj)\r\n    ?.pipe(takeUntil(this.destroy$))\r\n    .subscribe({\r\n      next: (res: any) => {\r\n        if (res?.code === 200) {\r\n          this.ts.getSuccessToast(res.message);\r\n          this.activeModal.close('submit');\r\n        } else {\r\n          this.ts.getErrorToast('Unexpected response format');\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.ts.getErrorToast(\r\n          err?.error?.error || 'Something went wrong'\r\n        );\r\n      },\r\n      complete: () => {\r\n        // 🔓 UNLOCK BUTTON\r\n        this.isSubmitting = false;\r\n      }\r\n    });\r\n}\r\n\r\n\r\n\r\ntypeNOB ='single'\r\nnobStore(type:any){\r\n  this.typeNOB =type\r\n}\r\ndataTableShow =false;\r\ndataTableShow1 =false;\r\ntableHeaders:any;\r\nconvertedData:any;\r\n@ViewChild(\"inputFile\") inputFile: ElementRef;\r\nonUpload(event: any): void {\r\n  const file = event.target.files?.[0];\r\n  if (!file) return;\r\n\r\n  const reader = new FileReader();\r\n\r\n  reader.onload = (e: any) => {\r\n    try {\r\n      const binaryData = e.target.result;\r\n\r\n      const workbook: XLSX.WorkBook = XLSX.read(binaryData, {\r\n        type: 'binary'\r\n      });\r\n\r\n      const sheetName = workbook.SheetNames[0];\r\n      const sheet = workbook.Sheets[sheetName];\r\n\r\n      const sheetData: any[][] = XLSX.utils.sheet_to_json(sheet, {\r\n        header: 1,\r\n        defval: null\r\n      });\r\n\r\n      if (!sheetData || sheetData.length < 2) {\r\n        this.ts.getErrorToast('Excel file is empty');\r\n        return;\r\n      }\r\n\r\n const STORE_ID_HEADERS = ['storeid', 'store id','StoreId'];\r\nconst DATE_HEADERS = ['date', 'nobdate', 'nob date','NOBDate'];\r\nconst NOB_HEADERS = ['nobcount', 'overallnobcount', 'overall nob count','NOBCount'];\r\nconst normalize = (h: any) =>\r\n  String(h ?? '')\r\n    .toLowerCase()\r\n    .replace(/\\s+/g, '');\r\n       const rawHeaders = sheetData[0];\r\n\r\nconst headers = rawHeaders.map(h => normalize(h));\r\n\r\nconst isStoreValid = STORE_ID_HEADERS.includes(headers[0]);\r\nconst isDateValid = DATE_HEADERS.includes(headers[1]);\r\nconst isNobValid = NOB_HEADERS.includes(headers[2]);\r\n\r\nif (!isStoreValid || !isDateValid || !isNobValid) {\r\n  this.ts.getErrorToast(\r\n    'Invalid Excel file. First columns must be Store Id, NoB Date, Overall NoB Count'\r\n  );\r\n  return;\r\n}\r\n      const rows = sheetData.slice(1);\r\n\r\n      // ===============================\r\n      // 2️⃣ PROCESS ROWS\r\n      // ===============================\r\n      const bills = rows\r\n        .map((row: any[], rowIndex: number) => {\r\n\r\n          // 🔹 SKIP COMPLETELY EMPTY ROWS (SAFE)\r\n          const isEmptyRow = row.every(cell =>\r\n            cell === null ||\r\n            cell === undefined ||\r\n            (typeof cell === 'string' && cell.trim() === '')\r\n          );\r\n          if (isEmptyRow) return null;\r\n\r\n          // ===============================\r\n          // 3️⃣ STORE CODE\r\n          // ===============================\r\n          const storeId = String(row[0] ?? '').trim();\r\n          if (!storeId) {\r\n            throw new Error(`Missing Store Code at row ${rowIndex + 2}`);\r\n          }\r\n\r\n          // ===============================\r\n          // 4️⃣ DATE\r\n          // ===============================\r\n          let nobDate: any = row[1];\r\n          if (nobDate === null || nobDate === undefined || nobDate === '') {\r\n            throw new Error(`Missing Date at row ${rowIndex + 2}`);\r\n          }\r\n\r\n          if (typeof nobDate === 'number') {\r\n            nobDate = this.convertExcelDate(nobDate);\r\n          } else if (nobDate instanceof Date) {\r\n            // ok\r\n          } else if (typeof nobDate === 'string') {\r\n            const parsed = new Date(nobDate);\r\n            if (isNaN(parsed.getTime())) {\r\n              throw new Error(`Invalid Date format at row ${rowIndex + 2}`);\r\n            }\r\n            nobDate = parsed;\r\n          } else {\r\n            throw new Error(`Invalid Date format at row ${rowIndex + 2}`);\r\n          }\r\n\r\n          // ===============================\r\n          // 5️⃣ NoB COUNT\r\n          // ===============================\r\n          let nobCount: any = row[2];\r\n          if (nobCount === null || nobCount === undefined || nobCount === '') {\r\n            throw new Error(`Missing NoB count at row ${rowIndex + 2}`);\r\n          }\r\n\r\n          nobCount = Number(nobCount);\r\n          if (isNaN(nobCount)) {\r\n            throw new Error(`Invalid NoB count at row ${rowIndex + 2}`);\r\n          }\r\n\r\n          // ===============================\r\n          // 6️⃣ ZONE WISE NoB\r\n          // ===============================\r\n          const zonewisenob = headers.slice(3)\r\n            .map((zoneName, index) => {\r\n              const raw = row[index + 3];\r\n\r\n              if (\r\n                raw === null ||\r\n                raw === undefined ||\r\n                (typeof raw === 'string' && raw.trim() === '')\r\n              ) {\r\n                return null;\r\n              }\r\n\r\n              const value = Number(raw);\r\n              if (isNaN(value)) {\r\n                throw new Error(\r\n                  `Invalid Zone NoB at row ${rowIndex + 2} (${zoneName})`\r\n                );\r\n              }\r\n\r\n              return {\r\n                zoneName,\r\n                nobCount: value\r\n              };\r\n            })\r\n            .filter(Boolean);\r\n\r\n          const zoneTotal = zonewisenob.reduce(\r\n            (sum: number, z: any) => sum + z.nobCount,\r\n            0\r\n          );\r\n\r\n          if (zoneTotal > nobCount) {\r\n            throw new Error(\r\n              `Zone-wise NoB cannot exceed overall NoB (Row ${rowIndex + 2})`\r\n            );\r\n          }\r\n\r\n          // ===============================\r\n          // 7️⃣ FINAL OBJECT\r\n          // ===============================\r\n          return {\r\n            storeCode: storeId,\r\n            nobDate: this.datePipe.transform(nobDate, 'yyyy-MM-dd'),\r\n            nobCount,\r\n            zonewisenob\r\n          };\r\n        })\r\n        .filter(Boolean);\r\n\r\n      if (!bills.length) {\r\n        this.ts.getErrorToast('No valid rows found in Excel');\r\n        return;\r\n      }\r\n\r\n      // ===============================\r\n      // 8️⃣ FINAL PAYLOAD\r\n      // ===============================\r\n      this.convertedData = {\r\n        clientId: this.clientId,\r\n        bills\r\n      };\r\n      this.dataTableShow = true;\r\n      this.ts.getSuccessToast('File uploaded successfully');\r\n\r\n    } catch (err: any) {\r\n      console.error(err);\r\n      this.ts.getErrorToast(err.message || 'Invalid Excel file');\r\n    } finally {\r\n      this.resetFileInput();\r\n      this.cd.detectChanges();\r\n    }\r\n  };\r\n\r\n  reader.readAsBinaryString(file);\r\n}\r\n\r\nresetFileInput(): void {\r\n  if (this.inputFile && this.inputFile.nativeElement) {\r\n    this.inputFile.nativeElement.value = '';\r\n  }\r\n}\r\n\r\nconvertExcelDate(excelDate: number): string {\r\n  const baseDate = new Date(1900, 0, 1); \r\n  const correctedDate = new Date(baseDate.getTime() + (excelDate - 1) * 86400000);\r\n  return correctedDate.toISOString().split(\"T\")[0]; \r\n}\r\n\r\nproceed(){\r\n  this.service.getNOBDataList(this.convertedData)?.pipe(takeUntil(this.destroy$))\r\n  .subscribe({\r\n    next: (res: any) => {\r\n        if (res.code === 200 && res) {\r\n          const allMessages = res.message\r\n          this.ts.getSuccessToast(allMessages);\r\n    this.activeModal.close('submit')\r\n        } else {\r\n          this.ts.getErrorToast('Unexpected response format');\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n        this.ts.getErrorToast(err.error.error);\r\n      },\r\n  \r\n  })\r\n}\r\n\r\nisEnabled = false;\r\nzoneList:any=[];\r\nonCheckboxChange(event:any){\r\n  this.isEnabled = event.target.checked;\r\n  if(this.isEnabled){\r\n    this.getZoneList(this.storeId);\r\n  } else {\r\n    this.zoneList =[];\r\n  }\r\n}\r\n\r\ngetZoneList(store:any){\r\n  this.service.getZoneList({ \"storeId\": [store] })?.pipe(takeUntil(this.destroy$))\r\n  .subscribe({\r\n    next: (res: any) => {\r\n      if(res && res.code === 200){\r\n        this.zoneList = res?.data\r\n      } else{\r\n        this.zoneList =[];\r\n      }\r\n    },\r\n    error: (err) => {\r\n      this.zoneList =[];\r\n    }\r\n  });\r\n}\r\n\r\n\r\nzonewisenob: any[] = [];\r\n\r\nonNobChange() {\r\n  this.zonewisenob = this.zoneList.map((zone: any) => ({\r\n    zoneName: zone.tagName ? zone.tagName : zone.zoneName,\r\n    nobCount: Number(zone.nobCount) || 0\r\n  }));\r\n\r\n  console.log('Updated zonewisenob:', this.zonewisenob);\r\n}\r\n download() {\r\n  this.service\r\n    .getZoneTemplate({ clientId: this.clientId || '' })\r\n    .pipe(takeUntil(this.destroy$))\r\n    .subscribe({\r\n      next: (res: any) => {\r\n        if (res) {\r\n          this.excelService.saveAsExcelFile(\r\n            res,\r\n            'NOB Upload Template'\r\n          );\r\n        } else {\r\n          this.ts.getErrorToast('File is empty');\r\n        }\r\n      },\r\n      error: (err: any) => {\r\n           const errorMsg = err.error?.error || \r\n        err.error?.message || err.message || err.error\r\n          'An error occurred while downloading file';\r\n\r\n        this.ts.getErrorToast(errorMsg);\r\n      }\r\n    });\r\n}\r\n\r\n}","<div *ngIf=\"type !=='editView' && type !== 'view'\" class=\"card pt-0 pb-3 scroll\">\r\n    <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n        <div class=\"my-5 d-flex\">\r\n            <div *ngIf=\"type ==='add'\" class=\"symbol symbol-75px symbol-circle\">\r\n                <img alt=\"Pic\" src=\"./assets/tango/Icons/add-store-icon.svg\">\r\n            </div>\r\n            <div *ngIf=\"type ==='reupload'\" 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 31V35C37 35.5304 36.7893 36.0391 36.4142 36.4142C36.0391 36.7893 35.5304 37 35 37H21C20.4696 37 19.9609 36.7893 19.5858 36.4142C19.2107 36.0391 19 35.5304 19 35V31M33 24L28 19M28 19L23 24M28 19V31\" stroke=\"#00A3FF\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                    </svg>\r\n                    \r\n            </div>\r\n        </div>\r\n        <div class=\"row w-100\">\r\n            <div *ngIf=\"type ==='add'\" class=\"col-md-12\">\r\n                <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Add Single NoB</a>\r\n            </div>\r\n            <div *ngIf=\"type ==='reupload'\" class=\"col-md-12\">\r\n                <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Upload NoB for</a>\r\n            </div>\r\n<div  *ngIf=\"type ==='reupload'\" class=\"d-flex align-items-center mt-5\">\r\n            <div class=\"form-check w-50 cursor-pointer ps-5\" (click)=\"nobStore('single')\" [ngClass]=\"typeNOB ==='single' ? 'form-check-inline':'form-check-inline-none'\" >\r\n                <svg *ngIf=\"typeNOB ==='single'\" style=\"margin-top: -5px !important;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"#EAF8FF\"/>\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#00A3FF\"/>\r\n                    <circle cx=\"8\" cy=\"8\" r=\"3\" fill=\"#00A3FF\"/>\r\n                  </svg>\r\n\r\n                  <svg *ngIf=\"typeNOB !=='single'\" style=\"margin-top: -5px !important;\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"white\"/>\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#D0D5DD\"/>\r\n                    </svg>\r\n                <!-- <input class=\"form-check-input ms-10\" type=\"radio\" name=\"inlineRadioOptions\" id=\"inlineRadio1\" value=\"option1\"> -->\r\n                <span class=\"ms-3 pt-12\" [ngClass]=\"typeNOB ==='single' ? 'form-text-primary ':'form-defult'\">Single Store</span>\r\n            </div>\r\n            <div class=\"form-check  w-50 cursor-pointer ps-5\" (click)=\"nobStore('multiple')\" [ngClass]=\"typeNOB ==='multiple' ? 'form-check-inline':'form-check-inline-none'\">\r\n                <svg *ngIf=\"typeNOB ==='multiple'\" style=\"margin-top: -5px !important;\" xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"#EAF8FF\"/>\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#00A3FF\"/>\r\n                    <circle cx=\"8\" cy=\"8\" r=\"3\" fill=\"#00A3FF\"/>\r\n                  </svg>\r\n\r\n                  <svg *ngIf=\"typeNOB !=='multiple'\" style=\"margin-top: -5px !important;\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" fill=\"white\"/>\r\n                    <rect x=\"0.5\" y=\"0.5\" width=\"15\" height=\"15\" rx=\"7.5\" stroke=\"#D0D5DD\"/>\r\n                    </svg>\r\n                    <span class=\"ms-3 pt-12\" [ngClass]=\"typeNOB ==='multiple' ? 'form-text-primary':'form-defult'\">Multiple Stores</span>\r\n              \r\n            </div>\r\n            </div>\r\n            <div *ngIf=\"typeNOB ==='single'\" class=\"w-100 h-0px scroll\">\r\n                <div class=\"mt-5\">\r\n                    <div class=\"row px-0 me-3\">\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"storeName\" class=\"form-label\">Store Name<span\r\n                                    class=\"alert-required text-danger\"> *</span></label>\r\n                            <lib-custom-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeName'\"\r\n                                [idField]=\"'storeName'\" (selected)=\"onNOBStoreSelect($event, 'storeName')\"\r\n                                [selectedValues]=\"[{ storeName: storeName }]\">\r\n                            </lib-custom-select>\r\n                        </div>\r\n\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"storeID\" class=\"form-label\">Store ID /<span *ngIf=\"type !=='add'\"> Store Code</span><span *ngIf=\"type ==='add'\"> Reference Code</span>  <span\r\n                                    class=\"alert-required text-danger\"> *</span></label>\r\n                            <lib-custom-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeId'\"\r\n                                [idField]=\"'storeId'\" (selected)=\"onNOBStoreSelect($event, 'storeId')\"\r\n                                [selectedValues]=\"[{ storeId: storeId }]\">\r\n                            </lib-custom-select>\r\n                        </div>\r\n\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"Date\" class=\"form-label\">Select Date <span\r\n                                    class=\"alert-required text-danger\">*</span></label>\r\n                            <input type=\"date\" class=\"form-control\" id=\"myDate\" [(ngModel)]=\"dateValue\"\r\n                                (change)=\"onDateChange($event)\"  [max]=\"maxDate\">\r\n                        </div>\r\n                        <div class=\"col-md-12 col-lg-6 col-xl-6 col-xxl-6 mb-7\">\r\n                            <label for=\"count\" class=\"form-label\">NOB Count <span\r\n                                    class=\"alert-required text-danger\">*</span></label>\r\n                            <input type=\"text\" class=\"form-control\" [(ngModel)]=\"nobCount\"\r\n                                (keypress)=\"omit_special_char($event)\">\r\n                        </div>\r\n                        <div *ngIf=\"zoneShow\" class=\"col-12\">\r\n                            <div *ngIf=\"clientData?.isZonewiseNOB\" class=\"toggle-wrapper\">\r\n  <label class=\"switch\">\r\n    <input type=\"checkbox\" [(ngModel)]=\"isEnabled\" (change)=\"onCheckboxChange($event)\" />\r\n    <span class=\"slider\"></span>\r\n  </label>\r\n\r\n  <span class=\"toggle-label\">\r\n    Add Zone-wise NoB Count\r\n  </span>\r\n</div>\r\n\r\n                        </div>\r\n                        <div *ngIf=\"isEnabled\" class=\"table-responsive\">\r\n                            <table  class=\"table bottom-border text-nowrap mt-5\">\r\n                                <thead>\r\n                                    <tr>\r\n                                        <th scope=\"col\">Zone Name</th>\r\n                                        <th scope=\"col\">NoB Count</th>\r\n                                    </tr>\r\n                                </thead>\r\n                                <tbody>\r\n                                    <tr *ngFor=\"let zone of zoneList\">\r\n                                        <td class=\"py-3 mt-10\">{{zone.tagName}}</td>\r\n                                        <td class=\"py-2\"><input type=\"text\" class=\"form-control form-control-sm mb-0 py-0\" [(ngModel)]=\"zone.nobCount\" (ngModelChange)=\"onNobChange()\" \r\n                                                (keypress)=\"omit_special_char($event)\"></td>\r\n                                    </tr>\r\n                                </tbody>\r\n                                </table>\r\n                        </div>\r\n                         <div *ngIf=\"erroShow\" class=\"text-danger mt-2\"><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<g clip-path=\"url(#clip0_15055_156438)\">\r\n<path d=\"M9 6V9M9 12H9.0075M16.5 9C16.5 13.1421 13.1421 16.5 9 16.5C4.85786 16.5 1.5 13.1421 1.5 9C1.5 4.85786 4.85786 1.5 9 1.5C13.1421 1.5 16.5 4.85786 16.5 9Z\" stroke=\"#B42318\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</g>\r\n<defs>\r\n<clipPath id=\"clip0_15055_156438\">\r\n<rect width=\"18\" height=\"18\" fill=\"white\"/>\r\n</clipPath>\r\n</defs>\r\n</svg></span>{{ erroShow }}</div>\r\n\r\n                        <div class=\"d-flex mt-3 mb-10\" role=\"group\">\r\n                            <button class=\"btn btn-outline w-100 me-3\" (click)=\"cancel()\">Cancel</button>\r\n                            <button\r\n  class=\"btn btn-primary w-100 ms-3\"\r\n  id=\"alert-toast\"\r\n  (click)=\"onSubmit()\"\r\n  [disabled]=\"\r\n    !dateValue ||\r\n    !nobCount ||\r\n    !storeId ||\r\n    !storeName ||\r\n    isSubmitting\r\n  \"\r\n>\r\n  <span *ngIf=\"!isSubmitting && type !== 'add'\">Proceed</span>\r\n  <span *ngIf=\"!isSubmitting && type === 'add'\">Add</span>\r\n  <span *ngIf=\"isSubmitting\">Please wait...</span>\r\n</button>\r\n\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n            <div *ngIf=\"typeNOB ==='multiple'\" class=\"d-flex justify-content\">\r\n                <div class=\"fw-bold text-gray-500 my-6\">\r\n                    <ul class=\"text-gray-400 fw-bold fs-6\">\r\n                        <li class=\"user-text\">Use the template to upload multiple NoB’s at once.</li>\r\n                        <li class=\"user-text \">Download the template here - <a *ngIf=\"!clientData?.isZonewiseNOB\" href=\"../../assets/files/nobUploadTemplate.xlsx\" download><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\r\n                            <path d=\"M17.5 13V16.3333C17.5 16.7754 17.3244 17.1993 17.0118 17.5118C16.6993 17.8244 16.2754 18 15.8333 18H4.16667C3.72464 18 3.30072 17.8244 2.98816 17.5118C2.67559 17.1993 2.5 16.7754 2.5 16.3333V13M5.83333 8.83333L10 13M10 13L14.1667 8.83333M10 13V3\" stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                          </svg><span class=\"ms-2 text-download text-primary\">Download Template</span></a> <span *ngIf=\"clientData?.isZonewiseNOB\" class=\" text-active-primary\"  (click)=\"download()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"21\" viewBox=\"0 0 20 21\" fill=\"none\">\r\n                            <path d=\"M17.5 13V16.3333C17.5 16.7754 17.3244 17.1993 17.0118 17.5118C16.6993 17.8244 16.2754 18 15.8333 18H4.16667C3.72464 18 3.30072 17.8244 2.98816 17.5118C2.67559 17.1993 2.5 16.7754 2.5 16.3333V13M5.83333 8.83333L10 13M10 13L14.1667 8.83333M10 13V3\" stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                          </svg><span class=\"ms-2 text-download text-primary cursor-pointer\">Download Template</span></span></li>\r\n                        <li class=\"user-text \">Add your data to the Template File</li>\r\n                        <li class=\"user-text\">Upload it below for processing</li>\r\n                    \r\n                    </ul>\r\n                </div>\r\n            </div>\r\n            <div *ngIf=\"typeNOB ==='multiple'\"\r\n                class=\"mt-3 ms-3 right-bar py-10 d-flex justify-content-center align-items-center flex-column\">\r\n                <input name=\"accountType\" type=\"radio\" id=\"kt_create_account_form_account_type_personal\"\r\n                    value=\"personal\" class=\"btn-check\" ng-reflect-name=\"accountType\"\r\n                    ng-reflect-form-control-name=\"accountType\"   (change)=\"onUpload($event)\"\r\n                    ng-reflect-value=\"personal\" type=\"file\" #inputFile />\r\n                <label for=\"kt_create_account_form_account_type_personal\" class=\" w-50 p-4 mt-5\"><span\r\n                        class=\"fw-bold text-center w-100 fs-4\">\r\n<div class=\"d-flex justify-content-center align-items-center w-100\">\r\n                        <svg width=\"46\" height=\"46\" viewBox=\"0 0 46 46\" fill=\"none\"\r\n                            xmlns=\"http://www.w3.org/2000/svg\">\r\n                            <rect x=\"3\" y=\"3\" width=\"40\" height=\"40\" rx=\"20\" fill=\"#F2F4F7\" />\r\n                            <rect x=\"3\" y=\"3\" width=\"40\" height=\"40\" rx=\"20\" stroke=\"#F9FAFB\"\r\n                                stroke-width=\"6\" />\r\n                            <g clip-path=\"url(#clip0_4047_40566)\">\r\n                                <path\r\n                                    d=\"M26.3333 26.3334L23 23M23 23L19.6666 26.3334M23 23V30.5M29.9916 28.325C30.8044 27.8819 31.4465 27.1808 31.8165 26.3322C32.1866 25.4837 32.2635 24.5361 32.0351 23.6389C31.8068 22.7418 31.2862 21.9463 30.5555 21.3779C29.8248 20.8095 28.9257 20.5006 28 20.5H26.95C26.6977 19.5244 26.2276 18.6186 25.5749 17.8509C24.9222 17.0831 24.104 16.4732 23.1817 16.0672C22.2594 15.6612 21.2571 15.4695 20.2501 15.5066C19.243 15.5437 18.2575 15.8086 17.3676 16.2814C16.4777 16.7542 15.7066 17.4226 15.1122 18.2363C14.5177 19.0501 14.1155 19.988 13.9358 20.9795C13.756 21.9711 13.8034 22.9905 14.0743 23.9611C14.3452 24.9317 14.8327 25.8282 15.5 26.5834\"\r\n                                    stroke=\"#475467\" stroke-width=\"1.66667\" stroke-linecap=\"round\"\r\n                                    stroke-linejoin=\"round\" />\r\n                            </g>\r\n                            <defs>\r\n                                <clipPath id=\"clip0_4047_40566\">\r\n                                    <rect width=\"20\" height=\"20\" fill=\"white\"\r\n                                        transform=\"translate(13 13)\" />\r\n                                </clipPath>\r\n                            </defs>\r\n                        </svg>\r\n                    </div>\r\n                        <div class=\"nodata-title\"><span class=\"click-upload cursor-pointer\">Click to\r\n                                upload </span>\r\n                                <!-- <span class=\"drag-drop\"> or drag and drop the template</span> -->\r\n                            </div>\r\n                       \r\n                    </span>\r\n                </label>\r\n            </div>\r\n\r\n            <div  *ngIf=\"typeNOB ==='multiple'\" class=\"d-flex mt-3 mb-10\" 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\" id=\"alert-toast\" (click)=\"proceed()\"\r\n                  >Proceed</button>\r\n            </div>\r\n        </div>\r\n\r\n    </div>\r\n</div>\r\n<div *ngIf=\"type ==='editView' || type === 'view'\" class=\"card pt-0  pb-3 \">\r\n    <div class=\"card-body py-0 d-flex flex-start flex-column p-9 \">\r\n        \r\n        <div class=\"row w-100 mt-5\">\r\n          \r\n            <div class=\"col-md-6\">\r\n                <a class=\"fs-4 text-gray-800 text-hover-primary fw-bold mb-0 title cursor-pointer\">Zone-wise NoB\r\n                    Count</a>\r\n            </div>\r\n            <div *ngIf=\"type === 'view'\" class=\"col-md-6 text-end\">\r\n                <span class=\"cursor-pointer\" (click)=\"cancel()\"><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\">\r\n<path d=\"M13 1L1 13M1 1L13 13\" stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</svg></span>\r\n        </div>\r\n        \r\n            <div *ngIf=\"zoneList?.length\" class=\"table-responsive max-h-500\">\r\n                <table class=\"table bottom-border text-nowrap mt-5\">\r\n                    <thead>\r\n                        <tr>\r\n                            <th scope=\"col\">Zone Name</th>\r\n                            <th scope=\"col\">NoB Count</th>\r\n                        </tr>\r\n                    </thead>\r\n                    <tbody>\r\n                        <tr *ngFor=\"let zone of zoneList;let i = index\">\r\n                            <td class=\"py-3 mt-10\">{{zone.zoneName}}</td>\r\n                            <td class=\"py-2\"><span *ngIf=\"type === 'view' || !isEditEnabled\">\r\n                                    {{ zone.nobCount }}\r\n                                </span>\r\n\r\n                                <!-- EDIT MODE -->\r\n                                <input *ngIf=\"type === 'editView' && isEditEnabled\" type=\"text\" class=\"form-control form-control-sm\"\r\n                                    [(ngModel)]=\"zone.nobCount\" (ngModelChange)=\"onNobChange()\"\r\n                                    (keypress)=\"omit_special_char($event)\" />\r\n                            </td>\r\n                        </tr>\r\n                    </tbody>\r\n                </table>\r\n            </div>\r\n            <div *ngIf=\"!zoneList?.length\" 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-nodata-table\" 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 Zone-wise NoB count</div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n          <div *ngIf=\"erroShow\" class=\"text-danger mt-2\"><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<g clip-path=\"url(#clip0_15055_156438)\">\r\n<path d=\"M9 6V9M9 12H9.0075M16.5 9C16.5 13.1421 13.1421 16.5 9 16.5C4.85786 16.5 1.5 13.1421 1.5 9C1.5 4.85786 4.85786 1.5 9 1.5C13.1421 1.5 16.5 4.85786 16.5 9Z\" stroke=\"#B42318\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n</g>\r\n<defs>\r\n<clipPath id=\"clip0_15055_156438\">\r\n<rect width=\"18\" height=\"18\" fill=\"white\"/>\r\n</clipPath>\r\n</defs>\r\n</svg></span>{{ erroShow }}</div>\r\n\r\n                <div *ngIf=\"type ==='editView' && isEditEnabled\" class=\"d-flex mt-3 mb-10\" role=\"group\">\r\n                    <button class=\"btn btn-outline w-100 me-3\" (click)=\"cancelEdit()\">Cancel</button>\r\n                    <button class=\"btn btn-primary w-100 ms-3\" id=\"alert-toast\" (click)=\"onSubmit()\"\r\n                        [disabled]=\"!dateValue || !nobCount || !storeId || !storeName\"><span\r\n                            *ngIf=\"type !=='add'\">Save</span><span *ngIf=\"type ==='add'\">Add</span></button>\r\n                </div>\r\n            \r\n        </div>\r\n    </div>\r\n</div>"]}
|