VistA-FOIAVistA/r/IFCAP-PRC-PRX--PRCA--PRCN/PRCPRSS1.m

156 lines
6.7 KiB
Mathematica

PRCPRSS1 ;WOIFO/DAP-stock status report for primaries and secondaries; 10/16/06 2:17pm
V ;;5.1;IFCAP;**98**;Oct 20, 2000;Build 37
;Per VHA Directive 2004-038, this routine should not be modified.
Q
;
;
PRINT ; print report
N DAYS,MONTH,NOW,PAGE,PRCPFLAG,SCREEN,TOTCLOS,TOTISS,TOTN,TOTOPEN,TOTVAL,ITEMCTA,X,Y
S Y=DATESTRT D DD^%DT S MONTH=Y
S DAYS=$P("31^28^31^30^31^30^31^31^30^31^30^31","^",+$E(DATESTRT,4,5))
I DAYS=28 S %=(17+$E(DATESTRT))_$E(DATESTRT,2,3),DAYS=$S(%#400=0:29,(%#4=0&(%#100'=0)):29,1:28)
;
;*98 Added looping logic to go through print cycle for each type of
;item report (Standard/ODI/All)
;
N P,PRCPTP,PRCPTP2,NODE1
S PAGE=1
F P=1:1:3 S NODE1=P D
. I $G(PRCPFLAG) Q
. I P=1 S PRCPTP="STANDARD",PRCPTP2="STD"
. I P=2 S PRCPTP="ON-DEMAND",PRCPTP2="OD"
. I P=3 S PRCPTP="ALL",PRCPTP2=PRCPTP
. D REP^PRCPRSS1
. Q
;
D Q^PRCPRSS1
Q
;
REP ;*98 Added header to display type of reporting, moved header logic
;from earlier in routine to support looping structure
;
I P>1 D LC
I $G(PRCPFLAG) Q
S SCREEN=$$SCRPAUSE^PRCPUREP D NOW^%DTC S Y=% D DD^%DT S NOW=Y U IO I P=1 D HEAD
;
W !,"INVENTORY ("_PRCPTP_" ITEMS)"
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
;
W !,"OPEN BALANCE",?14 S TOTOPEN=0 F ACCT=1,2,3,6,8 S %=$P($G(^TMP($J,NODE1,"OPEN",ACCT)),"^",2) S OPEN(ACCT)=%,TOTOPEN=TOTOPEN+% W $$SHOWVALU(%)
W $$SHOWVALU(TOTOPEN)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
W !!,"RECEIPTS",?14 S TOTAL=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"REC",ACCT)),TOTAL=TOTAL+%,OPEN(ACCT)=$G(OPEN(ACCT))+% W $$SHOWVALU(%)
W $$SHOWVALU(TOTAL)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
;*98 Modified report to replace "ISSUES" with "USAGE"
W !,"USAGE",?14 S TOTISS=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"ISS",ACCT)),TOTISS=TOTISS+%,OPEN(ACCT)=$G(OPEN(ACCT))+% W $$SHOWVALU(%)
W $$SHOWVALU(TOTISS)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
W !,"ADJUSTMENTS",?14 S TOTAL=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"ADJ",ACCT)),TOTAL=TOTAL+%,OPEN(ACCT)=$G(OPEN(ACCT))+% W $$SHOWVALU(%)
W $$SHOWVALU(TOTAL)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
S %="",$P(%,"=",80)=""
W !,%,!,"CLOSE BALANCE",?14 S TOTCLOS=0 F ACCT=1,2,3,6,8 S %=$G(OPEN(ACCT)),TOTCLOS=TOTCLOS+% W $$SHOWVALU(%)
W $$SHOWVALU(TOTCLOS)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
W !!!,"# RECEIPTS",?13 S TOTAL=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"RECN",ACCT)),TOTAL=TOTAL+%,TOTN(ACCT)=% W $J(%,11,0)
W $J(TOTAL,11,0)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
;*98 Modified report to replace "ISSUES" with "USAGES"
W !,"# USAGE",?13 S TOTAL=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"ISSN",ACCT)),TOTAL=TOTAL+%,TOTN(ACCT)=$G(TOTN(ACCT))+% W $J(%,11,0)
W $J(TOTAL,11,0)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
W !,"# ADJUSTMENTS",?13 S TOTAL=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"ADJN",ACCT)),TOTAL=TOTAL+%,TOTN(ACCT)=$G(TOTN(ACCT))+% W $J(%,11,0)
W $J(TOTAL,11,0)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
S %="",$P(%,"=",80)=""
W !,%,!,"# TOTAL",?13 S TOTAL=0 F ACCT=1,2,3,6,8 S %=$G(TOTN(ACCT)),TOTAL=TOTAL+% W $J(%,11,0)
W $J(TOTAL,11,0)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
W !!,"TURNOVER",?13 F ACCT=1,2,3,6,8 S %=($G(^TMP($J,NODE1,"ISS",ACCT))*365)/DAYS,%=$S('$G(OPEN(ACCT)):"X",1:-%/OPEN(ACCT)) W $J(%,11,2)
S %=(TOTISS*365)/DAYS,%=$S('TOTCLOS:"X",1:-%/TOTCLOS) W $J(%,11,2)
;*98 Added indicator of type of report (Standard/ODI/All)
W !,"("_PRCPTP_" ITEMS)"
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
;
;*98 Added indicator of type of report (Standard/ODI/All)
W !!?28,"*** CURRENT DATA ("_PRCPTP_" ITEMS) ***"
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
;
;*98 Rearranged report placement of sections and added indicator of
;type of report (Standard/ODI/All)
;
S Y=$E(DATEINAC,1,5)_"01" D DD^%DT
W !!?2,"INACTIVE ITEMS ("_PRCPTP_" ITEMS) FROM ",Y," TO ",$P(NOW,"@"),!,"# INACTIVE",?13
S TOTAL=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"INACTN",ACCT)),TOTAL=TOTAL+% W $J(%,11,0)
W $J(TOTAL,11,0)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
W !,"$ INACTIVE",?14 S TOTAL=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"INACT",ACCT)),TOTAL=TOTAL+% W $$SHOWVALU(%)
W $$SHOWVALU(TOTAL)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
W !,"% INACTIVE",?13 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"VALUE",ACCT)),%=$S('%:0,1:$G(^TMP($J,NODE1,"INACT",ACCT))/%) W $J(%,11,2)
;
;*98 Moved TOTVAL logic to support reordered processing
S TOTVAL=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"VALUE",ACCT)),TOTVAL=TOTVAL+%
;
S %=$S('TOTVAL:0,1:TOTAL/TOTVAL) W $J(%,11,2)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
S Y=$E(DATELONG,1,5)_"01" D DD^%DT
W !!?2,"LONG SUPPLY ("_PRCPTP_" ITEMS) AVG. FROM ",Y," TO ",$P(NOW,"@"),!?2,"(>90 DAYS)",!,"# LONG SUPPLY",?13
S TOTAL=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"LONGN",ACCT)),TOTAL=TOTAL+% W $J(%,11,0)
W $J(TOTAL,11,0)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
W !,"$ LONG SUPPLY",?14 S TOTAL=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"LONG",ACCT)),TOTAL=TOTAL+% W $$SHOWVALU(%)
W $$SHOWVALU(TOTAL)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
W !,"% LONG SUPPLY",?13 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"VALUE",ACCT)),%=$S('%:0,1:$G(^TMP($J,NODE1,"LONG",ACCT))/%) W $J(%,11,2)
S %=$S('TOTVAL:0,1:TOTAL/TOTVAL) W $J(%,11,2)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
;
;*98 Modified section to display a new section header, item type count,
;and display "$ONHAND" by specific type (Standard/ODI/All)
;
W !!,"# "_PRCPTP2_" ITEMS",?13 S ITEMCTA=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"CNT",ACCT)),ITEMCTA=ITEMCTA+% W $J(%,11,0)
W $J(ITEMCTA,11,0)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
;
W !!,"INVENTORY VALUE"
W !,"$ "_PRCPTP,?14 S TOTVAL=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"VALUE",ACCT)),TOTVAL=TOTVAL+% W $$SHOWVALU(%)
W $$SHOWVALU(TOTVAL)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
W !,"$ DUEINS",?14 S X=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"DUEIN",ACCT)),X=X+% W $$SHOWVALU(%)
W $$SHOWVALU(X)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
W !,"$ DUEOUTS",?14 S X=0 F ACCT=1,2,3,6,8 S %=$G(^TMP($J,NODE1,"DUEOUT",ACCT)),X=X+% W $$SHOWVALU(%)
W $$SHOWVALU(X)
I $Y>(IOSL-7) D LC G:$G(PRCPFLAG) Q
;
;*98 Modified report to not show the section addressing nonissuable
;items for primary and secondary inventory points
Q
;
;
Q ;Tag ends printing and exits routine
D END^PRCPUREP
D ^%ZISC Q
;
;
SHOWVALU(V1) ;show value
N % S %="+" S:+V1=0 %=" " I V1<0 S V1=-V1,%="-"
Q $J(V1,10,2)_%
;
LC ;*98 Moved line control logic into subroutines
I SCREEN W ! D P^PRCPUREP I $D(PRCPFLAG) Q
;
HEAD ;heading
N PRCPT
S %=NOW_" PAGE: "_PAGE,PAGE=PAGE+1 I PAGE'=2!(SCREEN) W @IOF
W !,"STOCK STATUS REPORT FOR: ",$E(PRCP("IN"),1,20),?(80-$L(%)),%
;*98 Added type of reporting (Standard/ODI/All) to header
S PRCPT=PRCPTP_" ITEMS"
W !?5,"TRANSACTIONS FOR THE MONTH-YEAR: ",MONTH,?(80-$L(PRCPT)),PRCPT
;
W !,"SUMMARY",?14,$J("ACCT 1",11),$J("ACCT 2",11),$J("ACCT 3",11),$J("ACCT 6",11),$J("ACCT 8",11),$J("TOTAL",11)
S %="",$P(%,"-",81)="" W !,%
Q