PRCPRQDP ;WISC/RFJ-quantity distribution report (primary) ;10 Jun 93
V ;;5.1;IFCAP;**1**;Oct 20, 2000
;Per VHA Directive 10-93-142, this routine should not be modified.
Q
;
;
PRIMARY ; quantity distribution report for primary
SECONDY ; quantity distribution report for secondary
N PRCPALLI,X
K X
S X(1)="The Quantity Distribution Report displays all sales from the Primary to the Secondary inventory points."
I PRCP("DPTYPE")="S" S X(1)="The Quantity Distribution Report lists all sales from a supply station to a recipient."
S X(1)=X(1)_" This report is sorted by description and date issued."
D DISPLAY^PRCPUX2(40,79,.X)
;
K X S X(1)="Select the Items to display" W !! D DISPLAY^PRCPUX2(2,40,.X)
D ITEMSEL^PRCPURS4
I '$G(PRCPALLI),'$O(^TMP($J,"PRCPURS4",0)) Q
;
W ! S %ZIS="Q" D ^%ZIS G:POP Q I $D(IO("Q")) D D ^%ZTLOAD K IO("Q"),ZTSK D Q Q
. S ZTDESC="Quantity Distribution Report",ZTRTN="DQ^PRCPRQDP"
. S ZTSAVE("PRCP*")="",ZTSAVE("^TMP($J,""PRCPURS4"",")="",ZTSAVE("ZTREQ")="@"
W !!,"<*> please wait <*>"
;
DQ ; queue starts here
N %,%H,%I,COUNT,CURRENT,DA,DATA,DATE,DATEDAT,DATEEDT,DATESDT,DATESTRT,DESCR,H,ITEMDA,ITEMDATA,L,NOW,PAGE,PRCPDATA,PRCPFLAG,Q,QTY,SCREEN,TOTALC,TOTALQ,TOTALV,TYPE,V,VALUE,X,Y
K DATEDAT
S CURRENT=$E(DT,1,5)_"00",X1=$E(DT,1,5)_"15",X2=-375
D C^%DTC S (DATESTRT,Y)=$E(X,1,5)_"00"
D DD^%DT S DATEDAT($E(X,1,5))=$P(Y," ")_$E(X,2,3)
S DATE=$E(DATESTRT,1,5)_"15"
F S X1=DATE,X2=30 D Q:$E(X,1,5)'<$E(CURRENT,1,5) S DATE=$E(X,1,5)_"15"
. D C^%DTC S Y=$E(X,1,5)_"00"
. D DD^%DT S DATEDAT($E(X,1,5))=$P(Y," ")_$E(X,2,3)
K ^TMP($J,"PRCPRQDP")
S DATE=DATESTRT-.01
F S DATE=$O(^PRCP(445.2,"AX",PRCP("I"),DATE)) Q:'DATE!($E(DATE,1,5)>$E(CURRENT,1,5)) D SELECT
G PRINT
;
SELECT I PRCP("DPTYPE")="P" F TYPE="R","C","E" D COMPILE
I PRCP("DPTYPE")="S" F TYPE="U" D COMPILE
Q
;
COMPILE S DA=0 F S DA=$O(^PRCP(445.2,"AX",PRCP("I"),DATE,TYPE,DA)) Q:'DA D
. S DATA=$G(^PRCP(445.2,DA,0)) I DATA="" Q
. S ITEMDA=$P(DATA,"^",5)
. I '$G(PRCPALLI),'$D(^TMP($J,"PRCPURS4",ITEMDA)) Q
. S DESCR=$E($$DESCR^PRCPUX1(PRCP("I"),ITEMDA),1,33) S:DESCR="" DESCR=" "
. S $P(DATA,"^",7)=-$P(DATA,"^",7),$P(DATA,"^",23)=-$P(DATA,"^",23)
. I '$P(DATA,"^",23) S $P(DATA,"^",23)=$J($P(DATA,"^",7)*$P(DATA,"^",9),0,2)
. S %=$G(^TMP($J,"PRCPRQDP",DESCR,ITEMDA,$E(DATE,1,5)))
. S ^TMP($J,"PRCPRQDP",DESCR,ITEMDA,$E(DATE,1,5))=($P(DATA,"^",7)+$P(%,"^"))_"^"_($P(DATA,"^",23)+$P(%,"^",2))
Q
;
; print report
PRINT S Y=DATESTRT D DD^%DT S DATESDT=Y,Y=DT D DD^%DT S DATEEDT=Y
D NOW^%DTC S Y=% D DD^%DT S NOW=Y
S PAGE=1,SCREEN=$$SCRPAUSE^PRCPUREP U IO D H
S DESCR="" F S DESCR=$O(^TMP($J,"PRCPRQDP",DESCR)) Q:DESCR=""!($G(PRCPFLAG)) S ITEMDA=0 F S ITEMDA=$O(^TMP($J,"PRCPRQDP",DESCR,ITEMDA)) Q:'ITEMDA!($G(PRCPFLAG)) D
. I $G(ZTQUEUED),$$S^%ZTLOAD S PRCPFLAG=1 W !?10,"<<< TASKMANAGER JOB TERMINATED BY USER >>>" Q
. I $Y>(IOSL-8) D:SCREEN P^PRCPUREP Q:$D(PRCPFLAG) D H
. S ITEMDATA=$G(^PRCP(445,PRCP("I"),1,ITEMDA,0))
. W !!,DESCR,?34,ITEMDA
. W ?39,$J($$UNIT^PRCPUX1(PRCP("I"),ITEMDA,"/"),7)
. W $J($P(ITEMDATA,"^",10),6)
. W $J($P(ITEMDATA,"^",4),7)
. W $J($P(ITEMDATA,"^",23),7)
. W $J($P(ITEMDATA,"^",11),7)
. W $J($P(ITEMDATA,"^",9),7)
. S (H(0),H(1),Q(0),Q(1),V(0),V(1))=""
. S (COUNT,DATE,L,TOTALC,TOTALQ,TOTALV)=0
. F S DATE=$O(DATEDAT(DATE)) Q:'DATE S PRCPDATA=$G(^TMP($J,"PRCPRQDP",DESCR,ITEMDA,DATE)) D
. . S QTY=+$P(PRCPDATA,"^") I QTY=0 S QTY="..."
. . S VALUE=$J($P(PRCPDATA,"^",2),0,2) I VALUE="0.00" S VALUE="..."
. . I TOTALC'=12 S TOTALQ=TOTALQ+$P(PRCPDATA,"^"),TOTALV=TOTALV+$P(PRCPDATA,"^",2),TOTALC=TOTALC+1
. . S H(L)=H(L)_$J(DATEDAT(DATE),10)
. . S Q(L)=Q(L)_$J(QTY,10)
. . S V(L)=V(L)_$J(VALUE,10)
. . S COUNT=COUNT+1
. . I COUNT=6 S L=1,COUNT=0
. S H(1)=H(1)_$J("AVG",10)
. S Q(1)=Q(1)_$J(TOTALQ/TOTALC,10,0)
. S V(1)=V(1)_$J(TOTALV/TOTALC,10,2)
. W !,H(0),?79,"^",!,Q(0),?79,"|",!,V(0),?79,"v",!,H(1),!,Q(1),!,V(1)
I $G(PRCPFLAG) D Q Q
D END^PRCPUREP
;
Q D ^%ZISC K ^TMP($J,"PRCPRQDP"),^TMP($J,"PRCPURS4")
Q
;
H S %=NOW_" PAGE "_PAGE,PAGE=PAGE+1 I PAGE'=2!(SCREEN) W @IOF
W $C(13),"QUANTITY DISTRIBUTION REPORT FOR: ",$E(PRCP("IN"),1,20),?(80-$L(%)),%
W !?5,"QUANTITY DISTRIBUTION DATE RANGE: ",DATESDT," TO ",DATEEDT
S %="",$P(%,"-",81)=""
W !?46,$J("STAND",6),$J("OPT",7),$J("TEMP",7),$J("EMER",7),$J("NORM",7),!,"DESCRIPTION",?34,"MI#",?39,$J("UNIT/IS",7),$J("REOPT",6),$J("REOPT",7),$J("S.LVL",7),$J("S.LVL",7),$J("S.LVL",7)
W !,%
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPRCPRQDP 4654 printed Mar 13, 2025@21:20:13 Page 2
PRCPRQDP ;WISC/RFJ-quantity distribution report (primary) ;10 Jun 93
V ;;5.1;IFCAP;**1**;Oct 20, 2000
+1 ;Per VHA Directive 10-93-142, this routine should not be modified.
+2 QUIT
+3 ;
+4 ;
PRIMARY ; quantity distribution report for primary
SECONDY ; quantity distribution report for secondary
+1 NEW PRCPALLI,X
+2 KILL X
+3 SET X(1)="The Quantity Distribution Report displays all sales from the Primary to the Secondary inventory points."
+4 IF PRCP("DPTYPE")="S"
SET X(1)="The Quantity Distribution Report lists all sales from a supply station to a recipient."
+5 SET X(1)=X(1)_" This report is sorted by description and date issued."
+6 DO DISPLAY^PRCPUX2(40,79,.X)
+7 ;
+8 KILL X
SET X(1)="Select the Items to display"
WRITE !!
DO DISPLAY^PRCPUX2(2,40,.X)
+9 DO ITEMSEL^PRCPURS4
+10 IF '$GET(PRCPALLI)
IF '$ORDER(^TMP($JOB,"PRCPURS4",0))
QUIT
+11 ;
+12 WRITE !
SET %ZIS="Q"
DO ^%ZIS
if POP
GOTO Q
IF $DATA(IO("Q"))
Begin DoDot:1
+13 SET ZTDESC="Quantity Distribution Report"
SET ZTRTN="DQ^PRCPRQDP"
+14 SET ZTSAVE("PRCP*")=""
SET ZTSAVE("^TMP($J,""PRCPURS4"",")=""
SET ZTSAVE("ZTREQ")="@"
End DoDot:1
DO ^%ZTLOAD
KILL IO("Q"),ZTSK
DO Q
QUIT
+15 WRITE !!,"<*> please wait <*>"
+16 ;
DQ ; queue starts here
+1 NEW %,%H,%I,COUNT,CURRENT,DA,DATA,DATE,DATEDAT,DATEEDT,DATESDT,DATESTRT,DESCR,H,ITEMDA,ITEMDATA,L,NOW,PAGE,PRCPDATA,PRCPFLAG,Q,QTY,SCREEN,TOTALC,TOTALQ,TOTALV,TYPE,V,VALUE,X,Y
+2 KILL DATEDAT
+3 SET CURRENT=$EXTRACT(DT,1,5)_"00"
SET X1=$EXTRACT(DT,1,5)_"15"
SET X2=-375
+4 DO C^%DTC
SET (DATESTRT,Y)=$EXTRACT(X,1,5)_"00"
+5 DO DD^%DT
SET DATEDAT($EXTRACT(X,1,5))=$PIECE(Y," ")_$EXTRACT(X,2,3)
+6 SET DATE=$EXTRACT(DATESTRT,1,5)_"15"
+7 FOR
SET X1=DATE
SET X2=30
Begin DoDot:1
+8 DO C^%DTC
SET Y=$EXTRACT(X,1,5)_"00"
+9 DO DD^%DT
SET DATEDAT($EXTRACT(X,1,5))=$PIECE(Y," ")_$EXTRACT(X,2,3)
End DoDot:1
if $EXTRACT(X,1,5)'<$EXTRACT(CURRENT,1,5)
QUIT
SET DATE=$EXTRACT(X,1,5)_"15"
+10 KILL ^TMP($JOB,"PRCPRQDP")
+11 SET DATE=DATESTRT-.01
+12 FOR
SET DATE=$ORDER(^PRCP(445.2,"AX",PRCP("I"),DATE))
if 'DATE!($EXTRACT(DATE,1,5)>$EXTRACT(CURRENT,1,5))
QUIT
DO SELECT
+13 GOTO PRINT
+14 ;
SELECT IF PRCP("DPTYPE")="P"
FOR TYPE="R","C","E"
DO COMPILE
+1 IF PRCP("DPTYPE")="S"
FOR TYPE="U"
DO COMPILE
+2 QUIT
+3 ;
COMPILE SET DA=0
FOR
SET DA=$ORDER(^PRCP(445.2,"AX",PRCP("I"),DATE,TYPE,DA))
if 'DA
QUIT
Begin DoDot:1
+1 SET DATA=$GET(^PRCP(445.2,DA,0))
IF DATA=""
QUIT
+2 SET ITEMDA=$PIECE(DATA,"^",5)
+3 IF '$GET(PRCPALLI)
IF '$DATA(^TMP($JOB,"PRCPURS4",ITEMDA))
QUIT
+4 SET DESCR=$EXTRACT($$DESCR^PRCPUX1(PRCP("I"),ITEMDA),1,33)
if DESCR=""
SET DESCR=" "
+5 SET $PIECE(DATA,"^",7)=-$PIECE(DATA,"^",7)
SET $PIECE(DATA,"^",23)=-$PIECE(DATA,"^",23)
+6 IF '$PIECE(DATA,"^",23)
SET $PIECE(DATA,"^",23)=$JUSTIFY($PIECE(DATA,"^",7)*$PIECE(DATA,"^",9),0,2)
+7 SET %=$GET(^TMP($JOB,"PRCPRQDP",DESCR,ITEMDA,$EXTRACT(DATE,1,5)))
+8 SET ^TMP($JOB,"PRCPRQDP",DESCR,ITEMDA,$EXTRACT(DATE,1,5))=($PIECE(DATA,"^",7)+$PIECE(%,"^"))_"^"_($PIECE(DATA,"^",23)+$PIECE(%,"^",2))
End DoDot:1
+9 QUIT
+10 ;
+11 ; print report
PRINT SET Y=DATESTRT
DO DD^%DT
SET DATESDT=Y
SET Y=DT
DO DD^%DT
SET DATEEDT=Y
+1 DO NOW^%DTC
SET Y=%
DO DD^%DT
SET NOW=Y
+2 SET PAGE=1
SET SCREEN=$$SCRPAUSE^PRCPUREP
USE IO
DO H
+3 SET DESCR=""
FOR
SET DESCR=$ORDER(^TMP($JOB,"PRCPRQDP",DESCR))
if DESCR=""!($GET(PRCPFLAG))
QUIT
SET ITEMDA=0
FOR
SET ITEMDA=$ORDER(^TMP($JOB,"PRCPRQDP",DESCR,ITEMDA))
if 'ITEMDA!($GET(PRCPFLAG))
QUIT
Begin DoDot:1
+4 IF $GET(ZTQUEUED)
IF $$S^%ZTLOAD
SET PRCPFLAG=1
WRITE !?10,"<<< TASKMANAGER JOB TERMINATED BY USER >>>"
QUIT
+5 IF $Y>(IOSL-8)
if SCREEN
DO P^PRCPUREP
if $DATA(PRCPFLAG)
QUIT
DO H
+6 SET ITEMDATA=$GET(^PRCP(445,PRCP("I"),1,ITEMDA,0))
+7 WRITE !!,DESCR,?34,ITEMDA
+8 WRITE ?39,$JUSTIFY($$UNIT^PRCPUX1(PRCP("I"),ITEMDA,"/"),7)
+9 WRITE $JUSTIFY($PIECE(ITEMDATA,"^",10),6)
+10 WRITE $JUSTIFY($PIECE(ITEMDATA,"^",4),7)
+11 WRITE $JUSTIFY($PIECE(ITEMDATA,"^",23),7)
+12 WRITE $JUSTIFY($PIECE(ITEMDATA,"^",11),7)
+13 WRITE $JUSTIFY($PIECE(ITEMDATA,"^",9),7)
+14 SET (H(0),H(1),Q(0),Q(1),V(0),V(1))=""
+15 SET (COUNT,DATE,L,TOTALC,TOTALQ,TOTALV)=0
+16 FOR
SET DATE=$ORDER(DATEDAT(DATE))
if 'DATE
QUIT
SET PRCPDATA=$GET(^TMP($JOB,"PRCPRQDP",DESCR,ITEMDA,DATE))
Begin DoDot:2
+17 SET QTY=+$PIECE(PRCPDATA,"^")
IF QTY=0
SET QTY="..."
+18 SET VALUE=$JUSTIFY($PIECE(PRCPDATA,"^",2),0,2)
IF VALUE="0.00"
SET VALUE="..."
+19 IF TOTALC'=12
SET TOTALQ=TOTALQ+$PIECE(PRCPDATA,"^")
SET TOTALV=TOTALV+$PIECE(PRCPDATA,"^",2)
SET TOTALC=TOTALC+1
+20 SET H(L)=H(L)_$JUSTIFY(DATEDAT(DATE),10)
+21 SET Q(L)=Q(L)_$JUSTIFY(QTY,10)
+22 SET V(L)=V(L)_$JUSTIFY(VALUE,10)
+23 SET COUNT=COUNT+1
+24 IF COUNT=6
SET L=1
SET COUNT=0
End DoDot:2
+25 SET H(1)=H(1)_$JUSTIFY("AVG",10)
+26 SET Q(1)=Q(1)_$JUSTIFY(TOTALQ/TOTALC,10,0)
+27 SET V(1)=V(1)_$JUSTIFY(TOTALV/TOTALC,10,2)
+28 WRITE !,H(0),?79,"^",!,Q(0),?79,"|",!,V(0),?79,"v",!,H(1),!,Q(1),!,V(1)
End DoDot:1
+29 IF $GET(PRCPFLAG)
DO Q
QUIT
+30 DO END^PRCPUREP
+31 ;
Q DO ^%ZISC
KILL ^TMP($JOB,"PRCPRQDP"),^TMP($JOB,"PRCPURS4")
+1 QUIT
+2 ;
H SET %=NOW_" PAGE "_PAGE
SET PAGE=PAGE+1
IF PAGE'=2!(SCREEN)
WRITE @IOF
+1 WRITE $CHAR(13),"QUANTITY DISTRIBUTION REPORT FOR: ",$EXTRACT(PRCP("IN"),1,20),?(80-$LENGTH(%)),%
+2 WRITE !?5,"QUANTITY DISTRIBUTION DATE RANGE: ",DATESDT," TO ",DATEEDT
+3 SET %=""
SET $PIECE(%,"-",81)=""
+4 WRITE !?46,$JUSTIFY("STAND",6),$JUSTIFY("OPT",7),$JUSTIFY("TEMP",7),$JUSTIFY("EMER",7),$JUSTIFY("NORM",7),!,"DESCRIPTION",?34,"MI#",?39,$JUSTIFY("UNIT/IS",7),$JUSTIFY("REOPT",6),$JUSTIFY("REOPT",7),$JUSTIFY("S.LVL",7),$JUSTIFY("S.LVL",7),$JUSTI
FY("S.LVL",7)
+5 WRITE !,%
+6 QUIT