RORX008A ;HOIFO/BH,SG - VERA REIMBURSEMENT REPORT ; 10/6/05 1:00pm ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006 ; Q ; ;***** QUERIES THE REGISTRY ; ; FLAGS Flags for the $$SKIP^RORXU005 ; ; Return Values: ; <0 Error code ; 0 Ok ; >0 Number of non-fatal errors ; QUERY(FLAGS) ; N RORPTN ; Number of patients in the registry ; N CLINAIDS,CMPXCARE,CNT,CNTARV,CNTBASIC,CNTCMPX,ECNT,IEN,NAME,PATIEN,RC,RORIEN,RORXDST,TMP,UTLCHK,VA,VADM,VAERR,XREFNODE ; S XREFNODE=$NA(^RORDATA(798,"AC",+RORREG)) S RORPTN=$$REGSIZE^RORUTL02(+RORREG) S:RORPTN<0 RORPTN=0 S (CNT,CNTARV,CNTBASIC,CNTCMPX,ECNT,RC)=0 S UTLCHK("ALL")="" ; ;--- Prepare parameters for the pharmacy search API S RORXDST("RORCB")="$$RXSCB^RORX008A" S TMP=$$PARAM^RORTSK01("OPTIONS","REGMEDSMRY") S RORXDST("SINGLE")='TMP!'$$PARAM^RORTSK01("PATIENTS","COMPLEX") ; ;--- Browse through the registry records S RORIEN=0 F S RORIEN=$O(@XREFNODE@(RORIEN)) Q:RORIEN'>0 D Q:RC<0 . S TMP=$S(RORPTN>0:CNT/RORPTN,1:"") . S RC=$$LOOP^RORTSK01(TMP) Q:RC<0 . S CNT=CNT+1 . ;--- Check if the patient should be skipped . Q:$$SKIP^RORXU005(RORIEN,FLAGS,RORSDT,ROREDT) . ; . ;--- Get the patient IEN (DFN) . S PATIEN=$$PTIEN^RORUTL01(RORIEN) Q:PATIEN'>0 . ; . ;--- Skip Clinical AIDS if Complex Care was not requested . S CMPXCARE=0 . S CLINAIDS=$S($$CLINAIDS^RORHIVUT(RORIEN,ROREDT):1,1:0) . I CLINAIDS Q:'$$PARAM^RORTSK01("PATIENTS","COMPLEX") S CMPXCARE=1 . ; . ;--- Skip a patient without utlilization . Q:'$$UTIL^RORXU003(RORSDT,ROREDT,PATIEN,.UTLCHK) . ; . ;--- Search for pharmacy data . K RORXDST("ARV") . S TMP=$$RXSEARCH^RORUTL14(PATIEN,RORXL,.RORXDST,"EIOV",RORSDT,ROREDT1) . I TMP<0 S ECNT=ECNT+1 Q . I $D(RORXDST("ARV")) Q:'$$PARAM^RORTSK01("PATIENTS","COMPLEX") D . . S IEN=0 . . F S IEN=$O(RORXDST("ARV",IEN)) Q:IEN'>0 D . . . D:'$D(^TMP("RORX008",$J,"DRG",IEN)) . . . . S ^TMP("RORX008",$J,"DRG",IEN)=RORXDST("ARV",IEN) . . . S ^(CLINAIDS)=$G(^TMP("RORX008",$J,"DRG",IEN,CLINAIDS))+1 . . S CMPXCARE=1,CNTARV=CNTARV+1 . ; . ;--- Skip Basic Care if it was not requested . I CMPXCARE S CNTCMPX=CNTCMPX+1 . E Q:'$$PARAM^RORTSK01("PATIENTS","BASIC") S CNTBASIC=CNTBASIC+1 . ; . D:$$PARAM^RORTSK01("OPTIONS","PTLIST") . . D VADEM^RORUTL05(PATIEN,1) . . S TMP=$$DATE^RORXU002(VADM(6)\1) . . S TMP=TMP_U_($D(RORXDST("ARV"))>0)_U_CMPXCARE_U_CLINAIDS . . S ^TMP("RORX008",$J,"PAT",PATIEN)=VA("BID")_U_VADM(1)_U_TMP ; ;--- Totals S ^TMP("RORX008",$J,"PAT")=CNTBASIC_U_CNTCMPX_U_CNTARV ;--- Q $S(RC<0:RC,1:ECNT) ; ;***** CALLBACK FUNCTION FOR THE PHARMACY SEARCH API RXSCB(ROR8DST,ORDER,ORDFLG,DRUG,DATE) ; N CA,IEN,NAME S IEN=+ROR8DST("RORXGEN"),NAME=$P(ROR8DST("RORXGEN"),U,2) Q:(IEN'>0)!(NAME="") 1 ;--- S ROR8DST("ARV")="" Q:ROR8DST("SINGLE") 2 ;--- S ROR8DST("ARV",IEN)=NAME Q 0 ; ;***** STORES THE REPORT DATA ; ; REPORT IEN of the REPORT element ; ; Return Values: ; <0 Error code ; 0 Ok ; >0 Number of non-fatal errors ; STORE(REPORT) ; N BUF,CNT,ITEM,IEN,NODE,NPAIDS,NPHIV,RC,TABLE,TMP S NODE=$NA(^TMP("RORX008",$J)),RC=0 ; ;--- List of ARV drugs S TMP=$$PARAM^RORTSK01("OPTIONS","REGMEDSMRY") I TMP,$$PARAM^RORTSK01("PATIENTS","COMPLEX") D Q:RC<0 RC . S TABLE=$$ADDVAL^RORTSK11(RORTSK,"DRUGS",,REPORT) . I TABLE<0 S RC=TABLE Q . D ADDATTR^RORTSK11(RORTSK,TABLE,"TABLE","DRUGS") . S IEN=0 . F S IEN=$O(@NODE@("DRG",IEN)) Q:IEN'>0 D . . S BUF=@NODE@("DRG",IEN) . . S ITEM=$$ADDVAL^RORTSK11(RORTSK,"DRUG",,TABLE) . . D ADDVAL^RORTSK11(RORTSK,"NAME",$P(@NODE@("DRG",IEN),U),ITEM,1) . . S NPHIV=+$G(@NODE@("DRG",IEN,0)) . . S NPAIDS=+$G(@NODE@("DRG",IEN,1)) . . D ADDVAL^RORTSK11(RORTSK,"NP",NPHIV+NPAIDS,ITEM,3) . . D ADDVAL^RORTSK11(RORTSK,"NPHIV",NPHIV,ITEM,3) . . D ADDVAL^RORTSK11(RORTSK,"NPAIDS",NPAIDS,ITEM,3) ; ;--- List of patients I $$PARAM^RORTSK01("OPTIONS","PTLIST") D Q:RC<0 RC . S TABLE=$$ADDVAL^RORTSK11(RORTSK,"PATIENTS",,REPORT) . I TABLE<0 S RC=TABLE Q . D ADDATTR^RORTSK11(RORTSK,TABLE,"TABLE","PATIENTS") . S IEN=0 . F S IEN=$O(@NODE@("PAT",IEN)) Q:IEN'>0 D . . S BUF=@NODE@("PAT",IEN) . . S ITEM=$$ADDVAL^RORTSK11(RORTSK,"PATIENT",,TABLE,,IEN) . . D ADDVAL^RORTSK11(RORTSK,"NAME",$P(BUF,U,2),ITEM,1) . . D ADDVAL^RORTSK11(RORTSK,"LAST4",$P(BUF,U),ITEM,2) . . D ADDVAL^RORTSK11(RORTSK,"DOD",$P(BUF,U,3),ITEM,1) . . D ADDVAL^RORTSK11(RORTSK,"AIDSTAT",+$P(BUF,U,6),ITEM,1) . . D ADDVAL^RORTSK11(RORTSK,"ARV",+$P(BUF,U,4),ITEM,1) . . D ADDVAL^RORTSK11(RORTSK,"COMPLEX",+$P(BUF,U,5),ITEM,1) ; ;--- Summary S BUF=@NODE@("PAT") S ITEM=$$ADDVAL^RORTSK11(RORTSK,"SUMMARY",,REPORT) D ADDVAL^RORTSK11(RORTSK,"NP",$P(BUF,U)+$P(BUF,U,2),ITEM) D ADDVAL^RORTSK11(RORTSK,"NPBASIC",+$P(BUF,U,1),ITEM) D ADDVAL^RORTSK11(RORTSK,"NPCOMPLEX",+$P(BUF,U,2),ITEM) D ADDVAL^RORTSK11(RORTSK,"NPARV",+$P(BUF,U,3),ITEM) Q 0