[613] | 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 | ;
|
---|