MCAROHB ; GENERATED FROM 'MCARHEMB' PRINT TEMPLATE (#986) ; 06/25/01 ; (FILE 694, 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 M DXS=^DIPT(986,"DXS")
S I(0)="^MCAR(694,",J(0)=694
D N:$X>4 Q:'DN W ?4 W "WARD/CLINIC: "
S X=$G(^MCAR(694,D0,0)) D N:$X>17 Q:'DN W ?17 S Y=$P(X,U,4) S Y=$S(Y="":Y,$D(^SC(Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,30)
D N:$X>4 Q:'DN W ?4 W "PROCEDURE: "
X DXS(1,9.4) S X=$S(DIP(2):DIP(3),DIP(4):DIP(5),DIP(6):DIP(7),DIP(8):X) K DIP K:DN Y W X
X DXS(2,9.2) S DIP(3)=X S X=1,DIP(4)=X S X="",X=$S(DIP(2):DIP(3),DIP(4):X) K DIP K:DN Y W X
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "PERFORMED BY:"
S X=$G(^MCAR(694,D0,1)) D N:$X>18 Q:'DN W ?18 S Y=$P(X,U,11) 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>49 Q:'DN W ?49 W "DATE PERFORMED:"
D N:$X>65 Q:'DN W ?65 S DIP(1)=$S($D(^MCAR(694,D0,0)):^(0),1:"") S X=$P(DIP(1),U,8) S:X X=$E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3) K DIP K:DN Y W X
D N:$X>4 Q:'DN W ?4 W "APPROVED BY:"
S X=$G(^MCAR(694,D0,1)) D N:$X>18 Q:'DN W ?18 S Y=$P(X,U,9) 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>49 Q:'DN W ?49 W "DATE APPROVED:"
D N:$X>65 Q:'DN W ?65 S DIP(1)=$S($D(^MCAR(694,D0,1)):^(1),1:"") S X=$P(DIP(1),U,10) S:X X=$E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3) K DIP K:DN Y W X
D N:$X>39 Q:'DN W ?39 W "DATE OF ORIGINAL CONSULT:"
D N:$X>65 Q:'DN W ?65 S DIP(1)=$S($D(^MCAR(694,D0,0)):^(0),1:"") S X=$P(DIP(1),U,7) S:X X=$E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3) K DIP K:DN Y W X
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "INDICATION(S) FOR PERFORMANCE: "
S I(1)=12,J(1)=694.057 F D1=0:0 Q:$O(^MCAR(694,D0,12,D1))'>0 X:$D(DSC(694.057)) DSC(694.057) S D1=$O(^(D1)) Q:D1'>0 D:$X>37 T Q:'DN D A1
G A1R
A1 ;
S X=$G(^MCAR(694,D0,12,D1,0)) D T Q:'DN W ?9 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(694.1,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,100)
Q
A1R ;
S I(1)=13,J(1)=694.058 F D1=0:0 Q:$O(^MCAR(694,D0,13,D1))'>0 S D1=$O(^(D1)) D:$X>111 T Q:'DN D B1
G B1R
B1 ;
S X=$G(^MCAR(694,D0,13,D1,0)) S DIWL=7,DIWR=76 D ^DIWP
Q
B1R ;
D A^DIWW
D T Q:'DN W ?2 X DXS(3,9) K DIP K:DN Y
S I(1)=10,J(1)=694.038 F D1=0:0 Q:$O(^MCAR(694,D0,10,D1))'>0 X:$D(DSC(694.038)) DSC(694.038) S D1=$O(^(D1)) Q:D1'>0 D:$X>13 T Q:'DN D C1
G C1R
C1 ;
S X=$G(^MCAR(694,D0,10,D1,0)) D N:$X>9 Q:'DN S DIWL=10,DIWR=79 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(697.5,Y,0))#2:$P(^(0),U,1),1:Y) S X=Y D ^DIWP
D A^DIWW
Q
C1R ;
S X=$G(^MCAR(694,D0,1)) D N:$X>6 Q:'DN S DIWL=7,DIWR=76 S Y=$P(X,U,2) S X=Y D ^DIWP
D A^DIWW
D T Q:'DN D N D N:$X>0 Q:'DN W ?0 W " "
W ?3 D BMB^MCARHP:$P(^MCAR(697.2,$P(^MCAR(694,D0,0),U,3),0),U)="BMB" K DIP K:DN Y
D N:$X>4 Q:'DN W ?4 W "PERIPHERAL BLOOD SMEAR:"
S X=$G(^MCAR(694,D0,11)) D N:$X>29 Q:'DN S DIWL=30,DIWR=80 S Y=$P(X,U,1) S X=Y D ^DIWP
D 0^DIWW K DIP K:DN Y
D ^DIWW K Y K DIWF
Q
HEAD ;
W !,"--------------------------------------------------------------------------------",!!
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HMCAROHB 3461 printed Oct 16, 2024@18:14:08 Page 2
MCAROHB ; GENERATED FROM 'MCARHEMB' PRINT TEMPLATE (#986) ; 06/25/01 ; (FILE 694, 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
MERGE DXS=^DIPT(986,"DXS")
+3 SET I(0)="^MCAR(694,"
SET J(0)=694
+4 if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "WARD/CLINIC: "
+5 SET X=$GET(^MCAR(694,D0,0))
if $X>17
DO N
if 'DN
QUIT
WRITE ?17
SET Y=$PIECE(X,U,4)
SET Y=$SELECT(Y="":Y,$DATA(^SC(Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,30)
+6 if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "PROCEDURE: "
+7 XECUTE DXS(1,9.4)
SET X=$SELECT(DIP(2):DIP(3),DIP(4):DIP(5),DIP(6):DIP(7),DIP(8):X)
KILL DIP
if DN
KILL Y
WRITE X
+8 XECUTE DXS(2,9.2)
SET DIP(3)=X
SET X=1
SET DIP(4)=X
SET X=""
SET X=$SELECT(DIP(2):DIP(3),DIP(4):X)
KILL DIP
if DN
KILL Y
WRITE X
+9 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "PERFORMED BY:"
+10 SET X=$GET(^MCAR(694,D0,1))
if $X>18
DO N
if 'DN
QUIT
WRITE ?18
SET Y=$PIECE(X,U,11)
SET Y=$SELECT(Y="":Y,$DATA(^VA(200,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,35)
+11 if $X>49
DO N
if 'DN
QUIT
WRITE ?49
WRITE "DATE PERFORMED:"
+12 if $X>65
DO N
if 'DN
QUIT
WRITE ?65
SET DIP(1)=$SELECT($DATA(^MCAR(694,D0,0)):^(0),1:"")
SET X=$PIECE(DIP(1),U,8)
if X
SET X=$EXTRACT(X,4,5)_"/"_$EXTRACT(X,6,7)_"/"_$EXTRACT(X,2,3)
KILL DIP
if DN
KILL Y
WRITE X
+13 if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "APPROVED BY:"
+14 SET X=$GET(^MCAR(694,D0,1))
if $X>18
DO N
if 'DN
QUIT
WRITE ?18
SET Y=$PIECE(X,U,9)
SET Y=$SELECT(Y="":Y,$DATA(^VA(200,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,35)
+15 if $X>49
DO N
if 'DN
QUIT
WRITE ?49
WRITE "DATE APPROVED:"
+16 if $X>65
DO N
if 'DN
QUIT
WRITE ?65
SET DIP(1)=$SELECT($DATA(^MCAR(694,D0,1)):^(1),1:"")
SET X=$PIECE(DIP(1),U,10)
if X
SET X=$EXTRACT(X,4,5)_"/"_$EXTRACT(X,6,7)_"/"_$EXTRACT(X,2,3)
KILL DIP
if DN
KILL Y
WRITE X
+17 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "DATE OF ORIGINAL CONSULT:"
+18 if $X>65
DO N
if 'DN
QUIT
WRITE ?65
SET DIP(1)=$SELECT($DATA(^MCAR(694,D0,0)):^(0),1:"")
SET X=$PIECE(DIP(1),U,7)
if X
SET X=$EXTRACT(X,4,5)_"/"_$EXTRACT(X,6,7)_"/"_$EXTRACT(X,2,3)
KILL DIP
if DN
KILL Y
WRITE X
+19 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "INDICATION(S) FOR PERFORMANCE: "
+20 SET I(1)=12
SET J(1)=694.057
FOR D1=0:0
if $ORDER(^MCAR(694,D0,12,D1))'>0
QUIT
if $DATA(DSC(694.057))
XECUTE DSC(694.057)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>37
DO T
if 'DN
QUIT
DO A1
+21 GOTO A1R
A1 ;
+1 SET X=$GET(^MCAR(694,D0,12,D1,0))
DO T
if 'DN
QUIT
WRITE ?9
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(694.1,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,100)
+2 QUIT
A1R ;
+1 SET I(1)=13
SET J(1)=694.058
FOR D1=0:0
if $ORDER(^MCAR(694,D0,13,D1))'>0
QUIT
SET D1=$ORDER(^(D1))
if $X>111
DO T
if 'DN
QUIT
DO B1
+2 GOTO B1R
B1 ;
+1 SET X=$GET(^MCAR(694,D0,13,D1,0))
SET DIWL=7
SET DIWR=76
DO ^DIWP
+2 QUIT
B1R ;
+1 DO A^DIWW
+2 DO T
if 'DN
QUIT
WRITE ?2
XECUTE DXS(3,9)
KILL DIP
if DN
KILL Y
+3 SET I(1)=10
SET J(1)=694.038
FOR D1=0:0
if $ORDER(^MCAR(694,D0,10,D1))'>0
QUIT
if $DATA(DSC(694.038))
XECUTE DSC(694.038)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>13
DO T
if 'DN
QUIT
DO C1
+4 GOTO C1R
C1 ;
+1 SET X=$GET(^MCAR(694,D0,10,D1,0))
if $X>9
DO N
if 'DN
QUIT
SET DIWL=10
SET DIWR=79
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(697.5,Y,0))#2:$PIECE(^(0),U,1),1:Y)
SET X=Y
DO ^DIWP
+2 DO A^DIWW
+3 QUIT
C1R ;
+1 SET X=$GET(^MCAR(694,D0,1))
if $X>6
DO N
if 'DN
QUIT
SET DIWL=7
SET DIWR=76
SET Y=$PIECE(X,U,2)
SET X=Y
DO ^DIWP
+2 DO A^DIWW
+3 DO T
if 'DN
QUIT
DO N
if $X>0
DO N
if 'DN
QUIT
WRITE ?0
WRITE " "
+4 WRITE ?3
if $PIECE(^MCAR(697.2,$PIECE(^MCAR(694,D0,0),U,3),0),U)="BMB"
DO BMB^MCARHP
KILL DIP
if DN
KILL Y
+5 if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "PERIPHERAL BLOOD SMEAR:"
+6 SET X=$GET(^MCAR(694,D0,11))
if $X>29
DO N
if 'DN
QUIT
SET DIWL=30
SET DIWR=80
SET Y=$PIECE(X,U,1)
SET X=Y
DO ^DIWP
+7 DO 0^DIWW
KILL DIP
if DN
KILL Y
+8 DO ^DIWW
KILL Y
KILL DIWF
+9 QUIT
HEAD ;
+1 WRITE !,"--------------------------------------------------------------------------------",!!