@cityssm/dynamics-gp
Version:
Read only inquiries into Microsoft Dynamics GP using a SQL Server connection.
144 lines (126 loc) • 4.95 kB
text/typescript
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,
[] as documentNumber,
rtrim([BACHNUMB]) as batchNumber,
rtrim([BCHSOURC]) as batchSource,
rtrim([dINITIALS]) as initials,
[] 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,
[] as totalBalance,
[] as totalTaxes,
[] + [dTXAMOUNT] as total,
[] as cashAmount,
[] as chequeAmount,
rtrim([dCHEQUENMBR]) as chequeNumber,
[] as creditCardAmount,
rtrim([dCREDITCARDNAME]) as creditCardName,
[] as otherAmount,
[] as dateCreated,
[] as dateModified
FROM [CR10101]
where dDOCSUFFIX = @documentNumber
union SELECT top 1
1 as isHistorical,
rtrim([dTRXSRC]) as transactionSource,
[] as documentNumber,
rtrim([BACHNUMB]) as batchNumber,
rtrim([BCHSOURC]) as batchSource,
rtrim([dINITIALS]) as initials,
[] 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,
[] as totalBalance,
[] as totalTaxes,
[] as total,
[] as cashAmount,
[] as chequeAmount,
rtrim([dCHEQUENMBR]) as chequeNumber,
[] as creditCardAmount,
rtrim([dCREDITCARDNAME]) as creditCardName,
[] as otherAmount,
[] as dateCreated,
[] 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,
[] 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