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