| [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) | 
|---|