import * as gp from '@cityssm/dynamics-gp/gp.js'; import * as diamond from '@cityssm/dynamics-gp/diamond.js'; import * as configFunctions from './functions.config.js'; if (configFunctions.getProperty('settings.dynamicsGP.integrationIsEnabled')) { gp.setMSSQLConfig(configFunctions.getProperty('settings.dynamicsGP.mssqlConfig')); diamond.setMSSQLConfig(configFunctions.getProperty('settings.dynamicsGP.mssqlConfig')); } function filterCashReceipt(cashReceipt) { const accountCodes = configFunctions.getProperty('settings.dynamicsGP.accountCodes'); for (const accountCode of accountCodes) { let found = cashReceipt.details.some((detailRecord) => { return detailRecord.accountCode === accountCode; }); if (!found) { found = cashReceipt.distributions.some((distributionRecord) => { return distributionRecord.accountCode === accountCode; }); } if (!found) { return undefined; } } return cashReceipt; } function filterInvoice(invoice) { const itemNumbers = configFunctions.getProperty('settings.dynamicsGP.itemNumbers'); for (const itemNumber of itemNumbers) { const found = invoice.lineItems.some((itemRecord) => { return itemRecord.itemNumber === itemNumber; }); if (!found) { return undefined; } } return invoice; } function filterExtendedInvoice(invoice) { if (filterInvoice(invoice) === undefined) { return undefined; } const trialBalanceCodes = configFunctions.getProperty('settings.dynamicsGP.trialBalanceCodes'); if (trialBalanceCodes.length > 0 && trialBalanceCodes.includes(invoice.trialBalanceCode ?? '')) { return invoice; } return undefined; } async function _getDynamicsGPDocument(documentNumber, lookupType) { let document; switch (lookupType) { case 'invoice': { let invoice = await gp.getInvoiceByInvoiceNumber(documentNumber); if (invoice !== undefined) { invoice = filterInvoice(invoice); } if (invoice !== undefined) { document = { documentType: 'Invoice', documentNumber: invoice.invoiceNumber, documentDate: invoice.documentDate, documentDescription: [ invoice.comment1, invoice.comment2, invoice.comment3, invoice.comment4 ], documentTotal: invoice.documentAmount }; } break; } case 'diamond/cashReceipt': { let receipt = await diamond.getCashReceiptByDocumentNumber(documentNumber); if (receipt !== undefined) { receipt = filterCashReceipt(receipt); } if (receipt !== undefined) { document = { documentType: 'Cash Receipt', documentNumber: receipt.documentNumber.toString(), documentDate: receipt.documentDate, documentDescription: [ receipt.description, receipt.description2, receipt.description3, receipt.description4, receipt.description5 ], documentTotal: receipt.total }; } break; } case 'diamond/extendedInvoice': { let invoice = await diamond.getDiamondExtendedGPInvoice(documentNumber); if (invoice !== undefined) { invoice = filterExtendedInvoice(invoice); } if (invoice !== undefined) { document = { documentType: 'Invoice', documentNumber: invoice.invoiceNumber, documentDate: invoice.documentDate, documentDescription: [ invoice.comment1, invoice.comment2, invoice.comment3, invoice.comment4 ], documentTotal: invoice.documentAmount }; } break; } } return document; } export async function getDynamicsGPDocument(documentNumber) { if (!configFunctions.getProperty('settings.dynamicsGP.integrationIsEnabled')) { return; } let document; for (const lookupType of configFunctions.getProperty('settings.dynamicsGP.lookupOrder')) { document = await _getDynamicsGPDocument(documentNumber, lookupType); if (document !== undefined) { break; } } return document; }