BRARPT2 ; IHS/ADC/PDW - Print Rad Exam Roster by Rad, Proc, Diag Code. ;
;;5.0;Radiology/Nuclear Medicine;;Feb 20, 2004
;
PRINT ;
U IO S RAPAGE=0,BRAY=1
;---> N=DIV,O=RAD,P=PROC,Q=PAT,R=DATE,X=NODEDATA
N N,O,P,Q,R,X
S N=0 F S N=$O(^TMP($J,"RA",N)) Q:N="" D Q:'BRAY
.S O=0 F S O=$O(^TMP($J,"RA",N,O)) Q:O="" D HD Q:'BRAY D Q:'BRAY
..S P=0
..F S P=$O(^TMP($J,"RA",N,O,P)) Q:P="" D HD2 Q:'BRAY D Q:'BRAY
...S Q=0 F S Q=$O(^TMP($J,"RA",N,O,P,Q)) Q:Q="" D Q:'BRAY
....S R=0 F S R=$O(^TMP($J,"RA",N,O,P,Q,R)) Q:R="" D Q:'BRAY
.....S X=^TMP($J,"RA",N,O,P,Q,R) D LINE
EXIT ;
W:$E(IOST)'="C" @IOF
I $E(IOST)="C"&('$D(IO("S")))&(BRAY) W ! S DIR(0)="E" D ^DIR
D ^%ZISC
Q
;
LINE ;---> PRINT A LINE OF PATIENT DATA.
I ($Y+6)>IOSL D HD2 Q:'BRAY
W !,$P(X,U,2),?10,$E(Q,1,20) ;---> CHART#, NAME
W ?31,$E(R,4,7),$E(R,2,3),"-",$P(X,U) ;---> DATE-CASE#
W ?43,$E($P(X,U,3),1,4) ;---> EXAM STATUS
W ?49,$E($P(X,U,4),1,31) ;---> DIAGNOSTIC CODE
Q
;
HD ;---> HEADER
N X,Y
I $E(IOST)="C",RAPAGE W ! S DIR(0)="E" D ^DIR S BRAY=Y Q:'BRAY
W:RAPAGE @IOF W:'RAPAGE&($E(IOST)="C") @IOF
W ?8," *** EXAM ROSTER BY RADIOLOGIST, PROCEDURE, DIAG CODE ***"
S RAPAGE=RAPAGE+1 W ?70,"Page: ",RAPAGE
W !!?1,"Division: ",$P(^DIC(4,N,0),U),?52,"For period: "
S Y=RABEGDT D D^RAUTL W ?64,Y,?76,"to"
S X="NOW",%DT="T" D ^%DT K %DT D D^RAUTL W !?1,"Run Date: ",Y
S Y=RAENDDT D D^RAUTL W ?64,Y
W ! F I=1:1:80 W "-"
W !,"Chart#",?10,"Patient",?31,"Date-Case#",?43,"Status"
W ?53,"Diagnostic Code"
W ! F I=1:1:80 W "-"
Q
;
HD2 ;---> SUBHEADER
I ($Y+9)>IOSL D HD Q:'BRAY
W !!?4,"RADIOLOGIST: ",O,?40,"PROCEDURE: ",P
W !?4 F I=1:1:$L(O)+13 W "-"
W ?40 F I=1:1:$L(P)+11 W "-"
Q
BRARPT2 ; IHS/ADC/PDW - Print Rad Exam Roster by Rad, Proc, Diag Code. ;
+1 ;;5.0;Radiology/Nuclear Medicine;;Feb 20, 2004
+2 ;
PRINT ;
+1 USE IO
SET RAPAGE=0
SET BRAY=1
+2 ;---> N=DIV,O=RAD,P=PROC,Q=PAT,R=DATE,X=NODEDATA
+3 NEW N,O,P,Q,R,X
+4 SET N=0
FOR
SET N=$ORDER(^TMP($JOB,"RA",N))
IF N=""
QUIT
Begin DoDot:1
+5 SET O=0
FOR
SET O=$ORDER(^TMP($JOB,"RA",N,O))
IF O=""
QUIT
DO HD
IF 'BRAY
QUIT
Begin DoDot:2
+6 SET P=0
+7 FOR
SET P=$ORDER(^TMP($JOB,"RA",N,O,P))
IF P=""
QUIT
DO HD2
IF 'BRAY
QUIT
Begin DoDot:3
+8 SET Q=0
FOR
SET Q=$ORDER(^TMP($JOB,"RA",N,O,P,Q))
IF Q=""
QUIT
Begin DoDot:4
+9 SET R=0
FOR
SET R=$ORDER(^TMP($JOB,"RA",N,O,P,Q,R))
IF R=""
QUIT
Begin DoDot:5
+10 SET X=^TMP($JOB,"RA",N,O,P,Q,R)
DO LINE
End DoDot:5
IF 'BRAY
QUIT
End DoDot:4
IF 'BRAY
QUIT
End DoDot:3
IF 'BRAY
QUIT
End DoDot:2
IF 'BRAY
QUIT
End DoDot:1
IF 'BRAY
QUIT
EXIT ;
+1 IF $EXTRACT(IOST)'="C"
WRITE @IOF
+2 IF $EXTRACT(IOST)="C"&('$DATA(IO("S")))&(BRAY)
WRITE !
SET DIR(0)="E"
DO ^DIR
+3 DO ^%ZISC
+4 QUIT
+5 ;
LINE ;---> PRINT A LINE OF PATIENT DATA.
+1 IF ($Y+6)>IOSL
DO HD2
IF 'BRAY
QUIT
+2 ;---> CHART#, NAME
WRITE !,$PIECE(X,U,2),?10,$EXTRACT(Q,1,20)
+3 ;---> DATE-CASE#
WRITE ?31,$EXTRACT(R,4,7),$EXTRACT(R,2,3),"-",$PIECE(X,U)
+4 ;---> EXAM STATUS
WRITE ?43,$EXTRACT($PIECE(X,U,3),1,4)
+5 ;---> DIAGNOSTIC CODE
WRITE ?49,$EXTRACT($PIECE(X,U,4),1,31)
+6 QUIT
+7 ;
HD ;---> HEADER
+1 NEW X,Y
+2 IF $EXTRACT(IOST)="C"
IF RAPAGE
WRITE !
SET DIR(0)="E"
DO ^DIR
SET BRAY=Y
IF 'BRAY
QUIT
+3 IF RAPAGE
WRITE @IOF
IF 'RAPAGE&($EXTRACT(IOST)="C")
WRITE @IOF
+4 WRITE ?8," *** EXAM ROSTER BY RADIOLOGIST, PROCEDURE, DIAG CODE ***"
+5 SET RAPAGE=RAPAGE+1
WRITE ?70,"Page: ",RAPAGE
+6 WRITE !!?1,"Division: ",$PIECE(^DIC(4,N,0),U),?52,"For period: "
+7 SET Y=RABEGDT
DO D^RAUTL
WRITE ?64,Y,?76,"to"
+8 SET X="NOW"
SET %DT="T"
DO ^%DT
KILL %DT
DO D^RAUTL
WRITE !?1,"Run Date: ",Y
+9 SET Y=RAENDDT
DO D^RAUTL
WRITE ?64,Y
+10 WRITE !
FOR I=1:1:80
WRITE "-"
+11 WRITE !,"Chart#",?10,"Patient",?31,"Date-Case#",?43,"Status"
+12 WRITE ?53,"Diagnostic Code"
+13 WRITE !
FOR I=1:1:80
WRITE "-"
+14 QUIT
+15 ;
HD2 ;---> SUBHEADER
+1 IF ($Y+9)>IOSL
DO HD
IF 'BRAY
QUIT
+2 WRITE !!?4,"RADIOLOGIST: ",O,?40,"PROCEDURE: ",P
+3 WRITE !?4
FOR I=1:1:$LENGTH(O)+13
WRITE "-"
+4 WRITE ?40
FOR I=1:1:$LENGTH(P)+11
WRITE "-"
+5 QUIT