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