| 1 | RORX008A ;HOIFO/BH,SG - VERA REIMBURSEMENT REPORT ; 10/6/05 1:00pm | 
|---|
| 2 | ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006 | 
|---|
| 3 | ; | 
|---|
| 4 | Q | 
|---|
| 5 | ; | 
|---|
| 6 | ;***** QUERIES THE REGISTRY | 
|---|
| 7 | ; | 
|---|
| 8 | ; FLAGS         Flags for the $$SKIP^RORXU005 | 
|---|
| 9 | ; | 
|---|
| 10 | ; Return Values: | 
|---|
| 11 | ;       <0  Error code | 
|---|
| 12 | ;        0  Ok | 
|---|
| 13 | ;       >0  Number of non-fatal errors | 
|---|
| 14 | ; | 
|---|
| 15 | QUERY(FLAGS) ; | 
|---|
| 16 | N RORPTN        ; Number of patients in the registry | 
|---|
| 17 | ; | 
|---|
| 18 | N CLINAIDS,CMPXCARE,CNT,CNTARV,CNTBASIC,CNTCMPX,ECNT,IEN,NAME,PATIEN,RC,RORIEN,RORXDST,TMP,UTLCHK,VA,VADM,VAERR,XREFNODE | 
|---|
| 19 | ; | 
|---|
| 20 | S XREFNODE=$NA(^RORDATA(798,"AC",+RORREG)) | 
|---|
| 21 | S RORPTN=$$REGSIZE^RORUTL02(+RORREG)  S:RORPTN<0 RORPTN=0 | 
|---|
| 22 | S (CNT,CNTARV,CNTBASIC,CNTCMPX,ECNT,RC)=0 | 
|---|
| 23 | S UTLCHK("ALL")="" | 
|---|
| 24 | ; | 
|---|
| 25 | ;--- Prepare parameters for the pharmacy search API | 
|---|
| 26 | S RORXDST("RORCB")="$$RXSCB^RORX008A" | 
|---|
| 27 | S TMP=$$PARAM^RORTSK01("OPTIONS","REGMEDSMRY") | 
|---|
| 28 | S RORXDST("SINGLE")='TMP!'$$PARAM^RORTSK01("PATIENTS","COMPLEX") | 
|---|
| 29 | ; | 
|---|
| 30 | ;--- Browse through the registry records | 
|---|
| 31 | S RORIEN=0 | 
|---|
| 32 | F  S RORIEN=$O(@XREFNODE@(RORIEN))  Q:RORIEN'>0  D  Q:RC<0 | 
|---|
| 33 | . S TMP=$S(RORPTN>0:CNT/RORPTN,1:"") | 
|---|
| 34 | . S RC=$$LOOP^RORTSK01(TMP)  Q:RC<0 | 
|---|
| 35 | . S CNT=CNT+1 | 
|---|
| 36 | . ;--- Check if the patient should be skipped | 
|---|
| 37 | . Q:$$SKIP^RORXU005(RORIEN,FLAGS,RORSDT,ROREDT) | 
|---|
| 38 | . ; | 
|---|
| 39 | . ;--- Get the patient IEN (DFN) | 
|---|
| 40 | . S PATIEN=$$PTIEN^RORUTL01(RORIEN)  Q:PATIEN'>0 | 
|---|
| 41 | . ; | 
|---|
| 42 | . ;--- Skip Clinical AIDS if Complex Care was not requested | 
|---|
| 43 | . S CMPXCARE=0 | 
|---|
| 44 | . S CLINAIDS=$S($$CLINAIDS^RORHIVUT(RORIEN,ROREDT):1,1:0) | 
|---|
| 45 | . I CLINAIDS  Q:'$$PARAM^RORTSK01("PATIENTS","COMPLEX")  S CMPXCARE=1 | 
|---|
| 46 | . ; | 
|---|
| 47 | . ;--- Skip a patient without utlilization | 
|---|
| 48 | . Q:'$$UTIL^RORXU003(RORSDT,ROREDT,PATIEN,.UTLCHK) | 
|---|
| 49 | . ; | 
|---|
| 50 | . ;--- Search for pharmacy data | 
|---|
| 51 | . K RORXDST("ARV") | 
|---|
| 52 | . S TMP=$$RXSEARCH^RORUTL14(PATIEN,RORXL,.RORXDST,"EIOV",RORSDT,ROREDT1) | 
|---|
| 53 | . I TMP<0  S ECNT=ECNT+1  Q | 
|---|
| 54 | . I $D(RORXDST("ARV"))  Q:'$$PARAM^RORTSK01("PATIENTS","COMPLEX")  D | 
|---|
| 55 | . . S IEN=0 | 
|---|
| 56 | . . F  S IEN=$O(RORXDST("ARV",IEN))  Q:IEN'>0  D | 
|---|
| 57 | . . . D:'$D(^TMP("RORX008",$J,"DRG",IEN)) | 
|---|
| 58 | . . . . S ^TMP("RORX008",$J,"DRG",IEN)=RORXDST("ARV",IEN) | 
|---|
| 59 | . . . S ^(CLINAIDS)=$G(^TMP("RORX008",$J,"DRG",IEN,CLINAIDS))+1 | 
|---|
| 60 | . . S CMPXCARE=1,CNTARV=CNTARV+1 | 
|---|
| 61 | . ; | 
|---|
| 62 | . ;--- Skip Basic Care if it was not requested | 
|---|
| 63 | . I CMPXCARE  S CNTCMPX=CNTCMPX+1 | 
|---|
| 64 | . E  Q:'$$PARAM^RORTSK01("PATIENTS","BASIC")  S CNTBASIC=CNTBASIC+1 | 
|---|
| 65 | . ; | 
|---|
| 66 | . D:$$PARAM^RORTSK01("OPTIONS","PTLIST") | 
|---|
| 67 | . . D VADEM^RORUTL05(PATIEN,1) | 
|---|
| 68 | . . S TMP=$$DATE^RORXU002(VADM(6)\1) | 
|---|
| 69 | . . S TMP=TMP_U_($D(RORXDST("ARV"))>0)_U_CMPXCARE_U_CLINAIDS | 
|---|
| 70 | . . S ^TMP("RORX008",$J,"PAT",PATIEN)=VA("BID")_U_VADM(1)_U_TMP | 
|---|
| 71 | ; | 
|---|
| 72 | ;--- Totals | 
|---|
| 73 | S ^TMP("RORX008",$J,"PAT")=CNTBASIC_U_CNTCMPX_U_CNTARV | 
|---|
| 74 | ;--- | 
|---|
| 75 | Q $S(RC<0:RC,1:ECNT) | 
|---|
| 76 | ; | 
|---|
| 77 | ;***** CALLBACK FUNCTION FOR THE PHARMACY SEARCH API | 
|---|
| 78 | RXSCB(ROR8DST,ORDER,ORDFLG,DRUG,DATE) ; | 
|---|
| 79 | N CA,IEN,NAME | 
|---|
| 80 | S IEN=+ROR8DST("RORXGEN"),NAME=$P(ROR8DST("RORXGEN"),U,2) | 
|---|
| 81 | Q:(IEN'>0)!(NAME="") 1 | 
|---|
| 82 | ;--- | 
|---|
| 83 | S ROR8DST("ARV")=""  Q:ROR8DST("SINGLE") 2 | 
|---|
| 84 | ;--- | 
|---|
| 85 | S ROR8DST("ARV",IEN)=NAME | 
|---|
| 86 | Q 0 | 
|---|
| 87 | ; | 
|---|
| 88 | ;***** STORES THE REPORT DATA | 
|---|
| 89 | ; | 
|---|
| 90 | ; REPORT        IEN of the REPORT element | 
|---|
| 91 | ; | 
|---|
| 92 | ; Return Values: | 
|---|
| 93 | ;       <0  Error code | 
|---|
| 94 | ;        0  Ok | 
|---|
| 95 | ;       >0  Number of non-fatal errors | 
|---|
| 96 | ; | 
|---|
| 97 | STORE(REPORT) ; | 
|---|
| 98 | N BUF,CNT,ITEM,IEN,NODE,NPAIDS,NPHIV,RC,TABLE,TMP | 
|---|
| 99 | S NODE=$NA(^TMP("RORX008",$J)),RC=0 | 
|---|
| 100 | ; | 
|---|
| 101 | ;--- List of ARV drugs | 
|---|
| 102 | S TMP=$$PARAM^RORTSK01("OPTIONS","REGMEDSMRY") | 
|---|
| 103 | I TMP,$$PARAM^RORTSK01("PATIENTS","COMPLEX")  D  Q:RC<0 RC | 
|---|
| 104 | . S TABLE=$$ADDVAL^RORTSK11(RORTSK,"DRUGS",,REPORT) | 
|---|
| 105 | . I TABLE<0  S RC=TABLE  Q | 
|---|
| 106 | . D ADDATTR^RORTSK11(RORTSK,TABLE,"TABLE","DRUGS") | 
|---|
| 107 | . S IEN=0 | 
|---|
| 108 | . F  S IEN=$O(@NODE@("DRG",IEN))  Q:IEN'>0  D | 
|---|
| 109 | . . S BUF=@NODE@("DRG",IEN) | 
|---|
| 110 | . . S ITEM=$$ADDVAL^RORTSK11(RORTSK,"DRUG",,TABLE) | 
|---|
| 111 | . . D ADDVAL^RORTSK11(RORTSK,"NAME",$P(@NODE@("DRG",IEN),U),ITEM,1) | 
|---|
| 112 | . . S NPHIV=+$G(@NODE@("DRG",IEN,0)) | 
|---|
| 113 | . . S NPAIDS=+$G(@NODE@("DRG",IEN,1)) | 
|---|
| 114 | . . D ADDVAL^RORTSK11(RORTSK,"NP",NPHIV+NPAIDS,ITEM,3) | 
|---|
| 115 | . . D ADDVAL^RORTSK11(RORTSK,"NPHIV",NPHIV,ITEM,3) | 
|---|
| 116 | . . D ADDVAL^RORTSK11(RORTSK,"NPAIDS",NPAIDS,ITEM,3) | 
|---|
| 117 | ; | 
|---|
| 118 | ;--- List of patients | 
|---|
| 119 | I $$PARAM^RORTSK01("OPTIONS","PTLIST")  D  Q:RC<0 RC | 
|---|
| 120 | . S TABLE=$$ADDVAL^RORTSK11(RORTSK,"PATIENTS",,REPORT) | 
|---|
| 121 | . I TABLE<0  S RC=TABLE  Q | 
|---|
| 122 | . D ADDATTR^RORTSK11(RORTSK,TABLE,"TABLE","PATIENTS") | 
|---|
| 123 | . S IEN=0 | 
|---|
| 124 | . F  S IEN=$O(@NODE@("PAT",IEN))  Q:IEN'>0  D | 
|---|
| 125 | . . S BUF=@NODE@("PAT",IEN) | 
|---|
| 126 | . . S ITEM=$$ADDVAL^RORTSK11(RORTSK,"PATIENT",,TABLE,,IEN) | 
|---|
| 127 | . . D ADDVAL^RORTSK11(RORTSK,"NAME",$P(BUF,U,2),ITEM,1) | 
|---|
| 128 | . . D ADDVAL^RORTSK11(RORTSK,"LAST4",$P(BUF,U),ITEM,2) | 
|---|
| 129 | . . D ADDVAL^RORTSK11(RORTSK,"DOD",$P(BUF,U,3),ITEM,1) | 
|---|
| 130 | . . D ADDVAL^RORTSK11(RORTSK,"AIDSTAT",+$P(BUF,U,6),ITEM,1) | 
|---|
| 131 | . . D ADDVAL^RORTSK11(RORTSK,"ARV",+$P(BUF,U,4),ITEM,1) | 
|---|
| 132 | . . D ADDVAL^RORTSK11(RORTSK,"COMPLEX",+$P(BUF,U,5),ITEM,1) | 
|---|
| 133 | ; | 
|---|
| 134 | ;--- Summary | 
|---|
| 135 | S BUF=@NODE@("PAT") | 
|---|
| 136 | S ITEM=$$ADDVAL^RORTSK11(RORTSK,"SUMMARY",,REPORT) | 
|---|
| 137 | D ADDVAL^RORTSK11(RORTSK,"NP",$P(BUF,U)+$P(BUF,U,2),ITEM) | 
|---|
| 138 | D ADDVAL^RORTSK11(RORTSK,"NPBASIC",+$P(BUF,U,1),ITEM) | 
|---|
| 139 | D ADDVAL^RORTSK11(RORTSK,"NPCOMPLEX",+$P(BUF,U,2),ITEM) | 
|---|
| 140 | D ADDVAL^RORTSK11(RORTSK,"NPARV",+$P(BUF,U,3),ITEM) | 
|---|
| 141 | Q 0 | 
|---|