60 lines
1.9 KiB
JavaScript
60 lines
1.9 KiB
JavaScript
const Dinero = require("dinero.js");
|
|
const queries = require("../graphql-client/queries");
|
|
const GraphQLClient = require("graphql-request").GraphQLClient;
|
|
const logger = require("../utils/logger");
|
|
// Dinero.defaultCurrency = "USD";
|
|
// Dinero.globalLocale = "en-CA";
|
|
Dinero.globalRoundingMode = "HALF_EVEN";
|
|
|
|
exports.calculateLaborTotals = async function (req, res) {
|
|
const BearerToken = req.headers.authorization;
|
|
const { jobid } = req.body;
|
|
logger.log("job-payroll-labor-totals", "DEBUG", req.user.email, jobid, null);
|
|
const client = new GraphQLClient(process.env.GRAPHQL_ENDPOINT, {
|
|
headers: {
|
|
Authorization: BearerToken,
|
|
},
|
|
});
|
|
|
|
try {
|
|
const { jobs_by_pk: job } = await client
|
|
.setHeaders({ Authorization: BearerToken })
|
|
.request(queries.QUERY_JOB_PAYROLL_DATA, {
|
|
id: jobid,
|
|
});
|
|
|
|
//iterate over each ticket, building a hash of team -> employee to calculate total assigned hours.
|
|
|
|
const assignmentHash = { unassigned: 0 };
|
|
job.joblines.forEach((jobline) => {
|
|
if (jobline.mod_lb_hrs > 0) {
|
|
//Check if the line is assigned. If not, keep track of it as an unassigned line by type.
|
|
if (jobline.assigned_team === null) {
|
|
assignmentHash.unassigned[jobline.mod_lbr_ty] =
|
|
assignmentHash.unassigned[jobline.mod_lbr_ty] + jobline.mod_lb_hrs;
|
|
} else {
|
|
//Line is assigned.
|
|
if (!assignmentHash[jobline.assigned_team]) {
|
|
assignmentHash[jobline.assigned_team] = 0;
|
|
}
|
|
assignmentHash[jobline.assigned_team] =
|
|
assignmentHash[jobline.assigned_team] + jobline.mod_lb_hrs;
|
|
}
|
|
}
|
|
});
|
|
res.json(assignmentHash);
|
|
} catch (error) {
|
|
logger.log(
|
|
"job-payroll-labor-totals-error",
|
|
"ERROR",
|
|
req.user.email,
|
|
jobid,
|
|
{
|
|
jobid: jobid,
|
|
error,
|
|
}
|
|
);
|
|
res.status(503).send();
|
|
}
|
|
};
|