1 | LA7UIIN1 ;DALOI/JRR - Process Incoming UI Msgs, continued ; 12/3/1997
|
---|
2 | ;;5.2;AUTOMATED LAB INSTRUMENTS;**17,23,27,57,59**;Sep 27, 1994
|
---|
3 | ; This routine is a continuation of LA7UIIN and is only
|
---|
4 | ; called from there. It is called with each message found
|
---|
5 | ; in the incoming queue.
|
---|
6 | ;
|
---|
7 | Q
|
---|
8 | ;
|
---|
9 | NXTMSG ;
|
---|
10 | N LA70070,LA7150,LA761,LA762,LA7624,LA762495
|
---|
11 | N LA7AA,LA7AD,LA7ACC,LA7CNT,LA7CS,LA7CUP,LA7ECH,LA7ENTRY,LA7FS,LA7IDE,LA7LWL,LA7MSH,LA7OBR,LA7OBR3,LA7QUIT,LA7TRAY,LA7USID
|
---|
12 | N CUP,IDE,IDENT,ISQN
|
---|
13 | ;
|
---|
14 | S (LA7CNT,LA7QUIT)=0
|
---|
15 | S (LA7AN,LA7INST,LA7OBR,LA7UID)=""
|
---|
16 | S DT=$$DT^XLFDT
|
---|
17 | ; Message built but no text.
|
---|
18 | I '$O(^LAHM(62.49,LA76249,150,0)) D Q
|
---|
19 | . D CREATE^LA7LOG(6)
|
---|
20 | ;
|
---|
21 | MSH S LA7MSH=$G(^($O(^LAHM(62.49,LA76249,150,0)),0))
|
---|
22 | ; Bad first line of message
|
---|
23 | I $E(LA7MSH,1,3)'="MSH" D Q
|
---|
24 | . D CREATE^LA7LOG(7)
|
---|
25 | S LA7FS=$E(LA7MSH,4)
|
---|
26 | S LA7CS=$E(LA7MSH,5)
|
---|
27 | S LA7ECH=$E(LA7MSH,5,8)
|
---|
28 | ; No field or component seperator
|
---|
29 | I LA7FS=""!(LA7CS="") D Q
|
---|
30 | . D CREATE^LA7LOG(8)
|
---|
31 | ;
|
---|
32 | ; Find the OBR segment
|
---|
33 | S LA762495=0
|
---|
34 | OBR F S LA762495=$O(^LAHM(62.49,LA76249,150,LA762495)) Q:'LA762495!($E($G(^(+LA762495,0)),1,3)="OBR")
|
---|
35 | S DT=$$DT^XLFDT
|
---|
36 | ;
|
---|
37 | ; No more OBR's, found at least 1.
|
---|
38 | I 'LA762495,$L($G(LA7OBR)) Q
|
---|
39 | ;
|
---|
40 | S LA7OBR=$G(^LAHM(62.49,LA76249,150,+LA762495,0))
|
---|
41 | ;
|
---|
42 | ; Should only be working on OBR
|
---|
43 | I $E(LA7OBR,1,3)'="OBR" D Q
|
---|
44 | . D CREATE^LA7LOG(9)
|
---|
45 | ;
|
---|
46 | ; Extracting 1st piece
|
---|
47 | S LA7INST=$P($P(LA7OBR,LA7FS,19),LA7CS,1)
|
---|
48 | I LA7INST="" D Q
|
---|
49 | . D CREATE^LA7LOG(10)
|
---|
50 | S LA7624=+$O(^LAB(62.4,"B",LA7INST,0))
|
---|
51 | ; Instrument name not found in xref
|
---|
52 | I 'LA7624 D Q
|
---|
53 | . D CREATE^LA7LOG(11)
|
---|
54 | S LA7INST=$G(^LAB(62.4,LA7624,0))
|
---|
55 | ; Instrument entry not found in file
|
---|
56 | I LA7INST="" D Q
|
---|
57 | . D CREATE^LA7LOG(11)
|
---|
58 | ;
|
---|
59 | S LA7ENTRY=$P(LA7INST,"^",6) ;LOG,LLIST,IDENT or SEQN
|
---|
60 | S:LA7ENTRY="" LA7ENTRY="LOG"
|
---|
61 | ;
|
---|
62 | ; Universal service id
|
---|
63 | S LA7USID=$P(LA7OBR,LA7FS,4)
|
---|
64 | ;
|
---|
65 | S LA7TRAY=+$P($P(LA7OBR,LA7FS,20),LA7CS,1) ;Tray
|
---|
66 | S LA7CUP=+$P($P(LA7OBR,LA7FS,20),LA7CS,2) ; Cup
|
---|
67 | S LA7AA=+$P($P(LA7OBR,LA7FS,20),LA7CS,3) ; Accession Area
|
---|
68 | S LA7AD=+$P($P(LA7OBR,LA7FS,20),LA7CS,4) ; Accession Date
|
---|
69 | S LA7AN=+$P($P(LA7OBR,LA7FS,20),LA7CS,5) ; Accession Entry
|
---|
70 | S LA7ACC=$P($P(LA7OBR,LA7FS,20),LA7CS,6) ; Accession
|
---|
71 | S LA7UID=$P($P(LA7OBR,LA7FS,20),LA7CS,7) ; Unique ID
|
---|
72 | S LA7IDE=$P($P(LA7OBR,LA7FS,20),LA7CS,8) ; Sequence Number
|
---|
73 | S LA7LWL=$P(LA7INST,"^",4) ; Load/Work List
|
---|
74 | S LA7OBR3=$P(LA7OBR,LA7FS,3) ; Sample ID or Bar code
|
---|
75 | S LA7OBR(15)=$P(LA7OBR,LA7FS,16) ; Specimen source
|
---|
76 | ;
|
---|
77 | ; UID might come as Sample ID
|
---|
78 | I LA7UID="",LA7OBR3?10UN S LA7UID=LA7OBR3
|
---|
79 | ;
|
---|
80 | ; Try to figure out LRAA LRAD LRAN by using the unique ID (LRUID)
|
---|
81 | ; accession may have rolled over, use UID to get current accession info.
|
---|
82 | I LA7UID]"" D
|
---|
83 | . N X
|
---|
84 | . S X=$Q(^LRO(68,"C",LA7UID))
|
---|
85 | . I $QS(X,3)'=LA7UID S LA7UID="" Q ; UID not on file.
|
---|
86 | . S LA7AA=+$QS(X,4),LA7AD=+$QS(X,5),LA7AN=+$QS(X,6)
|
---|
87 | ; If still not known, compute from default date and accession area
|
---|
88 | ; Calculate accession date based on accession transform.
|
---|
89 | I '(LA7AA*LA7AD*LA7AN) D
|
---|
90 | . N X
|
---|
91 | . S DT=$$DT^XLFDT
|
---|
92 | . S LA7AA=+$P(LA7INST,"^",11)
|
---|
93 | . S X=$P($G(^LRO(68,LA7AA,0)),U,3)
|
---|
94 | . S LA7AD=$S(X="D":DT,X="M":$E(DT,1,5)_"00",X="Y":$E(DT,1,3)_"0000",X="Q":$E(DT,1,3)_"0000"+(($E(DT,4,5)-1)\3*300+100),1:DT)
|
---|
95 | . S LA7AN=+LA7OBR3
|
---|
96 | ; Log but cont
|
---|
97 | I LA7ENTRY="LOG",'$D(^LRO(68,LA7AA,1,LA7AD,1,LA7AN,0)) D
|
---|
98 | . D CREATE^LA7LOG(13)
|
---|
99 | ; cup=sequence number
|
---|
100 | I LA7ENTRY="LLIST" S:'LA7CUP LA7CUP=LA7IDE
|
---|
101 | ;
|
---|
102 | ; Create entry in ^LAH global
|
---|
103 | D LAGEN
|
---|
104 | ; Couldn't create entry in ^LAH
|
---|
105 | I $G(LA7ISQN)="" D Q
|
---|
106 | . D CREATE^LA7LOG(14)
|
---|
107 | ;
|
---|
108 | ; specimen(topography), collection sample, HL7 specimen source
|
---|
109 | S (LA761,LA762,LA70070)=""
|
---|
110 | I $O(^LRO(68,LA7AA,1,LA7AD,1,LA7AN,5,0)) D
|
---|
111 | . N X
|
---|
112 | . S X=$O(^LRO(68,LA7AA,1,LA7AD,1,LA7AN,5,0))
|
---|
113 | . ; specimen^collection sample
|
---|
114 | . S X(0)=$G(^LRO(68,LA7AA,1,LA7AD,1,LA7AN,5,X,0))
|
---|
115 | . S LA761=$P(X(0),"^") ; specimen
|
---|
116 | . S LA762=$P(X(0),"^",2) ; collection sample
|
---|
117 | . ; HL7 code from Topography
|
---|
118 | . I LA761 S LA70070=$$GET1^DIQ(61,LA761_",","LEDI HL7:HL7 ABBR")
|
---|
119 | ;
|
---|
120 | ; Log error when specimen source does not match accession's specimen
|
---|
121 | I $L(LA70070),$L($P($P(LA7OBR(15),LA7CS),$E(LA7ECH,4))) D
|
---|
122 | . ; Check if using HL7 table 0070
|
---|
123 | . I $P($P(LA7OBR(15),LA7CS),$E(LA7ECH,4),3)'["0070" Q
|
---|
124 | . ; Message matches accession
|
---|
125 | . I LA70070=$P($P(LA7OBR(15),LA7CS),$E(LA7ECH,4)) Q
|
---|
126 | . D CREATE^LA7LOG(22)
|
---|
127 | . S LA7QUIT=1
|
---|
128 | ;
|
---|
129 | ; Something wrong, process next OBR
|
---|
130 | I LA7QUIT S LA7QUIT=0 G OBR
|
---|
131 | ;
|
---|
132 | ; Zeroth node of acession area.
|
---|
133 | S LA7AA(0)=$G(^LRO(68,+LA7AA,0))
|
---|
134 | ;
|
---|
135 | ; No subscript defined for this area.
|
---|
136 | I $P(LA7AA(0),"^",2)="" G OBR
|
---|
137 | ;
|
---|
138 | ; Processing of this subscript not supported.
|
---|
139 | I "CHMI"'[$P(LA7AA(0),"^",2) G OBR
|
---|
140 | ;
|
---|
141 | S LA7150=LA762495
|
---|
142 | ; Process "CH" subscript results - NTE and OBX segments.
|
---|
143 | I $P(LA7AA(0),"^",2)="CH" D NTE^LA7UIIN2
|
---|
144 | ;
|
---|
145 | ; Process "MI" subscript results.
|
---|
146 | I $P(LA7AA(0),"^",2)="MI" D
|
---|
147 | . N X
|
---|
148 | . S X="LA7UIIN3" X ^%ZOSF("TEST") Q:'$T
|
---|
149 | . D MI^LA7UIIN3
|
---|
150 | ;
|
---|
151 | ; No more segments to process, reached end of global array.
|
---|
152 | I 'LA762495 Q
|
---|
153 | ;
|
---|
154 | ; Reset subscript variable.
|
---|
155 | I LA762495>LA7150 S LA762495=LA762495-1
|
---|
156 | ;
|
---|
157 | ; Go back to find/process additional OBR segments.
|
---|
158 | G OBR
|
---|
159 | ;
|
---|
160 | ;
|
---|
161 | LAGEN ; subroutine to set up variables for call to ^LAGEN, build entry in LAH
|
---|
162 | ; requires LA7INST,LA7TRAY,LA7CUP,LA7AA,LA7AD,LA7AN,LA7LWL
|
---|
163 | ; returns LA7ISQN=subscript to store results in ^LAH global
|
---|
164 | ;
|
---|
165 | K TRAY,CUP,LWL,WL,LROVER,METH,LOG,IDENT,ISQN
|
---|
166 | K LADT,LAGEN,LA7ISQN
|
---|
167 | ;
|
---|
168 | S LA7ISQN=""
|
---|
169 | S TRAY=+$G(LA7TRAY) S:'TRAY TRAY=1
|
---|
170 | S CUP=+$G(LA7CUP) S:'CUP CUP=1
|
---|
171 | S LWL=LA7LWL
|
---|
172 | I '$D(^LRO(68.2,+LWL,0)) D Q
|
---|
173 | . D CREATE^LA7LOG(19)
|
---|
174 | ;
|
---|
175 | ; Set accession area to area of specimen, allow multiple areas on same instrument.
|
---|
176 | S WL=LA7AA
|
---|
177 | I '$D(^LRO(68,+WL,0)) D Q
|
---|
178 | . D CREATE^LA7LOG(20)
|
---|
179 | ;
|
---|
180 | S LROVER=$P(LA7INST,"^",12)
|
---|
181 | S METH=$P(LA7INST,"^",10)
|
---|
182 | S LOG=LA7AN
|
---|
183 | ; Identity field
|
---|
184 | S IDENT=$P($G(^LRO(68,LA7AA,1,LA7AD,1,LA7AN,0)),"^",6)
|
---|
185 | S IDE=+LA7IDE
|
---|
186 | S LADT=LA7AD
|
---|
187 | ;
|
---|
188 | ; This disregards the CROSS LINK field in 62.4
|
---|
189 | D @(LA7ENTRY_"^LAGEN")
|
---|
190 | S LA7ISQN=$G(ISQN)
|
---|
191 | ;
|
---|
192 | Q
|
---|