ANRVRP5 ;BIRM/LDT - VIST STATE LIST ; 05 Aug 98 / 2:18 PM
;;4.0; Visual Impairment Service Team ;**1**;12 Jun 98
EN1 ;Entry point for State List
K ANRVLP W @IOF,!!,"SORT BY STATE",!!
D SEL I '$D(ANRVLP),SEL'="A" G QUIT
K %ZIS,IOP S %ZIS="QM",%ZIS("B")="" D ^%ZIS I POP W !,"NO DEVICE SELECTED OR REPORT PRINTED!!" G QUIT
I $D(IO("Q")) K IO("Q") S ZTDESC="VIST ROSTER LIST BY STATE",ZTRTN="DEQ^ANRVRP5" S:$D(ANRVLP) ZTSAVE("ANRVLP(")="" S:$D(SEL) ZTSAVE("SEL")=""
I D ^%ZTLOAD K ZTSK G QUIT
U IO
DEQ ;Entry point when queued.
K ^TMP("ANRV",$J)
S ANRVP=0 F S ANRVP=$O(^ANRV(2040,ANRVP)) Q:'ANRVP I $P($G(^ANRV(2040,ANRVP,13)),U,2)'="I" S DFN=$P($G(^ANRV(2040,ANRVP,0)),U) D 4^VADPT,SETTMP
S HDR="VIST ROSTER LIST BY STATE"
S (PG,QFLG)=0,$P(LN,"-",81)="" D NOW^%DTC S Y=$E(%,1,12) X ^DD("DD") S HDT=Y D HDR
I '$D(^TMP("ANRV",$J)) W !,"NO DATA TO PRINT!" G QUIT
D REPORT
;
QUIT K %,%H,%I,%T,%Y,ANRVP,ANRV,ANRVLP,DFN,HDR,HDT,LN,NAME,PG,POP,QFLG,SEL,STATE,STATE2,SUB,X,Y,XX,DTOUT,DUOUT,DIRUT,^TMP("ANRV",$J) D KVAR^VADPT,KVA^VADPT
W:$E(IOST)'="C" @IOF D ^%ZISC S:$D(ZTQUEUED) ZTREQ="@"
Q
;
SETTMP ;Set ^TMP for report
I $D(ANRVLP),VAPA(5)]"",$D(ANRVLP($P(VAPA(5),U,2))) S ^TMP("ANRV",$J,$P(VAPA(5),U,2),VADM(1))=VADM(1)_U_$P(VADM(2),U,2)_U_$P(VAPA(5),U,2)
I $D(SEL),SEL="A" S SUB=$S(VAPA(5)]"":$P(VAPA(5),U,2),1:"zzz"),^TMP("ANRV",$J,SUB,VADM(1))=VADM(1)_U_$P(VADM(2),U,2)_U_$P(VAPA(5),U,2)
Q
;
HDR ;Report header
I $E(IOST)="C",PG>0 S DIR(0)="E" D ^DIR K DIR I 'Y S QFLG=1 Q
S PG=PG+1 W:$Y!($E(IOST)="C") @IOF Q:(PG>1)&($E(IOST)="C") W !,HDR,?45,"Printed ",HDT,?72,"Page ",PG,!!,"NAME",?27,"SSN",?47,"STATE",!,LN
Q
;
REPORT ;Print Report
S (STATE,STATE2,NAME)="" F S STATE=$O(^TMP("ANRV",$J,STATE)) Q:STATE="" F S NAME=$O(^TMP("ANRV",$J,STATE,NAME)) Q:NAME="" D
.Q:QFLG D:$Y+5>IOSL HDR Q:QFLG I STATE'=STATE2,STATE2]"" W !
.F XX=1:1:3 S ANRV(XX)=$P($G(^TMP("ANRV",$J,STATE,NAME)),U,XX)
.Q:QFLG D:$Y+5>IOSL HDR Q:QFLG W !,ANRV(1),?27,ANRV(2),?47,$S(ANRV(3)]"":ANRV(3),1:"NONE")
.S STATE2=STATE
Q:QFLG W !
Q
SEL W !!,"Do you want the report to list:",!?3,"(A)ll states or",!?3,"(S)elect states",!!
S DIR(0)="SAOBM^A:ALL;S:SELECTED",DIR("A")="Choose A or S: ",DIR("?")="^D HELPSEL^ANRVRP5" D ^DIR K DIR
S SEL=Y I SEL="A" Q
S:SEL="" SEL="^" G:SEL="^" QUIT2
W !
ASKST K X,Y S DIC(0)="QEAM",DIC="^DIC(5," D ^DIC K DIC
I Y<0!($D(DTOUT))!($D(DUOUT)) G QUIT2
I Y>0 D SETLP G ASKST
QUIT2 K %,DTOUT,DUOUT,X,Y Q
SETLP S ANRVLP($P(Y,U,2))=""
Q
HELPSEL ;
W !!,"Enter:",!?3,"""A"" to list patients for ALL states from the VIST ROSTER file.",!?3,"""S"" to select only a specific state or states.",!?3,"""^"" or <return> to halt." Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HANRVRP5 2716 printed Nov 22, 2024@17:55:50 Page 2
ANRVRP5 ;BIRM/LDT - VIST STATE LIST ; 05 Aug 98 / 2:18 PM
+1 ;;4.0; Visual Impairment Service Team ;**1**;12 Jun 98
EN1 ;Entry point for State List
+1 KILL ANRVLP
WRITE @IOF,!!,"SORT BY STATE",!!
+2 DO SEL
IF '$DATA(ANRVLP)
IF SEL'="A"
GOTO QUIT
+3 KILL %ZIS,IOP
SET %ZIS="QM"
SET %ZIS("B")=""
DO ^%ZIS
IF POP
WRITE !,"NO DEVICE SELECTED OR REPORT PRINTED!!"
GOTO QUIT
+4 IF $DATA(IO("Q"))
KILL IO("Q")
SET ZTDESC="VIST ROSTER LIST BY STATE"
SET ZTRTN="DEQ^ANRVRP5"
if $DATA(ANRVLP)
SET ZTSAVE("ANRVLP(")=""
if $DATA(SEL)
SET ZTSAVE("SEL")=""
+5 IF $TEST
DO ^%ZTLOAD
KILL ZTSK
GOTO QUIT
+6 USE IO
DEQ ;Entry point when queued.
+1 KILL ^TMP("ANRV",$JOB)
+2 SET ANRVP=0
FOR
SET ANRVP=$ORDER(^ANRV(2040,ANRVP))
if 'ANRVP
QUIT
IF $PIECE($GET(^ANRV(2040,ANRVP,13)),U,2)'="I"
SET DFN=$PIECE($GET(^ANRV(2040,ANRVP,0)),U)
DO 4^VADPT
DO SETTMP
+3 SET HDR="VIST ROSTER LIST BY STATE"
+4 SET (PG,QFLG)=0
SET $PIECE(LN,"-",81)=""
DO NOW^%DTC
SET Y=$EXTRACT(%,1,12)
XECUTE ^DD("DD")
SET HDT=Y
DO HDR
+5 IF '$DATA(^TMP("ANRV",$JOB))
WRITE !,"NO DATA TO PRINT!"
GOTO QUIT
+6 DO REPORT
+7 ;
QUIT KILL %,%H,%I,%T,%Y,ANRVP,ANRV,ANRVLP,DFN,HDR,HDT,LN,NAME,PG,POP,QFLG,SEL,STATE,STATE2,SUB,X,Y,XX,DTOUT,DUOUT,DIRUT,^TMP("ANRV",$JOB)
DO KVAR^VADPT
DO KVA^VADPT
+1 if $EXTRACT(IOST)'="C"
WRITE @IOF
DO ^%ZISC
if $DATA(ZTQUEUED)
SET ZTREQ="@"
+2 QUIT
+3 ;
SETTMP ;Set ^TMP for report
+1 IF $DATA(ANRVLP)
IF VAPA(5)]""
IF $DATA(ANRVLP($PIECE(VAPA(5),U,2)))
SET ^TMP("ANRV",$JOB,$PIECE(VAPA(5),U,2),VADM(1))=VADM(1)_U_$PIECE(VADM(2),U,2)_U_$PIECE(VAPA(5),U,2)
+2 IF $DATA(SEL)
IF SEL="A"
SET SUB=$SELECT(VAPA(5)]"":$PIECE(VAPA(5),U,2),1:"zzz")
SET ^TMP("ANRV",$JOB,SUB,VADM(1))=VADM(1)_U_$PIECE(VADM(2),U,2)_U_$PIECE(VAPA(5),U,2)
+3 QUIT
+4 ;
HDR ;Report header
+1 IF $EXTRACT(IOST)="C"
IF PG>0
SET DIR(0)="E"
DO ^DIR
KILL DIR
IF 'Y
SET QFLG=1
QUIT
+2 SET PG=PG+1
if $Y!($EXTRACT(IOST)="C")
WRITE @IOF
if (PG>1)&($EXTRACT(IOST)="C")
QUIT
WRITE !,HDR,?45,"Printed ",HDT,?72,"Page ",PG,!!,"NAME",?27,"SSN",?47,"STATE",!,LN
+3 QUIT
+4 ;
REPORT ;Print Report
+1 SET (STATE,STATE2,NAME)=""
FOR
SET STATE=$ORDER(^TMP("ANRV",$JOB,STATE))
if STATE=""
QUIT
FOR
SET NAME=$ORDER(^TMP("ANRV",$JOB,STATE,NAME))
if NAME=""
QUIT
Begin DoDot:1
+2 if QFLG
QUIT
if $Y+5>IOSL
DO HDR
if QFLG
QUIT
IF STATE'=STATE2
IF STATE2]""
WRITE !
+3 FOR XX=1:1:3
SET ANRV(XX)=$PIECE($GET(^TMP("ANRV",$JOB,STATE,NAME)),U,XX)
+4 if QFLG
QUIT
if $Y+5>IOSL
DO HDR
if QFLG
QUIT
WRITE !,ANRV(1),?27,ANRV(2),?47,$SELECT(ANRV(3)]"":ANRV(3),1:"NONE")
+5 SET STATE2=STATE
End DoDot:1
+6 if QFLG
QUIT
WRITE !
+7 QUIT
SEL WRITE !!,"Do you want the report to list:",!?3,"(A)ll states or",!?3,"(S)elect states",!!
+1 SET DIR(0)="SAOBM^A:ALL;S:SELECTED"
SET DIR("A")="Choose A or S: "
SET DIR("?")="^D HELPSEL^ANRVRP5"
DO ^DIR
KILL DIR
+2 SET SEL=Y
IF SEL="A"
QUIT
+3 if SEL=""
SET SEL="^"
if SEL="^"
GOTO QUIT2
+4 WRITE !
ASKST KILL X,Y
SET DIC(0)="QEAM"
SET DIC="^DIC(5,"
DO ^DIC
KILL DIC
+1 IF Y<0!($DATA(DTOUT))!($DATA(DUOUT))
GOTO QUIT2
+2 IF Y>0
DO SETLP
GOTO ASKST
QUIT2 KILL %,DTOUT,DUOUT,X,Y
QUIT
SETLP SET ANRVLP($PIECE(Y,U,2))=""
+1 QUIT
HELPSEL ;
+1 WRITE !!,"Enter:",!?3,"""A"" to list patients for ALL states from the VIST ROSTER file.",!?3,"""S"" to select only a specific state or states.",!?3,"""^"" or <return> to halt."
QUIT