MCARORA ; GENERATED FROM 'MCRHPROG' PRINT TEMPLATE (#1010) ; 08/18/14 ; (FILE 701, 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)
S I(0)="^MCAR(701,",J(0)=701
D T Q:'DN D N D N D N:$X>0 Q:'DN W ?0 W "PROVIDER: "
S X=$G(^MCAR(701,D0,"PROV")) S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^VA(200,Y,0))#2:$P(^(0),U),1:Y) W $E(Y,1,35)
D N:$X>0 Q:'DN W ?0 W "PROBLEM LIST"
S X=$G(^MCAR(701,D0,0)) D T Q:'DN D N D N D N:$X>0 Q:'DN W ?0 S Y=$P(X,U,1) D DT
D N:$X>0 Q:'DN W ?0 W "PATIENT"
D N:$X>16 Q:'DN W ?16 W "DATE"
D N:$X>29 Q:'DN W ?29 W "DIAGNOSIS"
D N:$X>67 Q:'DN W ?67 W "ICD CODE"
D N:$X>0 Q:'DN W ?0 W "-------"
D N:$X>16 Q:'DN W ?16 W "----"
D N:$X>29 Q:'DN W ?29 W "---------"
D N:$X>67 Q:'DN W ?67 W "---------"
D N:$X>0 Q:'DN W ?0 S Y=$P(X,U,2) S Y=$S(Y="":Y,$D(^MCAR(690,Y,0))#2:$P(^(0),U),1:Y) S Y=$S(Y="":Y,$D(^DPT(Y,0))#2:$P(^(0),U),1:Y) W $E(Y,1,15)
S I(1)=13,J(1)=701.0615 F D1=0:0 Q:$O(^MCAR(701,D0,13,D1))'>0 X:$D(DSC(701.0615)) DSC(701.0615) S D1=$O(^(D1)) Q:D1'>0 D:$X>17 T Q:'DN D A1
G A1R
A1 ;
D N:$X>16 Q:'DN W ?16 S DIP(1)=$S($D(^MCAR(701,D0,13,D1,0)):^(0),1:"") S X=$P(DIP(1),U,2) S:X X=$E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3) K DIP K:DN Y W $E(X,1,10)
S X=$G(^MCAR(701,D0,13,D1,0)) D N:$X>29 Q:'DN W ?29 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(697.5,Y,0))#2:$P(^(0),U),1:Y) W $E(Y,1,35)
W ?66 D PRINT^MCRH2 K DIP K:DN Y
Q
A1R ;
K Y
Q
HEAD ;
W !,"--------------------------------------------------------------------------------",!!
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HMCARORA 1986 printed Dec 13, 2024@02:13:47 Page 2
MCARORA ; GENERATED FROM 'MCRHPROG' PRINT TEMPLATE (#1010) ; 08/18/14 ; (FILE 701, 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 SET I(0)="^MCAR(701,"
SET J(0)=701
+3 DO T
if 'DN
QUIT
DO N
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "PROVIDER: "
+4 SET X=$GET(^MCAR(701,D0,"PROV"))
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^VA(200,Y,0))#2:$PIECE(^(0),U),1:Y)
WRITE $EXTRACT(Y,1,35)
+5 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "PROBLEM LIST"
+6 SET X=$GET(^MCAR(701,D0,0))
DO T
if 'DN
QUIT
DO N
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
SET Y=$PIECE(X,U,1)
DO DT
+7 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "PATIENT"
+8 if $X>16
DO N
if 'DN
QUIT
WRITE ?16
WRITE "DATE"
+9 if $X>29
DO N
if 'DN
QUIT
WRITE ?29
WRITE "DIAGNOSIS"
+10 if $X>67
DO N
if 'DN
QUIT
WRITE ?67
WRITE "ICD CODE"
+11 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE "-------"
+12 if $X>16
DO N
if 'DN
QUIT
WRITE ?16
WRITE "----"
+13 if $X>29
DO N
if 'DN
QUIT
WRITE ?29
WRITE "---------"
+14 if $X>67
DO N
if 'DN
QUIT
WRITE ?67
WRITE "---------"
+15 if $X>0
DO N
if 'DN
QUIT
WRITE ?0
SET Y=$PIECE(X,U,2)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(690,Y,0))#2:$PIECE(^(0),U),1:Y)
SET Y=$SELECT(Y="":Y,$DATA(^DPT(Y,0))#2:$PIECE(^(0),U),1:Y)
WRITE $EXTRACT(Y,1,15)
+16 SET I(1)=13
SET J(1)=701.0615
FOR D1=0:0
if $ORDER(^MCAR(701,D0,13,D1))'>0
QUIT
if $DATA(DSC(701.0615))
XECUTE DSC(701.0615)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>17
DO T
if 'DN
QUIT
DO A1
+17 GOTO A1R
A1 ;
+1 if $X>16
DO N
if 'DN
QUIT
WRITE ?16
SET DIP(1)=$SELECT($DATA(^MCAR(701,D0,13,D1,0)):^(0),1:"")
SET X=$PIECE(DIP(1),U,2)
if X
SET X=$EXTRACT(X,4,5)_"/"_$EXTRACT(X,6,7)_"/"_$EXTRACT(X,2,3)
KILL DIP
if DN
KILL Y
WRITE $EXTRACT(X,1,10)
+2 SET X=$GET(^MCAR(701,D0,13,D1,0))
if $X>29
DO N
if 'DN
QUIT
WRITE ?29
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(697.5,Y,0))#2:$PIECE(^(0),U),1:Y)
WRITE $EXTRACT(Y,1,35)
+3 WRITE ?66
DO PRINT^MCRH2
KILL DIP
if DN
KILL Y
+4 QUIT
A1R ;
+1 KILL Y
+2 QUIT
HEAD ;
+1 WRITE !,"--------------------------------------------------------------------------------",!!