1 | RARTR3 ;HIRMFO/SWM-Queue/print Radiology Reports (utility) ;8/31/99 13:57
|
---|
2 | ;;5.0;Radiology/Nuclear Medicine;**8,10,19,27,35,45,75**;Mar 16, 1998;Build 4
|
---|
3 | MEMS1 ;--- modifiers --- handle cases within print set
|
---|
4 | N RACNISAV,RAY3SAV,RAMEMARR,RACDIS,RALDIS
|
---|
5 | D EN2^RAUTL20(.RAMEMARR) Q:'$O(RAMEMARR(0))
|
---|
6 | S RACNISAV=RACNI,RAY3SAV=RAY3,RACNI=0
|
---|
7 | D CDIS^RAPROD S (RAREZON,RACNI)=0
|
---|
8 | ;for printsets print the REASON FOR STUDY along with the lead procedure
|
---|
9 | ;(avoid duplicate printing of the same data)
|
---|
10 | F S RACNI=$O(RAMEMARR(RACNI)) Q:'RACNI D S:$G(RAXIT) RAOOUT=1 Q:$D(RAOOUT)
|
---|
11 | . S RAY3=$G(^RADPT(RADFN,"DT",RADTI,"P",RACNI,0))
|
---|
12 | . ;Check if cancelled & not part of printset
|
---|
13 | . I $P(^RA(72,+$P(RAY3,"^",3),0),"^",3)=0,($P(RAY3,"^",17)="") Q
|
---|
14 | . D MODS^RAUTL2
|
---|
15 | . ; If printing page at a time we need to check the length - RA*5*8
|
---|
16 | . I '$D(RAUTOE),$Y>(IOSL-6),IOST["C-" S RAP="" D WAIT^RART1 I X="^"!(X="P")!(X="T") S RAOOUT=1 Q
|
---|
17 | . D OUT1 Q:$G(RAXIT) S RAREZON=1
|
---|
18 | . D:+$P(RAY3,"^",28) RDIO^RARTUTL(+$P(RAY3,"^",28)) Q:$D(RAOOUT)
|
---|
19 | . D:+$O(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"RX",0)) PHARM^RARTUTL(RACNI_","_RADTI_","_RADFN_",")
|
---|
20 | . Q
|
---|
21 | S RACNI=RACNISAV,RAY3=RAY3SAV K RAREZON
|
---|
22 | Q
|
---|
23 | OUT1 ;
|
---|
24 | ; $O(RAMEMARR(0)) may be defined, if previously called MEMS1^RARTR3
|
---|
25 | ; RALDIS flags long display wanted, comes from certain output options
|
---|
26 | ; RACDIS(n) exists if case n is to be displayed
|
---|
27 | ; RACDIS(n) not set for dupl proc+pmod+cptmod so don't display
|
---|
28 | I $O(RAMEMARR(0)),'$G(RALDIS),'$D(RACDIS(RACNI)) Q
|
---|
29 | S RASTUDY=$P($G(^RAO(75.1,+$P(RAY3,U,11),.1)),U) ;Convey 'Reason for Study' P75
|
---|
30 | I $D(RAUTOE) G MAIL1
|
---|
31 | W !,$$XAM()
|
---|
32 | ;check for contrast media; display if CM data exists (patch 45)
|
---|
33 | S RACMDATA=$$CMEDIA^RAUTL8(RADFN,RADTI,RACNI)
|
---|
34 | I $L(RACMDATA) D
|
---|
35 | .W !?5,"Contrast Media :"
|
---|
36 | .F RAIZ=1:1 Q:$P(RACMDATA,", ",RAIZ)="" D
|
---|
37 | ..W ?22,$P(RACMDATA,", ",RAIZ)
|
---|
38 | ..W:$P(RACMDATA,", ",RAIZ+1)'="" !
|
---|
39 | ..I $Y>(IOSL-5) S RAXIT=$$EOS^RAUTL5() Q:RAXIT W @IOF W !
|
---|
40 | ..Q
|
---|
41 | .K RAIZ
|
---|
42 | .QUIT
|
---|
43 | K RACMDATA Q:$G(RAXIT)
|
---|
44 | W:Y'="None" !?RATAB,"Proc Modifiers : ",Y
|
---|
45 | N I,J
|
---|
46 | W:Y(1)'="None" !?RATAB,"CPT Modifiers : "
|
---|
47 | I Y(1)'="None" F I=1:1 Q:$P(Y(2),", ",I)']"" S J=$P(Y(2),", ",I),J=$$BASICMOD^RACPTMSC(J,DT) W ?22,$P(J,"^",2)," ",$P(J,"^",3) W:$P(Y(2),", ",I+1)]"" ! I $Y>(IOSL-5) S RAXIT=$$EOS^RAUTL5() Q:RAXIT W @IOF W !
|
---|
48 | I $L(RASTUDY),$G(RAREZON,0)=0 W ! D DIWP^RAUTL5(RATAB,68,"Reason for Study: "_RASTUDY) ;P75
|
---|
49 | K RASTUDY
|
---|
50 | Q
|
---|
51 | ;
|
---|
52 | MAIL1 S ^TMP($J,"RA AUTOE",$$INCR^RAUTL4(RAACNT))=""
|
---|
53 | S ^TMP($J,"RA AUTOE",$$INCR^RAUTL4(RAACNT))=$$XAM()
|
---|
54 | ;check for contrast media; display if CM data exists (patch 45)
|
---|
55 | S RACMDATA=$$CMEDIA^RAUTL8(RADFN,RADTI,RACNI)
|
---|
56 | I $L(RACMDATA) D
|
---|
57 | .S ^TMP($J,"RA AUTOE",$$INCR^RAUTL4(RAACNT))=" Contrast Media : "_$P(RACMDATA,", ")
|
---|
58 | .F RAIZ=2:1 Q:$P(RACMDATA,", ",RAIZ)="" S ^TMP($J,"RA AUTOE",$$INCR^RAUTL4(RAACNT))=" "_$P(RACMDATA,", ",RAIZ)
|
---|
59 | .K RAIZ
|
---|
60 | .Q
|
---|
61 | K RACMDATA
|
---|
62 | S:Y'="None" ^TMP($J,"RA AUTOE",$$INCR^RAUTL4(RAACNT))=" Proc Modifiers : "_Y
|
---|
63 | I Y(1)'="None" D
|
---|
64 | .S J=$P(Y(2),", ",1),J=$$BASICMOD^RACPTMSC(J,DT) S:+J<0 $P(J,"^",2,3)="None^"
|
---|
65 | .S ^TMP($J,"RA AUTOE",$$INCR^RAUTL4(RAACNT))=" CPT Modifiers : "_$S(J]"":$P(J,"^",2)_" "_$P(J,"^",3),1:"")
|
---|
66 | .F I=2:1 Q:$P(Y(2),", ",I)']"" S J=$P(Y(2),", ",I),J=$$BASICMOD^RACPTMSC(J,DT) S ^TMP($J,"RA AUTOE",$$INCR^RAUTL4(RAACNT))=" "_$P(J,"^",2)_" "_$P(J,"^",3)
|
---|
67 | .Q
|
---|
68 | I $L(RASTUDY),$G(RAREZON,0)=0 D S RAREZON=1
|
---|
69 | .N RAY S RASTUDY="Reason for Study: "_RASTUDY
|
---|
70 | .I $L(RASTUDY)'>68 S $P(RAY," ",6)="",^TMP($J,"RA AUTOE",$$INCR^RAUTL4(RAACNT))=RAY_RASTUDY Q
|
---|
71 | .I $L(RASTUDY)>68 D
|
---|
72 | ..K ^UTILITY($J,"W") N %,DIW,DIWF,DIWL,DIWR,DIWT,DIWTC,DIWX,DN,RAI,RAX,X,X1,Z
|
---|
73 | ..S DIWF="",DIWL=1,DIWR=65,X=RASTUDY D ^DIWP
|
---|
74 | ..S RAI=0 F S RAI=$O(^UTILITY($J,"W",DIWL,RAI)) Q:'RAI D
|
---|
75 | ...S RAX=$G(^UTILITY($J,"W",DIWL,RAI,0))
|
---|
76 | ...I RAI=1 S $P(RAY," ",6)="",^TMP($J,"RA AUTOE",$$INCR^RAUTL4(RAACNT))=RAY_RAX
|
---|
77 | ...I RAI'=1 S $P(RAY," ",24)="",^TMP($J,"RA AUTOE",$$INCR^RAUTL4(RAACNT))=RAY_RAX
|
---|
78 | ...Q
|
---|
79 | ..Q
|
---|
80 | .K ^UTILITY($J,"W")
|
---|
81 | .Q
|
---|
82 | K RASTUDY
|
---|
83 | Q
|
---|
84 | ;
|
---|
85 | XAM() ; Return exam data information. Case number, exam status & procedure
|
---|
86 | ; name build into one string. Assumes RAY3 is the 0 node for exam data
|
---|
87 | Q:$G(RAY3)="" "" ; no exam information present.
|
---|
88 | N RAPROC,RAXAMSTR S RAXAMSTR=""
|
---|
89 | I $G(RALDIS)!('$O(RAMEMARR(0)))!($O(RAMEMARR(0))&($G(RACDIS(RACNI))=1)) D
|
---|
90 | . S $E(RAXAMSTR,1,5)="(Case"
|
---|
91 | . S $E(RAXAMSTR,7,(7+$L(+RAY3)))=+RAY3
|
---|
92 | . S $E(RAXAMSTR,$L(RAXAMSTR)+2,79)=$S($D(^RA(72,+$P(RAY3,"^",3),0)):$E($P(^(0),"^"),1,8)_")",1:"Unknown)")
|
---|
93 | . Q
|
---|
94 | E S:$G(RACDIS(RACNI)) $E(RAXAMSTR,1)="(",$E(RAXAMSTR,9,14)=RACDIS(RACNI)_"x",$E(RAXAMSTR,20)=")"
|
---|
95 | S RAPROC=$G(^RAMIS(71,+$P(RAY3,"^",2),0))
|
---|
96 | S $E(RAXAMSTR,22,54)=$S($P(RAPROC,"^")]"":$E($P(RAPROC,"^"),1,33),1:"Unknown")
|
---|
97 | N RADISPLY
|
---|
98 | S RADISPLY=$G(^RAMIS(71,+$P($G(^RADPT(+RADFN,"DT",+RADTI,"P",+RACNI,0)),U,2),0)) ; set $ZR to 71 for prccpt^radd1, not call raprod since store result
|
---|
99 | S RADISPLY=$$PRCCPT^RADD1()
|
---|
100 | S $E(RAXAMSTR,55,79)=RADISPLY
|
---|
101 | Q RAXAMSTR
|
---|