PRCPRISP ;WISC/RFJ/DWA-inventory sales (primary) ;24 May 93
;;5.1;IFCAP;**41**;Oct 20, 2000
;Per VHA Directive 10-93-142, this routine should not be modified.
Q
;
;
PRIMARY ; inventory sales for primary
N DATEEND,DATESTRT,DISTRALL,PRCPSUMM,X
K X S X(1)="The Inventory Sales Report will display all sales from the Primary to the Secondary inventory points. This report is sorted by description, the distribution point, and date issued." D DISPLAY^PRCPUX2(40,79,.X)
K X S X(1)="Select the DISTRIBUTION POINTS to display" D DISPLAY^PRCPUX2(2,40,.X)
D DISTRSEL^PRCPURS3(PRCP("I"))
I '$G(DISTRALL),'$O(^TMP($J,"PRCPURS3","YES",0)) W !,"*** NO DISTRIBUTION POINTS SELECTED !" D Q Q
K X S X(1)="Select the range of ISSUE DATES to display" W !! D DISPLAY^PRCPUX2(2,40,.X)
D DATESEL^PRCPURS2("Issue") I '$G(DATEEND) D Q Q
S PRCPSUMM=$$SUMMARY^PRCPURS0 I PRCPSUMM<0 D Q 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="Primary Inventory Sales Report",ZTRTN="DQ^PRCPRISP"
. S ZTSAVE("PRCP*")="",ZTSAVE("DATE*")="",ZTSAVE("DISTRALL")="",ZTSAVE("^TMP($J,""PRCPURS3"",")="",ZTSAVE("ZTREQ")="@"
W !!,"<*> please wait <*>"
DQ ; queue starts here
N %,%H,%I,DA,DATA,DATE,DATEEDT,DATESDT,DESCR,DISTRNM,DISTRPT,ITEMDA,ITEMDATA,NOW,PAGE,PRCPDATA,PRCPFLAG,SCREEN,TOTALQ,TOTALQI,TOTALV,TOTALVI,TYPE,X,Y
K ^TMP($J,"PRCPRISP"),^TMP($J,"PRCPRISP TOT")
S DATE=DATESTRT-.01 F S DATE=$O(^PRCP(445.2,"AX",PRCP("I"),DATE)) Q:'DATE!(DATE>DATEEND) F TYPE="R","C","E","U","S" 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),DESCR=$$DESCR^PRCPUX1(PRCP("I"),ITEMDA) S:DESCR="" DESCR=" "
. S DISTRPT=+$P(DATA,"^",18)
. I 'DISTRPT,'$G(DISTRALL) Q
. I $G(DISTRALL),$D(^TMP($J,"PRCPURS3","NO",DISTRPT)) Q
. I '$G(DISTRALL),'$D(^TMP($J,"PRCPURS3","YES",DISTRPT)) Q
. S DISTRNM=$$INVNAME^PRCPUX1(DISTRPT) S:DISTRNM="" DISTRNM=" "
. 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,"^",8),0,2)
. ;I $P(DATA,"^",23)<0 S $P(DATA,"^",23)=-$P(DATA,"^",23)
. S ^TMP($J,"PRCPRISP",$E(DESCR,1,10),ITEMDA,$E(DISTRNM,1,24),DATE,DA)=$P(DATA,"^",7)_"^"_$S('$P(DATA,"^",7):0,1:$J($P(DATA,"^",23)/$P(DATA,"^",7),0,3))_"^"_$P(DATA,"^",23)
; print report
S Y=DATESTRT D DD^%DT S DATESDT=Y,Y=DATEEND D DD^%DT S DATEEDT=Y
D NOW^%DTC S Y=% D DD^%DT S NOW=Y,PAGE=1,SCREEN=$$SCRPAUSE^PRCPUREP U IO D H
S DESCR="" F S DESCR=$O(^TMP($J,"PRCPRISP",DESCR)) Q:DESCR=""!($G(PRCPFLAG)) S ITEMDA=0 F S ITEMDA=$O(^TMP($J,"PRCPRISP",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-6) D:SCREEN P^PRCPUREP Q:$D(PRCPFLAG) D H
. S ITEMDATA=$G(^PRCP(445,PRCP("I"),1,ITEMDA,0))
. W:'PRCPSUMM !,$E($$DESCR^PRCPUX1(PRCP("I"),ITEMDA),1,38),?39,"[",ITEMDA,"]"
. S (TOTALQI,TOTALVI)=0
. S DISTRPT="" F S DISTRPT=$O(^TMP($J,"PRCPRISP",DESCR,ITEMDA,DISTRPT)) Q:DISTRPT=""!($G(PRCPFLAG)) D
. . W:'PRCPSUMM !?15,$S(DISTRPT=" ":"<<NONE>>",1:DISTRPT)
. . S (TOTALQ,TOTALV)=0
. . S DATE=0 F S DATE=$O(^TMP($J,"PRCPRISP",DESCR,ITEMDA,DISTRPT,DATE)) Q:'DATE!($G(PRCPFLAG)) S DA=0 F S DA=$O(^TMP($J,"PRCPRISP",DESCR,ITEMDA,DISTRPT,DATE,DA)) Q:'DA!($G(PRCPFLAG)) S PRCPDATA=^(DA) D
. . . W:'PRCPSUMM ?40,$E(DATE,4,5),"/",$E(DATE,6,7),"/",$E(DATE,2,3),$J($P(PRCPDATA,"^"),10),$J($P(PRCPDATA,"^",2),10,3),$J($P(PRCPDATA,"^",3),12,2),!
. . . S TOTALQ=TOTALQ+$P(PRCPDATA,"^"),TOTALV=TOTALV+$P(PRCPDATA,"^",3)
. . . I $Y>(IOSL-6) D:SCREEN P^PRCPUREP Q:$D(PRCPFLAG) D H W !
. . I $G(PRCPFLAG) Q
. . S TOTALQI=TOTALQI+TOTALQ,TOTALVI=TOTALVI+TOTALV
. . S ^TMP($J,"PRCPRISP TOT",DISTRPT)=$G(^TMP($J,"PRCPRISP TOT",DISTRPT))+TOTALV
. . I 'PRCPSUMM W:$X>20 ! W ?27,"TOTALS BY DISTR. PT: ",$J(TOTALQ,10),$J(TOTALV,22,2)
. I $G(PRCPFLAG) Q
. W:'PRCPSUMM !?32,"TOTALS BY ITEM: ",$J(TOTALQI,10),$J(TOTALVI,22,2)
I $G(PRCPFLAG) D Q Q
I $Y>(IOSL-8) D:SCREEN P^PRCPUREP Q:$D(PRCPFLAG) D H
W !!,"TOTAL SALES TO DISTRIBUTION POINTS:"
S TOTALV=0,DISTRPT="" F S DISTRPT=$O(^TMP($J,"PRCPRISP TOT",DISTRPT)) Q:DISTRPT=""!($G(PRCPFLAG)) S %=$G(^(DISTRPT)) D
. W !?10,DISTRPT,?40,$J(%,20,2)
. S TOTALV=TOTALV+%
. I $Y>(IOSL-4) D:SCREEN P^PRCPUREP Q:$D(PRCPFLAG) D H
I $G(PRCPFLAG) D Q Q
W !?10,"TOTAL",?40,$J(TOTALV,20,2)
D END^PRCPUREP
Q D ^%ZISC K ^TMP($J,"PRCPURS3"),^TMP($J,"PRCPRISP"),^TMP($J,"PRCPRISP TOT")
Q
;
H S %=NOW_" PAGE "_PAGE,PAGE=PAGE+1 I PAGE'=2!(SCREEN) W @IOF
W $C(13),"INVENTORY SALES FOR: ",$E(PRCP("IN"),1,20),?(80-$L(%)),%
W !?5,"INVENTORY SALES DATE RANGE: ",DATESDT," TO ",DATEEDT
S %="",$P(%,"-",81)=""
I PRCPSUMM W !?1,"*** ONLY SUMMARY OF SALES PRINTED ***",!,% Q
W !,"DESCRIPTION",?37,"DATE ISSUED",$J("QUANTITY",10),$J("SELL COST",10),$J("TOTAL VALUE",12),!,%
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPRCPRISP 4964 printed Dec 13, 2024@02:15 Page 2
PRCPRISP ;WISC/RFJ/DWA-inventory sales (primary) ;24 May 93
+1 ;;5.1;IFCAP;**41**;Oct 20, 2000
+2 ;Per VHA Directive 10-93-142, this routine should not be modified.
+3 QUIT
+4 ;
+5 ;
PRIMARY ; inventory sales for primary
+1 NEW DATEEND,DATESTRT,DISTRALL,PRCPSUMM,X
+2 KILL X
SET X(1)="The Inventory Sales Report will display all sales from the Primary to the Secondary inventory points. This report is sorted by description, the distribution point, and date issued."
DO DISPLAY^PRCPUX2(40,79,.X)
+3 KILL X
SET X(1)="Select the DISTRIBUTION POINTS to display"
DO DISPLAY^PRCPUX2(2,40,.X)
+4 DO DISTRSEL^PRCPURS3(PRCP("I"))
+5 IF '$GET(DISTRALL)
IF '$ORDER(^TMP($JOB,"PRCPURS3","YES",0))
WRITE !,"*** NO DISTRIBUTION POINTS SELECTED !"
DO Q
QUIT
+6 KILL X
SET X(1)="Select the range of ISSUE DATES to display"
WRITE !!
DO DISPLAY^PRCPUX2(2,40,.X)
+7 DO DATESEL^PRCPURS2("Issue")
IF '$GET(DATEEND)
DO Q
QUIT
+8 SET PRCPSUMM=$$SUMMARY^PRCPURS0
IF PRCPSUMM<0
DO Q
QUIT
+9 WRITE !
SET %ZIS="Q"
DO ^%ZIS
if POP
GOTO Q
IF $DATA(IO("Q"))
Begin DoDot:1
+10 SET ZTDESC="Primary Inventory Sales Report"
SET ZTRTN="DQ^PRCPRISP"
+11 SET ZTSAVE("PRCP*")=""
SET ZTSAVE("DATE*")=""
SET ZTSAVE("DISTRALL")=""
SET ZTSAVE("^TMP($J,""PRCPURS3"",")=""
SET ZTSAVE("ZTREQ")="@"
End DoDot:1
DO ^%ZTLOAD
KILL IO("Q"),ZTSK
DO Q
QUIT
+12 WRITE !!,"<*> please wait <*>"
DQ ; queue starts here
+1 NEW %,%H,%I,DA,DATA,DATE,DATEEDT,DATESDT,DESCR,DISTRNM,DISTRPT,ITEMDA,ITEMDATA,NOW,PAGE,PRCPDATA,PRCPFLAG,SCREEN,TOTALQ,TOTALQI,TOTALV,TOTALVI,TYPE,X,Y
+2 KILL ^TMP($JOB,"PRCPRISP"),^TMP($JOB,"PRCPRISP TOT")
+3 SET DATE=DATESTRT-.01
FOR
SET DATE=$ORDER(^PRCP(445.2,"AX",PRCP("I"),DATE))
if 'DATE!(DATE>DATEEND)
QUIT
FOR TYPE="R","C","E","U","S"
SET DA=0
FOR
SET DA=$ORDER(^PRCP(445.2,"AX",PRCP("I"),DATE,TYPE,DA))
if 'DA
QUIT
Begin DoDot:1
+4 SET DATA=$GET(^PRCP(445.2,DA,0))
IF DATA=""
QUIT
+5 SET ITEMDA=$PIECE(DATA,"^",5)
SET DESCR=$$DESCR^PRCPUX1(PRCP("I"),ITEMDA)
if DESCR=""
SET DESCR=" "
+6 SET DISTRPT=+$PIECE(DATA,"^",18)
+7 IF 'DISTRPT
IF '$GET(DISTRALL)
QUIT
+8 IF $GET(DISTRALL)
IF $DATA(^TMP($JOB,"PRCPURS3","NO",DISTRPT))
QUIT
+9 IF '$GET(DISTRALL)
IF '$DATA(^TMP($JOB,"PRCPURS3","YES",DISTRPT))
QUIT
+10 SET DISTRNM=$$INVNAME^PRCPUX1(DISTRPT)
if DISTRNM=""
SET DISTRNM=" "
+11 SET $PIECE(DATA,"^",7)=-$PIECE(DATA,"^",7)
SET $PIECE(DATA,"^",23)=-$PIECE(DATA,"^",23)
+12 IF '$PIECE(DATA,"^",23)
SET $PIECE(DATA,"^",23)=$JUSTIFY($PIECE(DATA,"^",7)*$PIECE(DATA,"^",8),0,2)
+13 ;I $P(DATA,"^",23)<0 S $P(DATA,"^",23)=-$P(DATA,"^",23)
+14 SET ^TMP($JOB,"PRCPRISP",$EXTRACT(DESCR,1,10),ITEMDA,$EXTRACT(DISTRNM,1,24),DATE,DA)=$PIECE(DATA,"^",7)_"^"_$SELECT('$PIECE(DATA,"^",7):0,1:$JUSTIFY($PIECE(DATA,"^",23)/$PIECE(DATA,"^",7),0,3))_"^"_$PIECE(DATA,"^",23)
End DoDot:1
+15 ; print report
+16 SET Y=DATESTRT
DO DD^%DT
SET DATESDT=Y
SET Y=DATEEND
DO DD^%DT
SET DATEEDT=Y
+17 DO NOW^%DTC
SET Y=%
DO DD^%DT
SET NOW=Y
SET PAGE=1
SET SCREEN=$$SCRPAUSE^PRCPUREP
USE IO
DO H
+18 SET DESCR=""
FOR
SET DESCR=$ORDER(^TMP($JOB,"PRCPRISP",DESCR))
if DESCR=""!($GET(PRCPFLAG))
QUIT
SET ITEMDA=0
FOR
SET ITEMDA=$ORDER(^TMP($JOB,"PRCPRISP",DESCR,ITEMDA))
if 'ITEMDA!($GET(PRCPFLAG))
QUIT
Begin DoDot:1
+19 IF $GET(ZTQUEUED)
IF $$S^%ZTLOAD
SET PRCPFLAG=1
WRITE !?10,"<<< TASKMANAGER JOB TERMINATED BY USER >>>"
QUIT
+20 IF $Y>(IOSL-6)
if SCREEN
DO P^PRCPUREP
if $DATA(PRCPFLAG)
QUIT
DO H
+21 SET ITEMDATA=$GET(^PRCP(445,PRCP("I"),1,ITEMDA,0))
+22 if 'PRCPSUMM
WRITE !,$EXTRACT($$DESCR^PRCPUX1(PRCP("I"),ITEMDA),1,38),?39,"[",ITEMDA,"]"
+23 SET (TOTALQI,TOTALVI)=0
+24 SET DISTRPT=""
FOR
SET DISTRPT=$ORDER(^TMP($JOB,"PRCPRISP",DESCR,ITEMDA,DISTRPT))
if DISTRPT=""!($GET(PRCPFLAG))
QUIT
Begin DoDot:2
+25 if 'PRCPSUMM
WRITE !?15,$SELECT(DISTRPT=" ":"<<NONE>>",1:DISTRPT)
+26 SET (TOTALQ,TOTALV)=0
+27 SET DATE=0
FOR
SET DATE=$ORDER(^TMP($JOB,"PRCPRISP",DESCR,ITEMDA,DISTRPT,DATE))
if 'DATE!($GET(PRCPFLAG))
QUIT
SET DA=0
FOR
SET DA=$ORDER(^TMP($JOB,"PRCPRISP",DESCR,ITEMDA,DISTRPT,DATE,DA))
if 'DA!($GET(PRCPFLAG))
QUIT
SET PRCPDATA=^(DA)
Begin DoDot:3
+28 if 'PRCPSUMM
WRITE ?40,$EXTRACT(DATE,4,5),"/",$EXTRACT(DATE,6,7),"/",$EXTRACT(DATE,2,3),$JUSTIFY($PIECE(PRCPDATA,"^"),10),$JUSTIFY($PIECE(PRCPDATA,"^",2),10,3),$JUSTIFY($PIECE(PRCPDATA,"^",3),12,2),!
+29 SET TOTALQ=TOTALQ+$PIECE(PRCPDATA,"^")
SET TOTALV=TOTALV+$PIECE(PRCPDATA,"^",3)
+30 IF $Y>(IOSL-6)
if SCREEN
DO P^PRCPUREP
if $DATA(PRCPFLAG)
QUIT
DO H
WRITE !
End DoDot:3
+31 IF $GET(PRCPFLAG)
QUIT
+32 SET TOTALQI=TOTALQI+TOTALQ
SET TOTALVI=TOTALVI+TOTALV
+33 SET ^TMP($JOB,"PRCPRISP TOT",DISTRPT)=$GET(^TMP($JOB,"PRCPRISP TOT",DISTRPT))+TOTALV
+34 IF 'PRCPSUMM
if $X>20
WRITE !
WRITE ?27,"TOTALS BY DISTR. PT: ",$JUSTIFY(TOTALQ,10),$JUSTIFY(TOTALV,22,2)
End DoDot:2
+35 IF $GET(PRCPFLAG)
QUIT
+36 if 'PRCPSUMM
WRITE !?32,"TOTALS BY ITEM: ",$JUSTIFY(TOTALQI,10),$JUSTIFY(TOTALVI,22,2)
End DoDot:1
+37 IF $GET(PRCPFLAG)
DO Q
QUIT
+38 IF $Y>(IOSL-8)
if SCREEN
DO P^PRCPUREP
if $DATA(PRCPFLAG)
QUIT
DO H
+39 WRITE !!,"TOTAL SALES TO DISTRIBUTION POINTS:"
+40 SET TOTALV=0
SET DISTRPT=""
FOR
SET DISTRPT=$ORDER(^TMP($JOB,"PRCPRISP TOT",DISTRPT))
if DISTRPT=""!($GET(PRCPFLAG))
QUIT
SET %=$GET(^(DISTRPT))
Begin DoDot:1
+41 WRITE !?10,DISTRPT,?40,$JUSTIFY(%,20,2)
+42 SET TOTALV=TOTALV+%
+43 IF $Y>(IOSL-4)
if SCREEN
DO P^PRCPUREP
if $DATA(PRCPFLAG)
QUIT
DO H
End DoDot:1
+44 IF $GET(PRCPFLAG)
DO Q
QUIT
+45 WRITE !?10,"TOTAL",?40,$JUSTIFY(TOTALV,20,2)
+46 DO END^PRCPUREP
Q DO ^%ZISC
KILL ^TMP($JOB,"PRCPURS3"),^TMP($JOB,"PRCPRISP"),^TMP($JOB,"PRCPRISP TOT")
+1 QUIT
+2 ;
H SET %=NOW_" PAGE "_PAGE
SET PAGE=PAGE+1
IF PAGE'=2!(SCREEN)
WRITE @IOF
+1 WRITE $CHAR(13),"INVENTORY SALES FOR: ",$EXTRACT(PRCP("IN"),1,20),?(80-$LENGTH(%)),%
+2 WRITE !?5,"INVENTORY SALES DATE RANGE: ",DATESDT," TO ",DATEEDT
+3 SET %=""
SET $PIECE(%,"-",81)=""
+4 IF PRCPSUMM
WRITE !?1,"*** ONLY SUMMARY OF SALES PRINTED ***",!,%
QUIT
+5 WRITE !,"DESCRIPTION",?37,"DATE ISSUED",$JUSTIFY("QUANTITY",10),$JUSTIFY("SELL COST",10),$JUSTIFY("TOTAL VALUE",12),!,%
+6 QUIT