MCOBPE ; GENERATED FROM 'MCARPULMBRPR' PRINT TEMPLATE (#1028) ; 10/04/96 ; (FILE 699, 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(1028,"DXS",X)) Q:'X S Y=$O(^(X,"")) F X=X:0 Q:Y="" S DXS(X,Y)=^(Y),Y=$O(^(Y))
W ?0 S DIP(1)=$S($D(^MCAR(699,D0,0)):^(0),1:"") S X="APPOINTMENT DATE/TIME: "_$P(DIP(1),U,1) S Y=X K DIP K:DN Y S Y=X D DT
D N:$X>39 Q:'DN W ?39 W "MEDICAL PATIENT: "
S X=$G(^MCAR(699,D0,0)) S Y=$P(X,U,2) S Y=$S(Y="":Y,$D(^MCAR(690,Y,0))#2:$P(^(0),U,1),1:Y) S Y=$S(Y="":Y,$D(^DPT(Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,30)
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "SIGNS AND SYMPTOMS: "
S I(1)=3,J(1)=699.18 F D1=0:0 Q:$O(^MCAR(699,D0,3,D1))'>0 X:$D(DSC(699.18)) DSC(699.18) S D1=$O(^(D1)) Q:D1'>0 D:$X>26 T Q:'DN D A1
G A1R
A1 ;
S X=$G(^MCAR(699,D0,3,D1,0)) S DIWL=1,DIWR=55 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(695.5,Y,0))#2:$P(^(0),U,1),1:Y) S X=Y D ^DIWP
D A^DIWW
Q
A1R ;
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "COUGH: "
S I(1)=10,J(1)=699.0206 F D1=0:0 Q:$O(^MCAR(699,D0,10,D1))'>0 X:$D(DSC(699.0206)) DSC(699.0206) S D1=$O(^(D1)) Q:D1'>0 D:$X>13 T Q:'DN D B1
G B1R
B1 ;
S X=$G(^MCAR(699,D0,10,D1,0)) S DIWL=1,DIWR=55 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(695.5,Y,0))#2:$P(^(0),U,1),1:Y) S X=Y D ^DIWP
D A^DIWW
Q
B1R ;
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "PNEUMONIA: "
S I(1)=11,J(1)=699.0207 F D1=0:0 Q:$O(^MCAR(699,D0,11,D1))'>0 X:$D(DSC(699.0207)) DSC(699.0207) S D1=$O(^(D1)) Q:D1'>0 D:$X>17 T Q:'DN D C1
G C1R
C1 ;
S X=$G(^MCAR(699,D0,11,D1,0)) S DIWL=1,DIWR=55 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(699.83,Y,0))#2:$P(^(0),U,1),1:Y) S X=Y D ^DIWP
D A^DIWW
Q
C1R ;
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "DISEASE FOLLOWUP: "
S I(1)=5,J(1)=699.35 F D1=0:0 Q:$O(^MCAR(699,D0,5,D1))'>0 X:$D(DSC(699.35)) DSC(699.35) S D1=$O(^(D1)) Q:D1'>0 D:$X>24 T Q:'DN D D1
G D1R
D1 ;
S X=$G(^MCAR(699,D0,5,D1,0)) S DIWL=1,DIWR=55 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(699.84,Y,0))#2:$P(^(0),U,1),1:Y) S X=Y D ^DIWP
D A^DIWW
Q
D1R ;
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "FOLLOWUP DEVICE OR THERAPY: "
S I(1)=6,J(1)=699.36 F D1=0:0 Q:$O(^MCAR(699,D0,6,D1))'>0 X:$D(DSC(699.36)) DSC(699.36) S D1=$O(^(D1)) Q:D1'>0 D:$X>34 T Q:'DN D E1
G E1R
E1 ;
S X=$G(^MCAR(699,D0,6,D1,0)) S DIWL=1,DIWR=55 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(699.85,Y,0))#2:$P(^(0),U,1),1:Y) S X=Y D ^DIWP
D A^DIWW
Q
E1R ;
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "OTHER FOLLOWUP DEVICE/THERAPY: "
S X=$G(^MCAR(699,D0,12)) S DIWL=1,DIWR=55 S Y=$P(X,U,1) S X=Y D ^DIWP
D A^DIWW
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "INDICATED THERAPY: "
S I(1)=2,J(1)=699.17 F D1=0:0 Q:$O(^MCAR(699,D0,2,D1))'>0 X:$D(DSC(699.17)) DSC(699.17) S D1=$O(^(D1)) Q:D1'>0 D:$X>25 T Q:'DN D F1
G F1R
F1 ;
S X=$G(^MCAR(699,D0,2,D1,0)) S DIWL=1,DIWR=55 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(699.6,Y,0))#2:$P(^(0),U,1),1:Y) S X=Y D ^DIWP
D A^DIWW
Q
F1R ;
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "BRONCHOSCOPIST: "
S X=$G(^MCAR(699,D0,0)) S Y=$P(X,U,8) S Y=$S(Y="":Y,$D(^VA(200,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,35)
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "SUMMARY: "
S X=$G(^MCAR(699,D0,.2)) S Y=$P(X,U,1) W:Y]"" $S($D(DXS(1,Y)):DXS(1,Y),1:Y)
D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "PROCEDURE SUMMARY: "
S DIWL=1,DIWR=55 S Y=$P(X,U,2) S X=Y D ^DIWP
D 0^DIWW K DIP K:DN Y
W ?25 S MCFILE=699 D DISP^MCMAG K DIP K:DN Y
W ?36 K MCFILE K DIP K:DN Y
D ^DIWW K Y K DIWF
Q
HEAD ;
W !,"--------------------------------------------------------------------------------",!!
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HMCOBPE 4048 printed Oct 16, 2024@18:16:09 Page 2
MCOBPE ; GENERATED FROM 'MCARPULMBRPR' PRINT TEMPLATE (#1028) ; 10/04/96 ; (FILE 699, 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(1028,"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 WRITE ?0
SET DIP(1)=$SELECT($DATA(^MCAR(699,D0,0)):^(0),1:"")
SET X="APPOINTMENT DATE/TIME: "_$PIECE(DIP(1),U,1)
SET Y=X
KILL DIP
if DN
KILL Y
SET Y=X
DO DT
+4 if $X>39
DO N
if 'DN
QUIT
WRITE ?39
WRITE "MEDICAL PATIENT: "
+5 SET X=$GET(^MCAR(699,D0,0))
SET Y=$PIECE(X,U,2)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(690,Y,0))#2:$PIECE(^(0),U,1),1:Y)
SET Y=$SELECT(Y="":Y,$DATA(^DPT(Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,30)
+6 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "SIGNS AND SYMPTOMS: "
+7 SET I(1)=3
SET J(1)=699.18
FOR D1=0:0
if $ORDER(^MCAR(699,D0,3,D1))'>0
QUIT
if $DATA(DSC(699.18))
XECUTE DSC(699.18)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>26
DO T
if 'DN
QUIT
DO A1
+8 GOTO A1R
A1 ;
+1 SET X=$GET(^MCAR(699,D0,3,D1,0))
SET DIWL=1
SET DIWR=55
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(695.5,Y,0))#2:$PIECE(^(0),U,1),1:Y)
SET X=Y
DO ^DIWP
+2 DO A^DIWW
+3 QUIT
A1R ;
+1 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "COUGH: "
+2 SET I(1)=10
SET J(1)=699.0206
FOR D1=0:0
if $ORDER(^MCAR(699,D0,10,D1))'>0
QUIT
if $DATA(DSC(699.0206))
XECUTE DSC(699.0206)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>13
DO T
if 'DN
QUIT
DO B1
+3 GOTO B1R
B1 ;
+1 SET X=$GET(^MCAR(699,D0,10,D1,0))
SET DIWL=1
SET DIWR=55
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(695.5,Y,0))#2:$PIECE(^(0),U,1),1:Y)
SET X=Y
DO ^DIWP
+2 DO A^DIWW
+3 QUIT
B1R ;
+1 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "PNEUMONIA: "
+2 SET I(1)=11
SET J(1)=699.0207
FOR D1=0:0
if $ORDER(^MCAR(699,D0,11,D1))'>0
QUIT
if $DATA(DSC(699.0207))
XECUTE DSC(699.0207)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>17
DO T
if 'DN
QUIT
DO C1
+3 GOTO C1R
C1 ;
+1 SET X=$GET(^MCAR(699,D0,11,D1,0))
SET DIWL=1
SET DIWR=55
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(699.83,Y,0))#2:$PIECE(^(0),U,1),1:Y)
SET X=Y
DO ^DIWP
+2 DO A^DIWW
+3 QUIT
C1R ;
+1 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "DISEASE FOLLOWUP: "
+2 SET I(1)=5
SET J(1)=699.35
FOR D1=0:0
if $ORDER(^MCAR(699,D0,5,D1))'>0
QUIT
if $DATA(DSC(699.35))
XECUTE DSC(699.35)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>24
DO T
if 'DN
QUIT
DO D1
+3 GOTO D1R
D1 ;
+1 SET X=$GET(^MCAR(699,D0,5,D1,0))
SET DIWL=1
SET DIWR=55
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(699.84,Y,0))#2:$PIECE(^(0),U,1),1:Y)
SET X=Y
DO ^DIWP
+2 DO A^DIWW
+3 QUIT
D1R ;
+1 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "FOLLOWUP DEVICE OR THERAPY: "
+2 SET I(1)=6
SET J(1)=699.36
FOR D1=0:0
if $ORDER(^MCAR(699,D0,6,D1))'>0
QUIT
if $DATA(DSC(699.36))
XECUTE DSC(699.36)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>34
DO T
if 'DN
QUIT
DO E1
+3 GOTO E1R
E1 ;
+1 SET X=$GET(^MCAR(699,D0,6,D1,0))
SET DIWL=1
SET DIWR=55
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(699.85,Y,0))#2:$PIECE(^(0),U,1),1:Y)
SET X=Y
DO ^DIWP
+2 DO A^DIWW
+3 QUIT
E1R ;
+1 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "OTHER FOLLOWUP DEVICE/THERAPY: "
+2 SET X=$GET(^MCAR(699,D0,12))
SET DIWL=1
SET DIWR=55
SET Y=$PIECE(X,U,1)
SET X=Y
DO ^DIWP
+3 DO A^DIWW
+4 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "INDICATED THERAPY: "
+5 SET I(1)=2
SET J(1)=699.17
FOR D1=0:0
if $ORDER(^MCAR(699,D0,2,D1))'>0
QUIT
if $DATA(DSC(699.17))
XECUTE DSC(699.17)
SET D1=$ORDER(^(D1))
if D1'>0
QUIT
if $X>25
DO T
if 'DN
QUIT
DO F1
+6 GOTO F1R
F1 ;
+1 SET X=$GET(^MCAR(699,D0,2,D1,0))
SET DIWL=1
SET DIWR=55
SET Y=$PIECE(X,U,1)
SET Y=$SELECT(Y="":Y,$DATA(^MCAR(699.6,Y,0))#2:$PIECE(^(0),U,1),1:Y)
SET X=Y
DO ^DIWP
+2 DO A^DIWW
+3 QUIT
F1R ;
+1 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "BRONCHOSCOPIST: "
+2 SET X=$GET(^MCAR(699,D0,0))
SET Y=$PIECE(X,U,8)
SET Y=$SELECT(Y="":Y,$DATA(^VA(200,Y,0))#2:$PIECE(^(0),U,1),1:Y)
WRITE $EXTRACT(Y,1,35)
+3 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "SUMMARY: "
+4 SET X=$GET(^MCAR(699,D0,.2))
SET Y=$PIECE(X,U,1)
if Y]""
WRITE $SELECT($DATA(DXS(1,Y)):DXS(1,Y),1:Y)
+5 DO T
if 'DN
QUIT
DO N
if $X>4
DO N
if 'DN
QUIT
WRITE ?4
WRITE "PROCEDURE SUMMARY: "
+6 SET DIWL=1
SET DIWR=55
SET Y=$PIECE(X,U,2)
SET X=Y
DO ^DIWP
+7 DO 0^DIWW
KILL DIP
if DN
KILL Y
+8 WRITE ?25
SET MCFILE=699
DO DISP^MCMAG
KILL DIP
if DN
KILL Y
+9 WRITE ?36
KILL MCFILE
KILL DIP
if DN
KILL Y
+10 DO ^DIWW
KILL Y
KILL DIWF
+11 QUIT
HEAD ;
+1 WRITE !,"--------------------------------------------------------------------------------",!!