| 1 | SCMSVZEL   ;ALB/ESD HL7 ZEL Segment Validation ; 8/11/99 9:24am
 | 
|---|
| 2 |  ;;5.3;Scheduling;**44,66,142,184,180,222,239,325**;Aug 13, 1993
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  ;
 | 
|---|
| 5 | EN(ZELSEG,HLQ,HLFS,VALERR,DFN) ;
 | 
|---|
| 6 |  ; Entry point to return the HL7 ZEL (Patient Eligibility) validation segment
 | 
|---|
| 7 |  ;
 | 
|---|
| 8 |  ;  Input: .ZELSEG - ZEL Segment Array
 | 
|---|
| 9 |  ;             HLQ - HL7 null variable
 | 
|---|
| 10 |  ;            HLFS - HL7 field separator
 | 
|---|
| 11 |  ;          VALERR - The array name to put the errors in
 | 
|---|
| 12 |  ;             DFN - The DFN of the patient
 | 
|---|
| 13 |  ;
 | 
|---|
| 14 |  ; Output:  1 if ZEL passed validity check
 | 
|---|
| 15 |  ;          Error message if ZEL failed validity check in form of:
 | 
|---|
| 16 |  ;          -1^"xxx failed validity check" (xxx=element in ZEL segment)
 | 
|---|
| 17 |  ;
 | 
|---|
| 18 |  ;
 | 
|---|
| 19 |  N I,MSG,X,CNT,DATA,SEG,ELIG,VET,LP,MSTSTAT,MSTDATE,SEGLINE,NODE,OFFSET
 | 
|---|
| 20 |  N CVET
 | 
|---|
| 21 |  S SEG="ZEL",CNT=1
 | 
|---|
| 22 |  S MSG="-1^Element in ZEL segment failed validity check"
 | 
|---|
| 23 |  S ZELSEG(1)=$G(ZELSEG(1))
 | 
|---|
| 24 |  D VALIDATE^SCMSVUT0(SEG,ZELSEG(1),"0010",VALERR,.CNT)
 | 
|---|
| 25 |  I $D(@VALERR@(SEG)) G ENQ
 | 
|---|
| 26 |  ;
 | 
|---|
| 27 |  ;- Convert HLQ to null
 | 
|---|
| 28 |  S ZELSEG(1)=$$CONVERT^SCMSVUT0(ZELSEG(1),HLFS,HLQ)
 | 
|---|
| 29 |  S I=0
 | 
|---|
| 30 |  F  S I=+$O(ZELSEG(1,I)) Q:'I  S ZELSEG(1,I)=$$CONVERT^SCMSVUT0(ZELSEG(1,I),HLFS,HLQ)
 | 
|---|
| 31 |  ;
 | 
|---|
| 32 |  S OFFSET=0,NODE=0,SEGLINE=ZELSEG(1)
 | 
|---|
| 33 |  F I=1,3,9,19,20,23,24,25,30,38,39 DO
 | 
|---|
| 34 |  . I $L(SEGLINE,HLFS)<(I-OFFSET) D
 | 
|---|
| 35 |  . . ;Segment wrapped
 | 
|---|
| 36 |  . . S OFFSET=OFFSET+$L(SEGLINE,HLFS)-1
 | 
|---|
| 37 |  . . S NODE=+$O(ZELSEG(1,NODE))
 | 
|---|
| 38 |  . . I NODE=0 S SEGLINE="",NODE=+$O(ZELSEG(1,NODE),-1) Q
 | 
|---|
| 39 |  . . S SEGLINE=$G(ZELSEG(1,NODE))
 | 
|---|
| 40 |  . S DATA=$P(SEGLINE,HLFS,I-OFFSET)
 | 
|---|
| 41 |  . I I=3 S ELIG=DATA
 | 
|---|
| 42 |  . I I=9 S VET=DATA
 | 
|---|
| 43 |  . I I=24 S MSTSTAT=DATA
 | 
|---|
| 44 |  . I I=25 S MSTDATE=DATA,DATA=MSTSTAT_"^"_MSTDATE
 | 
|---|
| 45 |  . I I=38 S CVET=DATA
 | 
|---|
| 46 |  . I I=39 S DATA=CVET_"^"_DATA
 | 
|---|
| 47 |  . D VALIDATE^SCMSVUT0(SEG,DATA,$P($T(@(I)),";",3),VALERR,.CNT)
 | 
|---|
| 48 |  . Q
 | 
|---|
| 49 |  ;
 | 
|---|
| 50 |  S DATA=ELIG_"^"_VET
 | 
|---|
| 51 |  F LP=32,91 D VALIDATE^SCMSVUT0(SEG,$S(LP=32:ELIG,LP=91:VET,1:DATA),$P($T(@(LP)),";",3),VALERR,.CNT)
 | 
|---|
| 52 |  ;
 | 
|---|
| 53 | ENQ Q $S($D(@VALERR@(SEG)):MSG,1:1)
 | 
|---|
| 54 |  ;
 | 
|---|
| 55 |  ;
 | 
|---|
| 56 |  ;
 | 
|---|
| 57 | ERR ;;Invalid or missing patient eligibility data for encounter (HL7 ZEL segment)
 | 
|---|
| 58 |  ;
 | 
|---|
| 59 |  ;
 | 
|---|
| 60 |  ;- ZEL data elements validated
 | 
|---|
| 61 |  ;
 | 
|---|
| 62 | 1 ;;0035;HL7 SEGMENT NAME
 | 
|---|
| 63 | 3 ;;7000;ELIGIBILITY CODE MISSING
 | 
|---|
| 64 | 31 ;;7020;ELIGIBILITY CODE INCONSISTENT WITH VET STATUS
 | 
|---|
| 65 | 32 ;;7030;ELIGIBILITY CODE INACTIVE
 | 
|---|
| 66 | 9 ;;7050;VETERAN?
 | 
|---|
| 67 | 91 ;;7100;VET STATUS INCONSISTENT WITH POW
 | 
|---|
| 68 | 19 ;;7120;AGENT ORANGE EXPOSURE
 | 
|---|
| 69 | 23 ;;7150;INVALID/INCONSISTENT RADIATION EXPOSURE METHOD
 | 
|---|
| 70 | 20 ;;7210;RADIATION EXPOSURE INDICATED
 | 
|---|
| 71 | 24 ;;7040;INVALID MST CLASSIFICATION
 | 
|---|
| 72 | 25 ;;7060;MST STATUS DATE INVALID OR INCONSISTENT WITH MST STATUS
 | 
|---|
| 73 | 30 ;;7130;AGENT ORANGE EXPOSURE LOCATION
 | 
|---|
| 74 | 38 ;;7330;COMBAT VET INDICATOR
 | 
|---|
| 75 | 39 ;;7340;COMBAT VET END DATE
 | 
|---|