- PRCPOPPP ;WISC/RFJ/DWA-move item from prim to seco to patient ;27 Sep 93
- ;;5.1;IFCAP;**4,33,200**;Oct 20, 2000;Build 3
- ;Per VA Directive 6402, this routine should not be modified.
- Q
- ;
- ;PRC*5.1*200 Check when posting inventory distribution to
- ; secondary IP that the qty and cost are not
- ; affected when Perpetual flag = "N"
- ;
- SALE(PRCPPRIM,ITEMDA,TRANORDR,PRCPOPPP) ; post item for primary sale
- ; tranordr=transaction register #
- ; prcpoppp("qty") = qty to sale (include minus for sale)
- ; prcpoppp("invval") = inv value sold (include minus for sale)
- ; prcpoppp("orderda")= ien of ordernumber in 445.3 (used for type)
- ; prcpoppp("otherpt") = inv pt sold to
- ; prcpoppp("dueout") = dueout qty to add (- to subtract)
- ; prcpoppp("reason") = 0:reason for transaction register
- ; prcpoppp("noinvpt") = set to 1 to prevent from updating invpt
- ; locks to inventory pt prcpprim need to be applied before entry
- ;
- ; distribution costs
- N COSTCNTR,TYPE
- ; use costcenter for primary since secondaries do not have costcenters
- S COSTCNTR=$P($G(^PRCP(445,PRCPPRIM,0)),"^",7)
- I COSTCNTR,$G(PRCPOPPP("OTHERPT")) D COSTCNTR^PRCPUCC(PRCPOPPP("OTHERPT"),PRCPPRIM,COSTCNTR,-PRCPOPPP("INVVAL"))
- ;
- ; usage
- D ADDUSAG^PRCPUSAG(PRCPPRIM,ITEMDA,-PRCPOPPP("QTY"),-PRCPOPPP("INVVAL"))
- ;
- ; if prcpoppp("noinvpt"), do not update inventory point
- I $G(PRCPOPPP("NOINVPT")) Q
- ;
- ; update begin balance, inventory point, transaction register
- S TYPE=$P($G(^PRCP(445.3,+$G(PRCPOPPP("ORDERDA")),0)),"^",8) I TYPE="" S TYPE="R"
- D INVPT(PRCPPRIM,ITEMDA,TYPE,TRANORDR,.PRCPOPPP)
- Q
- ;
- ;
- RECEIPT(PRCPSECO,ITEMDA,TRANORDR,PRCPOPPP) ; receive items
- ; tranordr=transaction register #
- ; prcpoppp("qty") = qty to receive
- ; prcpoppp("invval") = inv value received
- ; prcpoppp("otherpt") = inv pt received from
- ; prcpoppp("duein") = duein qty to add (- to subtract)
- ; prcpoppp("reason") = 0:reason for transaction register
- ; for patient distributions:
- ; prcpoppp("prcpptda") = ptr to file 446.1 (patient distribution)
- ; locks to inventory pt prcpseco need to be applied before entry
- ;
- ; receipt history
- D RECEIPTS^PRCPUSAG(PRCPSECO,ITEMDA,PRCPOPPP("QTY"))
- ;
- ; update inventory point
- D INVPT(PRCPSECO,ITEMDA,"RC",TRANORDR,.PRCPOPPP)
- ;
- ; if no patient quit
- I '$G(PRCPOPPP("PRCPPTDA")) Q
- ;
- ; sale to patient
- ;
- ; usage
- D ADDUSAG^PRCPUSAG(PRCPSECO,ITEMDA,PRCPOPPP("QTY"),PRCPOPPP("INVVAL"))
- ;
- ; take out of inventory point
- N COST,QTY,Y
- S QTY=PRCPOPPP("QTY"),COST=PRCPOPPP("INVVAL")
- S PRCPOPPP("QTY")=-QTY,(PRCPOPPP("INVVAL"),PRCPOPPP("SELVAL"))=-COST
- K PRCPOPPP("OTHERPT"),PRCPOPPP("DUEIN")
- S Y=PRCPPTDA D DD^%DT
- S PRCPOPPP("REASON")="0:Distribution to patient ("_Y_")"
- D INVPT(PRCPSECO,ITEMDA,"R",TRANORDR,.PRCPOPPP)
- ;
- ; distribute to patient
- D DISTITEM^PRCPUPAT(PRCPPTDA,ITEMDA,QTY,COST)
- Q
- ;
- ;
- INVPT(PRCPINPT,ITEMDA,TRANTYPE,TRANORDR,PRCPOPPP) ; update inventory point data
- ; trantype=type of transaction; tranordr=transaction register #
- ; prcpoppp("qty") = qty to add to inventory point
- ; prcpoppp("invval") = value to add to inventory point
- ; prcpoppp("otherpt") = inv pt sold to (for transaction register)
- ; prcpoppp("dueout") = qty to add to dueout
- ; prcpoppp("duein") = qty to add to duein
- ; prcpoppp("reason") = 0:reason for transaction register
- ; locks to inventory pt prcpinpt need to be applied before entry
- ;
- N ITEMDATA,QUANTITY
- I $P(^PRCP(445,PRCPINPT,0),"^",2)="N",$P(^PRCP(445,PRCPINPT,0),"^",3)="S" S PRCPOPPP("QTY")=0,PRCPOPPP("INVVAL")=0 ;PRC*5.1*200
- S ITEMDATA=$G(^PRCP(445,PRCPINPT,1,ITEMDA,0)) I ITEMDATA="" Q
- ;
- ; update beginning balance
- I '$D(^PRCP(445.1,PRCPINPT,1,ITEMDA,1,$E(DT,1,5),0)) D BALANCE^PRCPUBAL(PRCPINPT,ITEMDA,$E(DT,1,5))
- ;
- ; make sure inventory value has been set to qty*unitcost
- I '$P(ITEMDATA,"^",27) S $P(ITEMDATA,"^",27)=$J($P(ITEMDATA,"^",7)*$P(ITEMDATA,"^",22),0,2)
- S $P(ITEMDATA,"^",7)=$P(ITEMDATA,"^",7)+PRCPOPPP("QTY")
- S $P(ITEMDATA,"^",27)=$P(ITEMDATA,"^",27)+PRCPOPPP("INVVAL")
- ;
- ; update average cost
- S $P(ITEMDATA,"^",22)=0,QUANTITY=$P(ITEMDATA,"^",7)+$P(ITEMDATA,"^",19)
- I QUANTITY>0 S $P(ITEMDATA,"^",22)=$J($P(ITEMDATA,"^",27)/QUANTITY,0,3) I $P(ITEMDATA,"^",22)'>0 S $P(ITEMDATA,"^",22)=0
- S:TRANTYPE="RC" $P(ITEMDATA,"^",3)=DT
- S ^PRCP(445,PRCPINPT,1,ITEMDA,0)=ITEMDATA
- ;
- ; update dueout and duein
- I $G(PRCPOPPP("DUEOUT"))<0 D SETOUT^PRCPUDUE(PRCPINPT,ITEMDA,PRCPOPPP("DUEOUT"))
- I $G(PRCPOPPP("DUEIN"))<0 D SETIN^PRCPUDUE(PRCPINPT,ITEMDA,PRCPOPPP("DUEIN"))
- ;
- ;
- ; transaction register
- S PRCPOPPP("SELVAL")=PRCPOPPP("INVVAL")
- I TRANORDR D ADDTRAN^PRCPUTRX(PRCPINPT,ITEMDA,TRANTYPE,TRANORDR,.PRCPOPPP)
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPRCPOPPP 4791 printed Apr 23, 2025@18:28:49 Page 2
- PRCPOPPP ;WISC/RFJ/DWA-move item from prim to seco to patient ;27 Sep 93
- +1 ;;5.1;IFCAP;**4,33,200**;Oct 20, 2000;Build 3
- +2 ;Per VA Directive 6402, this routine should not be modified.
- +3 QUIT
- +4 ;
- +5 ;PRC*5.1*200 Check when posting inventory distribution to
- +6 ; secondary IP that the qty and cost are not
- +7 ; affected when Perpetual flag = "N"
- +8 ;
- SALE(PRCPPRIM,ITEMDA,TRANORDR,PRCPOPPP) ; post item for primary sale
- +1 ; tranordr=transaction register #
- +2 ; prcpoppp("qty") = qty to sale (include minus for sale)
- +3 ; prcpoppp("invval") = inv value sold (include minus for sale)
- +4 ; prcpoppp("orderda")= ien of ordernumber in 445.3 (used for type)
- +5 ; prcpoppp("otherpt") = inv pt sold to
- +6 ; prcpoppp("dueout") = dueout qty to add (- to subtract)
- +7 ; prcpoppp("reason") = 0:reason for transaction register
- +8 ; prcpoppp("noinvpt") = set to 1 to prevent from updating invpt
- +9 ; locks to inventory pt prcpprim need to be applied before entry
- +10 ;
- +11 ; distribution costs
- +12 NEW COSTCNTR,TYPE
- +13 ; use costcenter for primary since secondaries do not have costcenters
- +14 SET COSTCNTR=$PIECE($GET(^PRCP(445,PRCPPRIM,0)),"^",7)
- +15 IF COSTCNTR
- IF $GET(PRCPOPPP("OTHERPT"))
- DO COSTCNTR^PRCPUCC(PRCPOPPP("OTHERPT"),PRCPPRIM,COSTCNTR,-PRCPOPPP("INVVAL"))
- +16 ;
- +17 ; usage
- +18 DO ADDUSAG^PRCPUSAG(PRCPPRIM,ITEMDA,-PRCPOPPP("QTY"),-PRCPOPPP("INVVAL"))
- +19 ;
- +20 ; if prcpoppp("noinvpt"), do not update inventory point
- +21 IF $GET(PRCPOPPP("NOINVPT"))
- QUIT
- +22 ;
- +23 ; update begin balance, inventory point, transaction register
- +24 SET TYPE=$PIECE($GET(^PRCP(445.3,+$GET(PRCPOPPP("ORDERDA")),0)),"^",8)
- IF TYPE=""
- SET TYPE="R"
- +25 DO INVPT(PRCPPRIM,ITEMDA,TYPE,TRANORDR,.PRCPOPPP)
- +26 QUIT
- +27 ;
- +28 ;
- RECEIPT(PRCPSECO,ITEMDA,TRANORDR,PRCPOPPP) ; receive items
- +1 ; tranordr=transaction register #
- +2 ; prcpoppp("qty") = qty to receive
- +3 ; prcpoppp("invval") = inv value received
- +4 ; prcpoppp("otherpt") = inv pt received from
- +5 ; prcpoppp("duein") = duein qty to add (- to subtract)
- +6 ; prcpoppp("reason") = 0:reason for transaction register
- +7 ; for patient distributions:
- +8 ; prcpoppp("prcpptda") = ptr to file 446.1 (patient distribution)
- +9 ; locks to inventory pt prcpseco need to be applied before entry
- +10 ;
- +11 ; receipt history
- +12 DO RECEIPTS^PRCPUSAG(PRCPSECO,ITEMDA,PRCPOPPP("QTY"))
- +13 ;
- +14 ; update inventory point
- +15 DO INVPT(PRCPSECO,ITEMDA,"RC",TRANORDR,.PRCPOPPP)
- +16 ;
- +17 ; if no patient quit
- +18 IF '$GET(PRCPOPPP("PRCPPTDA"))
- QUIT
- +19 ;
- +20 ; sale to patient
- +21 ;
- +22 ; usage
- +23 DO ADDUSAG^PRCPUSAG(PRCPSECO,ITEMDA,PRCPOPPP("QTY"),PRCPOPPP("INVVAL"))
- +24 ;
- +25 ; take out of inventory point
- +26 NEW COST,QTY,Y
- +27 SET QTY=PRCPOPPP("QTY")
- SET COST=PRCPOPPP("INVVAL")
- +28 SET PRCPOPPP("QTY")=-QTY
- SET (PRCPOPPP("INVVAL"),PRCPOPPP("SELVAL"))=-COST
- +29 KILL PRCPOPPP("OTHERPT"),PRCPOPPP("DUEIN")
- +30 SET Y=PRCPPTDA
- DO DD^%DT
- +31 SET PRCPOPPP("REASON")="0:Distribution to patient ("_Y_")"
- +32 DO INVPT(PRCPSECO,ITEMDA,"R",TRANORDR,.PRCPOPPP)
- +33 ;
- +34 ; distribute to patient
- +35 DO DISTITEM^PRCPUPAT(PRCPPTDA,ITEMDA,QTY,COST)
- +36 QUIT
- +37 ;
- +38 ;
- INVPT(PRCPINPT,ITEMDA,TRANTYPE,TRANORDR,PRCPOPPP) ; update inventory point data
- +1 ; trantype=type of transaction; tranordr=transaction register #
- +2 ; prcpoppp("qty") = qty to add to inventory point
- +3 ; prcpoppp("invval") = value to add to inventory point
- +4 ; prcpoppp("otherpt") = inv pt sold to (for transaction register)
- +5 ; prcpoppp("dueout") = qty to add to dueout
- +6 ; prcpoppp("duein") = qty to add to duein
- +7 ; prcpoppp("reason") = 0:reason for transaction register
- +8 ; locks to inventory pt prcpinpt need to be applied before entry
- +9 ;
- +10 NEW ITEMDATA,QUANTITY
- +11 ;PRC*5.1*200
- IF $PIECE(^PRCP(445,PRCPINPT,0),"^",2)="N"
- IF $PIECE(^PRCP(445,PRCPINPT,0),"^",3)="S"
- SET PRCPOPPP("QTY")=0
- SET PRCPOPPP("INVVAL")=0
- +12 SET ITEMDATA=$GET(^PRCP(445,PRCPINPT,1,ITEMDA,0))
- IF ITEMDATA=""
- QUIT
- +13 ;
- +14 ; update beginning balance
- +15 IF '$DATA(^PRCP(445.1,PRCPINPT,1,ITEMDA,1,$EXTRACT(DT,1,5),0))
- DO BALANCE^PRCPUBAL(PRCPINPT,ITEMDA,$EXTRACT(DT,1,5))
- +16 ;
- +17 ; make sure inventory value has been set to qty*unitcost
- +18 IF '$PIECE(ITEMDATA,"^",27)
- SET $PIECE(ITEMDATA,"^",27)=$JUSTIFY($PIECE(ITEMDATA,"^",7)*$PIECE(ITEMDATA,"^",22),0,2)
- +19 SET $PIECE(ITEMDATA,"^",7)=$PIECE(ITEMDATA,"^",7)+PRCPOPPP("QTY")
- +20 SET $PIECE(ITEMDATA,"^",27)=$PIECE(ITEMDATA,"^",27)+PRCPOPPP("INVVAL")
- +21 ;
- +22 ; update average cost
- +23 SET $PIECE(ITEMDATA,"^",22)=0
- SET QUANTITY=$PIECE(ITEMDATA,"^",7)+$PIECE(ITEMDATA,"^",19)
- +24 IF QUANTITY>0
- SET $PIECE(ITEMDATA,"^",22)=$JUSTIFY($PIECE(ITEMDATA,"^",27)/QUANTITY,0,3)
- IF $PIECE(ITEMDATA,"^",22)'>0
- SET $PIECE(ITEMDATA,"^",22)=0
- +25 if TRANTYPE="RC"
- SET $PIECE(ITEMDATA,"^",3)=DT
- +26 SET ^PRCP(445,PRCPINPT,1,ITEMDA,0)=ITEMDATA
- +27 ;
- +28 ; update dueout and duein
- +29 IF $GET(PRCPOPPP("DUEOUT"))<0
- DO SETOUT^PRCPUDUE(PRCPINPT,ITEMDA,PRCPOPPP("DUEOUT"))
- +30 IF $GET(PRCPOPPP("DUEIN"))<0
- DO SETIN^PRCPUDUE(PRCPINPT,ITEMDA,PRCPOPPP("DUEIN"))
- +31 ;
- +32 ;
- +33 ; transaction register
- +34 SET PRCPOPPP("SELVAL")=PRCPOPPP("INVVAL")
- +35 IF TRANORDR
- DO ADDTRAN^PRCPUTRX(PRCPINPT,ITEMDA,TRANTYPE,TRANORDR,.PRCPOPPP)
- +36 QUIT