| [613] | 1 | RORX006A ;HCIOFO/BH,SG - LAB UTILIZATION (QUERY & SORT) ; 11/8/05 8:35am
 | 
|---|
 | 2 |  ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006
 | 
|---|
 | 3 |  ;
 | 
|---|
 | 4 |  Q
 | 
|---|
 | 5 |  ;
 | 
|---|
 | 6 |  ;***** LOADS AND PROCESSES THE LAB DATA
 | 
|---|
 | 7 |  ;
 | 
|---|
 | 8 |  ; DFN           Patient IEN (in file #2)
 | 
|---|
 | 9 |  ;
 | 
|---|
 | 10 |  ; Return Values:
 | 
|---|
 | 11 |  ;       <0  Error code
 | 
|---|
 | 12 |  ;        0  Ok
 | 
|---|
 | 13 |  ;       >0  Number of non-fatal errors
 | 
|---|
 | 14 |  ;
 | 
|---|
 | 15 | LABDATA(DFN) ;
 | 
|---|
 | 16 |  N DST,ENDT,NR,PTNO,PTNR,PRNT,RC,TSTIEN
 | 
|---|
 | 17 |  S DST=$NA(^TMP("RORX006",$J))
 | 
|---|
 | 18 |  ;
 | 
|---|
 | 19 |  ;--- Get the data
 | 
|---|
 | 20 |  S DST("RORCB")="$$LTSCB^RORX006A",DST("RORIDT")=""
 | 
|---|
 | 21 |  S RC=$$LTSEARCH^RORUTL10(DFN,RORLTST,.DST,,RORSDT,ROREDT1)
 | 
|---|
 | 22 |  Q:RC<0 RC  Q:$D(@DST@("PAT",DFN))<10 0
 | 
|---|
 | 23 |  ;
 | 
|---|
 | 24 |  ;--- Calculate intermediate totals of the tests
 | 
|---|
 | 25 |  S TSTIEN=0,(PTNR,PTNT)=0
 | 
|---|
 | 26 |  F  S TSTIEN=$O(@DST@("PAT",DFN,"R",TSTIEN))  Q:TSTIEN'>0  D
 | 
|---|
 | 27 |  . S NR=+$G(@DST@("PAT",DFN,"R",TSTIEN))
 | 
|---|
 | 28 |  . S PTNR=PTNR+NR  ; Number of patient's results
 | 
|---|
 | 29 |  . S PTNT=PTNT+1   ; Number of different tests
 | 
|---|
 | 30 |  . ;---
 | 
|---|
 | 31 |  . S @DST@("RES",TSTIEN,"P")=$G(@DST@("RES",TSTIEN,"P"))+1
 | 
|---|
 | 32 |  . S @DST@("RES",TSTIEN,"R")=$G(@DST@("RES",TSTIEN,"R"))+NR
 | 
|---|
 | 33 |  . ;---
 | 
|---|
 | 34 |  . S TMP=$G(@DST@("RES",TSTIEN,"M"))
 | 
|---|
 | 35 |  . D:NR'<TMP
 | 
|---|
 | 36 |  . . I NR>TMP  S @DST@("RES",TSTIEN,"M")=NR_U_1  Q
 | 
|---|
 | 37 |  . . S $P(@DST@("RES",TSTIEN,"M"),U,2)=$P(TMP,U,2)+1
 | 
|---|
 | 38 |  ;
 | 
|---|
 | 39 |  ;--- Orders
 | 
|---|
 | 40 |  S @DST@("ORD")=$G(@DST@("ORD"))+$G(@DST@("PAT",DFN,"O"))
 | 
|---|
 | 41 |  ;
 | 
|---|
 | 42 |  ;--- Results
 | 
|---|
 | 43 |  S @DST@("RES1",PTNR)=$G(@DST@("RES1",PTNR))+1
 | 
|---|
 | 44 |  S @DST@("RES1",PTNR,RORPNAME,DFN)=""
 | 
|---|
 | 45 |  ;
 | 
|---|
 | 46 |  ;--- Other totals
 | 
|---|
 | 47 |  S @DST@("PAT",DFN)=RORLAST4_U_RORDOD
 | 
|---|
 | 48 |  S @DST@("PAT",DFN,"R")=PTNR_U_PTNT
 | 
|---|
 | 49 |  S @DST@("PAT")=$G(@DST@("PAT"))+1
 | 
|---|
 | 50 |  S @DST@("RES")=$G(@DST@("RES"))+PTNR
 | 
|---|
 | 51 |  Q 0
 | 
|---|
 | 52 |  ;
 | 
|---|
 | 53 |  ;***** LAB SEARCH CALLBACK
 | 
|---|
 | 54 |  ;
 | 
|---|
 | 55 |  ; .ROR8DST      Reference to the ROR8DST parameter.
 | 
|---|
 | 56 |  ;
 | 
|---|
 | 57 |  ; INVDT         IEN of the Lab test (inverted date)
 | 
|---|
 | 58 |  ;
 | 
|---|
 | 59 |  ; .RESULT       Reference to a local variable, which contains
 | 
|---|
 | 60 |  ;               the result (see the $$LTSEARCH^RORUTL10).
 | 
|---|
 | 61 |  ;
 | 
|---|
 | 62 |  ; Return Values:
 | 
|---|
 | 63 |  ;       <0  Error code (the search will be aborted)
 | 
|---|
 | 64 |  ;        0  Ok
 | 
|---|
 | 65 |  ;        1  Skip this result
 | 
|---|
 | 66 |  ;        2  Skip this and all remaining results
 | 
|---|
 | 67 |  ;
 | 
|---|
 | 68 | LTSCB(ROR8DST,INVDT,RESULT) ;
 | 
|---|
 | 69 |  N DFN,TMP,TSTIEN
 | 
|---|
 | 70 |  S DFN=+ROR8DST("RORDFN"),TSTIEN=+RESULT(2)
 | 
|---|
 | 71 |  ;--- Number of orders
 | 
|---|
 | 72 |  I INVDT'=ROR8DST("RORIDT")  D  S ROR8DST("RORIDT")=INVDT
 | 
|---|
 | 73 |  . S @ROR8DST@("PAT",DFN,"O")=$G(@ROR8DST@("PAT",DFN,"O"))+1
 | 
|---|
 | 74 |  ;--- Number of results
 | 
|---|
 | 75 |  S TMP=$G(@ROR8DST@("PAT",DFN,"R",TSTIEN))
 | 
|---|
 | 76 |  S @ROR8DST@("PAT",DFN,"R",TSTIEN)=TMP+1
 | 
|---|
 | 77 |  Q 0
 | 
|---|
 | 78 |  ;
 | 
|---|
 | 79 |  ;***** QUERIES THE REGISTRY
 | 
|---|
 | 80 |  ;
 | 
|---|
 | 81 |  ; FLAGS         Flags for the $$SKIP^RORXU005
 | 
|---|
 | 82 |  ;
 | 
|---|
 | 83 |  ; Return Values:
 | 
|---|
 | 84 |  ;       <0  Error code
 | 
|---|
 | 85 |  ;        0  Ok
 | 
|---|
 | 86 |  ;       >0  Number of non-fatal errors
 | 
|---|
 | 87 |  ;
 | 
|---|
 | 88 | QUERY(FLAGS) ;
 | 
|---|
 | 89 |  N RORDOD        ; Date of death of the current patient
 | 
|---|
 | 90 |  N RORLAST4      ; Last 4 digits of the current patient's SSN
 | 
|---|
 | 91 |  N RORPNAME      ; Name of the current patient
 | 
|---|
 | 92 |  N RORPTN        ; Number of patients in the registry
 | 
|---|
 | 93 |  ;
 | 
|---|
 | 94 |  N CNT,ECNT,IEN,IENS,PATIEN,RC,TMP,VA,VADM,XREFNODE
 | 
|---|
 | 95 |  S XREFNODE=$NA(^RORDATA(798,"AC",+RORREG))
 | 
|---|
 | 96 |  S RORPTN=$$REGSIZE^RORUTL02(+RORREG)  S:RORPTN<0 RORPTN=0
 | 
|---|
 | 97 |  S (CNT,ECNT,RC)=0
 | 
|---|
 | 98 |  ;
 | 
|---|
 | 99 |  ;--- Browse through the registry records
 | 
|---|
 | 100 |  S IEN=0
 | 
|---|
 | 101 |  F  S IEN=$O(@XREFNODE@(IEN))  Q:IEN'>0  D  Q:RC<0
 | 
|---|
 | 102 |  . S TMP=$S(RORPTN>0:CNT/RORPTN,1:"")
 | 
|---|
 | 103 |  . S RC=$$LOOP^RORTSK01(TMP)  Q:RC<0
 | 
|---|
 | 104 |  . S IENS=IEN_",",CNT=CNT+1
 | 
|---|
 | 105 |  . ;--- Check if the patient should be skipped
 | 
|---|
 | 106 |  . Q:$$SKIP^RORXU005(IEN,FLAGS,RORSDT,ROREDT)
 | 
|---|
 | 107 |  . ;
 | 
|---|
 | 108 |  . ;--- Get the patient IEN (DFN)
 | 
|---|
 | 109 |  . S PATIEN=$$PTIEN^RORUTL01(IEN)  Q:PATIEN'>0
 | 
|---|
 | 110 |  . ;
 | 
|---|
 | 111 |  . ;--- Get the patient's data
 | 
|---|
 | 112 |  . D VADEM^RORUTL05(PATIEN,1)
 | 
|---|
 | 113 |  . S RORPNAME=VADM(1),RORLAST4=VA("BID")
 | 
|---|
 | 114 |  . S RORDOD=$$DATE^RORXU002($P(VADM(6),U)\1)
 | 
|---|
 | 115 |  . ;
 | 
|---|
 | 116 |  . ;--- Get the Lab data
 | 
|---|
 | 117 |  . S RC=$$LABDATA(PATIEN)
 | 
|---|
 | 118 |  . I RC  Q:RC<0  S ECNT=ECNT+RC
 | 
|---|
 | 119 |  ;---
 | 
|---|
 | 120 |  Q $S(RC<0:RC,1:ECNT)
 | 
|---|
 | 121 |  ;
 | 
|---|
 | 122 |  ;***** SORTS THE RESULTS AND COMPILES THE TOTALS
 | 
|---|
 | 123 |  ;
 | 
|---|
 | 124 |  ; Return Values:
 | 
|---|
 | 125 |  ;       <0  Error code
 | 
|---|
 | 126 |  ;        0  Ok
 | 
|---|
 | 127 |  ;       >0  Number of non-fatal errors
 | 
|---|
 | 128 |  ;
 | 
|---|
 | 129 | SORT() ;
 | 
|---|
 | 130 |  N ECNT,IEN,NAME,NDLT,NODE,RC,RORMSG,TMP
 | 
|---|
 | 131 |  S NODE=$NA(^TMP("RORX006",$J)),(ECNT,RC)=0
 | 
|---|
 | 132 |  ;---
 | 
|---|
 | 133 |  S RC=$$LOOP^RORTSK01(0)  Q:RC<0 RC
 | 
|---|
 | 134 |  Q:$D(@NODE)<10 0
 | 
|---|
 | 135 |  ;---
 | 
|---|
 | 136 |  S IEN=0,NDLT=0
 | 
|---|
 | 137 |  F  S IEN=$O(@NODE@("RES",IEN))  Q:IEN'>0  D
 | 
|---|
 | 138 |  . S NDLT=NDLT+1
 | 
|---|
 | 139 |  . S NAME=$$GET1^DIQ(60,IEN,.01,,,"RORMSG")
 | 
|---|
 | 140 |  . D:$G(DIERR) DBS^RORERR("RORMSG",-9,,,60,IEN)
 | 
|---|
 | 141 |  . S:NAME?." " NAME="Unknown ("_IEN_")"
 | 
|---|
 | 142 |  . S TMP=+$G(@NODE@("RES",IEN,"R"))
 | 
|---|
 | 143 |  . S @NODE@("RES","B",TMP,NAME,IEN)=""
 | 
|---|
 | 144 |  ;--- Total numbers of Lab tests
 | 
|---|
 | 145 |  S $P(@NODE@("RES"),U,2)=NDLT
 | 
|---|
 | 146 |  ;---
 | 
|---|
 | 147 |  Q $S(RC<0:RC,1:ECNT)
 | 
|---|