1 | RORRP041 ;HCIOFO/SG - RPC: REGISTRY-SPECIFIC LAB RESULTS ; 8/25/05 12:24pm
|
---|
2 | ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006
|
---|
3 | ;
|
---|
4 | Q
|
---|
5 | ;
|
---|
6 | ;***** LOADS AND PROCESSES CD4 AND VIRAL LOAD RESULTS
|
---|
7 | ;
|
---|
8 | ; .ROR8DST( Reference to the Lab search descriptor.
|
---|
9 | ; See the $$LTSEARCH^RORUTL10 for details
|
---|
10 | ;
|
---|
11 | ; "RORPTR") Index of the last node in the destination buffer
|
---|
12 | ;
|
---|
13 | ; "RORSTATS",
|
---|
14 | ; Group,
|
---|
15 | ; "LAST") Latest
|
---|
16 | ; ^01: Result Value
|
---|
17 | ; ^02: Date
|
---|
18 | ; "MAX") Highest
|
---|
19 | ; ^01: Result Value
|
---|
20 | ; ^02: Date
|
---|
21 | ; "MIN") Lowest
|
---|
22 | ; ^01: Result Value
|
---|
23 | ; ^02: Date
|
---|
24 | ;
|
---|
25 | ; INVDT IEN of the Lab test (inverted date)
|
---|
26 | ;
|
---|
27 | ; .RESULT Reference to a local variable, which contains the
|
---|
28 | ; result in the same format as it is stored into
|
---|
29 | ; the destination array by default.
|
---|
30 | ;
|
---|
31 | ; Return Values:
|
---|
32 | ; <0 Error code (the search will be aborted)
|
---|
33 | ; 0 Ok
|
---|
34 | ; 1 Skip this result
|
---|
35 | ; 2 Skip this and all remaining results
|
---|
36 | ;
|
---|
37 | LOADLT(ROR8DST,INVDT,RESULT) ;
|
---|
38 | N BUF,GROUP,LTDT,LTVAL,TMP
|
---|
39 | S LTDT=$P($G(RESULT(1)),U,2) Q:LTDT'>0 1 ; Date of the test
|
---|
40 | S LTVAL=$$TRIM^XLFSTR($P(RESULT(1),U,3)) ; Result value
|
---|
41 | S GROUP=+$P($G(RESULT(2)),U,3) Q:GROUP'>0 1 ; Code of the group
|
---|
42 | ;
|
---|
43 | ;=== Create and store the segment
|
---|
44 | S BUF="LTR"_U_$P(RESULT(1),U)
|
---|
45 | S $P(BUF,U,3,4)=LTDT_U_LTVAL
|
---|
46 | S $P(BUF,U,5,8)=$P(RESULT(2),U,1,4)
|
---|
47 | S ROR8DST("RORPTR")=$G(ROR8DST("RORPTR"))+1
|
---|
48 | S @ROR8DST@(ROR8DST("RORPTR"))=BUF
|
---|
49 | ;
|
---|
50 | ;=== Most recent result of the group
|
---|
51 | D:LTDT>$P($G(ROR8DST("RORSTATS",GROUP,"LAST")),U,2)
|
---|
52 | . S ROR8DST("RORSTATS",GROUP,"LAST")=LTVAL_U_LTDT
|
---|
53 | ;
|
---|
54 | ;=== Numeric results
|
---|
55 | D:$$NUMERIC^RORUTL05(LTVAL)
|
---|
56 | . ;--- Lowest result value of the group
|
---|
57 | . S TMP=+$G(ROR8DST("RORSTATS",GROUP,"MIN"))
|
---|
58 | . S:'TMP!(LTVAL<TMP) ROR8DST("RORSTATS",GROUP,"MIN")=LTVAL_U_LTDT
|
---|
59 | . ;--- Highest result value of the group
|
---|
60 | . S TMP=+$G(ROR8DST("RORSTATS",GROUP,"MAX"))
|
---|
61 | . S:LTVAL>TMP ROR8DST("RORSTATS",GROUP,"MAX")=LTVAL_U_LTDT
|
---|
62 | ;
|
---|
63 | ;=== Success
|
---|
64 | Q 0
|
---|
65 | ;
|
---|
66 | ;***** LOADS THE PATIENT'S REGISTRY-SPECIFIC LAB RESULTS
|
---|
67 | ; RPC: [ROR PATIENT REGISTRY LABS]
|
---|
68 | ;
|
---|
69 | ; .RESULTS Reference to a local variable where the results
|
---|
70 | ; are returned to.
|
---|
71 | ;
|
---|
72 | ; REGIEN Registry IEN
|
---|
73 | ;
|
---|
74 | ; PATIEN IEN of the registry patient (DFN)
|
---|
75 | ;
|
---|
76 | ; Return Values:
|
---|
77 | ;
|
---|
78 | ; A negative value of the first "^"-piece of the RESULTS(0)
|
---|
79 | ; indicates an error (see the RPCSTK^RORERR procedure for more
|
---|
80 | ; details).
|
---|
81 | ;
|
---|
82 | ; Otherwise, zero is returned in the @RESULTS@(0) and the
|
---|
83 | ; subsequent nodes of the global array contain the data.
|
---|
84 | ;
|
---|
85 | ; @RESULTS@(0) 0
|
---|
86 | ;
|
---|
87 | ; @RESULTS@(i) Registry-specific Lab Result
|
---|
88 | ; ^01: "LTR"
|
---|
89 | ; ^02: Result IEN (inverted date/time)
|
---|
90 | ; ^03: Date/time of the test (FileMan)
|
---|
91 | ; ^04: Result
|
---|
92 | ; ^05: Test IEN (in file #60)
|
---|
93 | ; ^06: Test name
|
---|
94 | ; ^07: Code of the group
|
---|
95 | ; ^08: Group name
|
---|
96 | ;
|
---|
97 | ; @RESULTS@(i) Lab Group Statistics
|
---|
98 | ; ^01: "LTG"
|
---|
99 | ; ^02: Code of the group
|
---|
100 | ; ^03: Group name
|
---|
101 | ; ^04: Latest result value
|
---|
102 | ; ^05: Date of the latest result (FileMan)
|
---|
103 | ; ^06: Lowest result value
|
---|
104 | ; ^07: Date of the lowest value (FileMan)
|
---|
105 | ;
|
---|
106 | LOADPRL(RESULTS,REGIEN,PATIEN) ;
|
---|
107 | N BUF,GRP,NAME,PTR,RC,RORBUF,RORERRDL,TMP
|
---|
108 | D CLEAR^RORERR("LOAD^RORRP041",1)
|
---|
109 | K RESULTS S RESULTS=$$ALLOC^RORTMP() S @RESULTS@(0)=0
|
---|
110 | ;
|
---|
111 | ;=== Check the parameters
|
---|
112 | S RC=0 D I RC<0 D RPCSTK^RORERR(.RESULTS,RC) Q
|
---|
113 | . ;--- Registry IEN
|
---|
114 | . I $G(REGIEN)'>0 D Q
|
---|
115 | . . S RC=$$ERROR^RORERR(-88,,,,"REGIEN",$G(REGIEN))
|
---|
116 | . S REGIEN=+REGIEN
|
---|
117 | . ;--- Patient IEN
|
---|
118 | . I $G(PATIEN)'>0 D Q
|
---|
119 | . . S RC=$$ERROR^RORERR(-88,,,,"PATIEN",$G(PATIEN))
|
---|
120 | . S PATIEN=+PATIEN
|
---|
121 | ;
|
---|
122 | ;=== Search for registry-specific lab results
|
---|
123 | S RORBUF=RESULTS
|
---|
124 | S RORBUF("RORCB")="$$LOADLT^RORRP041"
|
---|
125 | S RC=$$LTSEARCH^RORUTL10(PATIEN,+REGIEN,.RORBUF)
|
---|
126 | I RC<0 D RPCSTK^RORERR(.RESULTS,RC) Q
|
---|
127 | ;
|
---|
128 | ;=== Store the group statistics
|
---|
129 | S PTR=+$O(@RESULTS@(""),-1)
|
---|
130 | S GRP=0
|
---|
131 | F S GRP=$O(RORBUF("RORSTATS",GRP)) Q:GRP'>0 D
|
---|
132 | . S TMP=$$ITEMIEN^RORUTL09(3,REGIEN,GRP,.NAME)
|
---|
133 | . S BUF="LTG"_U_GRP_U_NAME
|
---|
134 | . S $P(BUF,U,4,5)=$G(RORBUF("RORSTATS",GRP,"LAST"))
|
---|
135 | . S $P(BUF,U,6,7)=$G(RORBUF("RORSTATS",GRP,"MIN"))
|
---|
136 | . S PTR=PTR+1,@RESULTS@(PTR)=BUF
|
---|
137 | Q
|
---|