[613] | 1 | SCMSVUT0 ;ALB/ESD HL7 Segment Validation Utilities ; 7/8/04 5:06pm
|
---|
| 2 | ;;5.3;Scheduling;**44,55,66,132,245,254,293,345,472**;Aug 13, 1993
|
---|
| 3 | ;
|
---|
| 4 | ;
|
---|
| 5 | CONVERT(SEG,HLFS,HLQ) ; Convert HLQ ("") to null in segment
|
---|
| 6 | ; Input: SEG = HL7 segment
|
---|
| 7 | ; HLFS = HL7 field separator
|
---|
| 8 | ; HLQ = HL7 "" character
|
---|
| 9 | ;
|
---|
| 10 | ; Output: SEG = Segment where HLQ replaced with null
|
---|
| 11 | ;
|
---|
| 12 | ;
|
---|
| 13 | N I
|
---|
| 14 | F I=1:1:55 I $P(SEG,HLFS,I)=HLQ S $P(SEG,HLFS,I)=""
|
---|
| 15 | Q SEG
|
---|
| 16 | ;
|
---|
| 17 | SETID(SDOE,SDDELOE) ; Set PCE Unique Visit Number in field #.2 of #409.68
|
---|
| 18 | ; Input: SDOE = IEN of Outpatient Encounter (#409.68) file
|
---|
| 19 | ; SDDELOE = IEN of Deleted Outpatient Encounter (#409.74) file
|
---|
| 20 | ;
|
---|
| 21 | ; Output: Unique Visit Number set in field #.2 of #409.68
|
---|
| 22 | ; or field #.2 of #409.74
|
---|
| 23 | ;
|
---|
| 24 | ;
|
---|
| 25 | N SDOEC,SDARRY
|
---|
| 26 | S SDOEC=0
|
---|
| 27 | S SDOE=+$G(SDOE)
|
---|
| 28 | S SDDELOE=+$G(SDDELOE)
|
---|
| 29 | ;
|
---|
| 30 | ;-Outpatient Enc pointer passed in; use file #409.68
|
---|
| 31 | S SDARRY="^SCE("_SDOE_",0)"
|
---|
| 32 | ;
|
---|
| 33 | ;-Deleted Outpatient Enc pointer passed in; use file #409.74
|
---|
| 34 | S:(SDDELOE) SDARRY="^SD(409.74,"_SDDELOE_",1)"
|
---|
| 35 | ;
|
---|
| 36 | ;-Quit if no encounter record or deleted encounter record
|
---|
| 37 | Q:($G(@SDARRY)="")
|
---|
| 38 | ;-Add unique ID to parent
|
---|
| 39 | D GETID
|
---|
| 40 | ;
|
---|
| 41 | ;-Add unique ID to children for Outpatient Enc only (quit if no child encounter record)
|
---|
| 42 | I (SDOE) F S SDOEC=+$O(^SCE("APAR",SDOE,SDOEC)) Q:'SDOEC S SDARRY="^SCE("_SDOEC_",0)" Q:($G(@SDARRY)="") D GETID
|
---|
| 43 | Q
|
---|
| 44 | ;
|
---|
| 45 | GETID ;Get unique visit ID
|
---|
| 46 | S:$P($G(@SDARRY),"^",20)="" $P(@SDARRY,"^",20)=$$IEN2VID^VSIT($P(@SDARRY,"^",5))
|
---|
| 47 | Q
|
---|
| 48 | ;
|
---|
| 49 | SETPRTY(SDOE) ;Set outpatient provider type in field #.06 of V PROVIDER
|
---|
| 50 | ; Input: SDOE = IEN of Outpatient Encounter (#409.68) file
|
---|
| 51 | ;
|
---|
| 52 | ; Output: Provider Type set in field #.06 of V PROVIDER
|
---|
| 53 | ;
|
---|
| 54 | ;
|
---|
| 55 | N SDPRTYP,SDVPRV,SDPRVS
|
---|
| 56 | S SDOE=+$G(SDOE),SDVPRV=0
|
---|
| 57 | ;
|
---|
| 58 | ;- Get all provider IENs for encounter
|
---|
| 59 | D GETPRV^SDOE(SDOE,"SDPRVS")
|
---|
| 60 | F S SDVPRV=+$O(SDPRVS(SDVPRV)) Q:'SDVPRV D
|
---|
| 61 | . S SDPRTYP=0
|
---|
| 62 | . ;
|
---|
| 63 | . ;- If no prov type, call API and add provider type to record
|
---|
| 64 | . S:$P(SDPRVS(SDVPRV),"^",6)="" SDPRTYP=$$GET^XUA4A72(+SDPRVS(SDVPRV),+$G(^SCE(SDOE,0)))
|
---|
| 65 | . I +$G(SDPRTYP)>0 D PCLASS^PXAPIOE(SDVPRV)
|
---|
| 66 | Q
|
---|
| 67 | ;
|
---|
| 68 | SETMAR(PIDSEG,HLQ,HLFS) ; Set marital status prior to PID segment validation
|
---|
| 69 | ;Input: PIDSEG = Array containing PID segment (pass by reference)
|
---|
| 70 | ; PIDSEG = First 245 characters
|
---|
| 71 | ; PIDSEG(1..n) = Continuation nodes
|
---|
| 72 | ; HLQ = HL7 null variable
|
---|
| 73 | ; HLFS = HL7 field separator
|
---|
| 74 | ;Output: Marital status changed from null to "U" (UNKNOWN) prior to
|
---|
| 75 | ; validation of PID segment and transmittal to AAC
|
---|
| 76 | ;Note: Assumes all input exists and is valid
|
---|
| 77 | ;
|
---|
| 78 | ;Declare variables
|
---|
| 79 | N REBLD,TMPARR,X
|
---|
| 80 | ;Parse segment
|
---|
| 81 | D SEGPRSE^SCMSVUT5($NA(PIDSEG),"TMPARR",HLFS)
|
---|
| 82 | ;Change marital status (if needed)
|
---|
| 83 | S REBLD=0
|
---|
| 84 | S X=$G(TMPARR(16))
|
---|
| 85 | I ((X="")!(X=HLQ)) S TMPARR(16)="U",REBLD=1
|
---|
| 86 | ;Rebuild segment (if needed)
|
---|
| 87 | I REBLD K TMPARR(0),PIDSEG D MAKEIT^VAFHLU("PID",.TMPARR,.PIDSEG,.PIDSEG)
|
---|
| 88 | Q
|
---|
| 89 | ;
|
---|
| 90 | SETPOW(DFN,ZPDSEG,HLQ,HLFS) ; Set POW Status Indicated field prior to ZPD segment validation
|
---|
| 91 | ;
|
---|
| 92 | ; Input: DFN = IEN of Patient (#2) file
|
---|
| 93 | ; ZPDSEG = Array containing ZPD segment (pass by reference)
|
---|
| 94 | ; ZPDSEG = First 245 characters
|
---|
| 95 | ; ZPDSEG(1..n) = Continuation nodes
|
---|
| 96 | ; HLQ = HL7 null variable
|
---|
| 97 | ; HLFS = HL7 field separator
|
---|
| 98 | ;
|
---|
| 99 | ; Output: If Veteran and POW Status Indicated field = null, set to
|
---|
| 100 | ; U (Unknown)
|
---|
| 101 | ; If Non-Veteran, set to null
|
---|
| 102 | ;
|
---|
| 103 | S DFN=$G(DFN)
|
---|
| 104 | G SETPOWQ:(DFN="")!($G(ZPDSEG)="")
|
---|
| 105 | ;Declare variables
|
---|
| 106 | N REBLD,TMPARR,X
|
---|
| 107 | ;Parse segment
|
---|
| 108 | D SEGPRSE^SCMSVUT5($NA(ZPDSEG),"TMPARR",HLFS)
|
---|
| 109 | ;Change POW status (if needed)
|
---|
| 110 | S REBLD=0
|
---|
| 111 | S X=$G(TMPARR(17))
|
---|
| 112 | I $P($G(^DPT(DFN,"VET")),"^")="Y",(X=""!(X=HLQ)) S TMPARR(17)="U",REBLD=1
|
---|
| 113 | I $P($G(^DPT(DFN,"VET")),"^")="N" S TMPARR(17)=HLQ,REBLD=1
|
---|
| 114 | ;Rebuild segment (if needed)
|
---|
| 115 | I REBLD K TMPARR(0),ZPDSEG D MAKEIT^VAFHLU("ZPD",.TMPARR,.ZPDSEG,.ZPDSEG)
|
---|
| 116 | ;
|
---|
| 117 | SETPOWQ Q
|
---|
| 118 | ;
|
---|
| 119 | ;
|
---|
| 120 | SETVSI(DFN,ZSPSEG,HLQ,HLFS) ;Set Vietnam Service Indicated field prior to ZSP segment validation
|
---|
| 121 | ;
|
---|
| 122 | ; Input: DFN = IEN of Patient (#2) file
|
---|
| 123 | ; ZSPSEG = HL7 ZSP segment
|
---|
| 124 | ; HLQ = HL7 null variable
|
---|
| 125 | ; HLFS = HL7 field separator
|
---|
| 126 | ;
|
---|
| 127 | ; Output: If Veteran and Vietnam Service Indicated field = null,
|
---|
| 128 | ; set to U (Unknown)
|
---|
| 129 | ; If Non-Veteran, set to null
|
---|
| 130 | ;
|
---|
| 131 | S DFN=$G(DFN),ZSPSEG=$G(ZSPSEG)
|
---|
| 132 | G SETVSIQ:(DFN="")!(ZSPSEG="")
|
---|
| 133 | I $P($G(^DPT(DFN,"VET")),"^")="Y",($P(ZSPSEG,HLFS,6)=""!($P(ZSPSEG,HLFS,6)=HLQ)) S $P(ZSPSEG,HLFS,6)="U"
|
---|
| 134 | I $P($G(^DPT(DFN,"VET")),"^")="N" S $P(ZSPSEG,HLFS,6)=HLQ
|
---|
| 135 | ;
|
---|
| 136 | SETVSIQ Q ZSPSEG
|
---|
| 137 | ;
|
---|
| 138 | ;
|
---|
| 139 | ;
|
---|
| 140 | ;The following subroutines all have to do with the validation of
|
---|
| 141 | ;data using the same edit checks that are used by Austin.
|
---|
| 142 | ;
|
---|
| 143 | HL7SEGNM(SEG,DATA) ;checks the validity of the HL7 segment name passed in.
|
---|
| 144 | ;INPUT SEG - the HL7 segment name
|
---|
| 145 | ; DATA - the data to compare. In this case the HL7 segment name.
|
---|
| 146 | ;
|
---|
| 147 | ;OUTPUT 0 (ZERO) if not validate
|
---|
| 148 | ; 1 if validated
|
---|
| 149 | ;
|
---|
| 150 | I '$D(SEG)!('$D(DATA)) Q 0
|
---|
| 151 | Q $S(SEG=DATA:1,1:0)
|
---|
| 152 | ;
|
---|
| 153 | EVTTYP(SEG,DATA) ;checks the event type of the segment passed in.
|
---|
| 154 | ;INPUT SEG - The HL7 segment name in question
|
---|
| 155 | ; DATA - The event type from the HL7 segment in question.
|
---|
| 156 | ;
|
---|
| 157 | ;OUTPUT 0 (ZERO) if not validate
|
---|
| 158 | ; 1 if validated
|
---|
| 159 | ;
|
---|
| 160 | I '$D(SEG)!('$D(DATA)) Q 0
|
---|
| 161 | I SEG="EVN"&(DATA="A08"!(DATA="A23")) Q 1
|
---|
| 162 | Q 0
|
---|
| 163 | ;
|
---|
| 164 | EVTDTTM(DATA) ;Checks the date and time to ensure it is correct.
|
---|
| 165 | ;INPUT DATA - this is the date and time in quesiton.
|
---|
| 166 | ;
|
---|
| 167 | ;OUTPUT 0 (ZERO) if not validate
|
---|
| 168 | ; 1 if validated
|
---|
| 169 | ;
|
---|
| 170 | I '$D(DATA) Q 0
|
---|
| 171 | N STRTDT,%DT,X,Y
|
---|
| 172 | S STRTDT=+$O(^SD(404.91,0))
|
---|
| 173 | S STRTDT=$P($G(^SD(404.91,STRTDT,"AMB")),U,2)
|
---|
| 174 | I 'STRTDT Q 0
|
---|
| 175 | S %DT="T",%DT(0)=STRTDT,X=DATA
|
---|
| 176 | D ^%DT
|
---|
| 177 | Q $S(Y=-1:0,1:1)
|
---|
| 178 | ;
|
---|
| 179 | VALIDATE(SEG,DATA,ERRCOD,VALERR,CTR) ;
|
---|
| 180 | ;
|
---|
| 181 | N ERRIEN,ERRCHK,RES
|
---|
| 182 | S ERRIEN=+$O(^SD(409.76,"B",ERRCOD,""))
|
---|
| 183 | I 'ERRIEN S @VALERR@(SEG,CTR)=ERRCOD D INCR Q
|
---|
| 184 | S ERRCHK=$G(^SD(409.76,ERRIEN,"CHK"))
|
---|
| 185 | I ERRCHK="" S @VALERR@(SEG,CTR)=ERRCOD D INCR Q
|
---|
| 186 | X ERRCHK
|
---|
| 187 | I 'RES S @VALERR@(SEG,CTR)=ERRCOD D INCR
|
---|
| 188 | Q
|
---|
| 189 | ;
|
---|
| 190 | DFN(DATA) ;
|
---|
| 191 | ;INPUT DATA - the DFN of the patient
|
---|
| 192 | ;
|
---|
| 193 | I '$D(DATA) Q 0
|
---|
| 194 | I DATA=""!(DATA=0) Q 0
|
---|
| 195 | I DATA'?1.N.".".N Q 0
|
---|
| 196 | Q 1
|
---|
| 197 | ;
|
---|
| 198 | PATNM(DATA) ;
|
---|
| 199 | ;INPUT DATA - The name of the patient
|
---|
| 200 | ;
|
---|
| 201 | I '$D(DATA) Q 0
|
---|
| 202 | I DATA="" Q 0
|
---|
| 203 | I DATA?.N.",".N Q 0
|
---|
| 204 | I DATA?1.C Q 0
|
---|
| 205 | Q 1
|
---|
| 206 | ;
|
---|
| 207 | DOB(DATA,ENCDT) ;
|
---|
| 208 | ;INPUT DATA - The DOB to be tested.
|
---|
| 209 | ; ENCDT - The date/time of the encounter
|
---|
| 210 | ;
|
---|
| 211 | N %DT,X,Y
|
---|
| 212 | I '$D(DATA) Q 0
|
---|
| 213 | I '$D(ENCDT) Q 0
|
---|
| 214 | I DATA'?1.N Q 0
|
---|
| 215 | S %DT="T",%DT(0)=-ENCDT,X=DATA
|
---|
| 216 | D ^%DT
|
---|
| 217 | Q $S(Y=-1:0,1:1)
|
---|
| 218 | ;
|
---|
| 219 | SEX(DATA) ;
|
---|
| 220 | ;INPUT DATA - The sex code to be validated
|
---|
| 221 | ;
|
---|
| 222 | I '$D(DATA) Q 0
|
---|
| 223 | I "FMUO"'[DATA Q 0
|
---|
| 224 | Q 1
|
---|
| 225 | ;
|
---|
| 226 | RACE(DATA) ;
|
---|
| 227 | ;INPUT DATA - the race code to be validated (NNNN-C-XXX)
|
---|
| 228 | ;
|
---|
| 229 | N VAL,MTHD
|
---|
| 230 | I '$D(DATA) Q 0
|
---|
| 231 | I DATA="" Q 1
|
---|
| 232 | S VAL=$P(DATA,"-",1,2)
|
---|
| 233 | S MTHD=$P(DATA,"-",3)
|
---|
| 234 | I VAL'?4N1"-"1N Q 0
|
---|
| 235 | I ",SLF,UNK,PRX,OBS,"'[MTHD Q 0
|
---|
| 236 | Q 1
|
---|
| 237 | ;
|
---|
| 238 | STR1(DATA) ;
|
---|
| 239 | ;INPUT DATA - Street address line 1
|
---|
| 240 | ;
|
---|
| 241 | N LP,VAR
|
---|
| 242 | I '$D(DATA) Q 0
|
---|
| 243 | I DATA="" Q 0
|
---|
| 244 | I DATA?1.N Q 0
|
---|
| 245 | I DATA=" " Q 0
|
---|
| 246 | F LP=1:1:$L(DATA) S VAR=$E(DATA,LP,LP) I $A(VAR)>32,($A(VAR)<127) S LP="Y" Q
|
---|
| 247 | Q $S(LP="Y":1,1:0)
|
---|
| 248 | ;
|
---|
| 249 | STR2(DATA) ;
|
---|
| 250 | ;INPUT DATA - Street address line 2
|
---|
| 251 | I DATA?1.N Q 0
|
---|
| 252 | Q 1
|
---|
| 253 | ;
|
---|
| 254 | CITY(DATA) ;
|
---|
| 255 | ;INPUT DATA - The city code to be validated
|
---|
| 256 | ;
|
---|
| 257 | I DATA="" Q 0
|
---|
| 258 | I DATA?1.N Q 0
|
---|
| 259 | Q 1
|
---|
| 260 | ;
|
---|
| 261 | STATE(DATA) ;
|
---|
| 262 | ;INPUT DATA - State code to be validated.
|
---|
| 263 | ;
|
---|
| 264 | I '$D(DATA) Q 0
|
---|
| 265 | I DATA="" Q 0
|
---|
| 266 | I '$D(^DIC(5,"C",DATA)) Q 0
|
---|
| 267 | Q 1
|
---|
| 268 | ;
|
---|
| 269 | ZIP(DATA) ;
|
---|
| 270 | ;INPUT DATA - The zipo code to be validated
|
---|
| 271 | ;
|
---|
| 272 | I '$D(DATA) Q 0
|
---|
| 273 | I $E(DATA,1,5)="00000" Q 0
|
---|
| 274 | I DATA'?5N."-".4N Q 0
|
---|
| 275 | Q 1
|
---|
| 276 | ;
|
---|
| 277 | COUNTY(DATA,STATE) ;
|
---|
| 278 | ;INPUT DATA - The county code to be validated
|
---|
| 279 | ; STATE - STATE file IEN
|
---|
| 280 | ;
|
---|
| 281 | I DATA="" Q 0
|
---|
| 282 | I STATE="" Q 0
|
---|
| 283 | I '$D(^DIC(5,+$G(STATE),1,"C",DATA)) Q 0
|
---|
| 284 | Q 1
|
---|
| 285 | ;
|
---|
| 286 | MARITAL(DATA) ;
|
---|
| 287 | ;INPUT DATA - The marital status code to be validated.
|
---|
| 288 | ;
|
---|
| 289 | I $L(DATA)>1 Q 0
|
---|
| 290 | I "ADMSWU"'[DATA Q 0
|
---|
| 291 | Q 1
|
---|
| 292 | ;
|
---|
| 293 | REL(DATA) ;
|
---|
| 294 | ;INPUT DATA - The religion abbreviation to the validated
|
---|
| 295 | ;
|
---|
| 296 | I '$D(DATA) Q 0
|
---|
| 297 | I DATA="" Q 0
|
---|
| 298 | I '$D(^DIC(13,"C",+DATA)) Q 0
|
---|
| 299 | Q 1
|
---|
| 300 | ;
|
---|
| 301 | SSN(DATA,NOPCHK,NULLOK) ; SD*5.3*345 added optional parameter NULLOK
|
---|
| 302 | ;INPUT DATA - The SSN to be validated
|
---|
| 303 | ; NOPCHK - O = Check pseudo indicator (default)
|
---|
| 304 | ; 1 = Don't check pseudo indicator
|
---|
| 305 | ; NULLOK (optional) - 1 = Allow SSN to be null
|
---|
| 306 | ; 2 = Don't allow null SSNs (default)
|
---|
| 307 | ;
|
---|
| 308 | I $G(DATA)="" Q +$G(NULLOK) ; SD*5.3*345
|
---|
| 309 | I '$D(DATA) Q 0
|
---|
| 310 | N SSN,PSD
|
---|
| 311 | S SSN=$E(DATA,1,9),PSD=$E(DATA,10)
|
---|
| 312 | I SSN'?9N Q 0
|
---|
| 313 | I '$G(NOPCHK) I (PSD'=" "),(PSD'=""),(PSD'="P") Q 0
|
---|
| 314 | I $E(SSN,1,5)="00000" Q 0
|
---|
| 315 | Q 1
|
---|
| 316 | ;
|
---|
| 317 | INCR ;increases the counter
|
---|
| 318 | S CTR=CTR+1
|
---|
| 319 | Q
|
---|
| 320 | ;
|
---|
| 321 | REMOVE(SEG,ERR,VALERR,CNT) ;
|
---|
| 322 | ;INPUT SEG - The segment being worked on
|
---|
| 323 | ; VALERR - The array holding the information
|
---|
| 324 | ; CNT - the counter to use
|
---|
| 325 | ; ERR - error code to remove
|
---|
| 326 | ;
|
---|
| 327 | N LP
|
---|
| 328 | F LP=1:1:CNT I $G(@VALERR@(SEG,LP))=ERR K @VALERR@(SEG,LP)
|
---|
| 329 | Q
|
---|
| 330 | ;
|
---|
| 331 | DECR(CNT) ;
|
---|
| 332 | S CNT=CNT-1
|
---|
| 333 | Q
|
---|
| 334 | ;
|
---|