Resolve sales tax code issue on payables IO-738

Payables bug fixes for class & bill number IO-742
Resolve 2 tier by source exporting IO-740
Payments table null check.
This commit is contained in:
Patrick Fic
2021-03-05 01:17:26 +00:00
6 changed files with 85 additions and 36 deletions

View File

@@ -66,12 +66,12 @@ export default function AccountingPayablesTableComponent({
return record.job.owner ? ( return record.job.owner ? (
<Link to={"/manage/owners/" + record.job.owner.id}> <Link to={"/manage/owners/" + record.job.owner.id}>
{`${record.job.ownr_fn || ""} ${record.job.ownr_ln || ""} ${ {`${record.job.ownr_fn || ""} ${record.job.ownr_ln || ""} ${
record.job.ownr_co_nm record.job.ownr_co_nm || ""
}`} }`}
</Link> </Link>
) : ( ) : (
<span>{`${record.job.ownr_fn || ""} ${record.job.ownr_ln || ""} ${ <span>{`${record.job.ownr_fn || ""} ${record.job.ownr_ln || ""} ${
record.job.ownr_co_nm record.job.ownr_co_nm || ""
}`}</span> }`}</span>
); );
}, },

View File

@@ -63,12 +63,16 @@ const generateBill = (bill) => {
TxnDate: moment(bill.date).format("YYYY-MM-DD"), TxnDate: moment(bill.date).format("YYYY-MM-DD"),
DueDate: DueDate:
bill.due_date && moment(bill.due_date).format("YYYY-MM-DD"), bill.due_date && moment(bill.due_date).format("YYYY-MM-DD"),
RefNumber: bill.bill_number, RefNumber: bill.invoice_number,
Memo: `RO ${bill.job.ro_number || ""} OWNER ${ Memo: `RO ${bill.job.ro_number || ""} OWNER ${
bill.job.ownr_fn || "" bill.job.ownr_fn || ""
} ${bill.job.ownr_ln || ""} ${bill.job.ownr_co_nm || ""}`, } ${bill.job.ownr_ln || ""} ${bill.job.ownr_co_nm || ""}`,
ExpenseLineAdd: bill.billlines.map((il) => ExpenseLineAdd: bill.billlines.map((il) =>
generateBillLine(il, bill.job.bodyshop.md_responsibility_centers) generateBillLine(
il,
bill.job.bodyshop.md_responsibility_centers,
bill.job.class
)
), ),
}, },
}, },
@@ -90,11 +94,7 @@ const generateBill = (bill) => {
return billQbxml_Full; return billQbxml_Full;
}; };
const generateBillLine = (billLine, responsibilityCenters) => { const generateBillLine = (billLine, responsibilityCenters, jobClass) => {
console.log(
" findTaxCode(billLine, responsibilityCenters.sales_tax_codes)",
findTaxCode(billLine, responsibilityCenters.sales_tax_codes)
);
return { return {
AccountRef: { AccountRef: {
FullName: responsibilityCenters.costs.find( FullName: responsibilityCenters.costs.find(
@@ -104,6 +104,7 @@ const generateBillLine = (billLine, responsibilityCenters) => {
Amount: Dinero({ Amount: Dinero({
amount: Math.round(billLine.actual_cost * 100), amount: Math.round(billLine.actual_cost * 100),
}).toFormat(DineroQbFormat), }).toFormat(DineroQbFormat),
...(jobClass ? { ClassRef: { FullName: jobClass } } : {}),
SalesTaxCodeRef: { SalesTaxCodeRef: {
FullName: findTaxCode(billLine, responsibilityCenters.sales_tax_codes), FullName: findTaxCode(billLine, responsibilityCenters.sales_tax_codes),
}, },
@@ -122,7 +123,10 @@ const findTaxCode = (billLine, taxcode) => {
applicable_taxes: { local, state, federal }, applicable_taxes: { local, state, federal },
} = billLine; } = billLine;
const t = taxcode.filter( const t = taxcode.filter(
(t) => t.local === local && t.state === state && t.federal === federal (t) =>
!!t.local === !!local &&
!!t.state === !!state &&
!!t.federal === !!federal
); );
if (t.length === 1) { if (t.length === 1) {
console.log(t); console.log(t);

View File

@@ -74,7 +74,7 @@ exports.default = async (req, res) => {
QbXmlToExecute.push({ QbXmlToExecute.push({
id: i.id, id: i.id,
okStatusCodes: ["0"], okStatusCodes: ["0"],
qbxml: generatePayment(i), qbxml: generatePayment(i, isThreeTier, twoTierPref),
}); });
}); });
@@ -85,7 +85,7 @@ exports.default = async (req, res) => {
} }
}; };
const generatePayment = (payment) => { const generatePayment = (payment, isThreeTier, twoTierPref) => {
console.log("generatePayment -> payment", payment); console.log("generatePayment -> payment", payment);
let paymentQbxmlObj; let paymentQbxmlObj;
if (payment.amount > 0) { if (payment.amount > 0) {
@@ -99,11 +99,15 @@ const generatePayment = (payment) => {
FullName: FullName:
payment.job.bodyshop.accountingconfig.tiers === 3 payment.job.bodyshop.accountingconfig.tiers === 3
? `${generateSourceTier(payment.job)}:${generateOwnerTier( ? `${generateSourceTier(payment.job)}:${generateOwnerTier(
payment.job payment.job,
isThreeTier,
twoTierPref
)}:${generateJobTier(payment.job)}` )}:${generateJobTier(payment.job)}`
: `${generateOwnerTier(payment.job)}:${generateJobTier( : `${generateOwnerTier(
payment.job payment.job,
)}`, isThreeTier,
twoTierPref
)}:${generateJobTier(payment.job)}`,
}, },
ARAccountRef: { ARAccountRef: {
FullName: FullName:
@@ -142,11 +146,15 @@ const generatePayment = (payment) => {
FullName: FullName:
payment.job.bodyshop.accountingconfig.tiers === 3 payment.job.bodyshop.accountingconfig.tiers === 3
? `${generateSourceTier(payment.job)}:${generateOwnerTier( ? `${generateSourceTier(payment.job)}:${generateOwnerTier(
payment.job payment.job,
isThreeTier,
twoTierPref
)}:${generateJobTier(payment.job)}` )}:${generateJobTier(payment.job)}`
: `${generateOwnerTier(payment.job)}:${generateJobTier( : `${generateOwnerTier(
payment.job payment.job,
)}`, isThreeTier,
twoTierPref
)}:${generateJobTier(payment.job)}`,
}, },
ARAccountRef: { ARAccountRef: {
FullName: FullName:

View File

@@ -39,6 +39,7 @@ exports.default = async (req, res) => {
const isThreeTier = bodyshop.accountingconfig.tiers === 3; const isThreeTier = bodyshop.accountingconfig.tiers === 3;
const twoTierPref = bodyshop.accountingconfig.twotierpref; const twoTierPref = bodyshop.accountingconfig.twotierpref;
//This is the Insurance Company tier IF 3 tier is selected.
if (isThreeTier) { if (isThreeTier) {
QbXmlToExecute.push({ QbXmlToExecute.push({
id: jobs_by_pk.id, id: jobs_by_pk.id,
@@ -47,6 +48,8 @@ exports.default = async (req, res) => {
}); });
} }
//If 3 tier, this should be the customer.
//If 2 tier, this should be based on the pref.
QbXmlToExecute.push({ QbXmlToExecute.push({
id: jobs_by_pk.id, id: jobs_by_pk.id,
okStatusCodes: ["0", "3100"], okStatusCodes: ["0", "3100"],
@@ -59,6 +62,7 @@ exports.default = async (req, res) => {
), ),
}); });
//This is always going to be the job.
QbXmlToExecute.push({ QbXmlToExecute.push({
id: jobs_by_pk.id, id: jobs_by_pk.id,
okStatusCodes: ["0", "3100"], okStatusCodes: ["0", "3100"],
@@ -74,7 +78,12 @@ exports.default = async (req, res) => {
QbXmlToExecute.push({ QbXmlToExecute.push({
id: jobs_by_pk.id, id: jobs_by_pk.id,
okStatusCodes: ["0"], okStatusCodes: ["0"],
qbxml: generateInvoiceQbxml(jobs_by_pk, bodyshop), qbxml: generateInvoiceQbxml(
jobs_by_pk,
bodyshop,
isThreeTier,
twoTierPref
),
}); });
}); });
@@ -130,19 +139,20 @@ const generateJobQbxml = (
let ParentRefName; let ParentRefName;
if (tierLevel === 2) { if (tierLevel === 2) {
Name = generateOwnerTier(jobs_by_pk); Name = generateOwnerTier(jobs_by_pk, isThreeTier, twoTierPref);
ParentRefName = isThreeTier ? generateSourceTier(jobs_by_pk) : null; ParentRefName = isThreeTier ? generateSourceTier(jobs_by_pk) : null;
} else if (tierLevel === 3) { } else if (tierLevel === 3) {
Name = generateJobTier(jobs_by_pk); Name = generateJobTier(jobs_by_pk);
ParentRefName = isThreeTier ParentRefName = isThreeTier
? `${jobs_by_pk.ins_co_nm}:${generateOwnerTier(jobs_by_pk)}` ? `${generateSourceTier(jobs_by_pk)}:${generateOwnerTier(jobs_by_pk)}`
: generateOwnerTier(jobs_by_pk); : generateOwnerTier(jobs_by_pk, isThreeTier, twoTierPref);
} }
const jobQbxmlObj = { const jobQbxmlObj = {
QBXML: { QBXML: {
QBXMLMsgsRq: { QBXMLMsgsRq: {
"@onError": "continueOnError", "@onError": "continueOnError",
CustomerAddRq: { CustomerAddRq: {
CustomerAdd: { CustomerAdd: {
Name: Name, Name: Name,
@@ -170,7 +180,12 @@ const generateJobQbxml = (
return jobQbxml_Full; return jobQbxml_Full;
}; };
exports.generateJobQbxml = generateJobQbxml; exports.generateJobQbxml = generateJobQbxml;
const generateInvoiceQbxml = (jobs_by_pk, bodyshop) => { const generateInvoiceQbxml = (
jobs_by_pk,
bodyshop,
isThreeTier,
twoTierPref
) => {
//Build the Invoice XML file. //Build the Invoice XML file.
const InvoiceLineAdd = []; const InvoiceLineAdd = [];
const responsibilityCenters = bodyshop.md_responsibility_centers; const responsibilityCenters = bodyshop.md_responsibility_centers;
@@ -302,9 +317,11 @@ const generateInvoiceQbxml = (jobs_by_pk, bodyshop) => {
? `${generateSourceTier(jobs_by_pk)}:${generateOwnerTier( ? `${generateSourceTier(jobs_by_pk)}:${generateOwnerTier(
jobs_by_pk jobs_by_pk
)}:${generateJobTier(jobs_by_pk)}` )}:${generateJobTier(jobs_by_pk)}`
: `${generateOwnerTier(jobs_by_pk)}:${generateJobTier( : `${generateOwnerTier(
jobs_by_pk jobs_by_pk,
)}`, isThreeTier,
twoTierPref
)}:${generateJobTier(jobs_by_pk)}`,
}, },
...(jobs_by_pk.class ...(jobs_by_pk.class

View File

@@ -13,12 +13,30 @@ exports.generateJobTier = (jobs_by_pk) => {
return jobs_by_pk.ro_number; return jobs_by_pk.ro_number;
}; };
exports.generateOwnerTier = (jobs_by_pk) => { exports.generateOwnerTier = (jobs_by_pk, isThreeTier, twotierpref) => {
return jobs_by_pk.ownr_co_nm if (isThreeTier) {
? `${jobs_by_pk.ownr_co_nm} - ${jobs_by_pk.ownr_ln || ""} ${ //It's always gonna be the owner now. Same as 2 tier by name
jobs_by_pk.ownr_fn || "" return jobs_by_pk.ownr_co_nm
} #${jobs_by_pk.owner.accountingid || ""}` ? `${jobs_by_pk.ownr_co_nm} - ${jobs_by_pk.ownr_ln || ""} ${
: `${jobs_by_pk.ownr_ln || ""} ${jobs_by_pk.ownr_fn || ""} #${ jobs_by_pk.ownr_fn || ""
jobs_by_pk.owner.accountingid || "" } #${jobs_by_pk.owner.accountingid || ""}`
}`; : `${jobs_by_pk.ownr_ln || ""} ${jobs_by_pk.ownr_fn || ""} #${
jobs_by_pk.owner.accountingid || ""
}`;
} else {
//What's the 2 tier pref?
if (twotierpref === "source") {
return this.generateSourceTier(jobs_by_pk);
//It should be the insurance co.
} else {
//Same as 3 tier
return jobs_by_pk.ownr_co_nm
? `${jobs_by_pk.ownr_co_nm} - ${jobs_by_pk.ownr_ln || ""} ${
jobs_by_pk.ownr_fn || ""
} #${jobs_by_pk.owner.accountingid || ""}`
: `${jobs_by_pk.ownr_ln || ""} ${jobs_by_pk.ownr_fn || ""} #${
jobs_by_pk.owner.accountingid || ""
}`;
}
}
}; };

View File

@@ -118,6 +118,7 @@ query QUERY_BILLS_FOR_PAYABLES_EXPORT($bills: [uuid!]!) {
federal_tax_rate federal_tax_rate
invoice_number invoice_number
is_credit_memo is_credit_memo
invoice_number
job { job {
id id
ro_number ro_number
@@ -125,6 +126,7 @@ query QUERY_BILLS_FOR_PAYABLES_EXPORT($bills: [uuid!]!) {
ownr_fn ownr_fn
ownr_ln ownr_ln
ownr_co_nm ownr_co_nm
class
bodyshop{ bodyshop{
md_responsibility_centers md_responsibility_centers
} }