| 1 | PRCPRTRA ;WISC/RFJ-transaction register report                      ;07 Sep 91 | 
|---|
| 2 | V ;;5.1;IFCAP;**1**;Oct 20, 2000 | 
|---|
| 3 | ;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
| 4 | D ^PRCPUSEL Q:'$G(PRCP("I")) | 
|---|
| 5 | N %,%H,%I,ALLITEMS,ITEMDA,PRCPDATE,PRCPSUMM,X,Y | 
|---|
| 6 | ; | 
|---|
| 7 | K X S X(1)="The Transaction Register Report prints all activity for specified items, including the opening and closing balances." | 
|---|
| 8 | S X(2)="The current month-year balance on file appears under the calculated closing balance if the two values differ." | 
|---|
| 9 | D DISPLAY^PRCPUX2(40,79,.X) | 
|---|
| 10 | ; | 
|---|
| 11 | K X S X(1)="Enter the month-year for printing the transaction register" | 
|---|
| 12 | D DISPLAY^PRCPUX2(2,40,.X) | 
|---|
| 13 | S Y=$E(DT,1,5)_"00" S %DT(0)=-Y | 
|---|
| 14 | D DD^%DT | 
|---|
| 15 | S %DT="AEP",%DT("B")=Y | 
|---|
| 16 | S %DT("A")="Print Transaction Register for MONTH and YEAR: " | 
|---|
| 17 | D ^%DT K %DT I Y<1 Q | 
|---|
| 18 | S (Y,PRCPDATE)=$E(Y,1,5) | 
|---|
| 19 | ; | 
|---|
| 20 | I PRCPDATE=$E(DT,1,5) D  I '% Q | 
|---|
| 21 | .   K X S X(1)="You may now select to print only items whose calculated closing balance differs from the current on-hand inventory." | 
|---|
| 22 | .   D DISPLAY^PRCPUX2(2,40,.X) | 
|---|
| 23 | .   S XP="Display only items out of balance" | 
|---|
| 24 | .   S XH="Enter 'YES' to only show those items out of balance, 'NO' to select items." | 
|---|
| 25 | .   S %=$$YN^PRCPUYN(2) I '% Q | 
|---|
| 26 | .   I %=1 S PRCPSUMM=1 | 
|---|
| 27 | ; | 
|---|
| 28 | I $G(PRCPSUMM) S ALLITEMS=1 G DEVICE | 
|---|
| 29 | ; | 
|---|
| 30 | ITEMS ;return here after printing report | 
|---|
| 31 | ;  get selected item list | 
|---|
| 32 | D ITEMMAST^PRCPURS4(PRCPDATE) | 
|---|
| 33 | I '$O(^TMP($J,"PRCPITEMS",0)),'$D(ALLITEMS) Q | 
|---|
| 34 | ; | 
|---|
| 35 | DEVICE ;  ask device | 
|---|
| 36 | S %ZIS="Q" D ^%ZIS Q:POP | 
|---|
| 37 | I $D(IO("Q")) D  D ^%ZTLOAD K IO("Q"),ZTSK,^TMP($J,"PRCPITEMS") Q | 
|---|
| 38 | .   S ZTDESC="Transaction Register Report",ZTRTN="DQ^PRCPRTRA" | 
|---|
| 39 | .   S ZTSAVE("PRCP*")="",ZTSAVE("ALLITEMS")="",ZTSAVE("^TMP($J,""PRCPITEMS"",")="",ZTSAVE("ZTREQ")="@" | 
|---|
| 40 | W !!,"<*> please wait <*>" | 
|---|
| 41 | ; | 
|---|
| 42 | DQ ;queue comes here | 
|---|
| 43 | N %,CURRQTY,CURRVAL,D,DATE,DESCR,ITEMDA,ITEMDATA,NSN,OPENQTY,OPENVAL,TOTALQTY,TOTALVAL,TRX,TT,UNIT,X,Y | 
|---|
| 44 | K ^TMP($J,"PRCPRTRA") | 
|---|
| 45 | S ITEMDA=0 | 
|---|
| 46 | F  S ITEMDA=$O(^PRCP(445.1,PRCP("I"),1,ITEMDA)) Q:'ITEMDA  I $D(^(ITEMDA,1,PRCPDATE,0))&($D(ALLITEMS)!($D(^TMP($J,"PRCPITEMS",ITEMDA)))) D | 
|---|
| 47 | .   S %=$$GETOPEN^PRCPUBAL(PRCP("I"),ITEMDA,PRCPDATE) | 
|---|
| 48 | .   S OPENQTY=$P(%,"^",2)+$P(%,"^",3) | 
|---|
| 49 | .   S OPENVAL=+$P(%,"^",8) | 
|---|
| 50 | .   S NSN=$$NSN^PRCPUX1(ITEMDA) S:NSN="" NSN=" " | 
|---|
| 51 | .   S TOTALQTY=OPENQTY,TOTALVAL=OPENVAL | 
|---|
| 52 | .   S TRX=0 | 
|---|
| 53 | .   F  S TRX=$O(^PRCP(445.2,"AD",PRCP("I"),ITEMDA,TRX)) Q:'TRX  D | 
|---|
| 54 | .   .   S D=$G(^PRCP(445.2,TRX,0)),DATE=$P($P(D,"^",17),".") | 
|---|
| 55 | .   .   I $E(DATE,1,5)=PRCPDATE D | 
|---|
| 56 | .   .   .   S TT=$P(D,"^",4) | 
|---|
| 57 | .   .   .   S TT=$S($E(TT,1,2)="RC":"R",$E(TT)="R":"D",1:TT) | 
|---|
| 58 | .   .   .   S %=$E($P(D,"^",2),2,10) S:$E(%)?1A %=$E(%,2,10) | 
|---|
| 59 | .   .   .   I PRCP("DPTYPE")="P"&(TT="D"!(TT="C")!(TT="E")) D | 
|---|
| 60 | .   .   .   .   S X=$P($P($G(^PRCP(445,+$P(D,"^",18),0)),"^"),"-",2,99) | 
|---|
| 61 | .   .   .   .   S:X'="" X=$E("to: "_X,1,18) | 
|---|
| 62 | .   .   .   .   S:$P(D,"^",19)="" $P(D,"^",19)=X | 
|---|
| 63 | .   .   .   I PRCP("DPTYPE")="S",TT="U" D | 
|---|
| 64 | .   .   .   .   S X=$P($G(^PRCP(445.2,TRX,2)),"^",2) | 
|---|
| 65 | .   .   .   .   S:X'="" X=$E("to: "_X,1,18) | 
|---|
| 66 | .   .   .   .   S $P(D,"^",19)=X | 
|---|
| 67 | .   .   .   I $P(D,"^",22)="",$P(D,"^",23)="" D | 
|---|
| 68 | .   .   .   .   S $P(D,"^",22)=$J($P(D,"^",7)*$S($E(TT,1,2)="R":$P(D,"^",9),1:$P(D,"^",8)),0,2) | 
|---|
| 69 | .   .   .   .   S $P(D,"^",23)=$J($P(D,"^",7)*$P(D,"^",9),0,2) | 
|---|
| 70 | .   .   .   S $P(D,"^",22)=$J($P(D,"^",22),0,2) | 
|---|
| 71 | .   .   .   S $P(D,"^",23)=$J($P(D,"^",23),0,2) | 
|---|
| 72 | .   .   .   ;  nonissuable | 
|---|
| 73 | .   .   .   I $P(D,"^",11)'="" D | 
|---|
| 74 | .   .   .   .   S $P(D,"^",19)=$S($P(D,"^",7)<0:"  TO",1:"FROM") | 
|---|
| 75 | .   .   .   .   S $P(D,"^",19)=$P(D,"^",19)_" noniss qty: " | 
|---|
| 76 | .   .   .   .   S $P(D,"^",19)=$P(D,"^",19)_$S($P(D,"^",7)<0:-$P(D,"^",7),1:$P(D,"^",7)) | 
|---|
| 77 | .   .   .   .   S $P(D,"^",7)="" | 
|---|
| 78 | .   .   .   .   S $P(D,"^",22,23)="^" | 
|---|
| 79 | .   .   .   S TOTALQTY=TOTALQTY+$P(D,"^",7),TOTALVAL=TOTALVAL+$P(D,"^",22) | 
|---|
| 80 | .   .   .   S ^TMP($J,"PRCPRTRA",NSN,ITEMDA,DATE,TRX)=TT_%_"^"_$P(D,"^",19)_"^"_$P(D,"^",6)_"^"_$P(D,"^",22)_"^"_$P(D,"^",23)_"^"_$P(D,"^",7) | 
|---|
| 81 | .   S ITEMDATA=$G(^PRCP(445,PRCP("I"),1,ITEMDA,0)) | 
|---|
| 82 | .   S CURRQTY=$P(ITEMDATA,"^",7)+$P(ITEMDATA,"^",19) | 
|---|
| 83 | .   S CURRVAL=$P(ITEMDATA,"^",27) | 
|---|
| 84 | .   I CURRVAL="" S CURRVAL=+$J(CURRQTY*$P(ITEMDATA,"^",22),0,2) | 
|---|
| 85 | .   I $G(PRCPSUMM),CURRQTY=TOTALQTY,CURRVAL=TOTALVAL K ^TMP($J,"PRCPRTRA",NSN,ITEMDA) Q | 
|---|
| 86 | .   S DESCR=$E($$DESCR^PRCPUX1(PRCP("I"),ITEMDA),1,30) | 
|---|
| 87 | .   S UNIT=$$UNIT^PRCPUX1(PRCP("I"),ITEMDA,"/") | 
|---|
| 88 | .   S ^TMP($J,"PRCPRTRA",NSN,ITEMDA)=DESCR_"^"_UNIT_"^"_$$GETIN^PRCPUDUE(PRCP("I"),ITEMDA)_"^"_$$GETOUT^PRCPUDUE(PRCP("I"),ITEMDA)_"^"_$P(ITEMDATA,"^",19)_"^"_OPENQTY_"^"_OPENVAL_"^"_TOTALQTY_"^"_TOTALVAL | 
|---|
| 89 | .   I CURRQTY=TOTALQTY,CURRVAL=TOTALVAL Q | 
|---|
| 90 | .   S ^TMP($J,"PRCPRTRA",NSN,ITEMDA,"BAL")=CURRQTY_"^"_CURRVAL | 
|---|
| 91 | D PRINT^PRCPRTR1 | 
|---|
| 92 | I '$D(ZTQUEUED) W !!!! K PRCPSUMM G ITEMS | 
|---|
| 93 | Q | 
|---|