ezlibrary_v2 2.0.0
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/README.md +24 -0
- package/esm2020/ezlibrary_v2.mjs +5 -0
- package/esm2020/lib/admin-service/admin-service.service.mjs +34 -0
- package/esm2020/lib/analysis-search/analysis-search.component.mjs +1077 -0
- package/esm2020/lib/assort-service/assort-service.service.mjs +28 -0
- package/esm2020/lib/attribute-definition/attribute-definition.component.mjs +225 -0
- package/esm2020/lib/auth/auth.guard.mjs +37 -0
- package/esm2020/lib/bi-service/bi.service.mjs +57 -0
- package/esm2020/lib/call-info/callinfo.component.mjs +125 -0
- package/esm2020/lib/comman-service/comman-service.service.mjs +678 -0
- package/esm2020/lib/comman-service/share-data-service.service.mjs +23 -0
- package/esm2020/lib/contact-search/contact-search.component.mjs +690 -0
- package/esm2020/lib/contact-service/contact-service.service.mjs +45 -0
- package/esm2020/lib/ez-lib.component.mjs +26 -0
- package/esm2020/lib/ez-lib.module.mjs +232 -0
- package/esm2020/lib/ez-lib.service.mjs +14 -0
- package/esm2020/lib/ezheader/header.component.mjs +400 -0
- package/esm2020/lib/file-upload/fileupload.component.mjs +918 -0
- package/esm2020/lib/file-upload-log/file-upload-log.component.mjs +169 -0
- package/esm2020/lib/fileupload-module/fileupload-dashboard/fileupload-dashboard.component.mjs +14 -0
- package/esm2020/lib/fileupload-module/fileupload-routing.module.mjs +28 -0
- package/esm2020/lib/fileupload-module/fileupload.module.mjs +80 -0
- package/esm2020/lib/footer/footer.component.mjs +18 -0
- package/esm2020/lib/globle/common-pdf.service.mjs +28 -0
- package/esm2020/lib/globle/globle-env.service.mjs +45 -0
- package/esm2020/lib/globle/memo-report.service.mjs +2798 -0
- package/esm2020/lib/globle/shared-services.service.mjs +25 -0
- package/esm2020/lib/globle/upload-service.service.mjs +63 -0
- package/esm2020/lib/header/header.component.mjs +172 -0
- package/esm2020/lib/invalid/invalid.component.mjs +70 -0
- package/esm2020/lib/logout/logout.component.mjs +104 -0
- package/esm2020/lib/menu-right/menu-right.component.mjs +258 -0
- package/esm2020/lib/pipes/number-with-commas.pipe.mjs +24 -0
- package/esm2020/lib/pipes/order-by-pipe.pipe.mjs +17 -0
- package/esm2020/lib/pipes/selectedCount.mjs +19 -0
- package/esm2020/lib/pipes/sum.pipe.mjs +17 -0
- package/esm2020/lib/pkt-data/pkt-data.component.mjs +1109 -0
- package/esm2020/lib/pricing-service/pricing.service.mjs +64 -0
- package/esm2020/lib/qa-analysis/qa-analysis.component.mjs +1028 -0
- package/esm2020/lib/report-format/report-format.component.mjs +403 -0
- package/esm2020/lib/sessionend/session-end.guard.mjs +27 -0
- package/esm2020/lib/stock-service/lazyload.service.mjs +21 -0
- package/esm2020/lib/stock-service/stock-service.service.mjs +58 -0
- package/esm2020/lib/system-module/subform/subform.component.mjs +2817 -0
- package/esm2020/lib/system-module/system/system.component.mjs +970 -0
- package/esm2020/lib/system-module/system-service/system-service.service.mjs +83 -0
- package/esm2020/lib/system-module/system-service/upload-file.service.mjs +83 -0
- package/esm2020/lib/utility/app-no-dbl-click.directive.mjs +24 -0
- package/esm2020/lib/utility/constants.mjs +5 -0
- package/esm2020/lib/utility/contact-table-search.pipe.mjs +25 -0
- package/esm2020/lib/utility/formate-num-field.pipe.mjs +19 -0
- package/esm2020/lib/utility/search-pipe.pipe.mjs +26 -0
- package/esm2020/lib/utility/selective-preloading-strategy.mjs +23 -0
- package/esm2020/lib/utility/table-search.pipe.mjs +25 -0
- package/esm2020/lib/utility/tranform.directive.mjs +27 -0
- package/esm2020/lib/websearch-history/websearch-history.component.mjs +273 -0
- package/esm2020/public-api.mjs +59 -0
- package/ezlibrary_v2.d.ts +5 -0
- package/fesm2015/ezlibrary_v2.mjs +15300 -0
- package/fesm2015/ezlibrary_v2.mjs.map +1 -0
- package/fesm2020/ezlibrary_v2.mjs +15291 -0
- package/fesm2020/ezlibrary_v2.mjs.map +1 -0
- package/lib/admin-service/admin-service.service.d.ts +13 -0
- package/lib/analysis-search/analysis-search.component.d.ts +118 -0
- package/lib/assort-service/assort-service.service.d.ts +12 -0
- package/lib/attribute-definition/attribute-definition.component.d.ts +43 -0
- package/lib/auth/auth.guard.d.ts +14 -0
- package/lib/bi-service/bi.service.d.ts +16 -0
- package/lib/call-info/callinfo.component.d.ts +26 -0
- package/lib/comman-service/comman-service.service.d.ts +106 -0
- package/lib/comman-service/share-data-service.service.d.ts +10 -0
- package/lib/contact-search/contact-search.component.d.ts +111 -0
- package/lib/contact-service/contact-service.service.d.ts +15 -0
- package/lib/ez-lib.component.d.ts +8 -0
- package/lib/ez-lib.module.d.ts +43 -0
- package/lib/ez-lib.service.d.ts +6 -0
- package/lib/ezheader/header.component.d.ts +57 -0
- package/lib/file-upload/fileupload.component.d.ts +127 -0
- package/lib/file-upload-log/file-upload-log.component.d.ts +49 -0
- package/lib/fileupload-module/fileupload-dashboard/fileupload-dashboard.component.d.ts +8 -0
- package/lib/fileupload-module/fileupload-routing.module.d.ts +7 -0
- package/lib/fileupload-module/fileupload.module.d.ts +15 -0
- package/lib/footer/footer.component.d.ts +9 -0
- package/lib/globle/common-pdf.service.d.ts +9 -0
- package/lib/globle/globle-env.service.d.ts +16 -0
- package/lib/globle/memo-report.service.d.ts +107 -0
- package/lib/globle/shared-services.service.d.ts +12 -0
- package/lib/globle/upload-service.service.d.ts +16 -0
- package/lib/header/header.component.d.ts +41 -0
- package/lib/invalid/invalid.component.d.ts +12 -0
- package/lib/logout/logout.component.d.ts +19 -0
- package/lib/menu-right/menu-right.component.d.ts +43 -0
- package/lib/pipes/number-with-commas.pipe.d.ts +7 -0
- package/lib/pipes/order-by-pipe.pipe.d.ts +7 -0
- package/lib/pipes/selectedCount.d.ts +7 -0
- package/lib/pipes/sum.pipe.d.ts +7 -0
- package/lib/pkt-data/pkt-data.component.d.ts +184 -0
- package/lib/pricing-service/pricing.service.d.ts +16 -0
- package/lib/qa-analysis/qa-analysis.component.d.ts +95 -0
- package/lib/report-format/report-format.component.d.ts +74 -0
- package/lib/sessionend/session-end.guard.d.ts +10 -0
- package/lib/stock-service/lazyload.service.d.ts +7 -0
- package/lib/stock-service/stock-service.service.d.ts +15 -0
- package/lib/system-module/subform/subform.component.d.ts +222 -0
- package/lib/system-module/system/system.component.d.ts +109 -0
- package/lib/system-module/system-service/system-service.service.d.ts +23 -0
- package/lib/system-module/system-service/upload-file.service.d.ts +12 -0
- package/lib/utility/app-no-dbl-click.directive.d.ts +7 -0
- package/lib/utility/constants.d.ts +4 -0
- package/lib/utility/contact-table-search.pipe.d.ts +7 -0
- package/lib/utility/formate-num-field.pipe.d.ts +7 -0
- package/lib/utility/search-pipe.pipe.d.ts +7 -0
- package/lib/utility/selective-preloading-strategy.d.ts +9 -0
- package/lib/utility/table-search.pipe.d.ts +7 -0
- package/lib/utility/tranform.directive.d.ts +10 -0
- package/lib/websearch-history/websearch-history.component.d.ts +56 -0
- package/package.json +31 -0
- package/public-api.d.ts +54 -0
|
@@ -0,0 +1,918 @@
|
|
|
1
|
+
import { Component, ViewChild } from '@angular/core';
|
|
2
|
+
// import { FlashMessagesService } from 'angular2-flash-messages'
|
|
3
|
+
// import { Ng4LoadingSpinnerService } from 'ng4-loading-spinner';
|
|
4
|
+
import { Cookie } from 'ng2-cookies/ng2-cookies';
|
|
5
|
+
// import * as XLSX from 'ts-xlsx';
|
|
6
|
+
// import * as XLSX from 'xlsx/xlsx.mjs';
|
|
7
|
+
import * as XLSX from 'xlsx';
|
|
8
|
+
import { document } from 'ngx-bootstrap';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "@angular/router";
|
|
11
|
+
import * as i2 from "@angular/common/http";
|
|
12
|
+
import * as i3 from "../comman-service/comman-service.service";
|
|
13
|
+
import * as i4 from "@ng-select/ng-select";
|
|
14
|
+
import * as i5 from "@angular/common";
|
|
15
|
+
import * as i6 from "@angular/forms";
|
|
16
|
+
import * as i7 from "../utility/app-no-dbl-click.directive";
|
|
17
|
+
// import { AsyncLocalStorage } from 'async_hooks';
|
|
18
|
+
export class FileuploadComponent {
|
|
19
|
+
constructor(router, route,
|
|
20
|
+
// private flashMessagesService: FlashMessagesService,
|
|
21
|
+
// private spinnerService: Ng4LoadingSpinnerService,
|
|
22
|
+
http, cs) {
|
|
23
|
+
this.router = router;
|
|
24
|
+
this.route = route;
|
|
25
|
+
this.http = http;
|
|
26
|
+
this.cs = cs;
|
|
27
|
+
this.header = {};
|
|
28
|
+
this.fileToUpload = null;
|
|
29
|
+
this.fileName = "";
|
|
30
|
+
this.step = 1;
|
|
31
|
+
this.sheetData = [];
|
|
32
|
+
this.headerAttributeDtl = {};
|
|
33
|
+
this.defultDisplayLen = 5;
|
|
34
|
+
this.defultDisplayObj = [];
|
|
35
|
+
this.attrStructureDtl = [];
|
|
36
|
+
this.headerList = [];
|
|
37
|
+
this.totalmatch = 0;
|
|
38
|
+
this.totalignore = 0;
|
|
39
|
+
this.pageDefination = {};
|
|
40
|
+
this.rowdatamapDetails = {};
|
|
41
|
+
this.rowdistinctDataMap = {};
|
|
42
|
+
this.charHeaderList = [];
|
|
43
|
+
this.attributeDtlMap = {};
|
|
44
|
+
this.mappSheetData = [];
|
|
45
|
+
this.lable = "";
|
|
46
|
+
this.lableFile = "";
|
|
47
|
+
this.statusList = [];
|
|
48
|
+
this.fileDetails = [];
|
|
49
|
+
this.fileTypeList = [];
|
|
50
|
+
this.fileOptionsList = [];
|
|
51
|
+
this.check_status = [];
|
|
52
|
+
this.pkt_status = [];
|
|
53
|
+
this.colFormate = [];
|
|
54
|
+
this.ignoreFormate = [];
|
|
55
|
+
this.allcols = [];
|
|
56
|
+
this.fileLogIdn = 0;
|
|
57
|
+
this.show = false;
|
|
58
|
+
this.stepMsg = '';
|
|
59
|
+
this.dateFormatMap = {};
|
|
60
|
+
this.mappingskip = false;
|
|
61
|
+
this.dateFormatList = [{ "k": "dd/mm/yy", "v": "dd/mm/yy" },
|
|
62
|
+
{ "k": "mm/dd/yy", "v": "mm/dd/yy" },
|
|
63
|
+
{ "k": "dd/Mon/yy", "v": "dd/Mon/yy" },
|
|
64
|
+
];
|
|
65
|
+
this.gmatchedCount = 0;
|
|
66
|
+
this.gresultCount = 0;
|
|
67
|
+
this.sttsFile = {};
|
|
68
|
+
// checkUploadStt() {
|
|
69
|
+
// this.spinnerService.show();
|
|
70
|
+
// let reqObj = {};
|
|
71
|
+
// reqObj['formNme'] = this.route.snapshot.params['frmname'];
|
|
72
|
+
// reqObj['file_log_idn'] = this.fileLogIdn;
|
|
73
|
+
// console.log(JSON.stringify(reqObj));
|
|
74
|
+
// this.us.data(reqObj, 'getFileLogStatus', 'fileUpload/load').subscribe(response => {
|
|
75
|
+
// if (response.status == 'SUCCESS') {
|
|
76
|
+
// this.clicked = true;
|
|
77
|
+
// let result = response.result || {};
|
|
78
|
+
// console.log(result);
|
|
79
|
+
// this.stts['C'] = result['C'];
|
|
80
|
+
// this.stts['P'] = result['P'];
|
|
81
|
+
// this.stts['E'] = result['E'];
|
|
82
|
+
// this.stts['T'] = result['T'];
|
|
83
|
+
// this.step = 4;
|
|
84
|
+
// this.spinnerService.hide();
|
|
85
|
+
// this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });
|
|
86
|
+
// }
|
|
87
|
+
// this.spinnerService.hide();
|
|
88
|
+
// }, error => {
|
|
89
|
+
// this.spinnerService.hide();
|
|
90
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
91
|
+
// });
|
|
92
|
+
// }
|
|
93
|
+
this.stts = {};
|
|
94
|
+
this.clicked = false;
|
|
95
|
+
this.totProgress = 0;
|
|
96
|
+
this.totProgressFile = 0;
|
|
97
|
+
this.lastRefreshTimeFile = null;
|
|
98
|
+
this.lastRefreshTime = null;
|
|
99
|
+
}
|
|
100
|
+
handleFileInput(files) {
|
|
101
|
+
this.fileToUpload = files.item(0);
|
|
102
|
+
this.fileName = files[0].name;
|
|
103
|
+
}
|
|
104
|
+
onFileSelect(input) {
|
|
105
|
+
const files = input.files;
|
|
106
|
+
if (files && files.length) {
|
|
107
|
+
const fileToRead = files[0];
|
|
108
|
+
const fileReader = new FileReader();
|
|
109
|
+
fileReader.onload = this.onFileLoad;
|
|
110
|
+
fileReader.readAsText(fileToRead, "UTF-8");
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
onFileLoad(fileLoadedEvent) {
|
|
114
|
+
const csvSeparator = ';';
|
|
115
|
+
const textFromFileLoaded = fileLoadedEvent.target.result;
|
|
116
|
+
this.csvContent = textFromFileLoaded;
|
|
117
|
+
const txt = textFromFileLoaded;
|
|
118
|
+
const csv = [];
|
|
119
|
+
const lines = txt.split('\n');
|
|
120
|
+
console.log(lines[0]);
|
|
121
|
+
lines.forEach(element => {
|
|
122
|
+
const cols = element.split(csvSeparator);
|
|
123
|
+
csv.push(cols);
|
|
124
|
+
});
|
|
125
|
+
this.parsedCsv = csv;
|
|
126
|
+
// demo output as alert
|
|
127
|
+
var output = "";
|
|
128
|
+
csv.forEach(row => {
|
|
129
|
+
output += "\n";
|
|
130
|
+
var colNo = 0;
|
|
131
|
+
row.forEach(col => {
|
|
132
|
+
if (colNo > 0)
|
|
133
|
+
output += " | ";
|
|
134
|
+
output += col;
|
|
135
|
+
colNo++;
|
|
136
|
+
});
|
|
137
|
+
});
|
|
138
|
+
return output;
|
|
139
|
+
}
|
|
140
|
+
incomingfile(event) {
|
|
141
|
+
this.file = event.target.files[0];
|
|
142
|
+
this.fileName = this.file.name;
|
|
143
|
+
this.Upload();
|
|
144
|
+
}
|
|
145
|
+
Upload() {
|
|
146
|
+
this.show = true;
|
|
147
|
+
this.stepMsg = 'File upload in process..';
|
|
148
|
+
// this.spinnerService.show();
|
|
149
|
+
this.mappSheetData = [];
|
|
150
|
+
this.sheetData = [];
|
|
151
|
+
let fileReader = new FileReader();
|
|
152
|
+
fileReader.onload = (e) => {
|
|
153
|
+
this.arrayBuffer = fileReader.result;
|
|
154
|
+
var data = new Uint8Array(this.arrayBuffer);
|
|
155
|
+
var arr = new Array();
|
|
156
|
+
for (var i = 0; i != data.length; ++i)
|
|
157
|
+
arr[i] = String.fromCharCode(data[i]);
|
|
158
|
+
var bstr = arr.join("");
|
|
159
|
+
var workbook = XLSX.read(bstr, { type: "binary" });
|
|
160
|
+
var first_sheet_name = workbook.SheetNames[0];
|
|
161
|
+
var worksheet = workbook.Sheets[first_sheet_name];
|
|
162
|
+
var sheetDataMap = XLSX.utils.sheet_to_json(worksheet, { header: 1 });
|
|
163
|
+
let headerList = sheetDataMap[0];
|
|
164
|
+
headerList.forEach(hdr => {
|
|
165
|
+
this.headerList.push(hdr.trim());
|
|
166
|
+
});
|
|
167
|
+
this.sheetData = XLSX.utils.sheet_to_json(worksheet);
|
|
168
|
+
this.mappSheetData = XLSX.utils.sheet_to_json(worksheet);
|
|
169
|
+
this.fileLogIdn = 0;
|
|
170
|
+
console.log("this.headerList", this.headerList);
|
|
171
|
+
this.getHeaderMatch();
|
|
172
|
+
// const distinctSh = [...new Set(this.sheetData.map(x=>x.SHAPE))];
|
|
173
|
+
};
|
|
174
|
+
fileReader.readAsArrayBuffer(this.file);
|
|
175
|
+
}
|
|
176
|
+
setSetp(step) {
|
|
177
|
+
this.step = step;
|
|
178
|
+
if (step == 1) {
|
|
179
|
+
this.ngOnDestroy();
|
|
180
|
+
this.ngOnInit();
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
getHeaderMatch() {
|
|
184
|
+
this.show = true;
|
|
185
|
+
debugger;
|
|
186
|
+
this.stepMsg = 'Header verification in process ...';
|
|
187
|
+
// this.spinnerService.show();
|
|
188
|
+
let reqObj = {};
|
|
189
|
+
reqObj['formNme'] = 'fileUpload';
|
|
190
|
+
reqObj['attrList'] = this.headerList;
|
|
191
|
+
reqObj['fileIdn'] = this.fileType;
|
|
192
|
+
this.header["method"] = 'loadHeaderAttr';
|
|
193
|
+
this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response) => {
|
|
194
|
+
if (response.status == 'SUCCESS') {
|
|
195
|
+
let result = response.result;
|
|
196
|
+
this.headerAttributeDtl = result.attrDetails || '';
|
|
197
|
+
console.log("this.headerAttributeDtl", this.headerAttributeDtl);
|
|
198
|
+
let headerListLnt = this.headerList.length;
|
|
199
|
+
this.totalmatch = result.totalmatch || 0;
|
|
200
|
+
if (this.headerAttributeDtl != '') {
|
|
201
|
+
this.attrStructureDtl = result.attrStructureDtl || [];
|
|
202
|
+
if (this.sheetData.length < 5)
|
|
203
|
+
this.defultDisplayLen = this.sheetData.length;
|
|
204
|
+
for (var i = 0; i < this.defultDisplayLen; i++)
|
|
205
|
+
this.defultDisplayObj[i] = this.sheetData[i];
|
|
206
|
+
let ignoreColumnLst = result.ignore_column || [];
|
|
207
|
+
ignoreColumnLst.forEach(hdrDsc => {
|
|
208
|
+
if (this.headerAttributeDtl[hdrDsc] != undefined) {
|
|
209
|
+
this.headerAttributeDtl[hdrDsc].ignore = 'Y';
|
|
210
|
+
headerListLnt--;
|
|
211
|
+
this.totalignore++;
|
|
212
|
+
if (this.headerAttributeDtl[hdrDsc].attr != "")
|
|
213
|
+
this.totalmatch--;
|
|
214
|
+
}
|
|
215
|
+
});
|
|
216
|
+
let isDate = false;
|
|
217
|
+
this.headerList.forEach(hdr => {
|
|
218
|
+
let hdrAttr = this.headerAttributeDtl[hdr] || {};
|
|
219
|
+
if (hdrAttr.dta_typ == 'd') {
|
|
220
|
+
this.dateFormatMap[hdr] = this.dateFormat;
|
|
221
|
+
isDate = true;
|
|
222
|
+
}
|
|
223
|
+
});
|
|
224
|
+
if (this.totalmatch == headerListLnt && isDate == false) {
|
|
225
|
+
this.ValidateFileHeaderMapping('N');
|
|
226
|
+
this.show = false;
|
|
227
|
+
this.step = 3;
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
this.step = 2;
|
|
231
|
+
}
|
|
232
|
+
this.show = false;
|
|
233
|
+
}
|
|
234
|
+
else {
|
|
235
|
+
// this.flashMessagesService.show("Some problem in File Header Matching", { cssClass: 'alert-danger', timeout: 3000 });
|
|
236
|
+
}
|
|
237
|
+
//this.spinnerService.hide();
|
|
238
|
+
this.show = false;
|
|
239
|
+
}
|
|
240
|
+
else {
|
|
241
|
+
this.show = false;
|
|
242
|
+
//this.spinnerService.hide();
|
|
243
|
+
// this.flashMessagesService.show(response.message, { cssClass: 'alert-danger', timeout: 3000 });
|
|
244
|
+
}
|
|
245
|
+
}, error => {
|
|
246
|
+
// this.spinnerService.hide();
|
|
247
|
+
this.show = false;
|
|
248
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
249
|
+
});
|
|
250
|
+
}
|
|
251
|
+
updatecolumnstatue(hdr) {
|
|
252
|
+
var isIgnore = this.headerAttributeDtl[hdr].ignore || '';
|
|
253
|
+
if (isIgnore == 'Y') {
|
|
254
|
+
this.headerAttributeDtl[hdr].ignore = 'N';
|
|
255
|
+
this.totalignore--;
|
|
256
|
+
}
|
|
257
|
+
else {
|
|
258
|
+
this.totalignore++;
|
|
259
|
+
this.headerAttributeDtl[hdr].ignore = 'Y';
|
|
260
|
+
}
|
|
261
|
+
console.log(this.headerAttributeDtl[hdr]);
|
|
262
|
+
}
|
|
263
|
+
confirmsetHeaderMapp(hdr) {
|
|
264
|
+
this.maphdr = hdr;
|
|
265
|
+
let attr = this.headerAttributeDtl[hdr].attr;
|
|
266
|
+
this.attrStructureDtl.forEach(ele => {
|
|
267
|
+
if (ele.attr == attr) {
|
|
268
|
+
this.hdrmassage = this.headerAttributeDtl[hdr].attr + "(" + ele.print + ")";
|
|
269
|
+
}
|
|
270
|
+
});
|
|
271
|
+
document.getElementById('btnCofirmmaphdr').click();
|
|
272
|
+
}
|
|
273
|
+
CancelHeaderMapp() {
|
|
274
|
+
this.headerAttributeDtl[this.maphdr].attr = "";
|
|
275
|
+
}
|
|
276
|
+
setHeaderMapp() {
|
|
277
|
+
debugger;
|
|
278
|
+
let attr = this.headerAttributeDtl[this.maphdr].attr || '';
|
|
279
|
+
if (attr != '') {
|
|
280
|
+
let reqObj = {};
|
|
281
|
+
reqObj['formNme'] = 'fileUpload';
|
|
282
|
+
reqObj['optionaVal'] = this.maphdr;
|
|
283
|
+
reqObj['attr'] = attr;
|
|
284
|
+
console.log(JSON.stringify(reqObj));
|
|
285
|
+
this.header["method"] = 'addHeaderAttr';
|
|
286
|
+
this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response) => {
|
|
287
|
+
console.log(response);
|
|
288
|
+
if (response.status == 'SUCCESS') {
|
|
289
|
+
let result = response.result || {};
|
|
290
|
+
let hdrDtl = result.attrDetails[this.maphdr] || '';
|
|
291
|
+
if (hdrDtl != '') {
|
|
292
|
+
this.totalmatch++;
|
|
293
|
+
this.headerAttributeDtl[this.maphdr] = hdrDtl;
|
|
294
|
+
}
|
|
295
|
+
else {
|
|
296
|
+
this.headerAttributeDtl[this.maphdr] = {
|
|
297
|
+
"attr": "",
|
|
298
|
+
"print": "",
|
|
299
|
+
"srt": "",
|
|
300
|
+
"dta_typ": "",
|
|
301
|
+
"attr_idn": ""
|
|
302
|
+
};
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
// this.spinnerService.hide();
|
|
306
|
+
}, error => {
|
|
307
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
308
|
+
});
|
|
309
|
+
}
|
|
310
|
+
else {
|
|
311
|
+
// this.flashMessagesService.show("Mapping attribute is empty please retry.", { cssClass: 'alert-danger', timeout: 3000 });
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
setRowDataMapp() {
|
|
315
|
+
if (!this.mappingskip) {
|
|
316
|
+
let rowMatchCount = 0;
|
|
317
|
+
this.charHeaderList = [];
|
|
318
|
+
debugger;
|
|
319
|
+
this.headerList.forEach(hdr => {
|
|
320
|
+
let attr = this.headerAttributeDtl[hdr].attr || '';
|
|
321
|
+
let attrType = this.headerAttributeDtl[hdr].dta_typ || '';
|
|
322
|
+
let isIgnore = this.headerAttributeDtl[hdr].ignore || '';
|
|
323
|
+
if (attr != '' && isIgnore != 'N' && attrType == 'c') {
|
|
324
|
+
debugger;
|
|
325
|
+
var distinctlist = Array.from(new Set(this.sheetData.map((item) => item[hdr])));
|
|
326
|
+
distinctlist = distinctlist.filter(function (e) { return e; });
|
|
327
|
+
if (distinctlist.length > 0) {
|
|
328
|
+
this.rowdistinctDataMap[attr] = distinctlist;
|
|
329
|
+
rowMatchCount = rowMatchCount + distinctlist.length;
|
|
330
|
+
this.gmatchedCount = rowMatchCount;
|
|
331
|
+
this.charHeaderList.push(hdr);
|
|
332
|
+
let attrDetails = this.attrStructureDtl.find(attrdtl => attrdtl.attr == attr) || {};
|
|
333
|
+
this.attributeDtlMap[attr] = attrDetails.prpList || [];
|
|
334
|
+
}
|
|
335
|
+
}
|
|
336
|
+
});
|
|
337
|
+
let reqObj = {};
|
|
338
|
+
reqObj['formNme'] = 'fileUpload';
|
|
339
|
+
reqObj['attrMap'] = this.rowdistinctDataMap;
|
|
340
|
+
console.log(JSON.stringify(reqObj));
|
|
341
|
+
this.header["method"] = 'loadHeaderAttrDtl';
|
|
342
|
+
this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response) => {
|
|
343
|
+
// this.spinnerService.hide();
|
|
344
|
+
if (response.status == 'SUCCESS') {
|
|
345
|
+
let result = response.result;
|
|
346
|
+
console.log(result);
|
|
347
|
+
console.log(rowMatchCount);
|
|
348
|
+
debugger;
|
|
349
|
+
this.rowdatamapDetails = result.attrDetails || {};
|
|
350
|
+
this.gresultCount = result.totalmatch;
|
|
351
|
+
this.step = 3;
|
|
352
|
+
if (rowMatchCount == result.totalmatch) {
|
|
353
|
+
this.step = 4;
|
|
354
|
+
this.uploadFile();
|
|
355
|
+
}
|
|
356
|
+
else {
|
|
357
|
+
// this.flashMessagesService.show("please verify data mapping.", { cssClass: 'alert-danger', timeout: 3000 });
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
else {
|
|
361
|
+
// this.flashMessagesService.show("something go wrong in row data.", { cssClass: 'alert-danger', timeout: 3000 });
|
|
362
|
+
}
|
|
363
|
+
}, error => {
|
|
364
|
+
// this.spinnerService.hide();
|
|
365
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
366
|
+
});
|
|
367
|
+
}
|
|
368
|
+
else {
|
|
369
|
+
this.step = 4;
|
|
370
|
+
this.uploadFile();
|
|
371
|
+
}
|
|
372
|
+
}
|
|
373
|
+
confirmHeaderDetailsMapp(attr, attr_idn, optionval) {
|
|
374
|
+
this.dtlAttr = attr;
|
|
375
|
+
this.dtlattr_idn = attr_idn;
|
|
376
|
+
this.dtloptionval = optionval;
|
|
377
|
+
let val = this.rowdatamapDetails[this.dtlAttr][this.dtloptionval].val;
|
|
378
|
+
let attributeDtlList = this.attributeDtlMap[attr];
|
|
379
|
+
attributeDtlList.forEach(ele => {
|
|
380
|
+
if (ele.val == val) {
|
|
381
|
+
this.dtlmassage = val + "(" + ele.print + ")";
|
|
382
|
+
}
|
|
383
|
+
});
|
|
384
|
+
document.getElementById('btnCofirmmapdtl').click();
|
|
385
|
+
}
|
|
386
|
+
CancelHeaderDetailsMapp() {
|
|
387
|
+
this.rowdatamapDetails[this.dtlAttr][this.dtloptionval].val = "";
|
|
388
|
+
}
|
|
389
|
+
setHeaderDetailsMapp() {
|
|
390
|
+
let attrDtlVal = this.rowdatamapDetails[this.dtlAttr][this.dtloptionval].val || '';
|
|
391
|
+
if (attrDtlVal != '') {
|
|
392
|
+
let reqObj = {};
|
|
393
|
+
reqObj['formNme'] = 'fileUpload';
|
|
394
|
+
reqObj['optionaVal'] = this.dtloptionval;
|
|
395
|
+
reqObj['attr_idn'] = this.dtlattr_idn;
|
|
396
|
+
reqObj['attr'] = this.dtlAttr;
|
|
397
|
+
reqObj['attrVal'] = attrDtlVal;
|
|
398
|
+
this.header["method"] = 'addDetailAttr';
|
|
399
|
+
console.log(JSON.stringify(reqObj));
|
|
400
|
+
this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response) => {
|
|
401
|
+
console.log("addDetailAttr", response);
|
|
402
|
+
if (response.status == 'SUCCESS') {
|
|
403
|
+
this.gresultCount++;
|
|
404
|
+
let result = response.result || {};
|
|
405
|
+
console.log(result.attrDetails);
|
|
406
|
+
let attrDetails = result.attrDetails || {};
|
|
407
|
+
this.rowdatamapDetails[this.dtlAttr][this.dtloptionval] = attrDetails[this.dtloptionval];
|
|
408
|
+
// this.spinnerService.hide();
|
|
409
|
+
}
|
|
410
|
+
// this.spinnerService.hide();
|
|
411
|
+
}, error => {
|
|
412
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
413
|
+
});
|
|
414
|
+
}
|
|
415
|
+
else {
|
|
416
|
+
// this.flashMessagesService.show("Mapping attribute is empty please retry.", { cssClass: 'alert-danger', timeout: 3000 });
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
onSubmit(formVal) {
|
|
420
|
+
var t = Object.keys(formVal.form.controls).forEach(field => {
|
|
421
|
+
const control = formVal.form.get(field);
|
|
422
|
+
});
|
|
423
|
+
this.saveFileOption(formVal.value);
|
|
424
|
+
}
|
|
425
|
+
saveFileOption(frmvals) {
|
|
426
|
+
// this.spinnerService.show();
|
|
427
|
+
let reqObj = {};
|
|
428
|
+
reqObj = { ...frmvals, column_format: this.colFormate, ignore_column: this.ignoreFormate };
|
|
429
|
+
reqObj['formNme'] = 'fileUpload';
|
|
430
|
+
console.log(JSON.stringify(reqObj));
|
|
431
|
+
debugger;
|
|
432
|
+
this.header["method"] = 'addFileOption';
|
|
433
|
+
this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response) => {
|
|
434
|
+
if (response.status == 'SUCCESS') {
|
|
435
|
+
debugger;
|
|
436
|
+
let result = response.result || {};
|
|
437
|
+
this.fileOptionsList = result.fileOptionsList;
|
|
438
|
+
this.fileType = result.file_idn;
|
|
439
|
+
this.ValidateFileHeaderMapping('N');
|
|
440
|
+
// this.spinnerService.hide();
|
|
441
|
+
// this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });
|
|
442
|
+
}
|
|
443
|
+
// this.spinnerService.hide();
|
|
444
|
+
}, error => {
|
|
445
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
446
|
+
});
|
|
447
|
+
}
|
|
448
|
+
addFileLog(fileIdn) {
|
|
449
|
+
debugger;
|
|
450
|
+
let reqObj = {};
|
|
451
|
+
reqObj['formNme'] = 'fileUpload';
|
|
452
|
+
reqObj['file_idn'] = fileIdn;
|
|
453
|
+
reqObj['file_status'] = "Header Inserted";
|
|
454
|
+
reqObj['validation_remarks'] = "Header validated";
|
|
455
|
+
reqObj['header_row'] = this.allcols;
|
|
456
|
+
reqObj['header_attr_row'] = this.colFormate;
|
|
457
|
+
this.header["method"] = 'addFileLog';
|
|
458
|
+
this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response) => {
|
|
459
|
+
if (response.status == 'SUCCESS') {
|
|
460
|
+
debugger;
|
|
461
|
+
let result = response.result || {};
|
|
462
|
+
this.fileLogIdn = result.file_log_idn;
|
|
463
|
+
this.setRowDataMapp();
|
|
464
|
+
// this.spinnerService.hide();
|
|
465
|
+
// this.flashMessagesService.show("Header validated successfully", { cssClass: 'alert-success', timeout: 3000 });
|
|
466
|
+
}
|
|
467
|
+
// this.spinnerService.hide();
|
|
468
|
+
}, error => {
|
|
469
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
470
|
+
});
|
|
471
|
+
}
|
|
472
|
+
ValidateFileHeaderMapping(formatSave) {
|
|
473
|
+
// this.spinnerService.show();
|
|
474
|
+
this.show = true;
|
|
475
|
+
this.stepMsg = 'Header verification in process ...';
|
|
476
|
+
this.colFormate = [];
|
|
477
|
+
this.ignoreFormate = [];
|
|
478
|
+
this.allcols = [];
|
|
479
|
+
let isValidate = true;
|
|
480
|
+
this.headerList.forEach(hdr => {
|
|
481
|
+
let hdrDtl = this.headerAttributeDtl[hdr] || '';
|
|
482
|
+
if (hdrDtl.attr == '' && hdrDtl.ignore != 'Y') {
|
|
483
|
+
isValidate = false;
|
|
484
|
+
}
|
|
485
|
+
if (hdrDtl.attr != '' && hdrDtl.ignore != 'N') {
|
|
486
|
+
this.colFormate.push(hdrDtl.attr);
|
|
487
|
+
}
|
|
488
|
+
if (hdrDtl.ignore == 'Y') {
|
|
489
|
+
this.ignoreFormate.push(hdr);
|
|
490
|
+
}
|
|
491
|
+
this.allcols.push(hdr);
|
|
492
|
+
});
|
|
493
|
+
if (isValidate && (this.fileType == null || this.fileType == undefined || this.fileType == "")) {
|
|
494
|
+
// this.spinnerService.hide();
|
|
495
|
+
this.stepMsg = "";
|
|
496
|
+
document.getElementById('btnfileUploadModal').click();
|
|
497
|
+
this.step = 2;
|
|
498
|
+
return;
|
|
499
|
+
}
|
|
500
|
+
else {
|
|
501
|
+
if (isValidate) {
|
|
502
|
+
if (formatSave == 'Y') {
|
|
503
|
+
this.updatefileOption();
|
|
504
|
+
}
|
|
505
|
+
this.addFileLog(this.fileType);
|
|
506
|
+
}
|
|
507
|
+
else {
|
|
508
|
+
// this.spinnerService.hide();
|
|
509
|
+
// this.flashMessagesService.show("Please specify mapping or marke as ignore ", { cssClass: 'alert-danger', timeout: 3000 });
|
|
510
|
+
}
|
|
511
|
+
}
|
|
512
|
+
this.show = false;
|
|
513
|
+
}
|
|
514
|
+
updatefileOption() {
|
|
515
|
+
let reqObj = {};
|
|
516
|
+
reqObj['formNme'] = 'fileUpload';
|
|
517
|
+
reqObj['fileIdn'] = this.fileType;
|
|
518
|
+
reqObj['column_format'] = this.colFormate;
|
|
519
|
+
reqObj['ignore_column'] = this.ignoreFormate;
|
|
520
|
+
this.header["method"] = 'updateColumnFormat';
|
|
521
|
+
console.log(JSON.stringify(reqObj));
|
|
522
|
+
this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response) => {
|
|
523
|
+
if (response.status == 'SUCCESS') {
|
|
524
|
+
}
|
|
525
|
+
}, error => {
|
|
526
|
+
});
|
|
527
|
+
}
|
|
528
|
+
uploadFile() {
|
|
529
|
+
this.dateFormat = this.dateFormat || 'dd/mm/yy';
|
|
530
|
+
this.delim = this.delim || '/';
|
|
531
|
+
this.show = true;
|
|
532
|
+
let dateValid = true;
|
|
533
|
+
let massage = "";
|
|
534
|
+
if (!this.mappingskip) {
|
|
535
|
+
this.stepMsg = "Data verification in process ...";
|
|
536
|
+
this.headerList.forEach(hdr => {
|
|
537
|
+
debugger;
|
|
538
|
+
let attr = this.headerAttributeDtl[hdr].attr || '';
|
|
539
|
+
let attrType = this.headerAttributeDtl[hdr].dta_typ || '';
|
|
540
|
+
let isIgnore = this.headerAttributeDtl[hdr].ignore || '';
|
|
541
|
+
if (isIgnore == 'Y') {
|
|
542
|
+
this.mappSheetData.map((rowData, i) => {
|
|
543
|
+
delete this.mappSheetData[i][hdr];
|
|
544
|
+
});
|
|
545
|
+
}
|
|
546
|
+
else {
|
|
547
|
+
if (attrType == 'c') {
|
|
548
|
+
this.mappSheetData.map((rowData, i) => {
|
|
549
|
+
if (this.charHeaderList.indexOf(hdr) != -1) {
|
|
550
|
+
let attrdtlVal = rowData[hdr] || '';
|
|
551
|
+
if (attrdtlVal != '') {
|
|
552
|
+
let attrDtlMapVal = this.rowdatamapDetails[attr][attrdtlVal].srt;
|
|
553
|
+
this.mappSheetData[i][attr] = attrDtlMapVal.toString();
|
|
554
|
+
}
|
|
555
|
+
if (attr != hdr)
|
|
556
|
+
delete this.mappSheetData[i][hdr];
|
|
557
|
+
}
|
|
558
|
+
});
|
|
559
|
+
}
|
|
560
|
+
else if (attrType == 'n') {
|
|
561
|
+
this.mappSheetData.map((rowData, i) => {
|
|
562
|
+
let attrdtlVal = rowData[hdr] || '';
|
|
563
|
+
if (attrdtlVal != '') {
|
|
564
|
+
debugger;
|
|
565
|
+
attrdtlVal = attrdtlVal.replace(/[^0-9.-]/g, "");
|
|
566
|
+
this.mappSheetData[i][attr] = attrdtlVal.toString();
|
|
567
|
+
}
|
|
568
|
+
if (attr != hdr)
|
|
569
|
+
delete this.mappSheetData[i][hdr];
|
|
570
|
+
});
|
|
571
|
+
}
|
|
572
|
+
else if (attrType == 'd') {
|
|
573
|
+
this.mappSheetData.map((rowData, i) => {
|
|
574
|
+
debugger;
|
|
575
|
+
let attrdtlVal = rowData[hdr] || '';
|
|
576
|
+
let dtFrm = this.dateFormatMap[hdr] || 'dd/mm/yy';
|
|
577
|
+
if (attrdtlVal != '')
|
|
578
|
+
attrdtlVal = this.cs.dateValidation(attrdtlVal, dtFrm);
|
|
579
|
+
if (attrdtlVal == 'invaild') {
|
|
580
|
+
dateValid = false;
|
|
581
|
+
massage = "Please check Date :" + rowData[hdr] + " Date Format :" + dtFrm;
|
|
582
|
+
}
|
|
583
|
+
this.mappSheetData[i][attr] = attrdtlVal.toString();
|
|
584
|
+
if (attr != hdr)
|
|
585
|
+
delete this.mappSheetData[i][hdr];
|
|
586
|
+
});
|
|
587
|
+
}
|
|
588
|
+
else if (attrType == 't') {
|
|
589
|
+
this.mappSheetData.map((rowData, i) => {
|
|
590
|
+
let attrdtlVal = rowData[hdr] || '';
|
|
591
|
+
this.mappSheetData[i][attr] = attrdtlVal.toString();
|
|
592
|
+
if (attr != hdr)
|
|
593
|
+
delete this.mappSheetData[i][hdr];
|
|
594
|
+
});
|
|
595
|
+
}
|
|
596
|
+
}
|
|
597
|
+
});
|
|
598
|
+
}
|
|
599
|
+
if (dateValid) {
|
|
600
|
+
let reqObj = {};
|
|
601
|
+
reqObj['formNme'] = 'fileUpload'; //this.route.snapshot.params['frmname'];
|
|
602
|
+
reqObj['file_log_idn'] = this.fileLogIdn;
|
|
603
|
+
reqObj['attr_data'] = this.mappSheetData;
|
|
604
|
+
reqObj['in_data'] = this.sheetData;
|
|
605
|
+
reqObj['dateformat'] = this.dateFormatMap;
|
|
606
|
+
this.header["method"] = 'fileUpload';
|
|
607
|
+
let url = "fileUpload/load";
|
|
608
|
+
if (this.mdl == 'inward') {
|
|
609
|
+
url = 'inward/loadFile';
|
|
610
|
+
reqObj['inward_idn'] = this.inward_idn;
|
|
611
|
+
}
|
|
612
|
+
// console.log(reqObj);
|
|
613
|
+
console.log(JSON.stringify(reqObj));
|
|
614
|
+
// console.log(this.header);
|
|
615
|
+
this.cs.loadiFile(reqObj, this.header, url).then((response) => {
|
|
616
|
+
if (response.status == 'SUCCESS') {
|
|
617
|
+
let result = response.result || {};
|
|
618
|
+
console.log(result);
|
|
619
|
+
this.show = false;
|
|
620
|
+
this.step = 4;
|
|
621
|
+
this.fileLogIdn = result.file_log_idn;
|
|
622
|
+
this.hdrIdn = result.hdrIdn;
|
|
623
|
+
this.getProgressFile(this.fileLogIdn);
|
|
624
|
+
this.lableFile = "File Sequence No. " + this.fileLogIdn + " Uploading in progress...";
|
|
625
|
+
// set file id to local storage
|
|
626
|
+
// AsyncLocalStorage.arguments('uploadedFileId', result.file_log_idn);
|
|
627
|
+
this.lable = "Pricing Sequence No. " + this.hdrIdn + " Price calculations in progress...";
|
|
628
|
+
this.getProgressPrice(this.hdrIdn);
|
|
629
|
+
// this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });
|
|
630
|
+
}
|
|
631
|
+
this.show = false;
|
|
632
|
+
// this.spinnerService.hide();
|
|
633
|
+
}, error => {
|
|
634
|
+
this.show = false;
|
|
635
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
636
|
+
});
|
|
637
|
+
}
|
|
638
|
+
else {
|
|
639
|
+
this.ngOnInit();
|
|
640
|
+
// this.flashMessagesService.show(massage, { cssClass: 'alert-danger', timeout: 4000 });
|
|
641
|
+
}
|
|
642
|
+
console.log("mappSheetData", JSON.stringify(this.mappSheetData));
|
|
643
|
+
console.log("this.sheetData", JSON.stringify(this.sheetData));
|
|
644
|
+
}
|
|
645
|
+
changeMapping(hdrObj, hdr, attr) {
|
|
646
|
+
this.headerAttributeDtl[hdr].ignore = 'Y';
|
|
647
|
+
this.headerAttributeDtl[hdr].attr = '';
|
|
648
|
+
this.removeAttrOptVal(attr, hdr);
|
|
649
|
+
}
|
|
650
|
+
removeAttrOptVal(attr, optionaVal) {
|
|
651
|
+
let reqObj = {};
|
|
652
|
+
reqObj['formNme'] = 'fileUpload';
|
|
653
|
+
reqObj['attr'] = attr;
|
|
654
|
+
reqObj['optionaVal'] = optionaVal;
|
|
655
|
+
console.log(JSON.stringify(reqObj));
|
|
656
|
+
this.header["method"] = 'removeAttrOptVal';
|
|
657
|
+
this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response) => {
|
|
658
|
+
if (response.status == 'SUCCESS') {
|
|
659
|
+
// this.spinnerService.hide();
|
|
660
|
+
// this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });
|
|
661
|
+
}
|
|
662
|
+
// this.spinnerService.hide();
|
|
663
|
+
}, error => {
|
|
664
|
+
// this.spinnerService.hide();
|
|
665
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
666
|
+
});
|
|
667
|
+
}
|
|
668
|
+
removeDetailAttrOptVal(attrIdn, optionaVal, val, hdrAttr) {
|
|
669
|
+
this.rowdatamapDetails[hdrAttr][optionaVal].val = '';
|
|
670
|
+
let reqObj = {};
|
|
671
|
+
reqObj['formNme'] = 'fileUpload';
|
|
672
|
+
reqObj['attrVal'] = val;
|
|
673
|
+
reqObj['optionaVal'] = optionaVal;
|
|
674
|
+
reqObj['attr_idn'] = attrIdn;
|
|
675
|
+
console.log(JSON.stringify(reqObj));
|
|
676
|
+
this.header["method"] = 'removeAttrOptVal';
|
|
677
|
+
this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response) => {
|
|
678
|
+
if (response.status == 'SUCCESS') {
|
|
679
|
+
// this.spinnerService.hide();
|
|
680
|
+
// this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });
|
|
681
|
+
}
|
|
682
|
+
// this.spinnerService.hide();
|
|
683
|
+
}, error => {
|
|
684
|
+
// this.spinnerService.hide();
|
|
685
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
686
|
+
});
|
|
687
|
+
}
|
|
688
|
+
getProgressFile(fileLogIdn) {
|
|
689
|
+
let reqObj = {};
|
|
690
|
+
reqObj['formNme'] = 'fileUpload';
|
|
691
|
+
reqObj['file_log_idn'] = fileLogIdn; //this.fileLogIdn;
|
|
692
|
+
console.log(JSON.stringify(reqObj));
|
|
693
|
+
this.header["method"] = 'getFileLogStatus';
|
|
694
|
+
this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response) => {
|
|
695
|
+
if (response.status == 'SUCCESS') {
|
|
696
|
+
this.clicked = true;
|
|
697
|
+
let result = response.result || {};
|
|
698
|
+
console.log(result);
|
|
699
|
+
this.sttsFile['C'] = result['C'];
|
|
700
|
+
this.sttsFile['P'] = result['P'];
|
|
701
|
+
this.sttsFile['E'] = result['E'];
|
|
702
|
+
this.sttsFile['T'] = result['T'];
|
|
703
|
+
this.sttsFile['I'] = result['I'];
|
|
704
|
+
this.step = 4;
|
|
705
|
+
this.totProgressFile = Math.ceil(parseFloat(result['C']) * 100 / parseFloat(result['T']));
|
|
706
|
+
this.recallFile(fileLogIdn);
|
|
707
|
+
console.log(this.totProgress);
|
|
708
|
+
// this.spinnerService.hide();
|
|
709
|
+
// this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });
|
|
710
|
+
}
|
|
711
|
+
// this.spinnerService.hide();
|
|
712
|
+
}, error => {
|
|
713
|
+
// this.spinnerService.hide();
|
|
714
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
715
|
+
});
|
|
716
|
+
}
|
|
717
|
+
getProgressPrice(hdrIdn) {
|
|
718
|
+
// this.spinnerService.show();
|
|
719
|
+
let reqObj = {};
|
|
720
|
+
reqObj['formNme'] = 'fileUpload';
|
|
721
|
+
reqObj['seqNo'] = hdrIdn; //"846";//this.fileLogIdn;
|
|
722
|
+
console.log(JSON.stringify(reqObj));
|
|
723
|
+
this.header["method"] = 'getPriceStatus';
|
|
724
|
+
this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response) => {
|
|
725
|
+
if (response.status == 'SUCCESS') {
|
|
726
|
+
this.clicked = true;
|
|
727
|
+
let result = response.result || {};
|
|
728
|
+
console.log(result);
|
|
729
|
+
this.stts['C'] = result['C'];
|
|
730
|
+
this.stts['P'] = result['P'];
|
|
731
|
+
this.stts['E'] = result['E'];
|
|
732
|
+
this.stts['T'] = result['T'];
|
|
733
|
+
this.step = 4;
|
|
734
|
+
this.totProgress = Math.ceil(parseFloat(result['C']) * 100 / parseFloat(result['T']));
|
|
735
|
+
this.recall(this.hdrIdn);
|
|
736
|
+
console.log(this.totProgress);
|
|
737
|
+
// this.spinnerService.hide();
|
|
738
|
+
// this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });
|
|
739
|
+
}
|
|
740
|
+
// this.spinnerService.hide();
|
|
741
|
+
}, error => {
|
|
742
|
+
// this.spinnerService.hide();
|
|
743
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
744
|
+
});
|
|
745
|
+
}
|
|
746
|
+
recallFile(fileLogIdn) {
|
|
747
|
+
if (this.totProgressFile < 100) {
|
|
748
|
+
this.lastRefreshTimeFile = new Date();
|
|
749
|
+
this.timerfile =
|
|
750
|
+
setTimeout(() => {
|
|
751
|
+
this.getProgressFile(fileLogIdn);
|
|
752
|
+
}, 5000);
|
|
753
|
+
}
|
|
754
|
+
else {
|
|
755
|
+
clearTimeout(this.timerfile);
|
|
756
|
+
// this.PlanningComponent.getPacketsByHeaderId(hdrIdn);
|
|
757
|
+
// this.closebtn.nativeElement.click();
|
|
758
|
+
if (this.totProgressFile == 100 && this.totProgress == 100) {
|
|
759
|
+
document.getElementById('btnfileUploadModal').click();
|
|
760
|
+
this.router.navigate(['/pricing/rough/planingscreen/roughPlaningScreen'], { queryParams: { hdrId: this.hdrIdn } });
|
|
761
|
+
}
|
|
762
|
+
}
|
|
763
|
+
}
|
|
764
|
+
recall(hdrIdn) {
|
|
765
|
+
if (this.totProgress < 100) {
|
|
766
|
+
this.lastRefreshTime = new Date();
|
|
767
|
+
this.timerPrice =
|
|
768
|
+
setTimeout(() => {
|
|
769
|
+
this.getProgressPrice(hdrIdn);
|
|
770
|
+
}, 5000);
|
|
771
|
+
}
|
|
772
|
+
else {
|
|
773
|
+
clearTimeout(this.timerPrice);
|
|
774
|
+
if (this.totProgressFile == 100 && this.totProgress == 100) {
|
|
775
|
+
document.getElementById('btnfileUploadModal').click();
|
|
776
|
+
this.router.navigate(['/pricing/rough/planingscreen/roughPlaningScreen'], { queryParams: { hdrId: this.hdrIdn } });
|
|
777
|
+
}
|
|
778
|
+
}
|
|
779
|
+
}
|
|
780
|
+
SkipVerification() {
|
|
781
|
+
debugger;
|
|
782
|
+
this.mappingskip = true;
|
|
783
|
+
this.addFileLog(this.fileType);
|
|
784
|
+
}
|
|
785
|
+
SkipVerificationDtl() {
|
|
786
|
+
this.mappingskip = true;
|
|
787
|
+
this.step = 4;
|
|
788
|
+
this.uploadFile();
|
|
789
|
+
}
|
|
790
|
+
loadFileTypeData(fileUpload, mdl) {
|
|
791
|
+
this.sheetData = [];
|
|
792
|
+
this.headerAttributeDtl = {};
|
|
793
|
+
this.defultDisplayLen = 5;
|
|
794
|
+
this.defultDisplayObj = [];
|
|
795
|
+
this.attrStructureDtl = [];
|
|
796
|
+
this.headerList = [];
|
|
797
|
+
this.headerprp;
|
|
798
|
+
this.attrprp;
|
|
799
|
+
this.totalmatch = 0;
|
|
800
|
+
this.totalignore = 0;
|
|
801
|
+
this.pageDefination = {};
|
|
802
|
+
this.rowdatamapDetails = {};
|
|
803
|
+
this.rowdistinctDataMap = {};
|
|
804
|
+
this.charHeaderList = [];
|
|
805
|
+
this.attributeDtlMap = {};
|
|
806
|
+
this.mappSheetData = [];
|
|
807
|
+
this.statusList = [];
|
|
808
|
+
this.fileDetails = [];
|
|
809
|
+
this.fileTypeList = [];
|
|
810
|
+
this.fileOptionsList = [];
|
|
811
|
+
this.fileType;
|
|
812
|
+
this.nme;
|
|
813
|
+
this.typ;
|
|
814
|
+
this.description;
|
|
815
|
+
this.check_status = [];
|
|
816
|
+
this.pkt_status = [];
|
|
817
|
+
this.colFormate = [];
|
|
818
|
+
this.allcols = [];
|
|
819
|
+
this.fileLogIdn = 0;
|
|
820
|
+
this.show = false;
|
|
821
|
+
this.stepMsg = '';
|
|
822
|
+
this.stts = {};
|
|
823
|
+
this.clicked = false;
|
|
824
|
+
this.totProgress = 0;
|
|
825
|
+
this.totProgressFile = 0;
|
|
826
|
+
this.step = 1;
|
|
827
|
+
this.lable = "";
|
|
828
|
+
this.filenme = "";
|
|
829
|
+
let reqObj = {};
|
|
830
|
+
this.dateFormatMap = {};
|
|
831
|
+
let filetype = this.route.snapshot.params['filetype'] || '';
|
|
832
|
+
this.mdl = mdl;
|
|
833
|
+
this.filenme = this.route.snapshot.params['filetype'] || '';
|
|
834
|
+
this.mappingskip = false;
|
|
835
|
+
reqObj['formNme'] = fileUpload;
|
|
836
|
+
if (mdl != '')
|
|
837
|
+
reqObj['mdl'] = mdl;
|
|
838
|
+
if (filetype != '')
|
|
839
|
+
reqObj['filenme'] = filetype;
|
|
840
|
+
console.log(JSON.stringify(this.header));
|
|
841
|
+
console.log(JSON.stringify(reqObj));
|
|
842
|
+
this.header["method"] = 'loadFileUpload';
|
|
843
|
+
this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response) => {
|
|
844
|
+
if (response.status == 'SUCCESS') {
|
|
845
|
+
console.log(response);
|
|
846
|
+
debugger;
|
|
847
|
+
let result = response.result || {};
|
|
848
|
+
this.pageDefination = result.pageDefination;
|
|
849
|
+
this.statusList = result.statusList;
|
|
850
|
+
this.fileDetails = result.fileDetails;
|
|
851
|
+
this.fileTypeList = result.fileTypeList;
|
|
852
|
+
this.fileOptionsList = result.fileOptionsList || [];
|
|
853
|
+
if (this.fileOptionsList.length > 0)
|
|
854
|
+
this.fileType = this.fileOptionsList[0].k;
|
|
855
|
+
let addlAttr = this.fileOptionsList[0].addl_attr || {};
|
|
856
|
+
this.dateFormat = addlAttr.dateformat || 'dd/mm/yy';
|
|
857
|
+
this.delim = addlAttr.delim || '/';
|
|
858
|
+
this.statusList = result.statusList.map(option => ({
|
|
859
|
+
value: option.k,
|
|
860
|
+
label: option.v
|
|
861
|
+
}));
|
|
862
|
+
}
|
|
863
|
+
// this.spinnerService.hide();
|
|
864
|
+
}, error => {
|
|
865
|
+
// this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });
|
|
866
|
+
});
|
|
867
|
+
}
|
|
868
|
+
ngOnInit() {
|
|
869
|
+
let mdlk = JSON.parse(localStorage.getItem('mdlKey'));
|
|
870
|
+
let cUrl = this.router.url;
|
|
871
|
+
this.cDt = new Date();
|
|
872
|
+
this.header = {
|
|
873
|
+
'clientkey': Cookie.get('_ck'),
|
|
874
|
+
'Content-Type': 'application/json',
|
|
875
|
+
'loginid': Cookie.get('_logid'),
|
|
876
|
+
'modulekey': mdlk[cUrl.split('/')[1]],
|
|
877
|
+
'source': 'qs'
|
|
878
|
+
};
|
|
879
|
+
this.route.params.subscribe((params) => {
|
|
880
|
+
let mdl = this.route.snapshot.params['grp'] || '';
|
|
881
|
+
this.loadFileTypeData('fileUpload', mdl);
|
|
882
|
+
});
|
|
883
|
+
}
|
|
884
|
+
stockInwardUpload(inwardDtl, mdl) {
|
|
885
|
+
this.inward_idn = inwardDtl.inward_idn;
|
|
886
|
+
this.inwardStockType = inwardDtl.stock_type;
|
|
887
|
+
this.mdl = mdl;
|
|
888
|
+
this.loadFileTypeData('fileUpload', mdl);
|
|
889
|
+
}
|
|
890
|
+
ngOnDestroy() {
|
|
891
|
+
if (this.timerfile != undefined)
|
|
892
|
+
clearTimeout(this.timerfile);
|
|
893
|
+
if (this.timerPrice != undefined)
|
|
894
|
+
clearTimeout(this.timerPrice);
|
|
895
|
+
}
|
|
896
|
+
setOptionsForMixToSingle() {
|
|
897
|
+
this.fileOptionsList = [
|
|
898
|
+
{ "k": "696", "v": "Marketing Stock" }
|
|
899
|
+
];
|
|
900
|
+
this.fileType = "696";
|
|
901
|
+
}
|
|
902
|
+
}
|
|
903
|
+
FileuploadComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FileuploadComponent, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }, { token: i2.HttpClient }, { token: i3.CommanServiceService }], target: i0.ɵɵFactoryTarget.Component });
|
|
904
|
+
FileuploadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: FileuploadComponent, selector: "app-fileupload", viewQueries: [{ propertyName: "closehdrbtn", first: true, predicate: ["closehdrbtn"], descendants: true }, { propertyName: "closedtlbtn", first: true, predicate: ["closedtlbtn"], descendants: true }, { propertyName: "Cofirmmapdtl", first: true, predicate: ["Cofirmmapdtl"], descendants: true }], ngImport: i0, template: "<div class=\"mt\" style=\"background: #fff;\">\r\n\r\n <div class=\"content-frame\">\r\n <p *ngIf=\"show\" class=\"loading-text\" style=\"z-index: 9999\"> {{stepMsg}} </p>\r\n\r\n <div class=\"innerD\">\r\n <div class=\"mt-element-step\">\r\n <div class=\"row step-thin\">\r\n\r\n <div class=\"col-md-2 bg-grey mt-step-col\" [ngClass]=\"{'done':step==1 ? 'done':''}\"\r\n (click)=setSetp(1)>\r\n <div class=\"mt-step-number bg-white font-grey\">1</div>\r\n <div class=\"mt-step-title uppercase font-grey-cascade\">Browse</div>\r\n </div>\r\n <div class=\"col-md-4 bg-grey mt-step-col\" [ngClass]=\"{'done':step==2 ? 'done':''}\"\r\n (click)=setSetp(2)>\r\n <div class=\"mt-step-number bg-white font-grey\">2</div>\r\n <div class=\"mt-step-title uppercase font-grey-cascade\">Header Verification</div>\r\n </div>\r\n <div class=\"col-md-3 bg-grey mt-step-col\" [ngClass]=\"{'done':step==3 ? 'done':''}\"\r\n (click)=setSetp(3)>\r\n <div class=\"mt-step-number bg-white font-grey\">3</div>\r\n <div class=\"mt-step-title uppercase font-grey-cascade\">Data Verification</div>\r\n </div>\r\n\r\n <div class=\"col-md-3 bg-grey mt-step-col\" [ngClass]=\"{'done':step==4 ? 'done':''}\"\r\n (click)=setSetp(4)>\r\n <div class=\"mt-step-number bg-white font-grey\">4</div>\r\n <div class=\"mt-step-title uppercase font-grey-cascade\">Uploading..</div>\r\n </div>\r\n </div>\r\n <div class=\"row upload\" *ngIf=\"step==1\">\r\n\r\n\r\n <div class=\"col-md-offset-3 col-md-3\" style=\"margin-top: 15px;\">\r\n <div class=\"form-group w-100\">\r\n <label class=\"col-md-4 control-label\" style=\"padding: 5px;\">File Type :</label>\r\n <div class=\"col-md-8\">\r\n <div class=\"input-group w-100\">\r\n <select class=\"form-control\" name=\"fileType\" [(ngModel)]=\"fileType\">\r\n <option value=\"\">--select--</option>\r\n <option *ngFor=\"let file of fileOptionsList\" value=\"{{file?.k}}\">{{file?.v}}\r\n </option>\r\n </select>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n <div class=\"col-md-2\">\r\n <a class=\"fileinput-wrapper btn btn-default fileinput btn-primary\"\r\n style=\"background: #3a5898\"><span>Browse file</span>\r\n <input type=\"file\" class=\"fileinput btn-primary\" name=\"filename\" id=\"filename\"\r\n title=\"Browse file\" accept=\".xlsx,.csv\" (change)=\"incomingfile($event)\"\r\n style=\"left: -163.75px; top: 9px;\"></a>\r\n\r\n </div>\r\n\r\n <!-- <label class=\"control-label\">Upload File : </label>\r\n\r\n <input type=\"file\" class=\"fileinput btn-primary\" accept=\".xlsx,.csv\" name=\"filename\" id=\"filename\"\r\n (change)=\"incomingfile($event)\" title=\"Browse file\"> -->\r\n\r\n\r\n </div>\r\n\r\n <div class=\"row upload\" *ngIf=\"step==2\">\r\n <div class=\"row\">\r\n <div class=\"col-md-1\">\r\n Total Match : {{totalmatch}}\r\n </div>\r\n <div class=\"col-md-1\">\r\n Total Ignore : {{totalignore}}\r\n </div>\r\n </div>\r\n\r\n <div class=\"row col-md-12\" style=\"overflow: auto;width: 100%;\">\r\n <table class=\"fileuploadview\">\r\n <tr>\r\n <ng-container *ngFor=\"let hdr of headerList ;\">\r\n <th [ngClass]=\"{\r\n 'match':headerAttributeDtl[hdr].attr!='' && headerAttributeDtl[hdr].ignore!='Y',\r\n 'ignore':headerAttributeDtl[hdr].ignore=='Y',\r\n 'thbg':headerAttributeDtl[hdr].attr=='' && headerAttributeDtl[hdr].ignore!='Y'\r\n }\" (click)=\"updatecolumnstatue(hdr)\">{{hdr}}\r\n </th>\r\n </ng-container>\r\n </tr>\r\n <tr>\r\n <ng-container *ngFor=\"let hdr of headerList ;\">\r\n <th>\r\n <ng-container *ngIf=\"headerAttributeDtl[hdr].attr==''\">\r\n <!-- <select class=\"select-control\" name=\"{{headerAttributeDtl[hdr].attr}}\"\r\n [(ngModel)]=\"headerAttributeDtl[hdr].attr\"\r\n (change)=\"confirmsetHeaderMapp(hdr,$event.target)\"> -->\r\n <select class=\"select-control\" name=\"{{headerAttributeDtl[hdr].attr}}\"\r\n [(ngModel)]=\"headerAttributeDtl[hdr].attr\"\r\n (change)=\"confirmsetHeaderMapp(hdr)\">\r\n <option value=\"\">--select--</option>\r\n <option *ngFor=\"let attrDtl of attrStructureDtl\"\r\n value=\"{{attrDtl?.attr}}\">{{attrDtl?.attr}}</option>\r\n </select>\r\n </ng-container>\r\n <ng-container *ngIf=\"headerAttributeDtl[hdr].attr!=''\">\r\n {{headerAttributeDtl[hdr].attr}}\r\n \r\n </ng-container>\r\n\r\n </th>\r\n </ng-container>\r\n </tr>\r\n <tr>\r\n <ng-container *ngFor=\"let hdr of headerList ;\">\r\n <th>\r\n <ng-container *ngIf=\"headerAttributeDtl[hdr].dta_typ=='d'\">\r\n <select class=\"select-control\" name=\"{{dateFormatMap[hdr]}}\"\r\n [(ngModel)]=\"dateFormatMap[hdr]\"\r\n >\r\n <option *ngFor=\"let dteFmt of dateFormatList\"\r\n value=\"{{dteFmt?.k}}\">{{dteFmt?.v}}</option>\r\n </select>\r\n </ng-container>\r\n </th>\r\n </ng-container>\r\n </tr> \r\n <tr *ngFor=\"let rowDis of defultDisplayObj ;\">\r\n <td *ngFor=\"let hdr of headerList ;\">\r\n {{rowDis[hdr]}}\r\n </td>\r\n\r\n </tr>\r\n\r\n </table>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-offset-11 col-md-1\">\r\n <button type=\"button\" *ngIf=\"fileLogIdn==0 && filenme=='generic'\" class=\"btn btn-success pull-right\"\r\n style=\"margin: 5px\" (click)=\"SkipVerification()\">Skip</button>\r\n \r\n <button type=\"button\" *ngIf=\"fileLogIdn==0\" class=\"btn btn-success pull-right\"\r\n style=\"margin: 5px\" (click)=\"ValidateFileHeaderMapping('Y')\">Verify</button>\r\n\r\n \r\n\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div class=\"row upload \" *ngIf=\"step==3\">\r\n <div class=\"row table-responsive col-md-12\">\r\n <table cellspacing=\"10\" class=\"displayTable fileuploadview\">\r\n <ng-container *ngFor=\"let hdr of charHeaderList ;let j=index;\">\r\n\r\n <tr>\r\n <th style=\"color:white;border: 1px solid white\">\r\n {{hdr}}({{headerAttributeDtl[hdr].attr}})</th>\r\n <td [ngClass]=\"{'even':j%2==0,'odd':j%2==1}\">\r\n <div class=\"row\" style=\"display: flex;\">\r\n <ng-container\r\n *ngFor=\"let attrVal of rowdistinctDataMap[headerAttributeDtl[hdr].attr];\">\r\n <div style=\"width:160px;margin-right: 1px\"\r\n [ngClass]=\"{'matchedUl':rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val !=''}\">\r\n <ul style=\"list-style: none;text-align:left\">\r\n <li> {{attrVal}} </li>\r\n <li>\r\n <select\r\n *ngIf=\"rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val==''\"\r\n class=\"select-control\"\r\n name=\"{{rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val}}\"\r\n [(ngModel)]=\"rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val\"\r\n (change)=\"confirmHeaderDetailsMapp(headerAttributeDtl[hdr].attr,headerAttributeDtl[hdr].attr_idn,attrVal)\">\r\n <option value=\"\">--select--</option>\r\n <option\r\n *ngFor=\"let attrdtlmap of attributeDtlMap[headerAttributeDtl[hdr].attr]\"\r\n value=\"{{attrdtlmap?.val}}\">{{attrdtlmap?.val}}\r\n </option>\r\n </select>\r\n\r\n <span\r\n *ngIf=\"rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val!=''\">\r\n {{rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val}} \r\n <i (click)=\"removeDetailAttrOptVal(headerAttributeDtl[hdr].attr_idn,attrVal,rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val,[headerAttributeDtl[hdr].attr])\" class=\"fa fa-times\" aria-hidden=\"true\" style=\"color: red;cursor: pointer;\"></i>\r\n </span>\r\n \r\n </li>\r\n </ul>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </td>\r\n\r\n </tr>\r\n </ng-container>\r\n </table>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-offset-11 col-md-1\">\r\n <button type=\"button\" *ngIf=\"fileLogIdn==0 && filenme=='generic'\" class=\"btn btn-success pull-right\"\r\n style=\"margin: 5px\" (click)=\"SkipVerificationDtl()\">Skip</button>\r\n \r\n <button type=\"button\" class=\"btn btn-success pull-right\" style=\"margin: 5px\"\r\n (click)=\"uploadFile()\" [disabled]=\"gmatchedCount!=gresultCount\">Upload</button>\r\n \r\n \r\n\r\n </div>\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n <div class=\"row upload\" *ngIf=\"step==4\">\r\n\r\n <div class=\"row\">\r\n\r\n </div>\r\n\r\n <div class=\"row\">\r\n\r\n <p *ngIf=\"step==4\" style=\"margin-left: 15px;color:green;font-size: 20px;text-align: left\">\r\n {{lableFile}}\r\n <span style=\"font-size: 14px;\" *ngIf=\"lastRefreshTimeFile != null\">Last\r\n refresh time :\r\n ({{lastRefreshTimeFile | date:'medium'}})</span>\r\n </p>\r\n\r\n <div class=\"progress\" style=\"margin: 15px;\">\r\n <div class=\"progress-bar progress-bar-warning\" role=\"progressbar\" aria-valuenow=\"60\"\r\n aria-valuemin=\"0\" aria-valuemax=\"100\" [ngStyle]=\"{'width':totProgressFile+'%'} \">\r\n {{totProgressFile}} %\r\n </div>\r\n </div>\r\n\r\n <p *ngIf=\"step==4 && clicked\" style=\"margin-top: 35px;\"><strong> Complete :{{sttsFile['C']}}\r\n Pending : {{sttsFile['P']}} Error :\r\n {{sttsFile['E']}} Invaild Status :\r\n {{sttsFile['I']}}\r\n Total : {{sttsFile['T']}}</strong></p>\r\n\r\n\r\n <p *ngIf=\"step==4\"\r\n style=\"margin-left: 15px;color:green;font-size: 20px;margin-top: 15px;text-align: left\">\r\n {{lable}}\r\n <span style=\"font-size: 12px;margin-left: 20px;color: black;\"\r\n *ngIf=\"lastRefreshTime != null\">Last\r\n refresh time :\r\n ({{lastRefreshTime | date:'medium'}})</span>\r\n </p>\r\n\r\n <div class=\"progress\" style=\"margin: 15px;\">\r\n <div class=\"progress-bar progress-bar-warning\" role=\"progressbar\" aria-valuenow=\"60\"\r\n aria-valuemin=\"0\" aria-valuemax=\"100\" [ngStyle]=\"{'width':totProgress+'%'} \">\r\n {{totProgress}} %\r\n </div>\r\n </div>\r\n\r\n <!-- <button type=\"button\" class=\"btn btn-success text-center\" style=\"margin: 5px\"\r\n (click)=\"checkUploadStt()\">Check\r\n Status</button> -->\r\n\r\n <p *ngIf=\"step==4 && clicked\" style=\"margin-top: 35px;\"><strong> Complete :{{stts['C']}}\r\n Pending : {{stts['P']}} Error : {{stts['E']}}\r\n Total : {{stts['T']}}</strong></p>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n<div class=\"modal\" id=\"fileUploadModal\" tabindex=\"-1\" style=\"z-index: 999999\" role=\"dialog\"\r\n aria-labelledby=\"smallModalHead\" aria-hidden=\"true\" data-backdrop=\"static\" data-keyboard=\"true\">\r\n <div class=\"modal-dialog \">\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\">\r\n <button type=\"button\" class=\"close\" data-dismiss=\"modal\" #fileUploadclsbtn>\r\n <span aria-hidden=\"true\">×</span>\r\n <span class=\"sr-only\">Close</span>\r\n </button>\r\n <h4 class=\"modal-title\" id=\"smallModalHead\">Add file upload option</h4>\r\n </div>\r\n <div class=\"modal-body\">\r\n <div class=\"row\">\r\n\r\n <div class=\"col-md-12\">\r\n <form class=\"form-horizontal\" role=\"form\" #f=\"ngForm\" (ngSubmit)=\"onSubmit(f)\" name=\"appForm\">\r\n <div class=\"form-group\">\r\n <div class=\"col-md-12\">\r\n <label class=\"col-md-3 control-label\">Name\r\n </label>\r\n <div class=\"col-md-5\">\r\n <div class=\"input-group w-100\">\r\n <input type=\"text\" class=\"form-control\" [(ngModel)]=\"nme\" name=\"nme\" />\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <div class=\"col-md-12\">\r\n <label class=\"col-md-3 control-label\">Description\r\n </label>\r\n <div class=\"col-md-5\">\r\n <div class=\"input-group w-100\">\r\n <input type=\"text\" class=\"form-control\" [(ngModel)]=\"description\"\r\n name=\"description\" />\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <div class=\"col-md-12\">\r\n <label class=\"col-md-3 control-label\">Type\r\n </label>\r\n <div class=\"col-md-5\">\r\n <div class=\"input-group w-100\">\r\n <select class=\"form-control\" name=\"typ\" [(ngModel)]=\"typ\">\r\n <option value=\"\">--select--</option>\r\n <option *ngFor=\"let file of fileTypeList\" value=\"{{file?.k}}\">\r\n {{file?.v}}\r\n </option>\r\n </select>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n <div class=\"form-group\">\r\n <div class=\"col-md-12\">\r\n <label class=\"col-md-3 control-label\">Check status\r\n </label>\r\n <div class=\"col-md-5\">\r\n <div class=\"input-group w-100\">\r\n <ng-select placeholder=\"Select Status\" [options]=\"statusList\"\r\n [(ngModel)]=\"check_status\" name=\"check_status\" [multiple]=\"true\"\r\n [allowClear]=\"true\">\r\n <ng-template #optionTemplate let-option=\"option\">\r\n <div class=\"famfamfam-flags {{option?.value}}\"></div>\r\n {{option?.label}}\r\n </ng-template>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <div class=\"col-md-12\">\r\n <label class=\"col-md-3 control-label\">Packet status\r\n </label>\r\n <div class=\"col-md-5\">\r\n <div class=\"input-group w-100\">\r\n <ng-select placeholder=\"Select Status\" [options]=\"statusList\"\r\n [(ngModel)]=\"pkt_status\" name=\"pkt_status\" [allowClear]=\"true\">\r\n <ng-template #optionTemplate let-option=\"option\">\r\n <div class=\"famfamfam-flags {{option?.value}}\"></div>\r\n {{option?.label}}\r\n </ng-template>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </form>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <button type=\"button\" class=\"btn btn-default\" data-dismiss=\"modal\" #fileUploadclsbtn>Close</button>\r\n <button type=\"button\" class=\"btn btn-success\" data-dismiss=\"modal\" appAppNoDblClick\r\n (click)=\"onSubmit(f)\">Save</button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<div class=\"modal\" id=\"Cofirmmaphdr\" role=\"dialog\" aria-labelledby=\"smallModalHead\" aria-hidden=\"true\" data-backdrop=\"static\"\r\n data-keyboard=\"false\">\r\n <div class=\"modal-dialog\">\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\">\r\n <button type=\"button\" (click)=\"CancelHeaderMapp()\" class=\"close\" data-dismiss=\"modal\">\r\n <span aria-hidden=\"true\">×</span>\r\n <span class=\"sr-only\" >Close</span>\r\n </button>\r\n <h4 class=\"modal-title\" id=\"smallModalHead\">Alert</h4>\r\n </div>\r\n <div class=\"modal-body\">\r\n <div class=\"row\">\r\n Are you sure For Mapping <b>{{maphdr}}</b> To Attribute <b>{{hdrmassage}}</b> \r\n </div>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <button type=\"button\" class=\"btn btn-default\" (click)=\"CancelHeaderMapp()\" data-dismiss=\"modal\" >Close</button>\r\n <button type=\"button\" class=\"btn btn-success\" data-dismiss=\"modal\" (click)=\"setHeaderMapp();\">Confirm</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"modal\" id=\"Cofirmmapdtl\" role=\"dialog\" aria-labelledby=\"smallModalHead\" aria-hidden=\"true\" data-backdrop=\"static\"\r\n data-keyboard=\"false\">\r\n <div class=\"modal-dialog\">\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\">\r\n <button type=\"button\" (click)=\"CancelHeaderMapp()\" class=\"close\" data-dismiss=\"modal\" >\r\n <span aria-hidden=\"true\">×</span>\r\n <span class=\"sr-only\" >Close</span>\r\n </button>\r\n <h4 class=\"modal-title\" id=\"smallModalHead\">Alert</h4>\r\n </div>\r\n <div class=\"modal-body\">\r\n <div class=\"row\">\r\n Are you sure For Mapping <b>{{dtloptionval}}</b> To Attribute <b> {{dtlAttr}} </b> with AttributeDetail <b>{{dtlmassage}}</b> \r\n </div>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <button type=\"button\" class=\"btn btn-default\" data-dismiss=\"modal\" (click)=\"CancelHeaderDetailsMapp()\">Close</button>\r\n <button type=\"button\" class=\"btn btn-success\" data-dismiss=\"modal\" (click)=\"setHeaderDetailsMapp()\">Confirm</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n<button id=\"btnfileUploadModal\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#fileUploadModal\"></button>\r\n\r\n<button id=\"btnCofirmmaphdr\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#Cofirmmaphdr\"></button>\r\n<button id=\"btnCofirmmapdtl\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#Cofirmmapdtl\"></button>\r\n\r\n\r\n\r\n<!-- <div class=\"centered\">\r\n <div id=\"divSpinner\" class=\"spinner loading\">\r\n <div class=\"loading-text\">Loading ...</div>\r\n </div>\r\n\r\n <button (click)=\"test()\" id=\"btnLoadRecords\" style=\"cursor:pointer;position: absolute; top: 52%; left: 45%;\">Load Records</button>\r\n </div> -->", styles: [".actionFooter{position:fixed;bottom:0;width:100%;text-align:right;padding:10px;background:#1b1e24}.innerD{min-height:calc(100vh - 100px);background:#fff}.mt-element-step .row{margin:0}.mt-element-step .step-thin .mt-step-col{padding-top:10px;padding-bottom:10px}.mt-element-step .step-thin .mt-step-number{font-size:22px;border-radius:50%!important;float:left;margin:auto;padding:3px 14px}.mt-element-step .step-thin .mt-step-title{font-size:20px;font-weight:100;padding-left:60px;margin-top:-4px}.mt-element-step .step-thin .mt-step-content{padding-left:60px;margin-top:-5px}.mt-element-step .step-thin .done{background-color:#3b5998!important}.mt-element-step .step-thin .done .mt-step-number{color:#3b5998!important}.mt-element-step .step-thin .done .mt-step-content,.mt-element-step .step-thin .done .mt-step-title{color:#fff!important}.font-grey-cascade{color:#95a5a6!important}.font-grey{color:#e5e5e5!important}.bg-grey{background:#E5E5E5!important}.bg-white{background:#fff!important}.mt-element-step .upload{text-align:center;padding-top:15px;padding-bottom:10px}.fileuploadview{width:calc(100% - 1px)}.fileuploadview th{padding:2px 5px;font-weight:700;font-size:12px;color:#000;height:35px;white-space:nowrap;text-align:center;vertical-align:middle}.fileuploadview tr{background-color:#fff}.fileuploadview td{height:25px;white-space:nowrap;text-align:center;font-size:9pt;padding:5px;border:1px solid white}.match{background-color:#95b75d!important}.ignore{background-color:#ff7a7a!important}.thbg{background-color:#e5e5e5!important}.select-control{height:20px;font-size:12px;line-height:18px;box-shadow:none;border:1px solid #D5D5D5;background:#F9F9F9;display:block;width:100%;border-radius:4px;box-shadow:inset 0 1px 1px #00000013;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}.displayTable td.odd:hover,.displayTable td.even:hover{background-color:#e3f6ff}.displayTable td.odd{background-color:#efefef}.displayTable td.even{background-color:#f8f8f8}.displayTable td a:BEFORE{color:green}.displayTable th a{text-align:center;color:#000}.displayTable th a:visited{text-align:center;color:#fff}.displayTable th a:hover{color:#fc0;background-color:transparent;text-align:center}.matchedUl{background-color:#beccd2}.loading-text{width:400px;position:absolute;top:calc(50% - 370px);left:calc(50% - 180px);text-align:center;color:#00f;font-size:25px}\n"], components: [{ type: i4.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i6.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i6.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i6.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i6.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i7.AppNoDblClickDirective, selector: "[appAppNoDblClick]" }], pipes: { "date": i5.DatePipe } });
|
|
905
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FileuploadComponent, decorators: [{
|
|
906
|
+
type: Component,
|
|
907
|
+
args: [{ selector: 'app-fileupload', template: "<div class=\"mt\" style=\"background: #fff;\">\r\n\r\n <div class=\"content-frame\">\r\n <p *ngIf=\"show\" class=\"loading-text\" style=\"z-index: 9999\"> {{stepMsg}} </p>\r\n\r\n <div class=\"innerD\">\r\n <div class=\"mt-element-step\">\r\n <div class=\"row step-thin\">\r\n\r\n <div class=\"col-md-2 bg-grey mt-step-col\" [ngClass]=\"{'done':step==1 ? 'done':''}\"\r\n (click)=setSetp(1)>\r\n <div class=\"mt-step-number bg-white font-grey\">1</div>\r\n <div class=\"mt-step-title uppercase font-grey-cascade\">Browse</div>\r\n </div>\r\n <div class=\"col-md-4 bg-grey mt-step-col\" [ngClass]=\"{'done':step==2 ? 'done':''}\"\r\n (click)=setSetp(2)>\r\n <div class=\"mt-step-number bg-white font-grey\">2</div>\r\n <div class=\"mt-step-title uppercase font-grey-cascade\">Header Verification</div>\r\n </div>\r\n <div class=\"col-md-3 bg-grey mt-step-col\" [ngClass]=\"{'done':step==3 ? 'done':''}\"\r\n (click)=setSetp(3)>\r\n <div class=\"mt-step-number bg-white font-grey\">3</div>\r\n <div class=\"mt-step-title uppercase font-grey-cascade\">Data Verification</div>\r\n </div>\r\n\r\n <div class=\"col-md-3 bg-grey mt-step-col\" [ngClass]=\"{'done':step==4 ? 'done':''}\"\r\n (click)=setSetp(4)>\r\n <div class=\"mt-step-number bg-white font-grey\">4</div>\r\n <div class=\"mt-step-title uppercase font-grey-cascade\">Uploading..</div>\r\n </div>\r\n </div>\r\n <div class=\"row upload\" *ngIf=\"step==1\">\r\n\r\n\r\n <div class=\"col-md-offset-3 col-md-3\" style=\"margin-top: 15px;\">\r\n <div class=\"form-group w-100\">\r\n <label class=\"col-md-4 control-label\" style=\"padding: 5px;\">File Type :</label>\r\n <div class=\"col-md-8\">\r\n <div class=\"input-group w-100\">\r\n <select class=\"form-control\" name=\"fileType\" [(ngModel)]=\"fileType\">\r\n <option value=\"\">--select--</option>\r\n <option *ngFor=\"let file of fileOptionsList\" value=\"{{file?.k}}\">{{file?.v}}\r\n </option>\r\n </select>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n <div class=\"col-md-2\">\r\n <a class=\"fileinput-wrapper btn btn-default fileinput btn-primary\"\r\n style=\"background: #3a5898\"><span>Browse file</span>\r\n <input type=\"file\" class=\"fileinput btn-primary\" name=\"filename\" id=\"filename\"\r\n title=\"Browse file\" accept=\".xlsx,.csv\" (change)=\"incomingfile($event)\"\r\n style=\"left: -163.75px; top: 9px;\"></a>\r\n\r\n </div>\r\n\r\n <!-- <label class=\"control-label\">Upload File : </label>\r\n\r\n <input type=\"file\" class=\"fileinput btn-primary\" accept=\".xlsx,.csv\" name=\"filename\" id=\"filename\"\r\n (change)=\"incomingfile($event)\" title=\"Browse file\"> -->\r\n\r\n\r\n </div>\r\n\r\n <div class=\"row upload\" *ngIf=\"step==2\">\r\n <div class=\"row\">\r\n <div class=\"col-md-1\">\r\n Total Match : {{totalmatch}}\r\n </div>\r\n <div class=\"col-md-1\">\r\n Total Ignore : {{totalignore}}\r\n </div>\r\n </div>\r\n\r\n <div class=\"row col-md-12\" style=\"overflow: auto;width: 100%;\">\r\n <table class=\"fileuploadview\">\r\n <tr>\r\n <ng-container *ngFor=\"let hdr of headerList ;\">\r\n <th [ngClass]=\"{\r\n 'match':headerAttributeDtl[hdr].attr!='' && headerAttributeDtl[hdr].ignore!='Y',\r\n 'ignore':headerAttributeDtl[hdr].ignore=='Y',\r\n 'thbg':headerAttributeDtl[hdr].attr=='' && headerAttributeDtl[hdr].ignore!='Y'\r\n }\" (click)=\"updatecolumnstatue(hdr)\">{{hdr}}\r\n </th>\r\n </ng-container>\r\n </tr>\r\n <tr>\r\n <ng-container *ngFor=\"let hdr of headerList ;\">\r\n <th>\r\n <ng-container *ngIf=\"headerAttributeDtl[hdr].attr==''\">\r\n <!-- <select class=\"select-control\" name=\"{{headerAttributeDtl[hdr].attr}}\"\r\n [(ngModel)]=\"headerAttributeDtl[hdr].attr\"\r\n (change)=\"confirmsetHeaderMapp(hdr,$event.target)\"> -->\r\n <select class=\"select-control\" name=\"{{headerAttributeDtl[hdr].attr}}\"\r\n [(ngModel)]=\"headerAttributeDtl[hdr].attr\"\r\n (change)=\"confirmsetHeaderMapp(hdr)\">\r\n <option value=\"\">--select--</option>\r\n <option *ngFor=\"let attrDtl of attrStructureDtl\"\r\n value=\"{{attrDtl?.attr}}\">{{attrDtl?.attr}}</option>\r\n </select>\r\n </ng-container>\r\n <ng-container *ngIf=\"headerAttributeDtl[hdr].attr!=''\">\r\n {{headerAttributeDtl[hdr].attr}}\r\n \r\n </ng-container>\r\n\r\n </th>\r\n </ng-container>\r\n </tr>\r\n <tr>\r\n <ng-container *ngFor=\"let hdr of headerList ;\">\r\n <th>\r\n <ng-container *ngIf=\"headerAttributeDtl[hdr].dta_typ=='d'\">\r\n <select class=\"select-control\" name=\"{{dateFormatMap[hdr]}}\"\r\n [(ngModel)]=\"dateFormatMap[hdr]\"\r\n >\r\n <option *ngFor=\"let dteFmt of dateFormatList\"\r\n value=\"{{dteFmt?.k}}\">{{dteFmt?.v}}</option>\r\n </select>\r\n </ng-container>\r\n </th>\r\n </ng-container>\r\n </tr> \r\n <tr *ngFor=\"let rowDis of defultDisplayObj ;\">\r\n <td *ngFor=\"let hdr of headerList ;\">\r\n {{rowDis[hdr]}}\r\n </td>\r\n\r\n </tr>\r\n\r\n </table>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-offset-11 col-md-1\">\r\n <button type=\"button\" *ngIf=\"fileLogIdn==0 && filenme=='generic'\" class=\"btn btn-success pull-right\"\r\n style=\"margin: 5px\" (click)=\"SkipVerification()\">Skip</button>\r\n \r\n <button type=\"button\" *ngIf=\"fileLogIdn==0\" class=\"btn btn-success pull-right\"\r\n style=\"margin: 5px\" (click)=\"ValidateFileHeaderMapping('Y')\">Verify</button>\r\n\r\n \r\n\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div class=\"row upload \" *ngIf=\"step==3\">\r\n <div class=\"row table-responsive col-md-12\">\r\n <table cellspacing=\"10\" class=\"displayTable fileuploadview\">\r\n <ng-container *ngFor=\"let hdr of charHeaderList ;let j=index;\">\r\n\r\n <tr>\r\n <th style=\"color:white;border: 1px solid white\">\r\n {{hdr}}({{headerAttributeDtl[hdr].attr}})</th>\r\n <td [ngClass]=\"{'even':j%2==0,'odd':j%2==1}\">\r\n <div class=\"row\" style=\"display: flex;\">\r\n <ng-container\r\n *ngFor=\"let attrVal of rowdistinctDataMap[headerAttributeDtl[hdr].attr];\">\r\n <div style=\"width:160px;margin-right: 1px\"\r\n [ngClass]=\"{'matchedUl':rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val !=''}\">\r\n <ul style=\"list-style: none;text-align:left\">\r\n <li> {{attrVal}} </li>\r\n <li>\r\n <select\r\n *ngIf=\"rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val==''\"\r\n class=\"select-control\"\r\n name=\"{{rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val}}\"\r\n [(ngModel)]=\"rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val\"\r\n (change)=\"confirmHeaderDetailsMapp(headerAttributeDtl[hdr].attr,headerAttributeDtl[hdr].attr_idn,attrVal)\">\r\n <option value=\"\">--select--</option>\r\n <option\r\n *ngFor=\"let attrdtlmap of attributeDtlMap[headerAttributeDtl[hdr].attr]\"\r\n value=\"{{attrdtlmap?.val}}\">{{attrdtlmap?.val}}\r\n </option>\r\n </select>\r\n\r\n <span\r\n *ngIf=\"rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val!=''\">\r\n {{rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val}} \r\n <i (click)=\"removeDetailAttrOptVal(headerAttributeDtl[hdr].attr_idn,attrVal,rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val,[headerAttributeDtl[hdr].attr])\" class=\"fa fa-times\" aria-hidden=\"true\" style=\"color: red;cursor: pointer;\"></i>\r\n </span>\r\n \r\n </li>\r\n </ul>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </td>\r\n\r\n </tr>\r\n </ng-container>\r\n </table>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-offset-11 col-md-1\">\r\n <button type=\"button\" *ngIf=\"fileLogIdn==0 && filenme=='generic'\" class=\"btn btn-success pull-right\"\r\n style=\"margin: 5px\" (click)=\"SkipVerificationDtl()\">Skip</button>\r\n \r\n <button type=\"button\" class=\"btn btn-success pull-right\" style=\"margin: 5px\"\r\n (click)=\"uploadFile()\" [disabled]=\"gmatchedCount!=gresultCount\">Upload</button>\r\n \r\n \r\n\r\n </div>\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n <div class=\"row upload\" *ngIf=\"step==4\">\r\n\r\n <div class=\"row\">\r\n\r\n </div>\r\n\r\n <div class=\"row\">\r\n\r\n <p *ngIf=\"step==4\" style=\"margin-left: 15px;color:green;font-size: 20px;text-align: left\">\r\n {{lableFile}}\r\n <span style=\"font-size: 14px;\" *ngIf=\"lastRefreshTimeFile != null\">Last\r\n refresh time :\r\n ({{lastRefreshTimeFile | date:'medium'}})</span>\r\n </p>\r\n\r\n <div class=\"progress\" style=\"margin: 15px;\">\r\n <div class=\"progress-bar progress-bar-warning\" role=\"progressbar\" aria-valuenow=\"60\"\r\n aria-valuemin=\"0\" aria-valuemax=\"100\" [ngStyle]=\"{'width':totProgressFile+'%'} \">\r\n {{totProgressFile}} %\r\n </div>\r\n </div>\r\n\r\n <p *ngIf=\"step==4 && clicked\" style=\"margin-top: 35px;\"><strong> Complete :{{sttsFile['C']}}\r\n Pending : {{sttsFile['P']}} Error :\r\n {{sttsFile['E']}} Invaild Status :\r\n {{sttsFile['I']}}\r\n Total : {{sttsFile['T']}}</strong></p>\r\n\r\n\r\n <p *ngIf=\"step==4\"\r\n style=\"margin-left: 15px;color:green;font-size: 20px;margin-top: 15px;text-align: left\">\r\n {{lable}}\r\n <span style=\"font-size: 12px;margin-left: 20px;color: black;\"\r\n *ngIf=\"lastRefreshTime != null\">Last\r\n refresh time :\r\n ({{lastRefreshTime | date:'medium'}})</span>\r\n </p>\r\n\r\n <div class=\"progress\" style=\"margin: 15px;\">\r\n <div class=\"progress-bar progress-bar-warning\" role=\"progressbar\" aria-valuenow=\"60\"\r\n aria-valuemin=\"0\" aria-valuemax=\"100\" [ngStyle]=\"{'width':totProgress+'%'} \">\r\n {{totProgress}} %\r\n </div>\r\n </div>\r\n\r\n <!-- <button type=\"button\" class=\"btn btn-success text-center\" style=\"margin: 5px\"\r\n (click)=\"checkUploadStt()\">Check\r\n Status</button> -->\r\n\r\n <p *ngIf=\"step==4 && clicked\" style=\"margin-top: 35px;\"><strong> Complete :{{stts['C']}}\r\n Pending : {{stts['P']}} Error : {{stts['E']}}\r\n Total : {{stts['T']}}</strong></p>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n<div class=\"modal\" id=\"fileUploadModal\" tabindex=\"-1\" style=\"z-index: 999999\" role=\"dialog\"\r\n aria-labelledby=\"smallModalHead\" aria-hidden=\"true\" data-backdrop=\"static\" data-keyboard=\"true\">\r\n <div class=\"modal-dialog \">\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\">\r\n <button type=\"button\" class=\"close\" data-dismiss=\"modal\" #fileUploadclsbtn>\r\n <span aria-hidden=\"true\">×</span>\r\n <span class=\"sr-only\">Close</span>\r\n </button>\r\n <h4 class=\"modal-title\" id=\"smallModalHead\">Add file upload option</h4>\r\n </div>\r\n <div class=\"modal-body\">\r\n <div class=\"row\">\r\n\r\n <div class=\"col-md-12\">\r\n <form class=\"form-horizontal\" role=\"form\" #f=\"ngForm\" (ngSubmit)=\"onSubmit(f)\" name=\"appForm\">\r\n <div class=\"form-group\">\r\n <div class=\"col-md-12\">\r\n <label class=\"col-md-3 control-label\">Name\r\n </label>\r\n <div class=\"col-md-5\">\r\n <div class=\"input-group w-100\">\r\n <input type=\"text\" class=\"form-control\" [(ngModel)]=\"nme\" name=\"nme\" />\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <div class=\"col-md-12\">\r\n <label class=\"col-md-3 control-label\">Description\r\n </label>\r\n <div class=\"col-md-5\">\r\n <div class=\"input-group w-100\">\r\n <input type=\"text\" class=\"form-control\" [(ngModel)]=\"description\"\r\n name=\"description\" />\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <div class=\"col-md-12\">\r\n <label class=\"col-md-3 control-label\">Type\r\n </label>\r\n <div class=\"col-md-5\">\r\n <div class=\"input-group w-100\">\r\n <select class=\"form-control\" name=\"typ\" [(ngModel)]=\"typ\">\r\n <option value=\"\">--select--</option>\r\n <option *ngFor=\"let file of fileTypeList\" value=\"{{file?.k}}\">\r\n {{file?.v}}\r\n </option>\r\n </select>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n <div class=\"form-group\">\r\n <div class=\"col-md-12\">\r\n <label class=\"col-md-3 control-label\">Check status\r\n </label>\r\n <div class=\"col-md-5\">\r\n <div class=\"input-group w-100\">\r\n <ng-select placeholder=\"Select Status\" [options]=\"statusList\"\r\n [(ngModel)]=\"check_status\" name=\"check_status\" [multiple]=\"true\"\r\n [allowClear]=\"true\">\r\n <ng-template #optionTemplate let-option=\"option\">\r\n <div class=\"famfamfam-flags {{option?.value}}\"></div>\r\n {{option?.label}}\r\n </ng-template>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"form-group\">\r\n <div class=\"col-md-12\">\r\n <label class=\"col-md-3 control-label\">Packet status\r\n </label>\r\n <div class=\"col-md-5\">\r\n <div class=\"input-group w-100\">\r\n <ng-select placeholder=\"Select Status\" [options]=\"statusList\"\r\n [(ngModel)]=\"pkt_status\" name=\"pkt_status\" [allowClear]=\"true\">\r\n <ng-template #optionTemplate let-option=\"option\">\r\n <div class=\"famfamfam-flags {{option?.value}}\"></div>\r\n {{option?.label}}\r\n </ng-template>\r\n </ng-select>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </form>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <button type=\"button\" class=\"btn btn-default\" data-dismiss=\"modal\" #fileUploadclsbtn>Close</button>\r\n <button type=\"button\" class=\"btn btn-success\" data-dismiss=\"modal\" appAppNoDblClick\r\n (click)=\"onSubmit(f)\">Save</button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<div class=\"modal\" id=\"Cofirmmaphdr\" role=\"dialog\" aria-labelledby=\"smallModalHead\" aria-hidden=\"true\" data-backdrop=\"static\"\r\n data-keyboard=\"false\">\r\n <div class=\"modal-dialog\">\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\">\r\n <button type=\"button\" (click)=\"CancelHeaderMapp()\" class=\"close\" data-dismiss=\"modal\">\r\n <span aria-hidden=\"true\">×</span>\r\n <span class=\"sr-only\" >Close</span>\r\n </button>\r\n <h4 class=\"modal-title\" id=\"smallModalHead\">Alert</h4>\r\n </div>\r\n <div class=\"modal-body\">\r\n <div class=\"row\">\r\n Are you sure For Mapping <b>{{maphdr}}</b> To Attribute <b>{{hdrmassage}}</b> \r\n </div>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <button type=\"button\" class=\"btn btn-default\" (click)=\"CancelHeaderMapp()\" data-dismiss=\"modal\" >Close</button>\r\n <button type=\"button\" class=\"btn btn-success\" data-dismiss=\"modal\" (click)=\"setHeaderMapp();\">Confirm</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"modal\" id=\"Cofirmmapdtl\" role=\"dialog\" aria-labelledby=\"smallModalHead\" aria-hidden=\"true\" data-backdrop=\"static\"\r\n data-keyboard=\"false\">\r\n <div class=\"modal-dialog\">\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\">\r\n <button type=\"button\" (click)=\"CancelHeaderMapp()\" class=\"close\" data-dismiss=\"modal\" >\r\n <span aria-hidden=\"true\">×</span>\r\n <span class=\"sr-only\" >Close</span>\r\n </button>\r\n <h4 class=\"modal-title\" id=\"smallModalHead\">Alert</h4>\r\n </div>\r\n <div class=\"modal-body\">\r\n <div class=\"row\">\r\n Are you sure For Mapping <b>{{dtloptionval}}</b> To Attribute <b> {{dtlAttr}} </b> with AttributeDetail <b>{{dtlmassage}}</b> \r\n </div>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <button type=\"button\" class=\"btn btn-default\" data-dismiss=\"modal\" (click)=\"CancelHeaderDetailsMapp()\">Close</button>\r\n <button type=\"button\" class=\"btn btn-success\" data-dismiss=\"modal\" (click)=\"setHeaderDetailsMapp()\">Confirm</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n<button id=\"btnfileUploadModal\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#fileUploadModal\"></button>\r\n\r\n<button id=\"btnCofirmmaphdr\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#Cofirmmaphdr\"></button>\r\n<button id=\"btnCofirmmapdtl\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#Cofirmmapdtl\"></button>\r\n\r\n\r\n\r\n<!-- <div class=\"centered\">\r\n <div id=\"divSpinner\" class=\"spinner loading\">\r\n <div class=\"loading-text\">Loading ...</div>\r\n </div>\r\n\r\n <button (click)=\"test()\" id=\"btnLoadRecords\" style=\"cursor:pointer;position: absolute; top: 52%; left: 45%;\">Load Records</button>\r\n </div> -->", styles: [".actionFooter{position:fixed;bottom:0;width:100%;text-align:right;padding:10px;background:#1b1e24}.innerD{min-height:calc(100vh - 100px);background:#fff}.mt-element-step .row{margin:0}.mt-element-step .step-thin .mt-step-col{padding-top:10px;padding-bottom:10px}.mt-element-step .step-thin .mt-step-number{font-size:22px;border-radius:50%!important;float:left;margin:auto;padding:3px 14px}.mt-element-step .step-thin .mt-step-title{font-size:20px;font-weight:100;padding-left:60px;margin-top:-4px}.mt-element-step .step-thin .mt-step-content{padding-left:60px;margin-top:-5px}.mt-element-step .step-thin .done{background-color:#3b5998!important}.mt-element-step .step-thin .done .mt-step-number{color:#3b5998!important}.mt-element-step .step-thin .done .mt-step-content,.mt-element-step .step-thin .done .mt-step-title{color:#fff!important}.font-grey-cascade{color:#95a5a6!important}.font-grey{color:#e5e5e5!important}.bg-grey{background:#E5E5E5!important}.bg-white{background:#fff!important}.mt-element-step .upload{text-align:center;padding-top:15px;padding-bottom:10px}.fileuploadview{width:calc(100% - 1px)}.fileuploadview th{padding:2px 5px;font-weight:700;font-size:12px;color:#000;height:35px;white-space:nowrap;text-align:center;vertical-align:middle}.fileuploadview tr{background-color:#fff}.fileuploadview td{height:25px;white-space:nowrap;text-align:center;font-size:9pt;padding:5px;border:1px solid white}.match{background-color:#95b75d!important}.ignore{background-color:#ff7a7a!important}.thbg{background-color:#e5e5e5!important}.select-control{height:20px;font-size:12px;line-height:18px;box-shadow:none;border:1px solid #D5D5D5;background:#F9F9F9;display:block;width:100%;border-radius:4px;box-shadow:inset 0 1px 1px #00000013;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}.displayTable td.odd:hover,.displayTable td.even:hover{background-color:#e3f6ff}.displayTable td.odd{background-color:#efefef}.displayTable td.even{background-color:#f8f8f8}.displayTable td a:BEFORE{color:green}.displayTable th a{text-align:center;color:#000}.displayTable th a:visited{text-align:center;color:#fff}.displayTable th a:hover{color:#fc0;background-color:transparent;text-align:center}.matchedUl{background-color:#beccd2}.loading-text{width:400px;position:absolute;top:calc(50% - 370px);left:calc(50% - 180px);text-align:center;color:#00f;font-size:25px}\n"] }]
|
|
908
|
+
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i1.ActivatedRoute }, { type: i2.HttpClient }, { type: i3.CommanServiceService }]; }, propDecorators: { closehdrbtn: [{
|
|
909
|
+
type: ViewChild,
|
|
910
|
+
args: ['closehdrbtn']
|
|
911
|
+
}], closedtlbtn: [{
|
|
912
|
+
type: ViewChild,
|
|
913
|
+
args: ['closedtlbtn']
|
|
914
|
+
}], Cofirmmapdtl: [{
|
|
915
|
+
type: ViewChild,
|
|
916
|
+
args: ['Cofirmmapdtl']
|
|
917
|
+
}] } });
|
|
918
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fileupload.component.js","sourceRoot":"","sources":["../../../../../projects/ez-lib/src/lib/file-upload/fileupload.component.ts","../../../../../projects/ez-lib/src/lib/file-upload/fileupload.component.html"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { Component, OnInit, ViewChild, ElementRef } from '@angular/core';\r\nimport { Router, ActivatedRoute, Params } from '@angular/router';\r\n// import { FlashMessagesService } from 'angular2-flash-messages'\r\n// import { Ng4LoadingSpinnerService } from 'ng4-loading-spinner';\r\nimport { Cookie } from 'ng2-cookies/ng2-cookies';\r\n// import { RequestOptions } from '@angular/http';\r\nimport { HttpHeaders } from '@angular/common/http';\r\n\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { CommanServiceService } from '../comman-service/comman-service.service';\r\n// import * as XLSX from 'ts-xlsx';\r\n// import * as XLSX from 'xlsx/xlsx.mjs';\r\nimport * as XLSX from 'xlsx';\r\n\r\n// import { UploadServiceService } from 'src/app/components/fileupload-module/upload-service.service';\r\nimport { ModalDirective } from 'ngx-bootstrap/modal'\r\nimport { document } from 'ngx-bootstrap';\r\n// import { AsyncLocalStorage } from 'async_hooks';\r\n\r\n@Component({\r\n  selector: 'app-fileupload',\r\n  templateUrl: './fileupload.component.html',\r\n  styleUrls: ['./fileupload.component.css']\r\n})\r\n\r\n\r\nexport class FileuploadComponent implements OnInit {\r\n\r\n  @ViewChild('closehdrbtn') closehdrbtn: ElementRef;\r\n  @ViewChild('closedtlbtn') closedtlbtn: ElementRef;\r\n  @ViewChild('Cofirmmapdtl') Cofirmmapdtl: ModalDirective;\r\n  header = {};\r\n  fileToUpload: File = null;\r\n  fileName = \"\";\r\n  cDt;\r\n  step = 1;\r\n  sheetData = [];\r\n  headerAttributeDtl = {};\r\n  defultDisplayLen = 5;\r\n  defultDisplayObj = [];\r\n  attrStructureDtl = [];\r\n  headerList = [];\r\n  headerprp;\r\n  attrprp;\r\n  totalmatch = 0;\r\n  totalignore = 0;\r\n  pageDefination = {};\r\n  rowdatamapDetails = {};\r\n  rowdistinctDataMap = {};\r\n  charHeaderList = [];\r\n  attributeDtlMap = {};\r\n  mappSheetData = [];\r\n  lable = \"\";\r\n  lableFile = \"\";\r\n  statusList = [];\r\n  fileDetails = [];\r\n  fileTypeList = [];\r\n  fileOptionsList = [];\r\n  fileType;\r\n  nme;\r\n  typ;\r\n  mdl;\r\n  description;\r\n  check_status = [];\r\n  pkt_status = [];\r\n  colFormate = [];\r\n  ignoreFormate = [];\r\n  allcols = [];\r\n  fileLogIdn = 0;\r\n  show = false;\r\n  stepMsg = '';\r\n  timerfile;\r\n  timerPrice;\r\n  dateFormat;\r\n  delim;\r\n  dateFormatMap = {};\r\n  mappingskip = false;\r\n  filetype;\r\n  filenme;\r\n  dateFormatList = [{ \"k\": \"dd/mm/yy\", \"v\": \"dd/mm/yy\" },\r\n  { \"k\": \"mm/dd/yy\", \"v\": \"mm/dd/yy\" },\r\n  { \"k\": \"dd/Mon/yy\", \"v\": \"dd/Mon/yy\" },\r\n  ]\r\n  constructor(\r\n    public router: Router,\r\n    private route: ActivatedRoute,\r\n    // private flashMessagesService: FlashMessagesService,\r\n    // private spinnerService: Ng4LoadingSpinnerService,\r\n    private http: HttpClient,\r\n    private cs: CommanServiceService\r\n  ) { }\r\n\r\n  handleFileInput(files: FileList) {\r\n    this.fileToUpload = files.item(0);\r\n    this.fileName = files[0].name;\r\n  }\r\n  onFileSelect(input: HTMLInputElement) {\r\n    const files = input.files;\r\n\r\n    if (files && files.length) {\r\n\r\n      const fileToRead = files[0];\r\n\r\n      const fileReader = new FileReader();\r\n      fileReader.onload = this.onFileLoad;\r\n\r\n      fileReader.readAsText(fileToRead, \"UTF-8\");\r\n    }\r\n\r\n  }\r\n\r\n\r\n\r\n  csvContent: string;\r\n  parsedCsv: string[][];\r\n  onFileLoad(fileLoadedEvent) {\r\n    const csvSeparator = ';';\r\n    const textFromFileLoaded = fileLoadedEvent.target.result;\r\n    this.csvContent = textFromFileLoaded;\r\n    const txt = textFromFileLoaded;\r\n    const csv = [];\r\n    const lines = txt.split('\\n');\r\n\r\n    console.log(lines[0]);\r\n\r\n\r\n    lines.forEach(element => {\r\n      const cols: string[] = element.split(csvSeparator);\r\n      csv.push(cols);\r\n    });\r\n    this.parsedCsv = csv;\r\n\r\n    // demo output as alert\r\n    var output: string = \"\";\r\n    csv.forEach(row => {\r\n      output += \"\\n\";\r\n      var colNo = 0;\r\n      row.forEach(col => {\r\n        if (colNo > 0) output += \" | \";\r\n        output += col;\r\n        colNo++;\r\n      });\r\n    });\r\n    return output;\r\n  }\r\n\r\n\r\n  arrayBuffer: any;\r\n  file: File;\r\n  incomingfile(event) {\r\n    this.file = event.target.files[0];\r\n    this.fileName = this.file.name;\r\n    this.Upload();\r\n  }\r\n\r\n  Upload() {\r\n\r\n    this.show = true;\r\n    this.stepMsg = 'File upload in process..';\r\n    // this.spinnerService.show();\r\n    this.mappSheetData = [];\r\n    this.sheetData = [];\r\n    let fileReader = new FileReader();\r\n    fileReader.onload = (e) => {\r\n      this.arrayBuffer = fileReader.result;\r\n      var data = new Uint8Array(this.arrayBuffer);\r\n      var arr = new Array();\r\n      for (var i = 0; i != data.length; ++i) arr[i] = String.fromCharCode(data[i]);\r\n      var bstr = arr.join(\"\");\r\n      var workbook = XLSX.read(bstr, { type: \"binary\" });\r\n      var first_sheet_name = workbook.SheetNames[0];\r\n      var worksheet = workbook.Sheets[first_sheet_name];\r\n\r\n      var sheetDataMap: any = XLSX.utils.sheet_to_json(worksheet, { header: 1 });\r\n      let headerList = sheetDataMap[0];\r\n      headerList.forEach(hdr => {\r\n        this.headerList.push(hdr.trim());\r\n      });\r\n      this.sheetData = XLSX.utils.sheet_to_json(worksheet);\r\n      this.mappSheetData = XLSX.utils.sheet_to_json(worksheet);\r\n      this.fileLogIdn = 0;\r\n      console.log(\"this.headerList\", this.headerList);\r\n\r\n      this.getHeaderMatch();\r\n      // const distinctSh = [...new Set(this.sheetData.map(x=>x.SHAPE))];\r\n    }\r\n    fileReader.readAsArrayBuffer(this.file);\r\n  }\r\n\r\n  setSetp(step) {\r\n    this.step = step;\r\n\r\n    if (step == 1) {\r\n      this.ngOnDestroy();\r\n      this.ngOnInit();\r\n    }\r\n  }\r\n\r\n  getHeaderMatch() {\r\n    this.show = true;\r\n    debugger;\r\n    this.stepMsg = 'Header verification in process ...';\r\n    // this.spinnerService.show();\r\n    let reqObj = {};\r\n    reqObj['formNme'] = 'fileUpload';\r\n    reqObj['attrList'] = this.headerList;\r\n    reqObj['fileIdn'] = this.fileType;\r\n    this.header[\"method\"] = 'loadHeaderAttr';\r\n    this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response: any) => {\r\n      if (response.status == 'SUCCESS') {\r\n        let result = response.result;\r\n        this.headerAttributeDtl = result.attrDetails || '';\r\n        console.log(\"this.headerAttributeDtl\", this.headerAttributeDtl);\r\n        let headerListLnt = this.headerList.length;\r\n        this.totalmatch = result.totalmatch || 0;\r\n        if (this.headerAttributeDtl != '') {\r\n          this.attrStructureDtl = result.attrStructureDtl || [];\r\n          if (this.sheetData.length < 5)\r\n            this.defultDisplayLen = this.sheetData.length;\r\n          for (var i = 0; i < this.defultDisplayLen; i++)\r\n            this.defultDisplayObj[i] = this.sheetData[i];\r\n\r\n          let ignoreColumnLst = result.ignore_column || [];\r\n          ignoreColumnLst.forEach(hdrDsc => {\r\n\r\n            if (this.headerAttributeDtl[hdrDsc] != undefined) {\r\n              this.headerAttributeDtl[hdrDsc].ignore = 'Y';\r\n              headerListLnt--;\r\n              this.totalignore++;\r\n              if (this.headerAttributeDtl[hdrDsc].attr != \"\")\r\n                this.totalmatch--;\r\n            }\r\n          });\r\n          let isDate = false;\r\n\r\n          this.headerList.forEach(hdr => {\r\n\r\n            let hdrAttr = this.headerAttributeDtl[hdr] || {};\r\n            if (hdrAttr.dta_typ == 'd') {\r\n              this.dateFormatMap[hdr] = this.dateFormat;\r\n              isDate = true;\r\n            }\r\n          });\r\n\r\n          if (this.totalmatch == headerListLnt && isDate == false) {\r\n            this.ValidateFileHeaderMapping('N');\r\n            this.show = false;\r\n            this.step = 3;\r\n          }\r\n          else {\r\n            this.step = 2;\r\n          }\r\n          this.show = false;\r\n        } else {\r\n          // this.flashMessagesService.show(\"Some problem in File Header Matching\", { cssClass: 'alert-danger', timeout: 3000 });\r\n        }\r\n        //this.spinnerService.hide();\r\n        this.show = false;\r\n      } else {\r\n        this.show = false;\r\n        //this.spinnerService.hide();\r\n        // this.flashMessagesService.show(response.message, { cssClass: 'alert-danger', timeout: 3000 });\r\n      }\r\n    }, error => {\r\n      // this.spinnerService.hide();\r\n      this.show = false;\r\n      // this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n    });\r\n  }\r\n  updatecolumnstatue(hdr) {\r\n\r\n    var isIgnore = this.headerAttributeDtl[hdr].ignore || '';\r\n    if (isIgnore == 'Y') {\r\n      this.headerAttributeDtl[hdr].ignore = 'N'\r\n      this.totalignore--;\r\n    } else {\r\n      this.totalignore++;\r\n      this.headerAttributeDtl[hdr].ignore = 'Y';\r\n    }\r\n    console.log(this.headerAttributeDtl[hdr]);\r\n  }\r\n  maphdr;\r\n  hdrmassage;\r\n  confirmsetHeaderMapp(hdr) {\r\n    this.maphdr = hdr;\r\n    let attr = this.headerAttributeDtl[hdr].attr;\r\n    this.attrStructureDtl.forEach(ele => {\r\n\r\n      if (ele.attr == attr) {\r\n        this.hdrmassage = this.headerAttributeDtl[hdr].attr + \"(\" + ele.print + \")\";\r\n      }\r\n    })\r\n\r\n    document.getElementById('btnCofirmmaphdr').click();\r\n  }\r\n  CancelHeaderMapp() {\r\n    this.headerAttributeDtl[this.maphdr].attr = \"\";\r\n  }\r\n  setHeaderMapp() {\r\n    debugger;\r\n    let attr = this.headerAttributeDtl[this.maphdr].attr || '';\r\n    if (attr != '') {\r\n      let reqObj = {};\r\n      reqObj['formNme'] = 'fileUpload';\r\n      reqObj['optionaVal'] = this.maphdr\r\n      reqObj['attr'] = attr;\r\n      console.log(JSON.stringify(reqObj));\r\n      this.header[\"method\"] = 'addHeaderAttr';\r\n      this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response: any) => {\r\n        console.log(response);\r\n\r\n        if (response.status == 'SUCCESS') {\r\n          let result = response.result || {};\r\n          let hdrDtl = result.attrDetails[this.maphdr] || '';\r\n          if (hdrDtl != '') {\r\n            this.totalmatch++;\r\n            this.headerAttributeDtl[this.maphdr] = hdrDtl;\r\n          } else {\r\n            this.headerAttributeDtl[this.maphdr] = {\r\n              \"attr\": \"\",\r\n              \"print\": \"\",\r\n              \"srt\": \"\",\r\n              \"dta_typ\": \"\",\r\n              \"attr_idn\": \"\"\r\n            }\r\n\r\n          }\r\n        }\r\n        // this.spinnerService.hide();\r\n      }, error => {\r\n\r\n        // this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n      });\r\n    } else {\r\n      // this.flashMessagesService.show(\"Mapping attribute is empty please retry.\", { cssClass: 'alert-danger', timeout: 3000 });\r\n    }\r\n\r\n  }\r\n\r\n  gmatchedCount = 0;\r\n  gresultCount = 0;\r\n  setRowDataMapp() {\r\n    if (!this.mappingskip) {\r\n      let rowMatchCount = 0;\r\n      this.charHeaderList = [];\r\n      debugger\r\n      this.headerList.forEach(hdr => {\r\n\r\n        let attr = this.headerAttributeDtl[hdr].attr || '';\r\n        let attrType = this.headerAttributeDtl[hdr].dta_typ || '';\r\n        let isIgnore = this.headerAttributeDtl[hdr].ignore || '';\r\n        if (attr != '' && isIgnore != 'N' && attrType == 'c') {\r\n          debugger\r\n          var distinctlist = Array.from(new Set(this.sheetData.map((item: any) => item[hdr])));\r\n          distinctlist = distinctlist.filter(function (e) { return e });\r\n          if (distinctlist.length > 0) {\r\n            this.rowdistinctDataMap[attr] = distinctlist;\r\n            rowMatchCount = rowMatchCount + distinctlist.length;\r\n            this.gmatchedCount = rowMatchCount;\r\n            this.charHeaderList.push(hdr);\r\n            let attrDetails = this.attrStructureDtl.find(attrdtl => attrdtl.attr == attr) || {};\r\n            this.attributeDtlMap[attr] = attrDetails.prpList || [];\r\n          }\r\n        }\r\n\r\n\r\n\r\n      });\r\n      let reqObj = {};\r\n      reqObj['formNme'] = 'fileUpload';\r\n      reqObj['attrMap'] = this.rowdistinctDataMap;\r\n      console.log(JSON.stringify(reqObj));\r\n      this.header[\"method\"] = 'loadHeaderAttrDtl';\r\n      this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response: any) => {\r\n        // this.spinnerService.hide();\r\n        if (response.status == 'SUCCESS') {\r\n          let result = response.result;\r\n          console.log(result);\r\n          console.log(rowMatchCount);\r\n          debugger;\r\n\r\n          this.rowdatamapDetails = result.attrDetails || {};\r\n          this.gresultCount = result.totalmatch;\r\n          this.step = 3;\r\n          if (rowMatchCount == result.totalmatch) {\r\n            this.step = 4;\r\n            this.uploadFile();\r\n\r\n          }\r\n          else {\r\n            // this.flashMessagesService.show(\"please verify data mapping.\", { cssClass: 'alert-danger', timeout: 3000 });\r\n          }\r\n\r\n        } else {\r\n          // this.flashMessagesService.show(\"something go wrong in row data.\", { cssClass: 'alert-danger', timeout: 3000 });\r\n        }\r\n      }, error => {\r\n        // this.spinnerService.hide();\r\n        // this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n      });\r\n    } else {\r\n      this.step = 4;\r\n      this.uploadFile();\r\n    }\r\n\r\n  }\r\n  dtlAttr;\r\n  dtlattr_idn;\r\n  dtloptionval;\r\n  dtlmassage;\r\n  confirmHeaderDetailsMapp(attr, attr_idn, optionval) {\r\n    this.dtlAttr = attr;\r\n    this.dtlattr_idn = attr_idn;\r\n    this.dtloptionval = optionval;\r\n    let val = this.rowdatamapDetails[this.dtlAttr][this.dtloptionval].val;\r\n    let attributeDtlList = this.attributeDtlMap[attr];\r\n    attributeDtlList.forEach(ele => {\r\n\r\n      if (ele.val == val) {\r\n        this.dtlmassage = val + \"(\" + ele.print + \")\";\r\n      }\r\n    })\r\n\r\n    document.getElementById('btnCofirmmapdtl').click();\r\n\r\n  }\r\n\r\n  CancelHeaderDetailsMapp() {\r\n    this.rowdatamapDetails[this.dtlAttr][this.dtloptionval].val = \"\";\r\n  }\r\n  setHeaderDetailsMapp() {\r\n    let attrDtlVal = this.rowdatamapDetails[this.dtlAttr][this.dtloptionval].val || '';\r\n    if (attrDtlVal != '') {\r\n      let reqObj = {};\r\n      reqObj['formNme'] = 'fileUpload';\r\n      reqObj['optionaVal'] = this.dtloptionval\r\n      reqObj['attr_idn'] = this.dtlattr_idn;\r\n      reqObj['attr'] = this.dtlAttr;\r\n      reqObj['attrVal'] = attrDtlVal;\r\n      this.header[\"method\"] = 'addDetailAttr';\r\n      console.log(JSON.stringify(reqObj));\r\n      this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response: any) => {\r\n        console.log(\"addDetailAttr\", response);\r\n        if (response.status == 'SUCCESS') {\r\n          this.gresultCount++;\r\n          let result = response.result || {};\r\n          console.log(result.attrDetails);\r\n          let attrDetails = result.attrDetails || {}\r\n          this.rowdatamapDetails[this.dtlAttr][this.dtloptionval] = attrDetails[this.dtloptionval];\r\n          // this.spinnerService.hide();\r\n        }\r\n        // this.spinnerService.hide();\r\n      }, error => {\r\n\r\n        // this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n      });\r\n    } else {\r\n      // this.flashMessagesService.show(\"Mapping attribute is empty please retry.\", { cssClass: 'alert-danger', timeout: 3000 });\r\n    }\r\n\r\n\r\n  }\r\n\r\n\r\n  onSubmit(formVal) {\r\n    var t = Object.keys(formVal.form.controls).forEach(field => {\r\n      const control = formVal.form.get(field);\r\n    });\r\n    this.saveFileOption(formVal.value);\r\n  }\r\n  saveFileOption(frmvals) {\r\n    // this.spinnerService.show();\r\n    let reqObj = {};\r\n    reqObj = { ...frmvals, column_format: this.colFormate, ignore_column: this.ignoreFormate };\r\n    reqObj['formNme'] = 'fileUpload';\r\n    console.log(JSON.stringify(reqObj));\r\n    debugger\r\n    this.header[\"method\"] = 'addFileOption';\r\n    this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response: any) => {\r\n      if (response.status == 'SUCCESS') {\r\n        debugger\r\n        let result = response.result || {};\r\n        this.fileOptionsList = result.fileOptionsList;\r\n        this.fileType = result.file_idn;\r\n        this.ValidateFileHeaderMapping('N');\r\n        // this.spinnerService.hide();\r\n        // this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });\r\n      }\r\n      // this.spinnerService.hide();\r\n    }, error => {\r\n      // this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n    });\r\n  }\r\n  addFileLog(fileIdn) {\r\n    debugger\r\n    let reqObj = {};\r\n    reqObj['formNme'] = 'fileUpload';\r\n    reqObj['file_idn'] = fileIdn;\r\n    reqObj['file_status'] = \"Header Inserted\";\r\n    reqObj['validation_remarks'] = \"Header validated\";\r\n    reqObj['header_row'] = this.allcols;\r\n    reqObj['header_attr_row'] = this.colFormate;\r\n    this.header[\"method\"] = 'addFileLog';\r\n    this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response: any) => {\r\n      if (response.status == 'SUCCESS') {\r\n        debugger\r\n        let result = response.result || {};\r\n        this.fileLogIdn = result.file_log_idn;\r\n        this.setRowDataMapp();\r\n        // this.spinnerService.hide();\r\n        // this.flashMessagesService.show(\"Header validated successfully\", { cssClass: 'alert-success', timeout: 3000 });\r\n      }\r\n      // this.spinnerService.hide();\r\n    }, error => {\r\n      // this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n    });\r\n  }\r\n\r\n  ValidateFileHeaderMapping(formatSave) {\r\n    // this.spinnerService.show();\r\n\r\n    this.show = true;\r\n    this.stepMsg = 'Header verification in process ...';\r\n    this.colFormate = [];\r\n    this.ignoreFormate = [];\r\n    this.allcols = [];\r\n    let isValidate = true;\r\n    this.headerList.forEach(hdr => {\r\n      let hdrDtl = this.headerAttributeDtl[hdr] || ''\r\n      if (hdrDtl.attr == '' && hdrDtl.ignore != 'Y') {\r\n        isValidate = false;\r\n      }\r\n      if (hdrDtl.attr != '' && hdrDtl.ignore != 'N') {\r\n        this.colFormate.push(hdrDtl.attr);\r\n      }\r\n      if (hdrDtl.ignore == 'Y') {\r\n        this.ignoreFormate.push(hdr);\r\n      }\r\n      this.allcols.push(hdr);\r\n    });\r\n\r\n    if (isValidate && (this.fileType == null || this.fileType == undefined || this.fileType == \"\")) {\r\n      // this.spinnerService.hide();\r\n\r\n      this.stepMsg = \"\";\r\n      document.getElementById('btnfileUploadModal').click();\r\n      this.step = 2;\r\n      return;\r\n    } else {\r\n\r\n      if (isValidate) {\r\n        if (formatSave == 'Y') {\r\n          this.updatefileOption();\r\n        }\r\n        this.addFileLog(this.fileType);\r\n      } else {\r\n        // this.spinnerService.hide();\r\n        // this.flashMessagesService.show(\"Please specify mapping or marke as ignore \", { cssClass: 'alert-danger', timeout: 3000 });\r\n      }\r\n    }\r\n    this.show = false;\r\n\r\n\r\n  }\r\n  hdrIdn;\r\n  updatefileOption() {\r\n    let reqObj = {};\r\n    reqObj['formNme'] = 'fileUpload';\r\n    reqObj['fileIdn'] = this.fileType;\r\n    reqObj['column_format'] = this.colFormate;\r\n    reqObj['ignore_column'] = this.ignoreFormate;\r\n\r\n    this.header[\"method\"] = 'updateColumnFormat';\r\n    console.log(JSON.stringify(reqObj));\r\n    this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response: any) => {\r\n      if (response.status == 'SUCCESS') {\r\n      }\r\n    }, error => {\r\n    });\r\n  }\r\n\r\n  uploadFile() {\r\n    this.dateFormat = this.dateFormat || 'dd/mm/yy';\r\n    this.delim = this.delim || '/';\r\n    this.show = true;\r\n    let dateValid = true;\r\n    let massage = \"\";\r\n\r\n    if (!this.mappingskip) {\r\n      this.stepMsg = \"Data verification in process ...\";\r\n      this.headerList.forEach(hdr => {\r\n        debugger\r\n        let attr = this.headerAttributeDtl[hdr].attr || '';\r\n        let attrType = this.headerAttributeDtl[hdr].dta_typ || '';\r\n        let isIgnore = this.headerAttributeDtl[hdr].ignore || '';\r\n        if (isIgnore == 'Y') {\r\n          this.mappSheetData.map((rowData, i) => {\r\n            delete this.mappSheetData[i][hdr];\r\n          });\r\n        } else {\r\n          if (attrType == 'c') {\r\n            this.mappSheetData.map((rowData, i) => {\r\n              if (this.charHeaderList.indexOf(hdr) != -1) {\r\n                let attrdtlVal = rowData[hdr] || '';\r\n                if (attrdtlVal != '') {\r\n\r\n                  let attrDtlMapVal = this.rowdatamapDetails[attr][attrdtlVal].srt;\r\n                  this.mappSheetData[i][attr] = attrDtlMapVal.toString();\r\n                }\r\n                if (attr != hdr)\r\n                  delete this.mappSheetData[i][hdr]\r\n              }\r\n\r\n            });\r\n\r\n          } else if (attrType == 'n') {\r\n            this.mappSheetData.map((rowData, i) => {\r\n              let attrdtlVal = rowData[hdr] || '';\r\n              if (attrdtlVal != '') {\r\n                debugger\r\n                attrdtlVal = attrdtlVal.replace(/[^0-9.-]/g, \"\");\r\n                this.mappSheetData[i][attr] = attrdtlVal.toString();\r\n              }\r\n              if (attr != hdr)\r\n                delete this.mappSheetData[i][hdr]\r\n\r\n            });\r\n          } else if (attrType == 'd') {\r\n\r\n            this.mappSheetData.map((rowData, i) => {\r\n              debugger\r\n              let attrdtlVal = rowData[hdr] || '';\r\n              let dtFrm = this.dateFormatMap[hdr] || 'dd/mm/yy';\r\n              if (attrdtlVal != '')\r\n                attrdtlVal = this.cs.dateValidation(attrdtlVal, dtFrm);\r\n              if (attrdtlVal == 'invaild') {\r\n                dateValid = false;\r\n                massage = \"Please check Date :\" + rowData[hdr] + \" Date Format :\" + dtFrm;\r\n              }\r\n\r\n              this.mappSheetData[i][attr] = attrdtlVal.toString();\r\n              if (attr != hdr)\r\n                delete this.mappSheetData[i][hdr]\r\n\r\n            });\r\n\r\n          } else if (attrType == 't') {\r\n            this.mappSheetData.map((rowData, i) => {\r\n              let attrdtlVal = rowData[hdr] || '';\r\n\r\n              this.mappSheetData[i][attr] = attrdtlVal.toString();\r\n              if (attr != hdr)\r\n                delete this.mappSheetData[i][hdr]\r\n\r\n            });\r\n          }\r\n        }\r\n      });\r\n    }\r\n    if (dateValid) {\r\n      let reqObj = {};\r\n      reqObj['formNme'] = 'fileUpload';//this.route.snapshot.params['frmname'];\r\n      reqObj['file_log_idn'] = this.fileLogIdn;\r\n      reqObj['attr_data'] = this.mappSheetData;\r\n      reqObj['in_data'] = this.sheetData;\r\n      reqObj['dateformat'] = this.dateFormatMap;\r\n      this.header[\"method\"] = 'fileUpload';\r\n      let url = \"fileUpload/load\";\r\n      if (this.mdl == 'inward') {\r\n        url = 'inward/loadFile';\r\n        reqObj['inward_idn'] = this.inward_idn;\r\n      }\r\n\r\n      // console.log(reqObj);\r\n      console.log(JSON.stringify(reqObj));\r\n      // console.log(this.header);\r\n\r\n      this.cs.loadiFile(reqObj, this.header, url).then((response: any) => {\r\n        if (response.status == 'SUCCESS') {\r\n          let result = response.result || {};\r\n          console.log(result);\r\n          this.show = false;\r\n          this.step = 4;\r\n          this.fileLogIdn = result.file_log_idn;\r\n          this.hdrIdn = result.hdrIdn;\r\n          this.getProgressFile(this.fileLogIdn);\r\n          this.lableFile = \"File Sequence No. \" + this.fileLogIdn + \" Uploading in progress...\";\r\n          // set file id to local storage\r\n          // AsyncLocalStorage.arguments('uploadedFileId', result.file_log_idn);\r\n\r\n          this.lable = \"Pricing Sequence No. \" + this.hdrIdn + \" Price calculations in progress...\";\r\n\r\n          this.getProgressPrice(this.hdrIdn);\r\n\r\n          // this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });\r\n        }\r\n        this.show = false;\r\n\r\n        // this.spinnerService.hide();\r\n      }, error => {\r\n        this.show = false;\r\n        // this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n      });\r\n    } else {\r\n      this.ngOnInit();\r\n      // this.flashMessagesService.show(massage, { cssClass: 'alert-danger', timeout: 4000 });\r\n    }\r\n    console.log(\"mappSheetData\", JSON.stringify(this.mappSheetData));\r\n    console.log(\"this.sheetData\", JSON.stringify(this.sheetData));\r\n  }\r\n\r\n  changeMapping(hdrObj, hdr, attr) {\r\n    this.headerAttributeDtl[hdr].ignore = 'Y';\r\n    this.headerAttributeDtl[hdr].attr = '';\r\n    this.removeAttrOptVal(attr, hdr);\r\n  }\r\n\r\n\r\n  removeAttrOptVal(attr, optionaVal) {\r\n    let reqObj = {};\r\n    reqObj['formNme'] = 'fileUpload';\r\n    reqObj['attr'] = attr;\r\n    reqObj['optionaVal'] = optionaVal;\r\n    console.log(JSON.stringify(reqObj));\r\n    this.header[\"method\"] = 'removeAttrOptVal';\r\n    this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response: any) => {\r\n      if (response.status == 'SUCCESS') {\r\n        // this.spinnerService.hide();\r\n        // this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });\r\n      }\r\n      // this.spinnerService.hide();\r\n    }, error => {\r\n      // this.spinnerService.hide();\r\n      // this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n    });\r\n  }\r\n\r\n\r\n  removeDetailAttrOptVal(attrIdn, optionaVal, val, hdrAttr) {\r\n    this.rowdatamapDetails[hdrAttr][optionaVal].val = '';\r\n    let reqObj = {};\r\n    reqObj['formNme'] = 'fileUpload';\r\n    reqObj['attrVal'] = val;\r\n    reqObj['optionaVal'] = optionaVal;\r\n    reqObj['attr_idn'] = attrIdn;\r\n    console.log(JSON.stringify(reqObj));\r\n    this.header[\"method\"] = 'removeAttrOptVal';\r\n    this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response: any) => {\r\n      if (response.status == 'SUCCESS') {\r\n        // this.spinnerService.hide();\r\n        // this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });\r\n      }\r\n      // this.spinnerService.hide();\r\n    }, error => {\r\n      // this.spinnerService.hide();\r\n      // this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n    });\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  sttsFile = {}\r\n  getProgressFile(fileLogIdn) {\r\n    let reqObj = {};\r\n    reqObj['formNme'] = 'fileUpload';\r\n    reqObj['file_log_idn'] = fileLogIdn;//this.fileLogIdn;\r\n    console.log(JSON.stringify(reqObj));\r\n    this.header[\"method\"] = 'getFileLogStatus';\r\n    this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response: any) => {\r\n      if (response.status == 'SUCCESS') {\r\n        this.clicked = true;\r\n        let result = response.result || {};\r\n        console.log(result);\r\n        this.sttsFile['C'] = result['C'];\r\n        this.sttsFile['P'] = result['P'];\r\n        this.sttsFile['E'] = result['E'];\r\n        this.sttsFile['T'] = result['T'];\r\n        this.sttsFile['I'] = result['I'];\r\n        this.step = 4;\r\n        this.totProgressFile = Math.ceil(parseFloat(result['C']) * 100 / parseFloat(result['T']));\r\n        this.recallFile(fileLogIdn);\r\n        console.log(this.totProgress);\r\n        // this.spinnerService.hide();\r\n        // this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });\r\n      }\r\n      // this.spinnerService.hide();\r\n    }, error => {\r\n      // this.spinnerService.hide();\r\n      // this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n    });\r\n  }\r\n  // checkUploadStt() {\r\n  //   this.spinnerService.show();\r\n  //   let reqObj = {};\r\n  //   reqObj['formNme'] = this.route.snapshot.params['frmname'];\r\n  //   reqObj['file_log_idn'] = this.fileLogIdn;\r\n  //   console.log(JSON.stringify(reqObj));\r\n  //   this.us.data(reqObj, 'getFileLogStatus', 'fileUpload/load').subscribe(response => {\r\n  //     if (response.status == 'SUCCESS') {\r\n  //       this.clicked = true;\r\n  //       let result = response.result || {};\r\n  //       console.log(result);\r\n  //       this.stts['C'] = result['C'];\r\n  //       this.stts['P'] = result['P'];\r\n  //       this.stts['E'] = result['E'];\r\n  //       this.stts['T'] = result['T'];\r\n  //       this.step = 4;\r\n  //       this.spinnerService.hide();\r\n  //       this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });\r\n  //     }\r\n  //     this.spinnerService.hide();\r\n  //   }, error => {\r\n  //     this.spinnerService.hide();\r\n  //     this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n  //   });\r\n\r\n  // }\r\n\r\n  stts = {};\r\n  clicked = false;\r\n  totProgress = 0;\r\n  totProgressFile = 0;\r\n  getProgressPrice(hdrIdn) {\r\n    // this.spinnerService.show();\r\n    let reqObj = {};\r\n    reqObj['formNme'] = 'fileUpload';\r\n    reqObj['seqNo'] = hdrIdn;//\"846\";//this.fileLogIdn;\r\n    console.log(JSON.stringify(reqObj));\r\n    this.header[\"method\"] = 'getPriceStatus';\r\n    this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response: any) => {\r\n      if (response.status == 'SUCCESS') {\r\n        this.clicked = true;\r\n        let result = response.result || {};\r\n        console.log(result);\r\n        this.stts['C'] = result['C'];\r\n        this.stts['P'] = result['P'];\r\n        this.stts['E'] = result['E'];\r\n        this.stts['T'] = result['T'];\r\n        this.step = 4;\r\n        this.totProgress = Math.ceil(parseFloat(result['C']) * 100 / parseFloat(result['T']));\r\n        this.recall(this.hdrIdn);\r\n        console.log(this.totProgress);\r\n        // this.spinnerService.hide();\r\n        // this.flashMessagesService.show(response.message, { cssClass: 'alert-success', timeout: 3000 });\r\n      }\r\n      // this.spinnerService.hide();\r\n    }, error => {\r\n      // this.spinnerService.hide();\r\n      // this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n    });\r\n\r\n  }\r\n  lastRefreshTimeFile = null;\r\n  recallFile(fileLogIdn) {\r\n\r\n    if (this.totProgressFile < 100) {\r\n      this.lastRefreshTimeFile = new Date();\r\n      this.timerfile =\r\n        setTimeout(() => {\r\n          this.getProgressFile(fileLogIdn);\r\n        }, 5000);\r\n    }\r\n    else {\r\n      clearTimeout(this.timerfile);\r\n      // this.PlanningComponent.getPacketsByHeaderId(hdrIdn);\r\n      // this.closebtn.nativeElement.click();\r\n      if (this.totProgressFile == 100 && this.totProgress == 100) {\r\n        document.getElementById('btnfileUploadModal').click();\r\n\r\n        this.router.navigate(['/pricing/rough/planingscreen/roughPlaningScreen'], { queryParams: { hdrId: this.hdrIdn } });\r\n      }\r\n\r\n    }\r\n  }\r\n  lastRefreshTime = null;\r\n  recall(hdrIdn) {\r\n    if (this.totProgress < 100) {\r\n      this.lastRefreshTime = new Date();\r\n      this.timerPrice =\r\n        setTimeout(() => {\r\n          this.getProgressPrice(hdrIdn);\r\n        }, 5000);\r\n    }\r\n\r\n    else {\r\n      clearTimeout(this.timerPrice);\r\n      if (this.totProgressFile == 100 && this.totProgress == 100) {\r\n        document.getElementById('btnfileUploadModal').click();\r\n        this.router.navigate(['/pricing/rough/planingscreen/roughPlaningScreen'], { queryParams: { hdrId: this.hdrIdn } });\r\n      }\r\n    }\r\n  }\r\n  SkipVerification() {\r\n    debugger\r\n    this.mappingskip = true;\r\n    this.addFileLog(this.fileType);\r\n\r\n  }\r\n  SkipVerificationDtl() {\r\n    this.mappingskip = true;\r\n    this.step = 4;\r\n    this.uploadFile();\r\n  }\r\n\r\n  loadFileTypeData(fileUpload, mdl) {\r\n    this.sheetData = [];\r\n    this.headerAttributeDtl = {};\r\n    this.defultDisplayLen = 5;\r\n    this.defultDisplayObj = [];\r\n    this.attrStructureDtl = [];\r\n    this.headerList = [];\r\n    this.headerprp;\r\n    this.attrprp;\r\n    this.totalmatch = 0;\r\n    this.totalignore = 0;\r\n    this.pageDefination = {};\r\n    this.rowdatamapDetails = {};\r\n    this.rowdistinctDataMap = {};\r\n    this.charHeaderList = [];\r\n    this.attributeDtlMap = {};\r\n    this.mappSheetData = [];\r\n    this.statusList = [];\r\n    this.fileDetails = [];\r\n    this.fileTypeList = [];\r\n    this.fileOptionsList = [];\r\n    this.fileType;\r\n    this.nme;\r\n    this.typ;\r\n    this.description;\r\n    this.check_status = [];\r\n    this.pkt_status = [];\r\n    this.colFormate = [];\r\n    this.allcols = [];\r\n    this.fileLogIdn = 0;\r\n    this.show = false;\r\n    this.stepMsg = '';\r\n    this.stts = {};\r\n    this.clicked = false;\r\n    this.totProgress = 0;\r\n    this.totProgressFile = 0;\r\n    this.step = 1;\r\n    this.lable = \"\";\r\n    this.filenme = \"\";\r\n    let reqObj = {};\r\n    this.dateFormatMap = {};\r\n    let filetype = this.route.snapshot.params['filetype'] || '';\r\n    this.mdl = mdl;\r\n    this.filenme = this.route.snapshot.params['filetype'] || '';\r\n    this.mappingskip = false;\r\n    reqObj['formNme'] = fileUpload;\r\n    if (mdl != '')\r\n      reqObj['mdl'] = mdl;\r\n    if (filetype != '')\r\n      reqObj['filenme'] = filetype;\r\n    console.log(JSON.stringify(this.header));\r\n    console.log(JSON.stringify(reqObj));\r\n    this.header[\"method\"] = 'loadFileUpload';\r\n    this.cs.loadiFile(reqObj, this.header, 'fileUpload/load').then((response: any) => {\r\n      if (response.status == 'SUCCESS') {\r\n        console.log(response);\r\n        debugger;\r\n        let result = response.result || {};\r\n        this.pageDefination = result.pageDefination\r\n        this.statusList = result.statusList;\r\n        this.fileDetails = result.fileDetails;\r\n        this.fileTypeList = result.fileTypeList;\r\n        this.fileOptionsList = result.fileOptionsList || [];\r\n        if (this.fileOptionsList.length > 0)\r\n          this.fileType = this.fileOptionsList[0].k;\r\n        let addlAttr = this.fileOptionsList[0].addl_attr || {};\r\n        this.dateFormat = addlAttr.dateformat || 'dd/mm/yy';\r\n        this.delim = addlAttr.delim || '/';\r\n        this.statusList = result.statusList.map(option => ({\r\n          value: option.k,\r\n          label: option.v\r\n        }));\r\n      }\r\n      // this.spinnerService.hide();\r\n    }, error => {\r\n\r\n      // this.flashMessagesService.show(error, { cssClass: 'alert-danger', timeout: 3000 });\r\n    });\r\n\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n\r\n    let mdlk = JSON.parse(localStorage.getItem('mdlKey'));\r\n    let cUrl = this.router.url;\r\n    this.cDt = new Date();\r\n    this.header = {\r\n      'clientkey': Cookie.get('_ck'),\r\n      'Content-Type': 'application/json',\r\n      'loginid': Cookie.get('_logid'),\r\n      'modulekey': mdlk[cUrl.split('/')[1]],\r\n      'source': 'qs'\r\n    };\r\n\r\n\r\n    this.route.params.subscribe((params: Params) => {\r\n      let mdl = this.route.snapshot.params['grp'] || '';\r\n\r\n      this.loadFileTypeData('fileUpload', mdl);\r\n    });\r\n  }\r\n  inward_idn;\r\n  inwardStockType;\r\n  stockInwardUpload(inwardDtl, mdl) {\r\n    this.inward_idn = inwardDtl.inward_idn;\r\n    this.inwardStockType = inwardDtl.stock_type;\r\n    this.mdl = mdl;\r\n    this.loadFileTypeData('fileUpload', mdl);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this.timerfile != undefined)\r\n      clearTimeout(this.timerfile);\r\n\r\n    if (this.timerPrice != undefined)\r\n      clearTimeout(this.timerPrice);\r\n\r\n  }\r\n\r\n  setOptionsForMixToSingle() {\r\n    this.fileOptionsList = [\r\n      { \"k\": \"696\", \"v\": \"Marketing Stock\" }\r\n    ];\r\n    this.fileType = \"696\";\r\n  }\r\n\r\n\r\n}","<div class=\"mt\" style=\"background: #fff;\">\r\n\r\n    <div class=\"content-frame\">\r\n        <p *ngIf=\"show\" class=\"loading-text\" style=\"z-index: 9999\"> {{stepMsg}} </p>\r\n\r\n        <div class=\"innerD\">\r\n            <div class=\"mt-element-step\">\r\n                <div class=\"row step-thin\">\r\n\r\n                    <div class=\"col-md-2 bg-grey mt-step-col\" [ngClass]=\"{'done':step==1 ? 'done':''}\"\r\n                        (click)=setSetp(1)>\r\n                        <div class=\"mt-step-number bg-white font-grey\">1</div>\r\n                        <div class=\"mt-step-title uppercase font-grey-cascade\">Browse</div>\r\n                    </div>\r\n                    <div class=\"col-md-4 bg-grey mt-step-col\" [ngClass]=\"{'done':step==2 ? 'done':''}\"\r\n                        (click)=setSetp(2)>\r\n                        <div class=\"mt-step-number bg-white font-grey\">2</div>\r\n                        <div class=\"mt-step-title uppercase font-grey-cascade\">Header Verification</div>\r\n                    </div>\r\n                    <div class=\"col-md-3 bg-grey mt-step-col\" [ngClass]=\"{'done':step==3 ? 'done':''}\"\r\n                        (click)=setSetp(3)>\r\n                        <div class=\"mt-step-number bg-white font-grey\">3</div>\r\n                        <div class=\"mt-step-title uppercase font-grey-cascade\">Data Verification</div>\r\n                    </div>\r\n\r\n                    <div class=\"col-md-3 bg-grey mt-step-col\" [ngClass]=\"{'done':step==4 ? 'done':''}\"\r\n                        (click)=setSetp(4)>\r\n                        <div class=\"mt-step-number bg-white font-grey\">4</div>\r\n                        <div class=\"mt-step-title uppercase font-grey-cascade\">Uploading..</div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"row upload\" *ngIf=\"step==1\">\r\n\r\n\r\n                    <div class=\"col-md-offset-3 col-md-3\" style=\"margin-top: 15px;\">\r\n                        <div class=\"form-group w-100\">\r\n                            <label class=\"col-md-4 control-label\" style=\"padding: 5px;\">File Type :</label>\r\n                            <div class=\"col-md-8\">\r\n                                <div class=\"input-group w-100\">\r\n                                    <select class=\"form-control\" name=\"fileType\" [(ngModel)]=\"fileType\">\r\n                                        <option value=\"\">--select--</option>\r\n                                        <option *ngFor=\"let file of fileOptionsList\" value=\"{{file?.k}}\">{{file?.v}}\r\n                                        </option>\r\n                                    </select>\r\n                                </div>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n\r\n\r\n                    <div class=\"col-md-2\">\r\n                        <a class=\"fileinput-wrapper btn btn-default  fileinput btn-primary\"\r\n                            style=\"background: #3a5898\"><span>Browse file</span>\r\n                            <input type=\"file\" class=\"fileinput btn-primary\" name=\"filename\" id=\"filename\"\r\n                                title=\"Browse file\" accept=\".xlsx,.csv\" (change)=\"incomingfile($event)\"\r\n                                style=\"left: -163.75px; top: 9px;\"></a>\r\n\r\n                    </div>\r\n\r\n                    <!-- <label class=\"control-label\">Upload File : &nbsp;&nbsp;&nbsp;</label>\r\n\r\n                    <input type=\"file\" class=\"fileinput btn-primary\" accept=\".xlsx,.csv\" name=\"filename\" id=\"filename\"\r\n                        (change)=\"incomingfile($event)\" title=\"Browse file\"> -->\r\n\r\n\r\n                </div>\r\n\r\n                <div class=\"row upload\" *ngIf=\"step==2\">\r\n                    <div class=\"row\">\r\n                        <div class=\"col-md-1\">\r\n                            Total Match : {{totalmatch}}\r\n                        </div>\r\n                        <div class=\"col-md-1\">\r\n                            Total Ignore : {{totalignore}}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <div class=\"row col-md-12\" style=\"overflow: auto;width: 100%;\">\r\n                        <table class=\"fileuploadview\">\r\n                            <tr>\r\n                                <ng-container *ngFor=\"let hdr of headerList ;\">\r\n                                    <th [ngClass]=\"{\r\n                                        'match':headerAttributeDtl[hdr].attr!='' && headerAttributeDtl[hdr].ignore!='Y',\r\n                                        'ignore':headerAttributeDtl[hdr].ignore=='Y',\r\n                                        'thbg':headerAttributeDtl[hdr].attr=='' && headerAttributeDtl[hdr].ignore!='Y'\r\n                                         }\" (click)=\"updatecolumnstatue(hdr)\">{{hdr}}\r\n                                    </th>\r\n                                </ng-container>\r\n                            </tr>\r\n                            <tr>\r\n                                <ng-container *ngFor=\"let hdr of headerList ;\">\r\n                                    <th>\r\n                                        <ng-container *ngIf=\"headerAttributeDtl[hdr].attr==''\">\r\n                                            <!-- <select class=\"select-control\" name=\"{{headerAttributeDtl[hdr].attr}}\"\r\n                                                [(ngModel)]=\"headerAttributeDtl[hdr].attr\"\r\n                                                (change)=\"confirmsetHeaderMapp(hdr,$event.target)\"> -->\r\n                                                <select class=\"select-control\" name=\"{{headerAttributeDtl[hdr].attr}}\"\r\n                                                [(ngModel)]=\"headerAttributeDtl[hdr].attr\"\r\n                                                (change)=\"confirmsetHeaderMapp(hdr)\">\r\n                                                <option value=\"\">--select--</option>\r\n                                                <option *ngFor=\"let attrDtl of attrStructureDtl\"\r\n                                                    value=\"{{attrDtl?.attr}}\">{{attrDtl?.attr}}</option>\r\n                                            </select>\r\n                                        </ng-container>\r\n                                        <ng-container *ngIf=\"headerAttributeDtl[hdr].attr!=''\">\r\n                                            {{headerAttributeDtl[hdr].attr}}\r\n                                           \r\n                                        </ng-container>\r\n\r\n                                    </th>\r\n                                </ng-container>\r\n                            </tr>\r\n                            <tr>\r\n                                <ng-container *ngFor=\"let hdr of headerList ;\">\r\n                                    <th>\r\n                                        <ng-container *ngIf=\"headerAttributeDtl[hdr].dta_typ=='d'\">\r\n                                            <select class=\"select-control\" name=\"{{dateFormatMap[hdr]}}\"\r\n                                                [(ngModel)]=\"dateFormatMap[hdr]\"\r\n                                               >\r\n                                                <option *ngFor=\"let dteFmt of dateFormatList\"\r\n                                                    value=\"{{dteFmt?.k}}\">{{dteFmt?.v}}</option>\r\n                                            </select>\r\n                                        </ng-container>\r\n                                        </th>\r\n                                </ng-container>\r\n                            </tr> \r\n                            <tr *ngFor=\"let rowDis of defultDisplayObj ;\">\r\n                                <td *ngFor=\"let hdr of headerList ;\">\r\n                                    {{rowDis[hdr]}}\r\n                                </td>\r\n\r\n                            </tr>\r\n\r\n                        </table>\r\n                    </div>\r\n                    <div class=\"row\">\r\n                        <div class=\"col-md-offset-11 col-md-1\">\r\n                                <button type=\"button\" *ngIf=\"fileLogIdn==0 && filenme=='generic'\" class=\"btn btn-success pull-right\"\r\n                                style=\"margin: 5px\" (click)=\"SkipVerification()\">Skip</button>\r\n                                &nbsp; &nbsp;\r\n                            <button type=\"button\" *ngIf=\"fileLogIdn==0\" class=\"btn btn-success pull-right\"\r\n                                style=\"margin: 5px\" (click)=\"ValidateFileHeaderMapping('Y')\">Verify</button>\r\n\r\n                       \r\n\r\n                        </div>\r\n                    </div>\r\n\r\n                </div>\r\n                <div class=\"row upload \" *ngIf=\"step==3\">\r\n                    <div class=\"row table-responsive col-md-12\">\r\n                        <table cellspacing=\"10\" class=\"displayTable fileuploadview\">\r\n                            <ng-container *ngFor=\"let hdr of charHeaderList ;let j=index;\">\r\n\r\n                                <tr>\r\n                                    <th style=\"color:white;border: 1px solid white\">\r\n                                        {{hdr}}({{headerAttributeDtl[hdr].attr}})</th>\r\n                                    <td [ngClass]=\"{'even':j%2==0,'odd':j%2==1}\">\r\n                                        <div class=\"row\" style=\"display: flex;\">\r\n                                            <ng-container\r\n                                                *ngFor=\"let attrVal of rowdistinctDataMap[headerAttributeDtl[hdr].attr];\">\r\n                                                <div style=\"width:160px;margin-right: 1px\"\r\n                                                    [ngClass]=\"{'matchedUl':rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val !=''}\">\r\n                                                    <ul style=\"list-style: none;text-align:left\">\r\n                                                        <li> {{attrVal}} </li>\r\n                                                        <li>\r\n                                                            <select\r\n                                                                *ngIf=\"rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val==''\"\r\n                                                                class=\"select-control\"\r\n                                                                name=\"{{rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val}}\"\r\n                                                                [(ngModel)]=\"rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val\"\r\n                                                                (change)=\"confirmHeaderDetailsMapp(headerAttributeDtl[hdr].attr,headerAttributeDtl[hdr].attr_idn,attrVal)\">\r\n                                                                <option value=\"\">--select--</option>\r\n                                                                <option\r\n                                                                    *ngFor=\"let attrdtlmap of attributeDtlMap[headerAttributeDtl[hdr].attr]\"\r\n                                                                    value=\"{{attrdtlmap?.val}}\">{{attrdtlmap?.val}}\r\n                                                                </option>\r\n                                                            </select>\r\n\r\n                                                            <span\r\n                                                                *ngIf=\"rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val!=''\">\r\n                                                                {{rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val}} \r\n                                                                    &nbsp;&nbsp; <i (click)=\"removeDetailAttrOptVal(headerAttributeDtl[hdr].attr_idn,attrVal,rowdatamapDetails[headerAttributeDtl[hdr].attr][attrVal].val,[headerAttributeDtl[hdr].attr])\" class=\"fa fa-times\" aria-hidden=\"true\" style=\"color: red;cursor: pointer;\"></i>\r\n                                                            </span>\r\n                                                        \r\n                                                        </li>\r\n                                                    </ul>\r\n                                                </div>\r\n                                            </ng-container>\r\n                                        </div>\r\n                                    </td>\r\n\r\n                                </tr>\r\n                            </ng-container>\r\n                        </table>\r\n                    </div>\r\n                    <div class=\"row\">\r\n                        <div class=\"col-md-offset-11 col-md-1\">\r\n                                <button type=\"button\" *ngIf=\"fileLogIdn==0 && filenme=='generic'\" class=\"btn btn-success pull-right\"\r\n                                style=\"margin: 5px\" (click)=\"SkipVerificationDtl()\">Skip</button>\r\n                                &nbsp; &nbsp;\r\n                            <button type=\"button\" class=\"btn btn-success pull-right\" style=\"margin: 5px\"\r\n                                (click)=\"uploadFile()\" [disabled]=\"gmatchedCount!=gresultCount\">Upload</button>\r\n                                \r\n                               \r\n\r\n                        </div>\r\n\r\n                    </div>\r\n\r\n                </div>\r\n\r\n                <div class=\"row upload\" *ngIf=\"step==4\">\r\n\r\n                    <div class=\"row\">\r\n\r\n                    </div>\r\n\r\n                    <div class=\"row\">\r\n\r\n                        <p *ngIf=\"step==4\" style=\"margin-left: 15px;color:green;font-size: 20px;text-align: left\">\r\n                            {{lableFile}}\r\n                            <span style=\"font-size: 14px;\" *ngIf=\"lastRefreshTimeFile != null\">Last\r\n                                refresh time :\r\n                                ({{lastRefreshTimeFile | date:'medium'}})</span>\r\n                        </p>\r\n\r\n                        <div class=\"progress\" style=\"margin: 15px;\">\r\n                            <div class=\"progress-bar progress-bar-warning\" role=\"progressbar\" aria-valuenow=\"60\"\r\n                                aria-valuemin=\"0\" aria-valuemax=\"100\" [ngStyle]=\"{'width':totProgressFile+'%'}  \">\r\n                                {{totProgressFile}} %\r\n                            </div>\r\n                        </div>\r\n\r\n                        <p *ngIf=\"step==4 && clicked\" style=\"margin-top: 35px;\"><strong> Complete :{{sttsFile['C']}}\r\n                                &nbsp;&nbsp;&nbsp; Pending : {{sttsFile['P']}} &nbsp;&nbsp;&nbsp; Error :\r\n                                {{sttsFile['E']}}&nbsp;&nbsp;&nbsp; Invaild Status :\r\n                                {{sttsFile['I']}}\r\n                                &nbsp;&nbsp;&nbsp; Total : {{sttsFile['T']}}</strong></p>\r\n\r\n\r\n                        <p *ngIf=\"step==4\"\r\n                            style=\"margin-left: 15px;color:green;font-size: 20px;margin-top: 15px;text-align: left\">\r\n                            {{lable}}\r\n                            <span style=\"font-size: 12px;margin-left: 20px;color: black;\"\r\n                                *ngIf=\"lastRefreshTime != null\">Last\r\n                                refresh time :\r\n                                ({{lastRefreshTime | date:'medium'}})</span>\r\n                        </p>\r\n\r\n                        <div class=\"progress\" style=\"margin: 15px;\">\r\n                            <div class=\"progress-bar progress-bar-warning\" role=\"progressbar\" aria-valuenow=\"60\"\r\n                                aria-valuemin=\"0\" aria-valuemax=\"100\" [ngStyle]=\"{'width':totProgress+'%'}  \">\r\n                                {{totProgress}} %\r\n                            </div>\r\n                        </div>\r\n\r\n                        <!-- <button type=\"button\" class=\"btn btn-success text-center\" style=\"margin: 5px\"\r\n                            (click)=\"checkUploadStt()\">Check\r\n                            Status</button> -->\r\n\r\n                        <p *ngIf=\"step==4 && clicked\" style=\"margin-top: 35px;\"><strong> Complete :{{stts['C']}}\r\n                                &nbsp;&nbsp;&nbsp; Pending : {{stts['P']}} &nbsp;&nbsp;&nbsp; Error : {{stts['E']}}\r\n                                &nbsp;&nbsp;&nbsp; Total : {{stts['T']}}</strong></p>\r\n\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n\r\n    </div>\r\n</div>\r\n\r\n\r\n\r\n\r\n<div class=\"modal\" id=\"fileUploadModal\" tabindex=\"-1\" style=\"z-index: 999999\" role=\"dialog\"\r\n    aria-labelledby=\"smallModalHead\" aria-hidden=\"true\" data-backdrop=\"static\" data-keyboard=\"true\">\r\n    <div class=\"modal-dialog \">\r\n        <div class=\"modal-content\">\r\n            <div class=\"modal-header\">\r\n                <button type=\"button\" class=\"close\" data-dismiss=\"modal\" #fileUploadclsbtn>\r\n                    <span aria-hidden=\"true\">&times;</span>\r\n                    <span class=\"sr-only\">Close</span>\r\n                </button>\r\n                <h4 class=\"modal-title\" id=\"smallModalHead\">Add file upload option</h4>\r\n            </div>\r\n            <div class=\"modal-body\">\r\n                <div class=\"row\">\r\n\r\n                    <div class=\"col-md-12\">\r\n                        <form class=\"form-horizontal\" role=\"form\" #f=\"ngForm\" (ngSubmit)=\"onSubmit(f)\" name=\"appForm\">\r\n                            <div class=\"form-group\">\r\n                                <div class=\"col-md-12\">\r\n                                    <label class=\"col-md-3 control-label\">Name\r\n                                    </label>\r\n                                    <div class=\"col-md-5\">\r\n                                        <div class=\"input-group w-100\">\r\n                                            <input type=\"text\" class=\"form-control\" [(ngModel)]=\"nme\" name=\"nme\" />\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n\r\n                            <div class=\"form-group\">\r\n                                <div class=\"col-md-12\">\r\n                                    <label class=\"col-md-3 control-label\">Description\r\n                                    </label>\r\n                                    <div class=\"col-md-5\">\r\n                                        <div class=\"input-group w-100\">\r\n                                            <input type=\"text\" class=\"form-control\" [(ngModel)]=\"description\"\r\n                                                name=\"description\" />\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n\r\n                            <div class=\"form-group\">\r\n                                <div class=\"col-md-12\">\r\n                                    <label class=\"col-md-3 control-label\">Type\r\n                                    </label>\r\n                                    <div class=\"col-md-5\">\r\n                                        <div class=\"input-group w-100\">\r\n                                            <select class=\"form-control\" name=\"typ\" [(ngModel)]=\"typ\">\r\n                                                <option value=\"\">--select--</option>\r\n                                                <option *ngFor=\"let file of fileTypeList\" value=\"{{file?.k}}\">\r\n                                                    {{file?.v}}\r\n                                                </option>\r\n                                            </select>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n\r\n\r\n                            <div class=\"form-group\">\r\n                                <div class=\"col-md-12\">\r\n                                    <label class=\"col-md-3 control-label\">Check status\r\n                                    </label>\r\n                                    <div class=\"col-md-5\">\r\n                                        <div class=\"input-group w-100\">\r\n                                            <ng-select placeholder=\"Select Status\" [options]=\"statusList\"\r\n                                                [(ngModel)]=\"check_status\" name=\"check_status\" [multiple]=\"true\"\r\n                                                [allowClear]=\"true\">\r\n                                                <ng-template #optionTemplate let-option=\"option\">\r\n                                                    <div class=\"famfamfam-flags {{option?.value}}\"></div>\r\n                                                    {{option?.label}}\r\n                                                </ng-template>\r\n                                            </ng-select>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n\r\n                            <div class=\"form-group\">\r\n                                <div class=\"col-md-12\">\r\n                                    <label class=\"col-md-3 control-label\">Packet status\r\n                                    </label>\r\n                                    <div class=\"col-md-5\">\r\n                                        <div class=\"input-group w-100\">\r\n                                            <ng-select placeholder=\"Select Status\" [options]=\"statusList\"\r\n                                                [(ngModel)]=\"pkt_status\" name=\"pkt_status\" [allowClear]=\"true\">\r\n                                                <ng-template #optionTemplate let-option=\"option\">\r\n                                                    <div class=\"famfamfam-flags {{option?.value}}\"></div>\r\n                                                    {{option?.label}}\r\n                                                </ng-template>\r\n                                            </ng-select>\r\n                                        </div>\r\n                                    </div>\r\n                                </div>\r\n                            </div>\r\n\r\n                        </form>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n            <div class=\"modal-footer\">\r\n                <button type=\"button\" class=\"btn btn-default\" data-dismiss=\"modal\" #fileUploadclsbtn>Close</button>\r\n                <button type=\"button\" class=\"btn btn-success\" data-dismiss=\"modal\" appAppNoDblClick\r\n                    (click)=\"onSubmit(f)\">Save</button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<div class=\"modal\" id=\"Cofirmmaphdr\"  role=\"dialog\" aria-labelledby=\"smallModalHead\" aria-hidden=\"true\" data-backdrop=\"static\"\r\n  data-keyboard=\"false\">\r\n  <div class=\"modal-dialog\">\r\n    <div class=\"modal-content\">\r\n      <div class=\"modal-header\">\r\n        <button type=\"button\" (click)=\"CancelHeaderMapp()\" class=\"close\"  data-dismiss=\"modal\">\r\n          <span aria-hidden=\"true\">&times;</span>\r\n          <span class=\"sr-only\" >Close</span>\r\n        </button>\r\n        <h4 class=\"modal-title\" id=\"smallModalHead\">Alert</h4>\r\n      </div>\r\n      <div class=\"modal-body\">\r\n         <div class=\"row\">\r\n            Are you sure For Mapping <b>{{maphdr}}</b> To Attribute <b>{{hdrmassage}}</b> \r\n          </div>\r\n        </div>\r\n        <div class=\"modal-footer\">\r\n                <button type=\"button\" class=\"btn btn-default\" (click)=\"CancelHeaderMapp()\"   data-dismiss=\"modal\" >Close</button>\r\n                <button type=\"button\" class=\"btn btn-success\" data-dismiss=\"modal\" (click)=\"setHeaderMapp();\">Confirm</button>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"modal\" id=\"Cofirmmapdtl\"  role=\"dialog\" aria-labelledby=\"smallModalHead\" aria-hidden=\"true\" data-backdrop=\"static\"\r\n  data-keyboard=\"false\">\r\n  <div class=\"modal-dialog\">\r\n    <div class=\"modal-content\">\r\n      <div class=\"modal-header\">\r\n        <button type=\"button\" (click)=\"CancelHeaderMapp()\" class=\"close\" data-dismiss=\"modal\" >\r\n          <span aria-hidden=\"true\">&times;</span>\r\n          <span class=\"sr-only\" >Close</span>\r\n        </button>\r\n        <h4 class=\"modal-title\" id=\"smallModalHead\">Alert</h4>\r\n      </div>\r\n      <div class=\"modal-body\">\r\n         <div class=\"row\">\r\n            Are you sure For Mapping <b>{{dtloptionval}}</b> To Attribute  <b> {{dtlAttr}} </b> with AttributeDetail <b>{{dtlmassage}}</b> \r\n          </div>\r\n        </div>\r\n        <div class=\"modal-footer\">\r\n                <button type=\"button\" class=\"btn btn-default\" data-dismiss=\"modal\" (click)=\"CancelHeaderDetailsMapp()\">Close</button>\r\n                <button type=\"button\" class=\"btn btn-success\" data-dismiss=\"modal\" (click)=\"setHeaderDetailsMapp()\">Confirm</button>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n\r\n<button id=\"btnfileUploadModal\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#fileUploadModal\"></button>\r\n\r\n<button id=\"btnCofirmmaphdr\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#Cofirmmaphdr\"></button>\r\n<button id=\"btnCofirmmapdtl\" [hidden]=\"true\" data-toggle=\"modal\" data-target=\"#Cofirmmapdtl\"></button>\r\n\r\n\r\n\r\n<!-- <div class=\"centered\">\r\n    <div id=\"divSpinner\" class=\"spinner loading\">\r\n      <div class=\"loading-text\">Loading ...</div>\r\n    </div>\r\n\r\n    <button (click)=\"test()\" id=\"btnLoadRecords\" style=\"cursor:pointer;position: absolute; top: 52%; left: 45%;\">Load Records</button>\r\n  </div> -->"]}
|