RACTRT ; GENERATED FROM 'RA REPORT PRINT STATUS' PRINT TEMPLATE (#612) ; 08/23/96 ; (FILE 74, MARGIN=80)
G BEGIN
N W !
T W:$X ! I '$D(DIOT(2)),DN,$D(IOSL),$S('$D(DIWF):1,$P(DIWF,"B",2):$P(DIWF,"B",2),1:1)+$Y'<IOSL,$D(^UTILITY($J,1))#2,^(1)?1U1P1E.E X ^(1)
S DISTP=DISTP+1,DILCT=DILCT+1 D:'(DISTP#100) CSTP^DIO2
Q
DT I $G(DUZ("LANG"))>1,Y W $$OUT^DIALOGU(Y,"DD") Q
I Y W $P("JAN^FEB^MAR^APR^MAY^JUN^JUL^AUG^SEP^OCT^NOV^DEC",U,$E(Y,4,5))_" " W:Y#100 $J(Y#100\1,2)_"," W Y\10000+1700 W:Y#1 " "_$E(Y_0,9,10)_":"_$E(Y_"000",11,12) Q
W Y Q
M D @DIXX
Q
BEGIN ;
S:'$D(DN) DN=1 S DISTP=$G(DISTP),DILCT=$G(DILCT)
I $D(DXS)<9 F X=0:0 S X=$O(^DIPT(612,"DXS",X)) Q:'X S Y=$O(^(X,"")) F X=X:0 Q:Y="" S DXS(X,Y)=^(Y),Y=$O(^(Y))
D N:$X>0 Q:'DN W ?0 W "Report :"
S X=$G(^RARPT(D0,0)) W ?12,$E($P(X,U,1),1,12)
D N:$X>35 Q:'DN W ?35 W "Patient :"
W ?46 S Y=$P(X,U,2) S Y=$S(Y="":Y,$D(^DPT(Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,20)
W ?68 S RADFN=+$P(^RARPT(D0,0),U,2) W $$SSN^RAUTL(RADFN) K RADFN,RASSN K DIP K:DN Y
D N:$X>0 Q:'DN W ?0 W "Procedure:"
W ?12 S RAEXFLD="PROC" D ^RARTFLDS K RAEXFLD W $E(X,1,20) K Y(74,102)
D N:$X>37 Q:'DN W ?37 W "Verified:"
S X=$G(^RARPT(D0,0)) W ?48 S Y=$P(X,U,7) D DT
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "Routing Queue"
D N:$X>24 Q:'DN W ?24 W "Date Printed"
D N:$X>44 Q:'DN W ?44 W "Printed By"
D N:$X>62 Q:'DN W ?62 W "Ward/Clinic"
D N:$X>4 Q:'DN W ?4 W "-------------"
D N:$X>24 Q:'DN W ?24 W "------------"
D N:$X>44 Q:'DN W ?44 W "----------"
D N:$X>62 Q:'DN W ?62 W "-----------"
S DIXX(1)="A1",I(0,0)=D0 S I(0,0)=$S($D(D0):D0,1:"") X DXS(1,9.2) S X="" S D0=I(0,0)
G A1R
A1 ;
I $D(DSC(74.4)) X DSC(74.4) E Q
W:$X>75 ! S I(100)="^RABTCH(74.4,",J(100)=74.4
S X=$G(^RABTCH(74.4,D0,0)) D N:$X>4 Q:'DN W ?4 S Y=$P(X,U,11) S Y=$S(Y="":Y,$D(^RABTCH(74.3,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,30)
D N:$X>24 Q:'DN W ?24 S Y=$P(X,U,4) D DT
D N:$X>44 Q:'DN W ?44 S Y=$P(X,U,3) S Y=$S(Y="":Y,$D(^VA(200,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,35)
D N:$X>62 Q:'DN W ?62 X DXS(2,9.3) S X=$S(DIP(102):DIP(103),DIP(104):X) K DIP K:DN Y W X
Q
A1R ;
K J(100),I(100) S:$D(I(0,0)) D0=I(0,0)
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 S X="=",DIP(1)=X,DIP(2)=X,X=$S($D(IOM):IOM,1:80) S X=X,X1=DIP(1) S %=X,X="" Q:X1="" S $P(X,X1,%\$L(X1)+1)=X1,X=$E(X,1,%) K DIP K:DN Y W X
K Y
Q
HEAD ;
W !,"--------------------------------------------------------------------------------",!!
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HRACTRT 2469 printed Nov 22, 2024@17:44:23 Page 2
RACTRT ; GENERATED FROM 'RA REPORT PRINT STATUS' PRINT TEMPLATE (#612) ; 08/23/96 ; (FILE 74, MARGIN=80)
+1 GOTO BEGIN
N WRITE !
T if $X
WRITE !
IF '$DATA(DIOT(2))
IF DN
IF $DATA(IOSL)
IF $SELECT('$DATA(DIWF):1,$PIECE(DIWF,"B",2):$PIECE(DIWF,"B",2),1:1)+$Y'<IOSL
IF $DATA(^UTILITY($JOB,1))#2
IF ^(1)?1U1P1E.E
XECUTE ^(1)
+1 SET DISTP=DISTP+1
SET DILCT=DILCT+1
if '(DISTP#100)
DO CSTP^DIO2
+2 QUIT
DT IF $GET(DUZ("LANG"))>1
IF Y
WRITE $$OUT^DIALOGU(Y,"DD")
QUIT
+1 IF Y
WRITE $PIECE("JAN^FEB^MAR^APR^MAY^JUN^JUL^AUG^SEP^OCT^NOV^DEC",U,$EXTRACT(Y,4,5))_" "
if Y#100
WRITE $JUSTIFY(Y#100\1,2)_","
WRITE Y\10000+1700
if Y#1
WRITE " "_$EXTRACT(Y_0,9,10)_":"_$EXTRACT(Y_"000",11,12)
QUIT
+2 WRITE Y
QUIT
M DO @DIXX
+1 QUIT
BEGIN ;
+1 if '$DATA(DN)
SET DN=1
SET DISTP=$GET(DISTP)
SET DILCT=$GET(DILCT)
+2 IF $DATA(DXS)<9
FOR X=0:0
SET X=$ORDER(^DIPT(612,"DXS",X))
if 'X
QUIT
SET Y=$ORDER(^(X,""))
FOR X=X:0
if Y=""
QUIT
SET DXS(X,Y)=^(Y)
SET Y=$ORDER(^(Y))
+3 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "Report :"
+4 SET X=$GET(^RARPT(D0,0))
WRITE ?12,$EXTRACT($PIECE(X,U,1),1,12)
+5 if $X>35
DO N
if 'DN
QUIT
WRITE ?35
WRITE "Patient :"
+6 WRITE ?46
SET Y=$PIECE(X,U,2)
SET Y=$SELECT(Y="":Y,$DATA(^DPT(Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,20)
+7 WRITE ?68
SET RADFN=+$PIECE(^RARPT(D0,0),U,2)
WRITE $$SSN^RAUTL(RADFN)
KILL RADFN,RASSN
KILL DIP
if DN
KILL Y
+8 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "Procedure:"
+9 WRITE ?12
SET RAEXFLD="PROC"
DO ^RARTFLDS
KILL RAEXFLD
WRITE $EXTRACT(X,1,20)
KILL Y(74,102)
+10 if $X>37
DO N
if 'DN
QUIT
WRITE ?37
WRITE "Verified:"
+11 SET X=$GET(^RARPT(D0,0))
WRITE ?48
SET Y=$PIECE(X,U,7)
DO DT
+12 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "Routing Queue"
+13 if $X>24
DO N
if 'DN
QUIT
WRITE ?24
WRITE "Date Printed"
+14 if $X>44
DO N
if 'DN
QUIT
WRITE ?44
WRITE "Printed By"
+15 if $X>62
DO N
if 'DN
QUIT
WRITE ?62
WRITE "Ward/Clinic"
+16 if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "-------------"
+17 if $X>24
DO N
if 'DN
QUIT
WRITE ?24
WRITE "------------"
+18 if $X>44
DO N
if 'DN
QUIT
WRITE ?44
WRITE "----------"
+19 if $X>62
DO N
if 'DN
QUIT
WRITE ?62
WRITE "-----------"
+20 SET DIXX(1)="A1"
SET I(0,0)=D0
SET I(0,0)=$SELECT($DATA(D0):D0,1:"")
XECUTE DXS(1,9.2)
SET X=""
SET D0=I(0,0)
+21 GOTO A1R
A1 ;
+1 IF $DATA(DSC(74.4))
XECUTE DSC(74.4)
IF '$TEST
QUIT
+2 if $X>75
WRITE !
SET I(100)="^RABTCH(74.4,"
SET J(100)=74.4
+3 SET X=$GET(^RABTCH(74.4,D0,0))
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
SET Y=$PIECE(X,U,11)
SET Y=$SELECT(Y="":Y,$DATA(^RABTCH(74.3,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,30)
+4 if $X>24
DO N
if 'DN
QUIT
WRITE ?24
SET Y=$PIECE(X,U,4)
DO DT
+5 if $X>44
DO N
if 'DN
QUIT
WRITE ?44
SET Y=$PIECE(X,U,3)
SET Y=$SELECT(Y="":Y,$DATA(^VA(200,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,35)
+6 if $X>62
DO N
if 'DN
QUIT
WRITE ?62
XECUTE DXS(2,9.3)
SET X=$SELECT(DIP(102):DIP(103),DIP(104):X)
KILL DIP
if DN
KILL Y
WRITE X
+7 QUIT
A1R ;
+1 KILL J(100),I(100)
if $DATA(I(0,0))
SET D0=I(0,0)
+2 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
SET X="="
SET DIP(1)=X
SET DIP(2)=X
SET X=$SELECT($DATA(IOM):IOM,1:80)
SET X=X
SET X1=DIP(1)
SET %=X
SET X=""
if X1=""
QUIT
SET $PIECE(X,X1,%\$LENGTH(X1)+1)=X1
SET X=$EXTRACT(X,1,%)
KILL DIP
if DN
KILL Y
WRITE X
+3 KILL Y
+4 QUIT
HEAD ;
+1 WRITE !,"--------------------------------------------------------------------------------",!!