1 | PXRMRCPT ; SLC/PKR - Code to handle radiology CPT data. ;08/23/2005
|
---|
2 | ;;2.0;CLINICAL REMINDERS;**4**;Feb 04, 2005;Build 21
|
---|
3 | ;
|
---|
4 | ;==============================================
|
---|
5 | FPDAT(DFN,TAXARR,NOCC,BDT,EDT,STATUSA,FLIST) ;Find data for a
|
---|
6 | ;patient. The expanded taxonomy stores radiology data by procedure
|
---|
7 | ;ien i.e.,
|
---|
8 | ;^PXD(811.3,N,71,"RCPTP",RADPROC,DA)
|
---|
9 | ;^PXD(811.3,81,DA,0)=ICPTP
|
---|
10 | N DA,DATE,FIEVT,ICPTP,IND,NOCCABS,NFOUND,PFINDPA
|
---|
11 | N RADPROC,SDIR,TE,TDATE,TIND,TF,TLIST,TS
|
---|
12 | I $G(^PXRMINDX(70,"DATE BUILT"))="" D Q
|
---|
13 | . D NOINDEX^PXRMERRH("TX",TAXARR("IEN"),70)
|
---|
14 | I '$D(^PXRMINDX(70,"PI",DFN)) Q
|
---|
15 | I '$D(TAXARR(71)) Q
|
---|
16 | S $P(PFINDPA(0),U,8)=BDT
|
---|
17 | S $P(PFINDPA(0),U,11)=EDT
|
---|
18 | S $P(PFINDPA(0),U,14)=NOCC
|
---|
19 | S SDIR=$S(NOCC<0:+1,1:-1)
|
---|
20 | F IND=1:1:STATUSA(0) S PFINDPA(5,IND)=STATUSA(IND)
|
---|
21 | ;Get the start and end of the taxonomy, for radiology these are
|
---|
22 | ;actually radiology procedures, which we use to get to the CPT codes.
|
---|
23 | S TS=$O(TAXARR(71,""))-1
|
---|
24 | S TE=$O(TAXARR(71,""),-1)
|
---|
25 | S NFOUND=0
|
---|
26 | S RADPROC=TS
|
---|
27 | F S RADPROC=$O(^PXRMINDX(70,"PI",DFN,RADPROC)) Q:(RADPROC>TE)!(RADPROC="") D
|
---|
28 | . I '$D(TAXARR(71,RADPROC)) Q
|
---|
29 | . K FIEVT
|
---|
30 | . D FIEVAL^PXRMINDX(70,"PI",DFN,RADPROC,.PFINDPA,.FIEVT)
|
---|
31 | . I FIEVT D
|
---|
32 | .. S DA=$O(TAXARR(71,RADPROC,""))
|
---|
33 | .. S ICPTP=TAXARR(71,RADPROC,DA,0)
|
---|
34 | .. S IND=0
|
---|
35 | .. F S IND=+$O(FIEVT(IND)) Q:IND=0 D
|
---|
36 | ... S NFOUND=NFOUND+1
|
---|
37 | ... S TLIST(FIEVT(IND,"DATE"),NFOUND)=FIEVT(IND,"DAS")_U_ICPTP_U_RADPROC_U_"CPT"
|
---|
38 | ... I NFOUND>NGET D
|
---|
39 | .... S TDATE=$O(TLIST(""),-SDIR),TIND=$O(TLIST(TDATE,""))
|
---|
40 | .... K TLIST(TDATE,TIND)
|
---|
41 | ;Return up to NOCC of the most recent entries.
|
---|
42 | S NOCCABS=$S(NOCC<0:-NOCC,1:NOCC)
|
---|
43 | S NFOUND=0
|
---|
44 | S DATE=""
|
---|
45 | F S DATE=$O(TLIST(DATE),SDIR) Q:(DATE="")!(NFOUND=NOCCABS) D
|
---|
46 | . S IND=0
|
---|
47 | . F S IND=$O(TLIST(DATE,IND)) Q:(IND="")!(NFOUND=NOCCABS) D
|
---|
48 | .. S NFOUND=NFOUND+1
|
---|
49 | .. S FLIST(DATE,NFOUND,70)=TLIST(DATE,IND)
|
---|
50 | Q
|
---|
51 | ;
|
---|
52 | ;==============================================
|
---|
53 | GPLIST(TAXARR,PFINDPA,PLIST) ;Build a patient list for radiology CPT entries.
|
---|
54 | N DA,DAS,DATE,DFN,ICPTP,NFOUND
|
---|
55 | N RADPROC,TEMP,TF,TLIST,VALUE
|
---|
56 | I $G(^PXRMINDX(70,"DATE BUILT"))="" D Q
|
---|
57 | . D NOINDEX^PXRMERRH("TX",TAXARR("IEN"),70)
|
---|
58 | S TLIST="GPLIST_PXRMRCPT"
|
---|
59 | S RADPROC=""
|
---|
60 | F S RADPROC=$O(TAXARR(71,RADPROC)) Q:RADPROC="" D
|
---|
61 | . I '$D(^PXRMINDX(70,"IP",RADPROC)) Q
|
---|
62 | . S DA=$O(TAXARR(71,RADPROC,""))
|
---|
63 | . S ICPTP=$P(TAXARR(71,RADPROC,DA,0),U,1)
|
---|
64 | . K ^TMP($J,TLIST)
|
---|
65 | . D GPLIST^PXRMINDL(70,"IP",RADPROC,.PFINDPA,TLIST)
|
---|
66 | . F TF=0,1 D
|
---|
67 | .. S DFN=0
|
---|
68 | .. F S DFN=$O(^TMP($J,TLIST,TF,DFN)) Q:DFN="" D
|
---|
69 | ... S NFOUND=0
|
---|
70 | ... F S NFOUND=$O(^TMP($J,TLIST,TF,DFN,RADPROC,NFOUND)) Q:NFOUND="" D
|
---|
71 | .... S TEMP=^TMP($J,TLIST,TF,DFN,RADPROC,NFOUND,70)
|
---|
72 | .... S DAS=$P(TEMP,U,1)
|
---|
73 | .... S DATE=$P(TEMP,U,2)
|
---|
74 | .... S VALUE=$P(TEMP,U,4)
|
---|
75 | .... S ^TMP($J,PLIST,TF,DFN,DATE,70)=DAS_U_DATE_U_ICPTP_U_"CPT"_U_VALUE
|
---|
76 | K ^TMP($J,TLIST)
|
---|
77 | Q
|
---|
78 | ;
|
---|
79 | ;==============================================
|
---|
80 | MHVOUT(INDENT,OCCLIST,IFIEVAL,NLINES,TEXT) ;Produce the MHV output.
|
---|
81 | N CODE,CPT,CPTDATA,DATE,ICPTP,IND,JND,NAME,NOUT,SNAME,TEMP,TEXTOUT
|
---|
82 | S NAME="Radiology Procedure = "
|
---|
83 | S IND=0
|
---|
84 | F S IND=$O(OCCLIST(IND)) Q:IND="" D
|
---|
85 | . S DATE=IFIEVAL(IND,"DATE")
|
---|
86 | . S ICPTP=IFIEVAL(IND,"CODEP")
|
---|
87 | . S CPTDATA=$$CPT^ICPTCOD(ICPTP)
|
---|
88 | . S CODE=$P(CPTDATA,U,2)
|
---|
89 | . S SNAME=$P(CPTDATA,U,3)
|
---|
90 | . S TEMP=" "_IFIEVAL(IND,"PROCEDURE")
|
---|
91 | . S TEMP=NAME_SNAME_" ("_$$EDATE^PXRMDATE(DATE)_")"
|
---|
92 | . D FORMATS^PXRMTEXT(INDENT+2,PXRMRM,TEMP,.NOUT,.TEXTOUT)
|
---|
93 | . F JND=1:1:NOUT S NLINES=NLINES+1,TEXT(NLINES)=TEXTOUT(JND)
|
---|
94 | S NLINES=NLINES+1,TEXT(NLINES)=""
|
---|
95 | Q
|
---|
96 | ;
|
---|
97 | ;==============================================
|
---|
98 | OUTPUT(INDENT,OCCLIST,IFIEVAL,NLINES,TEXT) ;Produce the clinical
|
---|
99 | ;maintenance output. The CPT information is: DATE, ICPT CODE,
|
---|
100 | ;SHORT NAME, PROVIDER NARRATIVE.
|
---|
101 | N CODE,CPT,CPTDATA,DATE,ICPTP,IND,JND,NOUT,SNAME,TAXIEN,TEMP,TEXTOUT
|
---|
102 | S TEMP=IFIEVAL("FINDING")
|
---|
103 | S TAXIEN=$P(TEMP,";",1)
|
---|
104 | S TEMP="Radiology Procedure(s) from taxonomy "_$P(^PXD(811.2,TAXIEN,0),U,1)
|
---|
105 | S NLINES=NLINES+1
|
---|
106 | S TEXT(NLINES)=$$INSCHR^PXRMEXLC(INDENT," ")_TEMP
|
---|
107 | S IND=0
|
---|
108 | F S IND=$O(OCCLIST(IND)) Q:IND="" D
|
---|
109 | . S DATE=IFIEVAL(IND,"DATE")
|
---|
110 | . S TEMP=$$EDATE^PXRMDATE(DATE)
|
---|
111 | . S ICPTP=IFIEVAL(IND,"CODEP")
|
---|
112 | . S CPTDATA=$$CPT^ICPTCOD(ICPTP)
|
---|
113 | . S CODE=$P(CPTDATA,U,2)
|
---|
114 | . S SNAME=$P(CPTDATA,U,3)
|
---|
115 | . S TEMP=TEMP_" "_IFIEVAL(IND,"PROCEDURE")
|
---|
116 | . S TEMP=TEMP_"-CPT: "_CODE_" "_SNAME
|
---|
117 | . S TEMP=TEMP_" Status: "_IFIEVAL(IND,"STATUS")
|
---|
118 | . D FORMATS^PXRMTEXT(INDENT+2,PXRMRM,TEMP,.NOUT,.TEXTOUT)
|
---|
119 | . F JND=1:1:NOUT S NLINES=NLINES+1,TEXT(NLINES)=TEXTOUT(JND)
|
---|
120 | S NLINES=NLINES+1,TEXT(NLINES)=""
|
---|
121 | Q
|
---|
122 | ;
|
---|