Merge release & add time ticket calculations.
This commit is contained in:
@@ -79,40 +79,78 @@ exports.default = async function (socket, jobid) {
|
||||
bill_val.billlines.map((line_val) => {
|
||||
if (!bill_acc[line_val.cost_center])
|
||||
bill_acc[line_val.cost_center] = Dinero();
|
||||
const lineDinero = Dinero({
|
||||
|
||||
let lineDinero = Dinero({
|
||||
amount: Math.round((line_val.actual_cost || 0) * 100),
|
||||
})
|
||||
.multiply(line_val.quantity)
|
||||
.multiply(bill_val.is_credit_memo ? -1 : 1);
|
||||
|
||||
bill_acc[line_val.cost_center] =
|
||||
bill_acc[line_val.cost_center].add(lineDinero);
|
||||
|
||||
//Add appropriate tax amounts.
|
||||
const {
|
||||
applicable_taxes: { local, state, federal },
|
||||
} = line_val;
|
||||
|
||||
if (local) {
|
||||
taxAllocations.local.cost = taxAllocations.local.cost.add(
|
||||
if (bodyshop.cdk_configuration.itc_local)
|
||||
taxAllocations.local.cost = taxAllocations.local.cost.add(
|
||||
lineDinero.percentage(bill_val.local_tax_rate || 0)
|
||||
);
|
||||
lineDinero = lineDinero.add(
|
||||
lineDinero.percentage(bill_val.local_tax_rate || 0)
|
||||
);
|
||||
}
|
||||
if (state) {
|
||||
taxAllocations.state.cost = taxAllocations.state.cost.add(
|
||||
if (bodyshop.cdk_configuration.itc_state)
|
||||
taxAllocations.state.cost = taxAllocations.state.cost.add(
|
||||
lineDinero.percentage(bill_val.state_tax_rate || 0)
|
||||
);
|
||||
lineDinero = lineDinero.add(
|
||||
lineDinero.percentage(bill_val.state_tax_rate || 0)
|
||||
);
|
||||
}
|
||||
if (federal) {
|
||||
taxAllocations.federal.cost = taxAllocations.federal.cost.add(
|
||||
//If it's an ITC, add it as a negative cost, otherwise add it to the item cost.
|
||||
if (bodyshop.cdk_configuration.itc_federal)
|
||||
taxAllocations.federal.cost = taxAllocations.federal.cost.add(
|
||||
lineDinero.percentage(bill_val.federal_tax_rate || 0)
|
||||
);
|
||||
|
||||
lineDinero = lineDinero.add(
|
||||
lineDinero.percentage(bill_val.federal_tax_rate || 0)
|
||||
);
|
||||
|
||||
// bill_acc[line_val.cost_center] = bill_acc[line_val.cost_center].add(
|
||||
// lineDinero.percentage(bill_val.federal_tax_rate || 0)
|
||||
// );
|
||||
}
|
||||
|
||||
bill_acc[line_val.cost_center] =
|
||||
bill_acc[line_val.cost_center].add(lineDinero);
|
||||
return null;
|
||||
});
|
||||
return bill_acc;
|
||||
}, {});
|
||||
|
||||
job.timetickets.forEach((ticket) => {
|
||||
//Get the total amount of the ticket.
|
||||
let TicketTotal = Dinero({
|
||||
amount: Math.round(
|
||||
ticket.rate *
|
||||
(ticket.employee && ticket.employee.flat_rate
|
||||
? ticket.productivehrs || 0
|
||||
: ticket.actualhrs || 0) *
|
||||
100
|
||||
),
|
||||
});
|
||||
//Add it to the right cost center.
|
||||
if (!costCenterHash[ticket.cost_center])
|
||||
costCenterHash[ticket.cost_center] = Dinero();
|
||||
|
||||
costCenterHash[ticket.cost_center] =
|
||||
costCenterHash[ticket.cost_center].add(TicketTotal);
|
||||
});
|
||||
|
||||
const jobAllocations = _.union(
|
||||
Object.keys(profitCenterHash),
|
||||
Object.keys(costCenterHash)
|
||||
|
||||
@@ -976,7 +976,7 @@ async function GenerateTransWips(socket) {
|
||||
const allocations = await CalcualteAllocations(socket, socket.JobData.id);
|
||||
const wips = [];
|
||||
allocations.forEach((alloc) => {
|
||||
//Add the sale item
|
||||
//Add the sale item from each allocation.
|
||||
if (alloc.sale.getAmount() > 0 && !alloc.tax) {
|
||||
const item = {
|
||||
acct: alloc.profitCenter.dms_acctnumber,
|
||||
@@ -993,6 +993,7 @@ async function GenerateTransWips(socket) {
|
||||
wips.push(item);
|
||||
}
|
||||
|
||||
//Add the cost Item.
|
||||
if (alloc.cost.getAmount() > 0 && !alloc.tax) {
|
||||
const item = {
|
||||
acct: alloc.costCenter.dms_acctnumber,
|
||||
@@ -1025,33 +1026,38 @@ async function GenerateTransWips(socket) {
|
||||
}
|
||||
|
||||
if (alloc.tax) {
|
||||
const item = {
|
||||
acct: alloc.costCenter.dms_acctnumber,
|
||||
cntl: socket.JobData.ro_number,
|
||||
cntl2: null,
|
||||
credtMemoNo: null,
|
||||
postAmt: alloc.cost.getAmount(),
|
||||
postDesc: null,
|
||||
prod: null,
|
||||
statCnt: 1,
|
||||
transID: socket.DMSTransHeader.transID,
|
||||
trgtCoID: socket.JobData.bodyshop.cdk_configuration.srcco,
|
||||
};
|
||||
// if (alloc.cost.getAmount() > 0) {
|
||||
// const item = {
|
||||
// acct: alloc.costCenter.dms_acctnumber,
|
||||
// cntl: socket.JobData.ro_number,
|
||||
// cntl2: null,
|
||||
// credtMemoNo: null,
|
||||
// postAmt: alloc.cost.getAmount(),
|
||||
// postDesc: null,
|
||||
// prod: null,
|
||||
// statCnt: 1,
|
||||
// transID: socket.DMSTransHeader.transID,
|
||||
// trgtCoID: socket.JobData.bodyshop.cdk_configuration.srcco,
|
||||
// };
|
||||
|
||||
wips.push(item);
|
||||
const item2 = {
|
||||
acct: alloc.profitCenter.dms_acctnumber,
|
||||
cntl: socket.JobData.ro_number,
|
||||
cntl2: null,
|
||||
credtMemoNo: null,
|
||||
postAmt: alloc.sale.multiply(-1).getAmount(),
|
||||
postDesc: null,
|
||||
prod: null,
|
||||
statCnt: 1,
|
||||
transID: socket.DMSTransHeader.transID,
|
||||
trgtCoID: socket.JobData.bodyshop.cdk_configuration.srcco,
|
||||
};
|
||||
wips.push(item2);
|
||||
// wips.push(item);
|
||||
// }
|
||||
|
||||
if (alloc.sale.getAmount() > 0) {
|
||||
const item2 = {
|
||||
acct: alloc.profitCenter.dms_acctnumber,
|
||||
cntl: socket.JobData.ro_number,
|
||||
cntl2: null,
|
||||
credtMemoNo: null,
|
||||
postAmt: alloc.sale.multiply(-1).getAmount(),
|
||||
postDesc: null,
|
||||
prod: null,
|
||||
statCnt: 1,
|
||||
transID: socket.DMSTransHeader.transID,
|
||||
trgtCoID: socket.JobData.bodyshop.cdk_configuration.srcco,
|
||||
};
|
||||
wips.push(item2);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
@@ -1076,7 +1082,11 @@ async function GenerateTransWips(socket) {
|
||||
|
||||
console.log(
|
||||
"WIPS TOTAL",
|
||||
wips.reduce((acc, val) => acc + val.postAmt, 0)
|
||||
wips.reduce((acc, val) => {
|
||||
console.log(val);
|
||||
console.log(acc + val.postAmt);
|
||||
return acc + val.postAmt;
|
||||
}, 0)
|
||||
);
|
||||
|
||||
return wips;
|
||||
|
||||
Reference in New Issue
Block a user