RORX008A ;HOIFO/BH,SG,VAC - VERA REIMBURSEMENT REPORT ;4/7/09 2:08pm
;;1.5;CLINICAL CASE REGISTRIES;**8,13,19,21,31,39**;Feb 17, 2006;Build 4
;
;******************************************************************************
;******************************************************************************
; --- ROUTINE MODIFICATION LOG ---
;
;PKG/PATCH DATE DEVELOPER MODIFICATION
;----------- ---------- ----------- ----------------------------------------
;ROR*1.5*8 MAR 2010 V CARR Modified to handle ICD9 filter for
; 'include' or 'exclude'.
;ROR*1.5*13 DEC 2010 A SAUNDERS User can select specific patients,
; clinics, or divisions for the report.
;ROR*1.5*19 FEB 2012 K GUPTA Support for ICD-10 Coding System
;ROR*1.5*21 SEP 2013 T KOPP Added ICN as last report column if
; additional identifier option selected
;ROR*1.5*31 MAY 2017 M FERRARESE Adding PACT, PCP, and AGE/DOB as additional
; identifiers.
;ROR*1.5*39 JUL 2021 M FERRARESE Setting SSN and LAST4 to zeros
;******************************************************************************
;******************************************************************************
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 RORCDLIST ; Flag to indicate whether a clinic or division list exists
N RORCDSTDT ; Start date for clinic/division utilization search
N RORCDENDT ; End date for clinic/division utilization search
;
N CLINAIDS,CMPXCARE,CNT,CNTARV,CNTBASIC,CNTCMPX,ECNT,FLAG,IEN,NAME,PATIEN,RC,RCC,RORIEN,RORXDST,TMP,UTLCHK,VA,VADM,VAERR,XREFNODE
N AGE,AGETYPE
;
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")
;
;=== Set up Clinic/Division list parameters
S RORCDLIST=$$CDPARMS^RORXU001(.RORTSK,.RORCDSTDT,.RORCDENDT)
;
;--- Browse through the registry records
S RORIEN=0
S FLAG=$G(RORTSK("PARAMS","ICDFILT","A","FILTER"))
F S RORIEN=$O(@XREFNODE@(RORIEN)) Q:RORIEN'>0 D Q:RC<0
. ;--- Start progress counter
. S TMP=$S(RORPTN>0:CNT/RORPTN,1:"")
. S RC=$$LOOP^RORTSK01(TMP) Q:RC<0
. S CNT=CNT+1
. ;--- Get patient DFN
. S PATIEN=$$PTIEN^RORUTL01(RORIEN) Q:PATIEN'>0
. ;check for patient list and quit if not on list
. I $D(RORTSK("PARAMS","PATIENTS","C")),'$D(RORTSK("PARAMS","PATIENTS","C",PATIEN)) Q
. ;--- Check if the patient should be skipped
. Q:$$SKIP^RORXU005(RORIEN,FLAGS,RORSDT,ROREDT)
. ;--- Check patient against ICD list
. S RCC=0
. I FLAG'="ALL" D
. . S RCC=$$ICD^RORXU010(PATIEN)
. I (FLAG="INCLUDE")&(RCC=0) Q
. I (FLAG="EXCLUDE")&(RCC=1) Q
. ; End of check of ICD list
. ;
. ;--- Check for Clinic or Division list and quit if not in list
. I RORCDLIST,'$$CDUTIL^RORXU001(.RORTSK,PATIEN,RORCDSTDT,RORCDENDT) Q
. ;
. ;--- 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 ;naked reference: ^TMP("RORX008",$J,"DRG",IEN,CLINAIDS)
. . 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
. . S $P(^TMP("RORX008",$J,"PAT",PATIEN),U,6)=$S($$PARAM^RORTSK01("PATIENTS","ICN"):$$ICN^RORUTL02(PATIEN),1:"")
. . S $P(^TMP("RORX008",$J,"PAT",PATIEN),U,7)=$S($$PARAM^RORTSK01("PATIENTS","PACT"):$$PACT^RORUTL02(PATIEN),1:"")
. . S $P(^TMP("RORX008",$J,"PAT",PATIEN),U,8)=$S($$PARAM^RORTSK01("PATIENTS","PCP"):$$PCP^RORUTL02(PATIEN),1:"")
. . S AGETYPE=$$PARAM^RORTSK01("AGE_RANGE","TYPE") D
. . . S AGE=$S(AGETYPE="AGE":$P(VADM(4),U),AGETYPE="DOB":$$DATE^RORXU002($P(VADM(3),U)\1),1:"")
. . S $P(^TMP("RORX008",$J,"PAT",PATIEN),U,9)=AGE
;
;--- 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 $P(BUF,U)="0000"
. . 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)
. . S AGETYPE=$$PARAM^RORTSK01("AGE_RANGE","TYPE") I AGETYPE'="ALL" D
. . . D ADDVAL^RORTSK11(RORTSK,AGETYPE,$P(BUF,U,9),ITEM,1)
. . 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)
. . I $$PARAM^RORTSK01("PATIENTS","ICN") D ADDVAL^RORTSK11(RORTSK,"ICN",$P(BUF,U,6),ITEM,1)
. . I $$PARAM^RORTSK01("PATIENTS","PACT") D ADDVAL^RORTSK11(RORTSK,"PACT",$P(BUF,U,7),ITEM,1)
. . I $$PARAM^RORTSK01("PATIENTS","PCP") D ADDVAL^RORTSK11(RORTSK,"PCP",$P(BUF,U,8),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
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HRORX008A 8327 printed Sep 15, 2024@21:08:44 Page 2
RORX008A ;HOIFO/BH,SG,VAC - VERA REIMBURSEMENT REPORT ;4/7/09 2:08pm
+1 ;;1.5;CLINICAL CASE REGISTRIES;**8,13,19,21,31,39**;Feb 17, 2006;Build 4
+2 ;
+3 ;******************************************************************************
+4 ;******************************************************************************
+5 ; --- ROUTINE MODIFICATION LOG ---
+6 ;
+7 ;PKG/PATCH DATE DEVELOPER MODIFICATION
+8 ;----------- ---------- ----------- ----------------------------------------
+9 ;ROR*1.5*8 MAR 2010 V CARR Modified to handle ICD9 filter for
+10 ; 'include' or 'exclude'.
+11 ;ROR*1.5*13 DEC 2010 A SAUNDERS User can select specific patients,
+12 ; clinics, or divisions for the report.
+13 ;ROR*1.5*19 FEB 2012 K GUPTA Support for ICD-10 Coding System
+14 ;ROR*1.5*21 SEP 2013 T KOPP Added ICN as last report column if
+15 ; additional identifier option selected
+16 ;ROR*1.5*31 MAY 2017 M FERRARESE Adding PACT, PCP, and AGE/DOB as additional
+17 ; identifiers.
+18 ;ROR*1.5*39 JUL 2021 M FERRARESE Setting SSN and LAST4 to zeros
+19 ;******************************************************************************
+20 ;******************************************************************************
+21 QUIT
+22 ;
+23 ;***** QUERIES THE REGISTRY
+24 ;
+25 ; FLAGS Flags for the $$SKIP^RORXU005
+26 ;
+27 ; Return Values:
+28 ; <0 Error code
+29 ; 0 Ok
+30 ; >0 Number of non-fatal errors
+31 ;
QUERY(FLAGS) ;
+1 ; Number of patients in the registry
NEW RORPTN
+2 ; Flag to indicate whether a clinic or division list exists
NEW RORCDLIST
+3 ; Start date for clinic/division utilization search
NEW RORCDSTDT
+4 ; End date for clinic/division utilization search
NEW RORCDENDT
+5 ;
+6 NEW CLINAIDS,CMPXCARE,CNT,CNTARV,CNTBASIC,CNTCMPX,ECNT,FLAG,IEN,NAME,PATIEN,RC,RCC,RORIEN,RORXDST,TMP,UTLCHK,VA,VADM,VAERR,XREFNODE
+7 NEW AGE,AGETYPE
+8 ;
+9 SET XREFNODE=$NAME(^RORDATA(798,"AC",+RORREG))
+10 SET RORPTN=$$REGSIZE^RORUTL02(+RORREG)
if RORPTN<0
SET RORPTN=0
+11 SET (CNT,CNTARV,CNTBASIC,CNTCMPX,ECNT,RC)=0
+12 SET UTLCHK("ALL")=""
+13 ;
+14 ;--- Prepare parameters for the pharmacy search API
+15 SET RORXDST("RORCB")="$$RXSCB^RORX008A"
+16 SET TMP=$$PARAM^RORTSK01("OPTIONS","REGMEDSMRY")
+17 SET RORXDST("SINGLE")='TMP!'$$PARAM^RORTSK01("PATIENTS","COMPLEX")
+18 ;
+19 ;=== Set up Clinic/Division list parameters
+20 SET RORCDLIST=$$CDPARMS^RORXU001(.RORTSK,.RORCDSTDT,.RORCDENDT)
+21 ;
+22 ;--- Browse through the registry records
+23 SET RORIEN=0
+24 SET FLAG=$GET(RORTSK("PARAMS","ICDFILT","A","FILTER"))
+25 FOR
SET RORIEN=$ORDER(@XREFNODE@(RORIEN))
if RORIEN'>0
QUIT
Begin DoDot:1
+26 ;--- Start progress counter
+27 SET TMP=$SELECT(RORPTN>0:CNT/RORPTN,1:"")
+28 SET RC=$$LOOP^RORTSK01(TMP)
if RC<0
QUIT
+29 SET CNT=CNT+1
+30 ;--- Get patient DFN
+31 SET PATIEN=$$PTIEN^RORUTL01(RORIEN)
if PATIEN'>0
QUIT
+32 ;check for patient list and quit if not on list
+33 IF $DATA(RORTSK("PARAMS","PATIENTS","C"))
IF '$DATA(RORTSK("PARAMS","PATIENTS","C",PATIEN))
QUIT
+34 ;--- Check if the patient should be skipped
+35 if $$SKIP^RORXU005(RORIEN,FLAGS,RORSDT,ROREDT)
QUIT
+36 ;--- Check patient against ICD list
+37 SET RCC=0
+38 IF FLAG'="ALL"
Begin DoDot:2
+39 SET RCC=$$ICD^RORXU010(PATIEN)
End DoDot:2
+40 IF (FLAG="INCLUDE")&(RCC=0)
QUIT
+41 IF (FLAG="EXCLUDE")&(RCC=1)
QUIT
+42 ; End of check of ICD list
+43 ;
+44 ;--- Check for Clinic or Division list and quit if not in list
+45 IF RORCDLIST
IF '$$CDUTIL^RORXU001(.RORTSK,PATIEN,RORCDSTDT,RORCDENDT)
QUIT
+46 ;
+47 ;--- Skip Clinical AIDS if Complex Care was not requested
+48 SET CMPXCARE=0
+49 SET CLINAIDS=$SELECT($$CLINAIDS^RORHIVUT(RORIEN,ROREDT):1,1:0)
+50 IF CLINAIDS
if '$$PARAM^RORTSK01("PATIENTS","COMPLEX")
QUIT
SET CMPXCARE=1
+51 ;
+52 ;--- Skip a patient without utlilization
+53 if '$$UTIL^RORXU003(RORSDT,ROREDT,PATIEN,.UTLCHK)
QUIT
+54 ;
+55 ;--- Search for pharmacy data
+56 KILL RORXDST("ARV")
+57 SET TMP=$$RXSEARCH^RORUTL14(PATIEN,RORXL,.RORXDST,"EIOV",RORSDT,ROREDT1)
+58 IF TMP<0
SET ECNT=ECNT+1
QUIT
+59 IF $DATA(RORXDST("ARV"))
if '$$PARAM^RORTSK01("PATIENTS","COMPLEX")
QUIT
Begin DoDot:2
+60 SET IEN=0
+61 FOR
SET IEN=$ORDER(RORXDST("ARV",IEN))
if IEN'>0
QUIT
Begin DoDot:3
+62 if '$DATA(^TMP("RORX008",$JOB,"DRG",IEN))
Begin DoDot:4
+63 SET ^TMP("RORX008",$JOB,"DRG",IEN)=RORXDST("ARV",IEN)
End DoDot:4
+64 ;naked reference: ^TMP("RORX008",$J,"DRG",IEN,CLINAIDS)
SET ^(CLINAIDS)=$GET(^TMP("RORX008",$JOB,"DRG",IEN,CLINAIDS))+1
End DoDot:3
+65 SET CMPXCARE=1
SET CNTARV=CNTARV+1
End DoDot:2
+66 ;
+67 ;--- Skip Basic Care if it was not requested
+68 IF CMPXCARE
SET CNTCMPX=CNTCMPX+1
+69 IF '$TEST
if '$$PARAM^RORTSK01("PATIENTS","BASIC")
QUIT
SET CNTBASIC=CNTBASIC+1
+70 ;
+71 if $$PARAM^RORTSK01("OPTIONS","PTLIST")
Begin DoDot:2
+72 DO VADEM^RORUTL05(PATIEN,1)
+73 SET TMP=$$DATE^RORXU002(VADM(6)\1)
+74 SET TMP=TMP_U_($DATA(RORXDST("ARV"))>0)_U_CMPXCARE_U_CLINAIDS
+75 SET ^TMP("RORX008",$JOB,"PAT",PATIEN)=VA("BID")_U_VADM(1)_U_TMP
+76 SET $PIECE(^TMP("RORX008",$JOB,"PAT",PATIEN),U,6)=$SELECT($$PARAM^RORTSK01("PATIENTS","ICN"):$$ICN^RORUTL02(PATIEN),1:"")
+77 SET $PIECE(^TMP("RORX008",$JOB,"PAT",PATIEN),U,7)=$SELECT($$PARAM^RORTSK01("PATIENTS","PACT"):$$PACT^RORUTL02(PATIEN),1:"")
+78 SET $PIECE(^TMP("RORX008",$JOB,"PAT",PATIEN),U,8)=$SELECT($$PARAM^RORTSK01("PATIENTS","PCP"):$$PCP^RORUTL02(PATIEN),1:"")
+79 SET AGETYPE=$$PARAM^RORTSK01("AGE_RANGE","TYPE")
Begin DoDot:3
+80 SET AGE=$SELECT(AGETYPE="AGE":$PIECE(VADM(4),U),AGETYPE="DOB":$$DATE^RORXU002($PIECE(VADM(3),U)\1),1:"")
End DoDot:3
+81 SET $PIECE(^TMP("RORX008",$JOB,"PAT",PATIEN),U,9)=AGE
End DoDot:2
End DoDot:1
if RC<0
QUIT
+82 ;
+83 ;--- Totals
+84 SET ^TMP("RORX008",$JOB,"PAT")=CNTBASIC_U_CNTCMPX_U_CNTARV
+85 ;---
+86 QUIT $SELECT(RC<0:RC,1:ECNT)
+87 ;
+88 ;***** CALLBACK FUNCTION FOR THE PHARMACY SEARCH API
RXSCB(ROR8DST,ORDER,ORDFLG,DRUG,DATE) ;
+1 NEW CA,IEN,NAME
+2 SET IEN=+ROR8DST("RORXGEN")
SET NAME=$PIECE(ROR8DST("RORXGEN"),U,2)
+3 if (IEN'>0)!(NAME="")
QUIT 1
+4 ;---
+5 SET ROR8DST("ARV")=""
if ROR8DST("SINGLE")
QUIT 2
+6 ;---
+7 SET ROR8DST("ARV",IEN)=NAME
+8 QUIT 0
+9 ;
+10 ;***** STORES THE REPORT DATA
+11 ;
+12 ; REPORT IEN of the REPORT element
+13 ;
+14 ; Return Values:
+15 ; <0 Error code
+16 ; 0 Ok
+17 ; >0 Number of non-fatal errors
+18 ;
STORE(REPORT) ;
+1 NEW BUF,CNT,ITEM,IEN,NODE,NPAIDS,NPHIV,RC,TABLE,TMP
+2 SET NODE=$NAME(^TMP("RORX008",$JOB))
SET RC=0
+3 ;
+4 ;--- List of ARV drugs
+5 SET TMP=$$PARAM^RORTSK01("OPTIONS","REGMEDSMRY")
+6 IF TMP
IF $$PARAM^RORTSK01("PATIENTS","COMPLEX")
Begin DoDot:1
+7 SET TABLE=$$ADDVAL^RORTSK11(RORTSK,"DRUGS",,REPORT)
+8 IF TABLE<0
SET RC=TABLE
QUIT
+9 DO ADDATTR^RORTSK11(RORTSK,TABLE,"TABLE","DRUGS")
+10 SET IEN=0
+11 FOR
SET IEN=$ORDER(@NODE@("DRG",IEN))
if IEN'>0
QUIT
Begin DoDot:2
+12 SET BUF=@NODE@("DRG",IEN)
+13 SET ITEM=$$ADDVAL^RORTSK11(RORTSK,"DRUG",,TABLE)
+14 DO ADDVAL^RORTSK11(RORTSK,"NAME",$PIECE(@NODE@("DRG",IEN),U),ITEM,1)
+15 SET NPHIV=+$GET(@NODE@("DRG",IEN,0))
+16 SET NPAIDS=+$GET(@NODE@("DRG",IEN,1))
+17 DO ADDVAL^RORTSK11(RORTSK,"NP",NPHIV+NPAIDS,ITEM,3)
+18 DO ADDVAL^RORTSK11(RORTSK,"NPHIV",NPHIV,ITEM,3)
+19 DO ADDVAL^RORTSK11(RORTSK,"NPAIDS",NPAIDS,ITEM,3)
End DoDot:2
End DoDot:1
if RC<0
QUIT RC
+20 ;
+21 ;--- List of patients
+22 IF $$PARAM^RORTSK01("OPTIONS","PTLIST")
Begin DoDot:1
+23 SET TABLE=$$ADDVAL^RORTSK11(RORTSK,"PATIENTS",,REPORT)
+24 IF TABLE<0
SET RC=TABLE
QUIT
+25 DO ADDATTR^RORTSK11(RORTSK,TABLE,"TABLE","PATIENTS")
+26 SET IEN=0
+27 FOR
SET IEN=$ORDER(@NODE@("PAT",IEN))
if IEN'>0
QUIT
Begin DoDot:2
+28 SET BUF=@NODE@("PAT",IEN)
SET $PIECE(BUF,U)="0000"
+29 SET ITEM=$$ADDVAL^RORTSK11(RORTSK,"PATIENT",,TABLE,,IEN)
+30 DO ADDVAL^RORTSK11(RORTSK,"NAME",$PIECE(BUF,U,2),ITEM,1)
+31 DO ADDVAL^RORTSK11(RORTSK,"LAST4",$PIECE(BUF,U),ITEM,2)
+32 SET AGETYPE=$$PARAM^RORTSK01("AGE_RANGE","TYPE")
IF AGETYPE'="ALL"
Begin DoDot:3
+33 DO ADDVAL^RORTSK11(RORTSK,AGETYPE,$PIECE(BUF,U,9),ITEM,1)
End DoDot:3
+34 DO ADDVAL^RORTSK11(RORTSK,"DOD",$PIECE(BUF,U,3),ITEM,1)
+35 DO ADDVAL^RORTSK11(RORTSK,"AIDSTAT",+$PIECE(BUF,U,6),ITEM,1)
+36 DO ADDVAL^RORTSK11(RORTSK,"ARV",+$PIECE(BUF,U,4),ITEM,1)
+37 DO ADDVAL^RORTSK11(RORTSK,"COMPLEX",+$PIECE(BUF,U,5),ITEM,1)
+38 IF $$PARAM^RORTSK01("PATIENTS","ICN")
DO ADDVAL^RORTSK11(RORTSK,"ICN",$PIECE(BUF,U,6),ITEM,1)
+39 IF $$PARAM^RORTSK01("PATIENTS","PACT")
DO ADDVAL^RORTSK11(RORTSK,"PACT",$PIECE(BUF,U,7),ITEM,1)
+40 IF $$PARAM^RORTSK01("PATIENTS","PCP")
DO ADDVAL^RORTSK11(RORTSK,"PCP",$PIECE(BUF,U,8),ITEM,1)
End DoDot:2
End DoDot:1
if RC<0
QUIT RC
+41 ;
+42 ;--- Summary
+43 SET BUF=@NODE@("PAT")
+44 SET ITEM=$$ADDVAL^RORTSK11(RORTSK,"SUMMARY",,REPORT)
+45 DO ADDVAL^RORTSK11(RORTSK,"NP",$PIECE(BUF,U)+$PIECE(BUF,U,2),ITEM)
+46 DO ADDVAL^RORTSK11(RORTSK,"NPBASIC",+$PIECE(BUF,U,1),ITEM)
+47 DO ADDVAL^RORTSK11(RORTSK,"NPCOMPLEX",+$PIECE(BUF,U,2),ITEM)
+48 DO ADDVAL^RORTSK11(RORTSK,"NPARV",+$PIECE(BUF,U,3),ITEM)
+49 QUIT 0