1 | LA7SBCR1 ;DALOI/JMC - Shipping Barcode Reader Utility ; 23 Feb 2004
|
---|
2 | ;;5.2;AUTOMATED LAB INSTRUMENTS;**27,46,64**;Sep 27, 1994
|
---|
3 | Q
|
---|
4 | ;
|
---|
5 | PT(LA7,LA7PROM,LA7SCFG) ; Setup patient/ordering site info from barcode.
|
---|
6 | ; Input:
|
---|
7 | ; LA7=array to return values
|
---|
8 | ; LA7PROM=array of prompts to display to user
|
---|
9 | ; LA7SCFG=array of shipping configuration info
|
---|
10 | ;
|
---|
11 | ; Returns array LA7()
|
---|
12 | ; If successful DFN=ien of patient in #2, if DPF=2
|
---|
13 | ; DOB=patient's date of birth
|
---|
14 | ; DPF=source file (2, 67, or 537010)
|
---|
15 | ; CDT=collection date/time
|
---|
16 | ; ERROR=0
|
---|
17 | ; PNM=patient name
|
---|
18 | ; RSITE=sending site
|
---|
19 | ; RUID=specimen unique identifier
|
---|
20 | ; SEX=patient's sex
|
---|
21 | ; SSN=patient's SSN
|
---|
22 | ;
|
---|
23 | ; unsuccessful ERROR=>0
|
---|
24 | ;
|
---|
25 | N LA7BCS,LA7IEN,LA7X,LA7Y,LA7Z,Y
|
---|
26 | S LA7="",LA7BCS=0,LA7PNM=""
|
---|
27 | S LA7PROM=$G(LA7PROM,"Patient/Accession Info (PD)")
|
---|
28 | S Y=$$RD^LA7SBCR(.LA7PROM,1)
|
---|
29 | ;
|
---|
30 | I Y=0 D Q
|
---|
31 | . S LA7("ERROR")="1^User timeout/abort"
|
---|
32 | ;
|
---|
33 | I Y<1 D Q
|
---|
34 | . S LA7("ERROR")="2^Incorrect bar-code format"
|
---|
35 | ;
|
---|
36 | ; barcode info & longitudinal parity check
|
---|
37 | ; original style bar code
|
---|
38 | I $E(Y,1,9)="1^STX^PD^" D
|
---|
39 | . S LA7=$P(Y,"STX^PD^",2)
|
---|
40 | . S LA7=$P(LA7,"^ETX",1)
|
---|
41 | . S LA7("LPC")=$P(Y,"^ETX",2)
|
---|
42 | ; new style bar code
|
---|
43 | I $E(Y,1,5)="1^PD^" D
|
---|
44 | . S LA7=$P(Y,"^",3,6)
|
---|
45 | . S LA7("LPC")=$P(Y,"^",7)
|
---|
46 | . S LA7BCS=1
|
---|
47 | ;
|
---|
48 | I LA7="" D Q
|
---|
49 | . S LA7("ERROR")="2^Incorrect bar-code format"
|
---|
50 | ;
|
---|
51 | I $G(LA7("LPC"))'=$G(LA7SCFG("LPC")) D Q
|
---|
52 | . S LA7("ERROR")="9^Parity check does not match on (SM) and (PD) barcodes"
|
---|
53 | ;
|
---|
54 | S LA7("RSITE")=$P(LA7,"^",2)
|
---|
55 | I LA7("RSITE")'=$P(LA7SCFG("RSITE"),"^",3) D
|
---|
56 | . S LA7("ERROR")="31^Site in PD barcode does not match shipping configuration file"
|
---|
57 | ;
|
---|
58 | ; Remote specimen identifier
|
---|
59 | S LA7("RUID")=$P(LA7,"^",3)
|
---|
60 | ;
|
---|
61 | ; Specimen collection date, using either old or new style(LA7BCS=1) bar code
|
---|
62 | I 'LA7BCS,$P(LA7,"^",5) S LA7("CDT")=$$DT^LA7SBCR($P(LA7,"^",5))
|
---|
63 | I LA7BCS,$P(LA7,"^",4) S LA7("CDT")=$$DT^LA7SBCR($P(LA7,"^",4))
|
---|
64 | ;
|
---|
65 | ; Patient identifier
|
---|
66 | S LA7X=$P(LA7,"^") ; Patient's ID
|
---|
67 | ;
|
---|
68 | ; No SSN in first piece
|
---|
69 | I LA7X="" S LA7("ERROR")="3^No SSN in barcode" Q
|
---|
70 | S LA7("SSN")=LA7X
|
---|
71 | ;
|
---|
72 | ; Try LAB PENDING ORDERS file
|
---|
73 | D LPO(.LA7,LA7SCFG("SMID"))
|
---|
74 | ;
|
---|
75 | ; Check for patient in file #2.
|
---|
76 | I $G(LA7("ERROR")) D DPT(.LA7,LA7X)
|
---|
77 | ;
|
---|
78 | ; Else try Lab Referral file.
|
---|
79 | I $G(LA7("ERROR")) D LRT(.LA7,LA7X)
|
---|
80 | ;
|
---|
81 | ; Get additional info from PD1 bar code
|
---|
82 | I +$G(LA7("ERROR"))=4 D PD1
|
---|
83 | Q
|
---|
84 | ;
|
---|
85 | ;
|
---|
86 | DPT(LA7,LA7X) ; Lookup in Patient file.
|
---|
87 | ; Check for patient in file #2.
|
---|
88 | S LA7Y=$O(^DPT("SSN",LA7X,0))
|
---|
89 | ; SSN not found.
|
---|
90 | I 'LA7Y S LA7("ERROR")="4^Unsuccessful SSN lookup" Q
|
---|
91 | S LA7Y(0)=$G(^DPT(LA7Y,0))
|
---|
92 | ; SSN not found.
|
---|
93 | I LA7Y(0)="" S LA7("ERROR")="4^Unsuccessful SSN lookup" Q
|
---|
94 | ;
|
---|
95 | D DPTSET(.LA7,LA7Y)
|
---|
96 | Q
|
---|
97 | ;
|
---|
98 | ;
|
---|
99 | LRT(LA7,LA7X) ; Lookup in Lab Referral file.
|
---|
100 | ; Clear error flag.
|
---|
101 | S LA7("ERROR")=""
|
---|
102 | S LA7Y=$O(^LRT(67,"C",LA7X,0))
|
---|
103 | ; SSN not found.
|
---|
104 | I 'LA7Y S LA7("ERROR")="4^Unsuccessful SSN lookup" Q
|
---|
105 | S LA7Y(0)=$G(^LRT(67,LA7Y,0))
|
---|
106 | ; SSN not found.
|
---|
107 | I LA7Y(0)="" S LA7("ERROR")="4^Unsuccessful SSN lookup" Q
|
---|
108 | D LRTSET(.LA7,LA7Y)
|
---|
109 | Q
|
---|
110 | ;
|
---|
111 | ;
|
---|
112 | LPO(LA7,LA7SM) ; Lookup in LAB PENDING ORDERS file #69.6
|
---|
113 | ;
|
---|
114 | N LA7696,LA7RUID
|
---|
115 | S LA7RUID=LA7("RUID"),LA7696=""
|
---|
116 | I LA7SM'="",LA7RUID'="" S LA7696=$O(^LRO(69.6,"AD",LA7SM,LA7RUID,0))
|
---|
117 | I 'LA7696 S LA7("ERROR")="4^Unsuccessful SSN lookup" Q
|
---|
118 | D LPOSET(.LA7,LA7696)
|
---|
119 | Q
|
---|
120 | ;
|
---|
121 | ;
|
---|
122 | DPTSET(LA7,LA7Y) ; Setup array from Patient file.
|
---|
123 | ;
|
---|
124 | N RACE,LA7ERR
|
---|
125 | S LA7Y(0)=$G(^DPT(LA7Y,0))
|
---|
126 | ; Zeroth node not found.
|
---|
127 | I LA7Y(0)="" S LA7("ERROR")="6^No zeroth node in file" Q
|
---|
128 | S LA7("DFN")=LA7Y
|
---|
129 | S LA7("DOB")=$P(LA7Y(0),"^",3)
|
---|
130 | ; Source file
|
---|
131 | S:LA7Y LA7("DPF")=2_U_"DPT("
|
---|
132 | S LA7("PNM")=$P(LA7Y(0),"^")
|
---|
133 | S LA7("RIEN")=+$G(^DPT(LA7Y,"LRT"))
|
---|
134 | S LA7("SEX")=$P(LA7Y(0),"^",2)
|
---|
135 | S LA7("SSN")=$P(LA7Y(0),"^",9)
|
---|
136 | D GETS^DIQ(2,LA7Y_",","2*","I","RACE","LA7ERR")
|
---|
137 | I '$D(LA7ERR) D
|
---|
138 | . S X=$Q(RACE(2.02)) Q:X=""
|
---|
139 | . S LA7("RACE")=$P(@X,"^")
|
---|
140 | Q
|
---|
141 | ;
|
---|
142 | ;
|
---|
143 | LRTSET(LA7,LA7Y) ; Setup array from Lab Referral file.
|
---|
144 | S LA7Y(0)=$G(^LRT(67,LA7Y,0))
|
---|
145 | ; Zeroth node not found.
|
---|
146 | I LA7Y(0)="" S LA7("ERROR")="6^No zeroth node in file" Q
|
---|
147 | S LA7("DFN")=LA7Y
|
---|
148 | S LA7("DOB")=$P(LA7Y(0),"^",3)
|
---|
149 | ;
|
---|
150 | ; Source file
|
---|
151 | S:LA7Y LA7("DPF")=67_U_"LRT(67,"
|
---|
152 | ;
|
---|
153 | S LA7("PNM")=$P(LA7Y(0),"^")
|
---|
154 | S LA7("RIEN")=LA7Y
|
---|
155 | S LA7("SEX")=$P(LA7Y(0),"^",2)
|
---|
156 | S LA7("SSN")=$P(LA7Y(0),"^",9)
|
---|
157 | Q
|
---|
158 | ;
|
---|
159 | ;
|
---|
160 | LPOSET(LA7,LA7Y) ; Setup array from LAB PENDING ORDERS file #69.6
|
---|
161 | ;
|
---|
162 | N I
|
---|
163 | F I=0,.1 S LA7Y(I)=$G(^LRO(69.6,LA7Y,I))
|
---|
164 | ; Zeroth node not found.
|
---|
165 | I LA7Y(0)="" D Q
|
---|
166 | . S LA7("ERROR")="6^No zeroth node in file"
|
---|
167 | ; Patient identifiers don't match
|
---|
168 | I LA7("SSN")'=$P(LA7Y(0),U,9) Q
|
---|
169 | ;
|
---|
170 | S LA7("PNM")=$P(LA7Y(0),U,1)
|
---|
171 | S LA7("DOB")=$P(LA7Y(0),U,3)
|
---|
172 | S LA7("SEX")=$P(LA7Y(0),U,2)
|
---|
173 | S LA7("DPF")="67^LRT(67,"
|
---|
174 | S LA7("RACE")=$P(LA7Y(.1),U)
|
---|
175 | S LA7("ERROR")=""
|
---|
176 | S LA7("RIEN")=$O(^LRT(67,"C",LA7("SSN"),0))
|
---|
177 | I $G(LA7("RIEN")),$G(^LRT(67,LA7("RIEN"),"LR")) D
|
---|
178 | . S LA7("LRDFN")=^LRT(67,LA7("RIEN"),"LR")
|
---|
179 | . S LA7("DFN")=LA7("RIEN")
|
---|
180 | Q
|
---|
181 | ;
|
---|
182 | ;
|
---|
183 | PD1 ; Read PD1 bar code information
|
---|
184 | ;
|
---|
185 | N LA7PROM
|
---|
186 | ;
|
---|
187 | S LA7PROM="Scan Patient Name Barcode (PD1)"
|
---|
188 | S LA7PROM(1)="Patient Demographics not found"
|
---|
189 | S LA7("ERROR")="",LA7Z=""
|
---|
190 | S Y=$$RD^LA7SBCR(.LA7PROM,1)
|
---|
191 | I Y<1 D Q
|
---|
192 | . S LA7("ERROR")="2^Incorrect bar-code format"
|
---|
193 | ;
|
---|
194 | ; barcode info & longitudinal parity check
|
---|
195 | ; original style bar code
|
---|
196 | I $E(Y,1,10)="1^STX^PD1^" D
|
---|
197 | . S LA7Z=$P(Y,"STX^PD1^",2)
|
---|
198 | . S LA7Z=$P(LA7Z,"^ETX")
|
---|
199 | . S LA7Z("LPC")=$P(Y,"^ETX",2)
|
---|
200 | ; new style bar code
|
---|
201 | I $E(Y,1,6)="1^PD1^" D
|
---|
202 | . S LA7Z=$P(Y,"^",3,6)
|
---|
203 | . S LA7Z("LPC")=$P(Y,"^",7)
|
---|
204 | ;
|
---|
205 | I LA7Z="" D Q
|
---|
206 | . S LA7("ERROR")="2^Incorrect bar-code format"
|
---|
207 | ;
|
---|
208 | I $G(LA7Z("LPC"))'=$G(LA7SCFG("LPC")) D Q
|
---|
209 | . S LA7("ERROR")="10^Parity check does not match on (SM) and (PD1) barcodes"
|
---|
210 | ;
|
---|
211 | ; Name not found.
|
---|
212 | I $L($P(LA7Z,U,2))<2 D Q
|
---|
213 | . S LA7("ERROR")="21^Unsuccessful name scan"
|
---|
214 | ;
|
---|
215 | ; wrong patient scanned not found.
|
---|
216 | I $P(LA7Z,U)'=LA7("SSN") D Q
|
---|
217 | . S LA7("ERROR")="22^SSN does not match PD barcode"
|
---|
218 | ;
|
---|
219 | ; Wrong DOB format.
|
---|
220 | I $P(LA7Z,U,3)'?7N D Q
|
---|
221 | . S LA7("ERROR")="23^Incorrect DOB"
|
---|
222 | ;
|
---|
223 | S LA7("PNM")=$P(LA7Z,U,2)
|
---|
224 | S LA7("DOB")=$P(LA7Z,U,3)
|
---|
225 | S LA7("SEX")=$P(LA7Z,U,4)
|
---|
226 | S LA7("DPF")="67^LRT(67,"
|
---|
227 | S LA7("ERROR")=""
|
---|
228 | Q
|
---|