cityssm/node-dynamics-gp

View on GitHub
gp/getItemByItemNumber.ts

Summary

Maintainability
A
45 mins
Test Coverage
import { connect } from '@cityssm/mssql-multi-pool'
import type { config as MSSQLConfig, IResult } from 'mssql'

import type { GPItem } from './types.js'

/**
 * Inquiry > Inventory > Item
 * @param itemNumber
 * @returns
 */
export async function _getItemByItemNumber(
  mssqlConfig: MSSQLConfig,
  itemNumber: string
): Promise<GPItem | undefined> {
  const pool = await connect(mssqlConfig)

  const itemResult: IResult<GPItem> = await pool
    .request()
    .input('itemNumber', itemNumber).query(`SELECT top 1
      rtrim(ITEMNMBR) as itemNumber,
      rtrim(ITEMDESC) as itemDescription,
      rtrim(ITMSHNAM) as itemShortName,
      rtrim(ITEMTYPE) as itemType,
      rtrim(ITMGEDSC) as itemGenericDescription,
      STNDCOST as standardCost,
      CURRCOST as currentCost,
      CREATDDT as dateCreated,
      MODIFDT as dateModified
      FROM IV00101
      where ITEMNMBR = @itemNumber`)

  const item: GPItem | undefined =
    itemResult.recordset.length > 0 ? itemResult.recordset[0] : undefined

  if (item !== undefined) {
    const quantityResults = await pool.request().input('itemNumber', itemNumber)
      .query(`SELECT
        rtrim(LOCNCODE) as locationCode,
        rtrim(BINNMBR) as binNumber,
        rtrim(PRIMVNDR) as primaryVendorId,
        BGNGQTY as beginningQuantity,
        LSORDQTY as lastOrderedQuantity,
        LSTORDDT as lastOrderedDate,
        rtrim(LSORDVND) as lastOrderedVendorId,
        LRCPTQTY as lastReceiptedQuantity,
        LSRCPTDT as lastReceiptedDate,
        QTYRQSTN as quantityRequisitioned,
        QTYONORD as quantityOnOrder,
        QTYBKORD as quantityBackOrdered,
        QTY_Drop_Shipped as quantityDropShipped,
        QTYINUSE as quantityInUse,
        QTYINSVC as quantityInService,
        QTYRTRND as quantityReturned,
        QTYDMGED as quantityDamaged,
        QTYONHND as quantityOnHand,
        ATYALLOC as quantityAllocated,
        QTYCOMTD as quantityCommitted,
        QTYSOLD as quantitySold,
        dateadd(second, DATEPART(second, LSTCNTTM), dateadd(minute, DATEPART(minute, LSTCNTTM), dateadd(hour, DATEPART(hour, LSTCNTTM), LSTCNTDT))) as lastCountDateTime,
        dateadd(second, DATEPART(second, NXTCNTTM), dateadd(minute, DATEPART(minute, NXTCNTTM), dateadd(hour, DATEPART(hour, NXTCNTTM), NXTCNTDT))) as nextCountDateTime
        FROM IV00102
        where ITEMNMBR = @itemNumber`)

    item.quantities = quantityResults.recordset
  }

  return item
}

export default _getItemByItemNumber