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
