| 1 | RORX011 ;HCIOFO/SG - PATIENT MEDICATION HISTORY ; 6/22/06 10:56am | 
|---|
| 2 | ;;1.5;CLINICAL CASE REGISTRIES;**1**;Feb 17, 2006;Build 24 | 
|---|
| 3 | ; | 
|---|
| 4 | Q | 
|---|
| 5 | ; | 
|---|
| 6 | ;***** OUTPUTS THE REPORT HEADER | 
|---|
| 7 | ; | 
|---|
| 8 | ; PARTAG        Reference (IEN) to the parent tag | 
|---|
| 9 | ; | 
|---|
| 10 | ; Return Values: | 
|---|
| 11 | ;       <0  Error code | 
|---|
| 12 | ;       >0  IEN of the HEADER element | 
|---|
| 13 | ; | 
|---|
| 14 | HEADER(PARTAG) ; | 
|---|
| 15 | ;;PATIENTS(#,NAME,LAST4,DOB,AGE,DOD) | 
|---|
| 16 | ;;PTRXL(DATE,ORDER,TYPE,NAME,GENERIC,DAYSPLY,FILLTYPE) | 
|---|
| 17 | ; | 
|---|
| 18 | N HEADER,NOTES,RC | 
|---|
| 19 | S HEADER=$$HEADER^RORXU002(.RORTSK,PARTAG) | 
|---|
| 20 | Q:HEADER<0 HEADER | 
|---|
| 21 | S NOTES=$$ADDVAL^RORTSK11(RORTSK,"NOTES",,HEADER) | 
|---|
| 22 | D ADDVAL^RORTSK11(RORTSK,"AGE",$$DT^XLFDT,NOTES) | 
|---|
| 23 | S RC=$$TBLDEF^RORXU002("HEADER^RORX011",HEADER) | 
|---|
| 24 | Q $S(RC<0:RC,1:HEADER) | 
|---|
| 25 | ; | 
|---|
| 26 | ;***** OUTPUTS THE PARAMETERS TO THE REPORT | 
|---|
| 27 | ; | 
|---|
| 28 | ; PARTAG        Reference (IEN) to the parent tag | 
|---|
| 29 | ; | 
|---|
| 30 | ; [.STDT]       Start and end dates of the report | 
|---|
| 31 | ; [.ENDT]       are returned via these parameters | 
|---|
| 32 | ; | 
|---|
| 33 | ; [.FLAGS]      Flags for the $$SKIP^RORXU005 are | 
|---|
| 34 | ;               returned via this parameter | 
|---|
| 35 | ; | 
|---|
| 36 | ; Return Values: | 
|---|
| 37 | ;       <0  Error code | 
|---|
| 38 | ;       >0  IEN of the PARAMETERS element | 
|---|
| 39 | ; | 
|---|
| 40 | PARAMS(PARTAG,STDT,ENDT,FLAGS) ; | 
|---|
| 41 | N PARAMS,TMP | 
|---|
| 42 | S PARAMS=$$PARAMS^RORXU002(.RORTSK,PARTAG,.STDT,.ENDT,.FLAGS) | 
|---|
| 43 | Q:PARAMS<0 PARAMS | 
|---|
| 44 | ;--- Process the drug list and options | 
|---|
| 45 | S TMP=$$DRUGLST^RORXU007(.RORTSK,PARAMS,.RORXL,.RORXGRP) | 
|---|
| 46 | Q:TMP<0 TMP | 
|---|
| 47 | ;--- | 
|---|
| 48 | Q PARAMS | 
|---|
| 49 | ; | 
|---|
| 50 | ;***** PROCESS THE PATIENT'S DATA | 
|---|
| 51 | ; | 
|---|
| 52 | ; PTLIST        Reference (IEN) to the parent tag | 
|---|
| 53 | ; PATIEN        Patient IEN in the file #2 (DFN) | 
|---|
| 54 | ; | 
|---|
| 55 | ; Return Values: | 
|---|
| 56 | ;       <0  Error code | 
|---|
| 57 | ;        0  Ok | 
|---|
| 58 | ;       >0  Number of non-fatal errors | 
|---|
| 59 | ; | 
|---|
| 60 | PATIENT(PTLIST,PATIEN) ; | 
|---|
| 61 | N BUF,FLT,FLTL,FQL,ITEM,NODE,PTAG,QSB,RC,TABLE,VA,VADM,VAERR | 
|---|
| 62 | S (ECNT,RC)=0 | 
|---|
| 63 | ;--- Patient data | 
|---|
| 64 | S PTAG=$$ADDVAL^RORTSK11(RORTSK,"PATIENT",,PTLIST,,PATIEN) | 
|---|
| 65 | Q:PTAG<0 PTAG | 
|---|
| 66 | D VADEM^RORUTL05(PATIEN,1) | 
|---|
| 67 | D ADDVAL^RORTSK11(RORTSK,"NAME",VADM(1),PTAG,1) | 
|---|
| 68 | D ADDVAL^RORTSK11(RORTSK,"LAST4",VA("BID"),PTAG,2) | 
|---|
| 69 | D ADDVAL^RORTSK11(RORTSK,"DOB",$$DATE^RORXU002(VADM(3)\1),PTAG,1) | 
|---|
| 70 | D ADDVAL^RORTSK11(RORTSK,"AGE",VADM(4),PTAG,3) | 
|---|
| 71 | D ADDVAL^RORTSK11(RORTSK,"DOD",$$DATE^RORXU002(VADM(6)\1),PTAG,1) | 
|---|
| 72 | ;--- List of drugs | 
|---|
| 73 | S TABLE=$$ADDVAL^RORTSK11(RORTSK,"PTRXL",,PTAG) | 
|---|
| 74 | Q:TABLE<0 TABLE | 
|---|
| 75 | D ADDATTR^RORTSK11(RORTSK,TABLE,"TABLE","PTRXL") | 
|---|
| 76 | ;--- | 
|---|
| 77 | S NODE=RORXDST,FLTL=$L(NODE)-1,FLT=$E(NODE,1,FLTL) | 
|---|
| 78 | S QSB=$QL(NODE),FQL=QSB+5 | 
|---|
| 79 | F  S NODE=$Q(@NODE)  Q:$E(NODE,1,FLTL)'=FLT  D:$QL(NODE)=FQL | 
|---|
| 80 | . ; NODE: @RORXDST@(DATE,DRUGNAME,DRUGIEN,RXNUM,RXCNT) | 
|---|
| 81 | . S BUF=@NODE | 
|---|
| 82 | . S ITEM=$$ADDVAL^RORTSK11(RORTSK,"DRUG",,TABLE) | 
|---|
| 83 | . D ADDVAL^RORTSK11(RORTSK,"DATE",$QS(NODE,QSB+1)\1,ITEM,1) | 
|---|
| 84 | . D ADDVAL^RORTSK11(RORTSK,"ORDER",$QS(NODE,QSB+4),ITEM,1) | 
|---|
| 85 | . S TMP=$P(BUF,U) | 
|---|
| 86 | . S TMP=$S(TMP="O":"ORIGINAL",TMP="P":"PARTIAL",TMP="R":"REFILL",1:"") | 
|---|
| 87 | . D ADDVAL^RORTSK11(RORTSK,"TYPE",TMP,ITEM,1) | 
|---|
| 88 | . D ADDVAL^RORTSK11(RORTSK,"NAME",$QS(NODE,QSB+2),ITEM,1) | 
|---|
| 89 | . D ADDVAL^RORTSK11(RORTSK,"GENERIC",$P(BUF,U,4),ITEM,1) | 
|---|
| 90 | . D ADDVAL^RORTSK11(RORTSK,"DAYSPLY",$P(BUF,U,5),ITEM,1) | 
|---|
| 91 | . S TMP=$P(BUF,U,2) | 
|---|
| 92 | . S TMP=$S(TMP="I":"INPATIENT",TMP="M":"MAIL",TMP="W":"WINDOW",1:"") | 
|---|
| 93 | . D ADDVAL^RORTSK11(RORTSK,"FILLTYPE",TMP,ITEM,1) | 
|---|
| 94 | ;--- | 
|---|
| 95 | Q $S(RC<0:RC,1:ECNT) | 
|---|
| 96 | ; | 
|---|
| 97 | ;***** PROCESSES THE LIST OF PATIENTS | 
|---|
| 98 | ; | 
|---|
| 99 | ; REPORT        Reference (IEN) to the parent tag | 
|---|
| 100 | ; | 
|---|
| 101 | ; Return Values: | 
|---|
| 102 | ;       <0  Error code | 
|---|
| 103 | ;        0  Ok | 
|---|
| 104 | ;       >0  Number of non-fatal errors | 
|---|
| 105 | ; | 
|---|
| 106 | PROCESS(REPORT,FLAGS) ; | 
|---|
| 107 | N CNT,ECNT,IEN798,PTIEN,PTLIST,PTNODE,RC,RORPTN,RORXDST,RXFLAGS,TMP | 
|---|
| 108 | S (CNT,ECNT,RC)=0 | 
|---|
| 109 | ; | 
|---|
| 110 | ;--- Count patients in the list | 
|---|
| 111 | I RORALL  D  S:RORPTN<0 RORPTN=0 | 
|---|
| 112 | . S PTNODE=$NA(^RORDATA(798,"ARP",RORREG_"#")) | 
|---|
| 113 | . S RORPTN=$$REGSIZE^RORUTL02(+RORREG) | 
|---|
| 114 | E  S (PTIEN,RORPTN)=0  D  Q:RORPTN'>0 0 | 
|---|
| 115 | . S PTNODE=$NA(RORTSK("PARAMS","PATIENTS","C")) | 
|---|
| 116 | . F  S PTIEN=$O(@PTNODE@(PTIEN))  Q:PTIEN'>0  S RORPTN=RORPTN+1 | 
|---|
| 117 | ;--- | 
|---|
| 118 | S PTLIST=$$ADDVAL^RORTSK11(RORTSK,"PATIENTS",,REPORT) | 
|---|
| 119 | Q:PTLIST<0 PTLIST | 
|---|
| 120 | ; | 
|---|
| 121 | ;--- Prepare parameters for the pharmacy search API | 
|---|
| 122 | S RORXDST=$NA(^TMP("RORX011",$J)) | 
|---|
| 123 | S RORXDST("RORCB")="$$RXSCB^RORX011" | 
|---|
| 124 | S RXFLAGS="E" | 
|---|
| 125 | S:$$PARAM^RORTSK01("PATIENTS","INPATIENT") RXFLAGS=RXFLAGS_"IV" | 
|---|
| 126 | S:$$PARAM^RORTSK01("PATIENTS","OUTPATIENT") RXFLAGS=RXFLAGS_"O" | 
|---|
| 127 | ; | 
|---|
| 128 | ;--- Browse through the list of patients | 
|---|
| 129 | S (CNT,PTIEN)=0 | 
|---|
| 130 | F  S PTIEN=$O(@PTNODE@(PTIEN))  Q:PTIEN'>0  D  Q:RC<0 | 
|---|
| 131 | . S RC=$$LOOP^RORTSK01(CNT/RORPTN)  Q:RC<0 | 
|---|
| 132 | . S CNT=CNT+1,IEN798=$$PRRIEN^RORUTL01(PTIEN,RORREG)  Q:IEN798'>0 | 
|---|
| 133 | . ;--- Check if the patient should be skipped | 
|---|
| 134 | . I RORALL  Q:$$SKIP^RORXU005(IEN798,FLAGS,RORSDT,ROREDT) | 
|---|
| 135 | . ;--- Search the pharmacy data | 
|---|
| 136 | . K @RORXDST | 
|---|
| 137 | . S TMP=$$RXSEARCH^RORUTL14(PTIEN,RORXL,.RORXDST,RXFLAGS,RORSDT,ROREDT1) | 
|---|
| 138 | . I TMP<0  S ECNT=ECNT+1  Q | 
|---|
| 139 | . I RORALL  Q:TMP'>0 | 
|---|
| 140 | . ;--- Append the patient's data to the report | 
|---|
| 141 | . S TMP=$$PATIENT(PTLIST,PTIEN) | 
|---|
| 142 | . I TMP  S ECNT=ECNT+$S(TMP>0:TMP,1:1)  Q | 
|---|
| 143 | ; | 
|---|
| 144 | ;--- Cleanup | 
|---|
| 145 | K @RORXDST | 
|---|
| 146 | Q $S(RC<0:RC,1:ECNT) | 
|---|
| 147 | ; | 
|---|
| 148 | ;***** COMPILES THE "PATIENT DRUG HISTORY" REPORT | 
|---|
| 149 | ; REPORT CODE: 011 | 
|---|
| 150 | ; | 
|---|
| 151 | ; .RORTSK       Task number and task parameters | 
|---|
| 152 | ; | 
|---|
| 153 | ; The ^TMP("RORX011",$J) global node is used by this function. | 
|---|
| 154 | ; | 
|---|
| 155 | ; Return Values: | 
|---|
| 156 | ;       <0  Error code | 
|---|
| 157 | ;        0  Ok | 
|---|
| 158 | ; | 
|---|
| 159 | RXHIST(RORTSK) ; | 
|---|
| 160 | N RORALL        ; Consider all registry patients | 
|---|
| 161 | N ROREDT        ; End date | 
|---|
| 162 | N ROREDT1       ; End date + 1 | 
|---|
| 163 | N RORREG        ; Registry IEN | 
|---|
| 164 | N RORSDT        ; Start date | 
|---|
| 165 | N RORXGRP       ; List of drug groups | 
|---|
| 166 | N RORXL         ; Closed root of the medication list | 
|---|
| 167 | ; | 
|---|
| 168 | N ECNT,FLAGS,RC,REPORT,TMP | 
|---|
| 169 | S RORXL="",(ECNT,RC)=0 | 
|---|
| 170 | K ^TMP("RORX011",$J) | 
|---|
| 171 | ; | 
|---|
| 172 | ;--- Root node of the report | 
|---|
| 173 | S REPORT=$$ADDVAL^RORTSK11(RORTSK,"REPORT") | 
|---|
| 174 | Q:REPORT<0 REPORT | 
|---|
| 175 | ; | 
|---|
| 176 | D | 
|---|
| 177 | . ;--- Get and prepare the report parameters | 
|---|
| 178 | . S RORREG=+$$PARAM^RORTSK01("REGIEN") | 
|---|
| 179 | . S RORALL=$$PARAM^RORTSK01("PATIENTS","ALL") | 
|---|
| 180 | . S RC=$$PARAMS(REPORT,.RORSDT,.ROREDT,.FLAGS)  Q:RC<0 | 
|---|
| 181 | . S ROREDT1=$$FMADD^XLFDT(ROREDT\1,1) | 
|---|
| 182 | . ; | 
|---|
| 183 | . ;--- Report header | 
|---|
| 184 | . S RC=$$HEADER(REPORT)  Q:RC<0 | 
|---|
| 185 | . ; | 
|---|
| 186 | . ;--- Process the data and generate the report | 
|---|
| 187 | . S RC=$$PROCESS(REPORT,FLAGS)  S:RC>0 ECNT=ECNT+RC | 
|---|
| 188 | ; | 
|---|
| 189 | ;--- Cleanup | 
|---|
| 190 | K ^TMP("RORX011",$J) | 
|---|
| 191 | D FREE^RORTMP(RORXL) | 
|---|
| 192 | Q $S(RC<0:RC,ECNT>0:-43,1:0) | 
|---|
| 193 | ; | 
|---|
| 194 | ;***** CALLBACK FUNCTION FOR THE PHARMACY SEARCH API | 
|---|
| 195 | RXSCB(ROR8DST,ORDER,ORDFLG,DRUG,DATE) ; | 
|---|
| 196 | N DRUGIEN,DRUGNAME,FILLTYPE,IEN,IRP,OFD,RPSUB,RXBUF,RXCNT,RXNUM,TMP | 
|---|
| 197 | S DRUGIEN=+DRUG,DRUGNAME=$P(DRUG,U,2) | 
|---|
| 198 | Q:(DRUGIEN'>0)!(DRUGNAME="") 1 | 
|---|
| 199 | ;--- Check the drug groups | 
|---|
| 200 | S TMP=$$RXGRPCHK^RORXU007(.ROR8DST,+DRUG,RORXL) | 
|---|
| 201 | Q:TMP TMP | 
|---|
| 202 | ;--- Process the order | 
|---|
| 203 | S:ROR8DST("RORXGEN")>0 $P(RXBUF,U,4)=$P(ROR8DST("RORXGEN"),U,2) | 
|---|
| 204 | S $P(RXBUF,U,5)=$P($G(^TMP("PS",$J,0)),U,7)  ; Days Supply | 
|---|
| 205 | S TMP=$G(^TMP("PS",$J,"RXN",0)) | 
|---|
| 206 | S FILLTYPE=$S(ORDFLG["I":"I",1:$P(TMP,U,3)) | 
|---|
| 207 | S RXNUM=$P(TMP,U)  S:RXNUM="" RXNUM=" " | 
|---|
| 208 | S RXCNT=0 | 
|---|
| 209 | ;--- Original prescription | 
|---|
| 210 | I ORDFLG["I"  D  ;--- Inpatient | 
|---|
| 211 | . S OFD=$P($G(^TMP("PS",$J,0)),U,5)         ; Start Date | 
|---|
| 212 | . S $P(RXBUF,U,1,2)="I"_U_FILLTYPE,RXCNT=RXCNT+1 | 
|---|
| 213 | . S @ROR8DST@(OFD,DRUGNAME,DRUGIEN,RXNUM,RXCNT)=RXBUF | 
|---|
| 214 | E  D             ;--- Outpatient | 
|---|
| 215 | . S OFD=+$P($G(^TMP("PS",$J,"RXN",0)),U,6)  ; Original Fill Date | 
|---|
| 216 | . Q:(OFD<ROR8DST("RORSDT"))!(OFD'<ROR8DST("ROREDT")) | 
|---|
| 217 | . S $P(RXBUF,U,1,2)="O"_U_FILLTYPE,RXCNT=RXCNT+1 | 
|---|
| 218 | . S @ROR8DST@(OFD,DRUGNAME,DRUGIEN,RXNUM,RXCNT)=RXBUF | 
|---|
| 219 | ;--- Refills and partials | 
|---|
| 220 | F RPSUB="REF","PAR"  D | 
|---|
| 221 | . S $P(RXBUF,U)=$E(RPSUB,1) | 
|---|
| 222 | . S IRP=0 | 
|---|
| 223 | . F  S IRP=$O(^TMP("PS",$J,RPSUB,IRP))  Q:IRP'>0  D | 
|---|
| 224 | . . S TMP=$G(^TMP("PS",$J,RPSUB,IRP,0)) | 
|---|
| 225 | . . S $P(RXBUF,U,2)=$S(ORDFLG["I":"I",1:$P(TMP,U,5)) | 
|---|
| 226 | . . S $P(RXBUF,U,5)=$P(TMP,U,2)  ; Days Supply | 
|---|
| 227 | . . I TMP>0  S RXCNT=RXCNT+1  D | 
|---|
| 228 | . . . S @ROR8DST@(+TMP,DRUGNAME,DRUGIEN,RXNUM,RXCNT)=RXBUF | 
|---|
| 229 | Q 0 | 
|---|