[613] | 1 | PRCPOPP3 ;WISC/RFJ/DWA-case cart/instrument kit post (cont) ;27 Sep 93
|
---|
| 2 | ;;5.1;IFCAP;**41**;Oct 20, 2000
|
---|
| 3 | ;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
| 4 | Q
|
---|
| 5 | ;
|
---|
| 6 | ;
|
---|
| 7 | POST ; post cc/ik items
|
---|
| 8 | N INVVALUE,ORDRDATA,PRCPOPP,QTYORDER,QTYPOST,QTYRET,QUANTITY,REUSABLE,UNITCOST
|
---|
| 9 | S CCIKITEM=0 F S CCIKITEM=$O(^TMP($J,"PRCPOPPC-ITEMS",CCIKITEM)) Q:'CCIKITEM D
|
---|
| 10 | . ; if cc or ik item is on distribution order, sell ccik item from
|
---|
| 11 | . ; primary and update primary qty on-hand, dueouts, etc.
|
---|
| 12 | . I $D(^PRCP(445.3,ORDERDA,1,CCIKITEM,0)) S ORDRDATA=^(0) D
|
---|
| 13 | . . S QUANTITY=$P(ORDRDATA,"^",2),INVVALUE=$J(QUANTITY*$P(ORDRDATA,"^",3),0,2)
|
---|
| 14 | . . I 'QUANTITY D DELITEM^PRCPOPD(ORDERDA,CCIKITEM) Q
|
---|
| 15 | . . ; sell item from primary
|
---|
| 16 | . . K PRCPOPP
|
---|
| 17 | . . S (PRCPOPP("QTY"),PRCPOPP("DUEOUT"))=-QUANTITY,PRCPOPP("INVVAL")=-INVVALUE,PRCPOPP("OTHERPT")=PRCPSECO,PRCPOPP("ORDERDA")=ORDERDA
|
---|
| 18 | . . D SALE^PRCPOPPP(PRCPPRIM,CCIKITEM,PRCPPORD,.PRCPOPP)
|
---|
| 19 | . . ;
|
---|
| 20 | . . K PRCPOPP
|
---|
| 21 | . . S PRCPOPP("QTY")=QUANTITY*$P($$GETVEN^PRCPUVEN(PRCPSECO,CCIKITEM,PRCPPRIM_";PRCP(445,",1),"^",4),PRCPOPP("DUEIN")=-PRCPOPP("QTY"),PRCPOPP("INVVAL")=INVVALUE
|
---|
| 22 | . . I $G(PRCPPTDA) S PRCPOPP("PRCPPTDA")=+$G(PRCPPTDA)
|
---|
| 23 | . . D RECEIPT^PRCPOPPP(PRCPSECO,CCIKITEM,PRCPSORD,.PRCPOPP)
|
---|
| 24 | . . ;
|
---|
| 25 | . . ; remove ccik item from order
|
---|
| 26 | . . ;D DELITEM^PRCPOPD(ORDERDA,CCIKITEM)
|
---|
| 27 | . ;
|
---|
| 28 | . ; post items in cc/ik
|
---|
| 29 | . S ITEMDA=0 F S ITEMDA=$O(^TMP($J,"PRCPOPPC-ITEMS",CCIKITEM,ITEMDA)) Q:'ITEMDA S %=^(ITEMDA) D
|
---|
| 30 | . . S QTYORDER=$P(%,"^"),QTYRET=$P(%,"^",2),QTYPOST=QTYORDER-QTYRET
|
---|
| 31 | . . S REUSABLE=$$REUSABLE^PRCPU441(ITEMDA)
|
---|
| 32 | . . ; calculate inventory value of items sold
|
---|
| 33 | . . S %=$G(^PRCP(445,PRCPPRIM,1,ITEMDA,0))
|
---|
| 34 | . . S UNITCOST=$P(%,"^",15) I 'UNITCOST S UNITCOST=$P(%,"^",22)
|
---|
| 35 | . . S INVVALUE=$J(QTYPOST*UNITCOST,0,2)
|
---|
| 36 | . . D PRIMARY
|
---|
| 37 | . . D SECOND
|
---|
| 38 | Q
|
---|
| 39 | ;
|
---|
| 40 | ;
|
---|
| 41 | PRIMARY ; sale of item from primary
|
---|
| 42 | ; if an item is an ik, sell it
|
---|
| 43 | ;I $D(^PRCP(445.8,ITEMDA)) D Q
|
---|
| 44 | ;. K PRCPOPP
|
---|
| 45 | ;. S PRCPOPP("QTY")=-QTYPOST,PRCPOPP("INVVAL")=-INVVALUE,PRCPOPP("OTHERPT")=PRCPSECO,PRCPOPP("ORDERDA")=ORDERDA
|
---|
| 46 | ;. S PRCPOPP("REASON")="0:Instrument kit sold with case cart IM# "_CCIKITEM
|
---|
| 47 | ;. D SALE^PRCPOPPP(PRCPPRIM,ITEMDA,PRCPPORD,.PRCPOPP)
|
---|
| 48 | ;
|
---|
| 49 | ; if item is reusable and was returned, do nothing
|
---|
| 50 | I REUSABLE,QTYPOST=0 Q
|
---|
| 51 | ;
|
---|
| 52 | ; if item is reusable and not returned, sell it
|
---|
| 53 | I REUSABLE D Q
|
---|
| 54 | . K PRCPOPP
|
---|
| 55 | . S PRCPOPP("QTY")=-QTYPOST,PRCPOPP("INVVAL")=-INVVALUE,PRCPOPP("OTHERPT")=PRCPSECO,PRCPOPP("ORDERDA")=ORDERDA
|
---|
| 56 | . S PRCPOPP("REASON")="0:Reusable item not returned in cc,ik IM# "_CCIKITEM
|
---|
| 57 | . D SALE^PRCPOPPP(PRCPPRIM,ITEMDA,PRCPPORD,.PRCPOPP)
|
---|
| 58 | ;
|
---|
| 59 | ; disposable items
|
---|
| 60 | ; if item is disposable and not returned, show distribution
|
---|
| 61 | ; do not update primary invpt since it was updated during assembly
|
---|
| 62 | I QTYRET=0 D Q
|
---|
| 63 | . K PRCPOPP
|
---|
| 64 | . S PRCPOPP("QTY")=-QTYPOST,PRCPOPP("INVVAL")=-INVVALUE,PRCPOPP("OTHERPT")=PRCPSECO,PRCPOPP("ORDERDA")=ORDERDA,PRCPOPP("NOINVPT")=1
|
---|
| 65 | . D SALE^PRCPOPPP(PRCPPRIM,ITEMDA,PRCPPORD,.PRCPOPP)
|
---|
| 66 | ;
|
---|
| 67 | ; if disposable item is returned, add back to primary inventory
|
---|
| 68 | K PRCPOPP
|
---|
| 69 | S PRCPOPP("QTY")=QTYRET,PRCPOPP("INVVAL")=$J(QTYRET*UNITCOST,0,2)
|
---|
| 70 | S PRCPOPP("REASON")="0:Disposable item returned with cc,ik IM# "_CCIKITEM
|
---|
| 71 | D INVPT^PRCPOPPP(PRCPPRIM,ITEMDA,"S",PRCPPORD,.PRCPOPP)
|
---|
| 72 | Q
|
---|
| 73 | ;
|
---|
| 74 | ;
|
---|
| 75 | SECOND ; receipt in secondary
|
---|
| 76 | ; if an item is an ik, receive it
|
---|
| 77 | I $D(^PRCP(445.8,ITEMDA)) D Q
|
---|
| 78 | . K PRCPOPP
|
---|
| 79 | . S PRCPOPP("QTY")=QTYPOST,PRCPOPP("INVVAL")=INVVALUE,PRCPOPP("OTHERPT")=PRCPPRIM
|
---|
| 80 | . I $G(PRCPPTDA) S PRCPOPP("PRCPPTDA")=+$G(PRCPPTDA)
|
---|
| 81 | . S PRCPOPP("REASON")="0:Instrument kit sold with case cart IM# "_CCIKITEM
|
---|
| 82 | . D RECEIPT^PRCPOPPP(PRCPSECO,ITEMDA,PRCPSORD,.PRCPOPP)
|
---|
| 83 | ;
|
---|
| 84 | ; if item is reusable and was returned, do nothing
|
---|
| 85 | I REUSABLE,QTYPOST=0 Q
|
---|
| 86 | ;
|
---|
| 87 | ; if item is reusable and not returned, receive it
|
---|
| 88 | I REUSABLE D Q
|
---|
| 89 | . K PRCPOPP
|
---|
| 90 | . S PRCPOPP("QTY")=QTYPOST,PRCPOPP("INVVAL")=INVVALUE,PRCPOPP("OTHERPT")=PRCPPRIM
|
---|
| 91 | . I $G(PRCPPTDA) S PRCPOPP("PRCPPTDA")=+$G(PRCPPTDA)
|
---|
| 92 | . S PRCPOPP("REASON")="0:Reusable item not returned in cc,ik IM# "_CCIKITEM
|
---|
| 93 | . D RECEIPT^PRCPOPPP(PRCPSECO,ITEMDA,PRCPSORD,.PRCPOPP)
|
---|
| 94 | ;
|
---|
| 95 | ; disposable items
|
---|
| 96 | ; if item is disposable and returned, do nothing
|
---|
| 97 | I QTYPOST=0 Q
|
---|
| 98 | ;
|
---|
| 99 | ; disposable items not returned
|
---|
| 100 | K PRCPOPP
|
---|
| 101 | S PRCPOPP("QTY")=QTYPOST,PRCPOPP("INVVAL")=INVVALUE,PRCPOPP("OTHERPT")=PRCPPRIM
|
---|
| 102 | I $G(PRCPPTDA) S PRCPOPP("PRCPPTDA")=+$G(PRCPPTDA)
|
---|
| 103 | D RECEIPT^PRCPOPPP(PRCPSECO,ITEMDA,PRCPSORD,.PRCPOPP)
|
---|
| 104 | Q
|
---|