/* eslint-disable unicorn/filename-case */ 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' import type { DynamicsGPLookup } from '../types/configTypes' import type { DynamicsGPDocument } from '../types/recordTypes.js' import type { DiamondExtendedGPInvoice, DiamondCashReceipt } from '@cityssm/dynamics-gp/diamond/types' import type { GPInvoice } from '@cityssm/dynamics-gp/gp/types' if (configFunctions.getProperty('settings.dynamicsGP.integrationIsEnabled')) { gp.setMSSQLConfig( configFunctions.getProperty('settings.dynamicsGP.mssqlConfig') ) diamond.setMSSQLConfig( configFunctions.getProperty('settings.dynamicsGP.mssqlConfig') ) } function filterCashReceipt( cashReceipt: DiamondCashReceipt ): DiamondCashReceipt | undefined { const accountCodes = configFunctions.getProperty( 'settings.dynamicsGP.accountCodes' ) if (accountCodes.length > 0) { for (const detail of cashReceipt.details) { if (accountCodes.includes(detail.accountCode)) { return cashReceipt } } for (const distribution of cashReceipt.distributions) { if (accountCodes.includes(distribution.accountCode)) { return cashReceipt } } return undefined } return cashReceipt } function filterInvoice(invoice: GPInvoice): GPInvoice | undefined { 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: DiamondExtendedGPInvoice ): DiamondExtendedGPInvoice | undefined { 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: string, lookupType: DynamicsGPLookup ): Promise { let document: DynamicsGPDocument | undefined 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: DiamondCashReceipt | undefined = 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: string ): Promise { if ( !configFunctions.getProperty('settings.dynamicsGP.integrationIsEnabled') ) { return } let document: DynamicsGPDocument | undefined for (const lookupType of configFunctions.getProperty( 'settings.dynamicsGP.lookupOrder' )) { document = await _getDynamicsGPDocument(documentNumber, lookupType) if (document !== undefined) { break } } return document }