- MCOBK ; GENERATED FROM 'MCARECHOBRPR' PRINT TEMPLATE (#1021) ; 10/04/96 ; (FILE 691, 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(1021,"DXS",X)) Q:'X S Y=$O(^(X,"")) F X=X:0 Q:Y="" S DXS(X,Y)=^(Y),Y=$O(^(Y))
- W ?0 W "DATE/TIME: "
- S X=$G(^MCAR(691,D0,0)) D N:$X>11 Q:'DN W ?11 S Y=$P(X,U,1) D DT
- D N:$X>34 Q:'DN W ?34 W "MEDICAL PATIENT: "
- 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 N:$X>9 Q:'DN W ?9 W "SEPTUM: "
- S X=$G(^MCAR(691,D0,4)) W ?0,$E($P(X,U,1),1,5)
- D N:$X>28 Q:'DN W ?28 W "(8-11mm)"
- D N:$X>9 Q:'DN W ?9 W "POST LV WALL: "
- W ?0,$E($P(X,U,2),1,5)
- D N:$X>28 Q:'DN W ?28 W "(8-11mm)"
- D N:$X>9 Q:'DN W ?9 W "LV DIASTOLE: "
- W ?0,$E($P(X,U,7),1,6)
- D N:$X>27 Q:'DN W ?27 W "(40-55mm)"
- D N:$X>9 Q:'DN W ?9 W "LV SYSTOLE: "
- W ?0,$E($P(X,U,8),1,6)
- D N:$X>27 Q:'DN W ?27 W "(25-30mm)"
- D N:$X>9 Q:'DN W ?9 W "% FRACT SHORT: "
- X ^DD(691,19,9.4) S X=$J(Y(691,19,8),Y(691,19,9),X) S X=$J(X,0,0) W $E(X,1,15) K Y(691,19)
- D N:$X>29 Q:'DN W ?29 W "(25-45)"
- D N:$X>9 Q:'DN W ?9 W "REGIONAL WALL MOTION"
- S I(1)=6,J(1)=691.04 F D1=0:0 Q:$O(^MCAR(691,D0,6,D1))'>0 X:$D(DSC(691.04)) DSC(691.04) S D1=$O(^(D1)) Q:D1'>0 D:$X>31 T Q:'DN D A1
- G A1R
- A1 ;
- S X=$G(^MCAR(691,D0,6,D1,0)) D N:$X>11 Q:'DN W ?11 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(695.1,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,30)
- X DXS(1,9.2) S X=X="",DIP(3)=X S X="",DIP(4)=X S X=1,DIP(5)=X S X=", ",X=$S(DIP(3):DIP(4),DIP(5):X) K DIP K:DN Y W X
- S X=$G(^MCAR(691,D0,6,D1,0)) S Y=$P(X,U,2) W:Y]"" $S($D(DXS(2,Y)):DXS(2,Y),1:Y)
- Q
- A1R ;
- D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "FINDINGS: "
- S I(1)=9,J(1)=691.06 F D1=0:0 Q:$O(^MCAR(691,D0,9,D1))'>0 X:$D(DSC(691.06)) DSC(691.06) S D1=$O(^(D1)) Q:D1'>0 D:$X>16 T Q:'DN D B1
- G B1R
- B1 ;
- S X=$G(^MCAR(691,D0,9,D1,0)) D N:$X>9 Q:'DN S DIWL=10,DIWR=74 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(693,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 "DIAGNOSIS(ES): "
- S I(1)=14,J(1)=691.15 F D1=0:0 Q:$O(^MCAR(691,D0,14,D1))'>0 X:$D(DSC(691.15)) DSC(691.15) S D1=$O(^(D1)) Q:D1'>0 D:$X>21 T Q:'DN D C1
- G C1R
- C1 ;
- S X=$G(^MCAR(691,D0,14,D1,0)) D N:$X>9 Q:'DN W ?9 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^MCAR(697.5,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,50)
- Q
- C1R ;
- D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "OTHER CONCLUSIONS:"
- S I(1)=10,J(1)=691.07 F D1=0:0 Q:$O(^MCAR(691,D0,10,D1))'>0 S D1=$O(^(D1)) D:$X>24 T Q:'DN D D1
- G D1R
- D1 ;
- S X=$G(^MCAR(691,D0,10,D1,0)) S DIWL=10,DIWR=74 D ^DIWP
- Q
- D1R ;
- D A^DIWW
- D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "SUMMARY: "
- S X=$G(^MCAR(691,D0,.2)) S Y=$P(X,U,1) W:Y]"" $S($D(DXS(3,Y)):DXS(3,Y),1:Y)
- D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "PROCEDURE SUMMARY: "
- D N:$X>9 Q:'DN S DIWL=10,DIWR=74 S Y=$P(X,U,2) S X=Y D ^DIWP
- D A^DIWW
- D T Q:'DN D N D N:$X>4 Q:'DN W ?4 W "CARDIOLOGY ATTENDING:"
- S X=$G(^MCAR(691,D0,11)) W ?27 S Y=$P(X,U,1) S Y=$S(Y="":Y,$D(^VA(200,Y,0))#2:$P(^(0),U,1),1:Y) W $E(Y,1,35)
- W ?64 S MCFILE=691 D DISP^MCMAG K DIP K:DN Y
- D T Q:'DN W ?2 K MCFILE K DIP K:DN Y
- K Y K DIWF
- Q
- HEAD ;
- W !,"--------------------------------------------------------------------------------",!!
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HMCOBK 3785 printed Jan 18, 2025@03:16:42 Page 2
- MCOBK ; GENERATED FROM 'MCARECHOBRPR' PRINT TEMPLATE (#1021) ; 10/04/96 ; (FILE 691, 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(1021,"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
- WRITE "DATE/TIME: "
- +4 SET X=$GET(^MCAR(691,D0,0))
- if $X>11
- DO N
- if 'DN
- QUIT
- WRITE ?11
- SET Y=$PIECE(X,U,1)
- DO DT
- +5 if $X>34
- DO N
- if 'DN
- QUIT
- WRITE ?34
- WRITE "MEDICAL PATIENT: "
- +6 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)
- +7 if $X>9
- DO N
- if 'DN
- QUIT
- WRITE ?9
- WRITE "SEPTUM: "
- +8 SET X=$GET(^MCAR(691,D0,4))
- WRITE ?0,$EXTRACT($PIECE(X,U,1),1,5)
- +9 if $X>28
- DO N
- if 'DN
- QUIT
- WRITE ?28
- WRITE "(8-11mm)"
- +10 if $X>9
- DO N
- if 'DN
- QUIT
- WRITE ?9
- WRITE "POST LV WALL: "
- +11 WRITE ?0,$EXTRACT($PIECE(X,U,2),1,5)
- +12 if $X>28
- DO N
- if 'DN
- QUIT
- WRITE ?28
- WRITE "(8-11mm)"
- +13 if $X>9
- DO N
- if 'DN
- QUIT
- WRITE ?9
- WRITE "LV DIASTOLE: "
- +14 WRITE ?0,$EXTRACT($PIECE(X,U,7),1,6)
- +15 if $X>27
- DO N
- if 'DN
- QUIT
- WRITE ?27
- WRITE "(40-55mm)"
- +16 if $X>9
- DO N
- if 'DN
- QUIT
- WRITE ?9
- WRITE "LV SYSTOLE: "
- +17 WRITE ?0,$EXTRACT($PIECE(X,U,8),1,6)
- +18 if $X>27
- DO N
- if 'DN
- QUIT
- WRITE ?27
- WRITE "(25-30mm)"
- +19 if $X>9
- DO N
- if 'DN
- QUIT
- WRITE ?9
- WRITE "% FRACT SHORT: "
- +20 XECUTE ^DD(691,19,9.4)
- SET X=$JUSTIFY(Y(691,19,8),Y(691,19,9),X)
- SET X=$JUSTIFY(X,0,0)
- WRITE $EXTRACT(X,1,15)
- KILL Y(691,19)
- +21 if $X>29
- DO N
- if 'DN
- QUIT
- WRITE ?29
- WRITE "(25-45)"
- +22 if $X>9
- DO N
- if 'DN
- QUIT
- WRITE ?9
- WRITE "REGIONAL WALL MOTION"
- +23 SET I(1)=6
- SET J(1)=691.04
- FOR D1=0:0
- if $ORDER(^MCAR(691,D0,6,D1))'>0
- QUIT
- if $DATA(DSC(691.04))
- XECUTE DSC(691.04)
- SET D1=$ORDER(^(D1))
- if D1'>0
- QUIT
- if $X>31
- DO T
- if 'DN
- QUIT
- DO A1
- +24 GOTO A1R
- A1 ;
- +1 SET X=$GET(^MCAR(691,D0,6,D1,0))
- if $X>11
- DO N
- if 'DN
- QUIT
- WRITE ?11
- SET Y=$PIECE(X,U,1)
- SET Y=$SELECT(Y="":Y,$DATA(^MCAR(695.1,Y,0))#2:$PIECE(^(0),U,1),1:Y)
- WRITE $EXTRACT(Y,1,30)
- +2 XECUTE DXS(1,9.2)
- SET X=X=""
- SET DIP(3)=X
- SET X=""
- SET DIP(4)=X
- SET X=1
- SET DIP(5)=X
- SET X=", "
- SET X=$SELECT(DIP(3):DIP(4),DIP(5):X)
- KILL DIP
- if DN
- KILL Y
- WRITE X
- +3 SET X=$GET(^MCAR(691,D0,6,D1,0))
- SET Y=$PIECE(X,U,2)
- if Y]""
- WRITE $SELECT($DATA(DXS(2,Y)):DXS(2,Y),1:Y)
- +4 QUIT
- A1R ;
- +1 DO T
- if 'DN
- QUIT
- DO N
- if $X>4
- DO N
- if 'DN
- QUIT
- WRITE ?4
- WRITE "FINDINGS: "
- +2 SET I(1)=9
- SET J(1)=691.06
- FOR D1=0:0
- if $ORDER(^MCAR(691,D0,9,D1))'>0
- QUIT
- if $DATA(DSC(691.06))
- XECUTE DSC(691.06)
- SET D1=$ORDER(^(D1))
- if D1'>0
- QUIT
- if $X>16
- DO T
- if 'DN
- QUIT
- DO B1
- +3 GOTO B1R
- B1 ;
- +1 SET X=$GET(^MCAR(691,D0,9,D1,0))
- if $X>9
- DO N
- if 'DN
- QUIT
- SET DIWL=10
- SET DIWR=74
- SET Y=$PIECE(X,U,1)
- SET Y=$SELECT(Y="":Y,$DATA(^MCAR(693,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 "DIAGNOSIS(ES): "
- +2 SET I(1)=14
- SET J(1)=691.15
- FOR D1=0:0
- if $ORDER(^MCAR(691,D0,14,D1))'>0
- QUIT
- if $DATA(DSC(691.15))
- XECUTE DSC(691.15)
- SET D1=$ORDER(^(D1))
- if D1'>0
- QUIT
- if $X>21
- DO T
- if 'DN
- QUIT
- DO C1
- +3 GOTO C1R
- C1 ;
- +1 SET X=$GET(^MCAR(691,D0,14,D1,0))
- if $X>9
- DO N
- if 'DN
- QUIT
- WRITE ?9
- SET Y=$PIECE(X,U,1)
- SET Y=$SELECT(Y="":Y,$DATA(^MCAR(697.5,Y,0))#2:$PIECE(^(0),U,1),1:Y)
- WRITE $EXTRACT(Y,1,50)
- +2 QUIT
- C1R ;
- +1 DO T
- if 'DN
- QUIT
- DO N
- if $X>4
- DO N
- if 'DN
- QUIT
- WRITE ?4
- WRITE "OTHER CONCLUSIONS:"
- +2 SET I(1)=10
- SET J(1)=691.07
- FOR D1=0:0
- if $ORDER(^MCAR(691,D0,10,D1))'>0
- QUIT
- SET D1=$ORDER(^(D1))
- if $X>24
- DO T
- if 'DN
- QUIT
- DO D1
- +3 GOTO D1R
- D1 ;
- +1 SET X=$GET(^MCAR(691,D0,10,D1,0))
- SET DIWL=10
- SET DIWR=74
- DO ^DIWP
- +2 QUIT
- D1R ;
- +1 DO A^DIWW
- +2 DO T
- if 'DN
- QUIT
- DO N
- if $X>4
- DO N
- if 'DN
- QUIT
- WRITE ?4
- WRITE "SUMMARY: "
- +3 SET X=$GET(^MCAR(691,D0,.2))
- SET Y=$PIECE(X,U,1)
- if Y]""
- WRITE $SELECT($DATA(DXS(3,Y)):DXS(3,Y),1:Y)
- +4 DO T
- if 'DN
- QUIT
- DO N
- if $X>4
- DO N
- if 'DN
- QUIT
- WRITE ?4
- WRITE "PROCEDURE SUMMARY: "
- +5 if $X>9
- DO N
- if 'DN
- QUIT
- SET DIWL=10
- SET DIWR=74
- SET Y=$PIECE(X,U,2)
- SET X=Y
- DO ^DIWP
- +6 DO A^DIWW
- +7 DO T
- if 'DN
- QUIT
- DO N
- if $X>4
- DO N
- if 'DN
- QUIT
- WRITE ?4
- WRITE "CARDIOLOGY ATTENDING:"
- +8 SET X=$GET(^MCAR(691,D0,11))
- WRITE ?27
- SET Y=$PIECE(X,U,1)
- SET Y=$SELECT(Y="":Y,$DATA(^VA(200,Y,0))#2:$PIECE(^(0),U,1),1:Y)
- WRITE $EXTRACT(Y,1,35)
- +9 WRITE ?64
- SET MCFILE=691
- DO DISP^MCMAG
- KILL DIP
- if DN
- KILL Y
- +10 DO T
- if 'DN
- QUIT
- WRITE ?2
- KILL MCFILE
- KILL DIP
- if DN
- KILL Y
- +11 KILL Y
- KILL DIWF
- +12 QUIT
- HEAD ;
- +1 WRITE !,"--------------------------------------------------------------------------------",!!