Begin Audit Functionality testing.
This commit is contained in:
51
electron/audit/audit-ipc.js
Normal file
51
electron/audit/audit-ipc.js
Normal file
@@ -0,0 +1,51 @@
|
||||
const { ipcMain, dialog } = require("electron");
|
||||
|
||||
const ipcTypes = require("../../src/ipc.types.commonjs");
|
||||
const { mainWindow } = require("../main");
|
||||
const _ = require("lodash");
|
||||
const { store } = require("../electron-store");
|
||||
const path = require("path");
|
||||
var xlsx = require("node-xlsx");
|
||||
|
||||
ipcMain.on(ipcTypes.default.audit.toMain.browseForFile, async (event, arg) => {
|
||||
const result = await dialog.showOpenDialog(mainWindow, {
|
||||
filters: [{ extensions: ["xls", "xlsx"], name: "Excel Files" }],
|
||||
properties: ["openFile"]
|
||||
});
|
||||
if (!result.canceled) {
|
||||
store.set("auditFilePath", result.filePaths);
|
||||
var obj = xlsx.parse(result.filePaths[0], { cellDates: true }); // parses a file
|
||||
|
||||
const detailSheet = obj.find((sheet) => sheet.name === "Shop RPS Claim Detail");
|
||||
const claimsArray = [];
|
||||
let foundHeaderRow, foundTotalRow;
|
||||
detailSheet.data.forEach((line) => {
|
||||
//Check the first element. If it's claim number, we have our header row. the next one is important.
|
||||
if (!foundHeaderRow && line[0] === "Claim Number") {
|
||||
foundHeaderRow = true;
|
||||
} else if (foundHeaderRow && !foundTotalRow && line[0] && line[0] !== "Grand Total") {
|
||||
//Add it to the array
|
||||
const row = {
|
||||
clm_no: line[0],
|
||||
close_date: line[1],
|
||||
v_model_yr: line[3],
|
||||
v_model_desc: line[4],
|
||||
under20kmiles: line[5],
|
||||
pan_total: line[6],
|
||||
paa_total: line[7],
|
||||
pal_total: line[8],
|
||||
pam_total: line[9],
|
||||
eligible_db_price_total: Math.round((line[10] + Number.EPSILON) * 100) / 100,
|
||||
eligible_act_price_total: Math.round((line[11] + Number.EPSILON) * 100) / 100,
|
||||
expected_rps_dollars: Math.round((line[15] + Number.EPSILON) * 100) / 100,
|
||||
actual_rps_dollars: Math.round((line[16] + Number.EPSILON) * 100) / 100
|
||||
};
|
||||
claimsArray.push(row);
|
||||
} else {
|
||||
// foundTotalRow = true;
|
||||
}
|
||||
});
|
||||
|
||||
event.sender.send(ipcTypes.default.audit.toRenderer.auditClaimsArray, claimsArray);
|
||||
}
|
||||
});
|
||||
@@ -8,6 +8,7 @@ const { ImportJobWithCloseDate } = require("./decoder/decoder");
|
||||
//Import Ipc Handlers
|
||||
require("./file-watcher/file-watcher-ipc");
|
||||
require("./file-scan/file-scan-ipc");
|
||||
require("./audit/audit-ipc");
|
||||
|
||||
console.log("*** Added IPC Handlers ***");
|
||||
|
||||
|
||||
Reference in New Issue
Block a user