UNPKG

@cityssm/dynamics-gp

Version:

Read only inquiries into Microsoft Dynamics GP using a SQL Server connection.

144 lines (126 loc) 4.95 kB
import { type mssql, connect } from '@cityssm/mssql-multi-pool' import _getAccountByAccountIndex from '../gp/getAccountByAccountIndex.js' import type { DiamondCashReceipt } from './types.js' /** * Retrieves a cash receipt from the Diamond database by its document number. * @param mssqlConfig - The configuration for the SQL Server connection. * @param documentNumber - The document number of the cash receipt to retrieve. * @returns A promise that resolves to the cash receipt, or undefined if not found. */ export async function _getCashReceiptByDocumentNumber( mssqlConfig: mssql.config, documentNumber: number | string ): Promise<DiamondCashReceipt | undefined> { if ( typeof documentNumber === 'string' && Number.isNaN(Number.parseFloat(documentNumber)) ) { return undefined } const pool = await connect(mssqlConfig) const receiptResult = await pool .request() .input('documentNumber', documentNumber) .query<DiamondCashReceipt>(`SELECT top 1 0 as isHistorical, '' as transactionSource, [dDOCSUFFIX] as documentNumber, rtrim([BACHNUMB]) as batchNumber, rtrim([BCHSOURC]) as batchSource, rtrim([dINITIALS]) as initials, [dDATE] as documentDate, rtrim([dDESC]) as description, rtrim([dDESC2]) as description2, rtrim([dDESC3]) as description3, rtrim([dDESC4]) as description4, rtrim([dDESC5]) as description5, rtrim([dDESC6]) as description6, [dTOTBAL] as totalBalance, [dTXAMOUNT] as totalTaxes, [dTOTBAL] + [dTXAMOUNT] as total, [dCASHAMOUNT] as cashAmount, [dCHEQUEAMOUNT] as chequeAmount, rtrim([dCHEQUENMBR]) as chequeNumber, [dCREDITCARDAMOUNT] as creditCardAmount, rtrim([dCREDITCARDNAME]) as creditCardName, [dOTHERAMOUNT] as otherAmount, [dDATECREATED] as dateCreated, [dDATEMODIFIED] as dateModified FROM [CR10101] where dDOCSUFFIX = @documentNumber union SELECT top 1 1 as isHistorical, rtrim([dTRXSRC]) as transactionSource, [dDOCSUFFIX] as documentNumber, rtrim([BACHNUMB]) as batchNumber, rtrim([BCHSOURC]) as batchSource, rtrim([dINITIALS]) as initials, [dDATE] as documentDate, rtrim([dDESC]) as description, rtrim([dDESC2]) as description2, rtrim([dDESC3]) as description3, rtrim([dDESC4]) as description4, rtrim([dDESC5]) as description5, rtrim([dDESC6]) as description6, [dTOTBAL] as totalBalance, [dTXAMOUNT] as totalTaxes, [dTOTREC] as total, [dCASHAMOUNT] as cashAmount, [dCHEQUEAMOUNT] as chequeAmount, rtrim([dCHEQUENMBR]) as chequeNumber, [dCREDITCARDAMOUNT] as creditCardAmount, rtrim([dCREDITCARDNAME]) as creditCardName, [dOTHERAMOUNT] as otherAmount, [dDATECREATED] as dateCreated, [dDATEMODIFIED] as dateModified FROM [CR30101] where dDOCSUFFIX = @documentNumber order by isHistorical`) const receipt = receiptResult.recordset.length > 0 ? receiptResult.recordset[0] : undefined if (receipt !== undefined) { const detailsResult = await pool .request() .input('documentNumber', documentNumber).query(`SELECT dSEQNMBR as sequenceNumber, rtrim(dCRACCT) as accountCode, dAMOUNTOUTSTANDING as outstandingAmount, dNMBRITEMS as quantity, dLINEAMOUNT as lineAmount, dDISCAMOUNT as discountAmount, dTXAMOUNT as taxAmount, dAMOUNTPAID as paidAmount, dPOSTAMOUNT as postAmount, rtrim(dCRDTLDESC) as description FROM ${receipt.isHistorical === 1 ? 'CR30102' : 'CR10102'} where dDOCSUFFIX = @documentNumber order by dSEQNMBR`) receipt.details = detailsResult.recordset receipt.distributions = [] if (receipt.isHistorical === 1) { const distributionResult = await pool .request() .input('documentNumber', documentNumber).query(`SELECT dACCTINDEX as accountIndex, rtrim(dQUICKCD) as accountCode, rtrim(dTXDTLID) as taxDetailCode, [dAMOUNTPAID] as paidAmount FROM CR30103 where dDOCSUFFIX = @documentNumber order by dACCTINDEX, dQUICKCD, dTXDTLID`) receipt.distributions = distributionResult.recordset for (const distribution of receipt.distributions) { const account = await _getAccountByAccountIndex( mssqlConfig, distribution.accountIndex ) if (account !== undefined) { distribution.accountNumber = account.accountNumber distribution.accountDescription = account.accountDescription } } } } return receipt } export default _getCashReceiptByDocumentNumber