Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: SCMSVZEL

SCMSVZEL.m

Go to the documentation of this file.
  1. SCMSVZEL ;ALB/ESD HL7 ZEL Segment Validation ; 6/20/05 9:24am
  1. ;;5.3;Scheduling;**44,66,142,184,180,222,239,325,441,1015**;Aug 13, 1993;Build 21
  1. ;
  1. ;
  1. EN(ZELSEG,HLQ,HLFS,VALERR,DFN) ;
  1. ; Entry point to return the HL7 ZEL (Patient Eligibility) validation segment
  1. ;
  1. ; Input: .ZELSEG - ZEL Segment Array
  1. ; HLQ - HL7 null variable
  1. ; HLFS - HL7 field separator
  1. ; VALERR - The array name to put the errors in
  1. ; DFN - The DFN of the patient
  1. ;
  1. ; Output: 1 if ZEL passed validity check
  1. ; Error message if ZEL failed validity check in form of:
  1. ; -1^"xxx failed validity check" (xxx=element in ZEL segment)
  1. ;
  1. ;
  1. N I,MSG,X,CNT,DATA,SEG,ELIG,VET,LP,MSTSTAT,MSTDATE,SEGLINE,NODE,OFFSET
  1. N CVET
  1. S SEG="ZEL",CNT=1
  1. S MSG="-1^Element in ZEL segment failed validity check"
  1. S ZELSEG(1)=$G(ZELSEG(1))
  1. D VALIDATE^SCMSVUT0(SEG,ZELSEG(1),"0010",VALERR,.CNT)
  1. I $D(@VALERR@(SEG)) G ENQ
  1. ;
  1. ;- Convert HLQ to null
  1. S ZELSEG(1)=$$CONVERT^SCMSVUT0(ZELSEG(1),HLFS,HLQ)
  1. S I=0
  1. F S I=+$O(ZELSEG(1,I)) Q:'I S ZELSEG(1,I)=$$CONVERT^SCMSVUT0(ZELSEG(1,I),HLFS,HLQ)
  1. ;
  1. S OFFSET=0,NODE=0,SEGLINE=ZELSEG(1)
  1. F I=1,3,9,19,20,23,24,25,30,38,39,41 DO
  1. . I $L(SEGLINE,HLFS)<(I-OFFSET) D
  1. . . ;Segment wrapped
  1. . . S OFFSET=OFFSET+$L(SEGLINE,HLFS)-1
  1. . . S NODE=+$O(ZELSEG(1,NODE))
  1. . . I NODE=0 S SEGLINE="",NODE=+$O(ZELSEG(1,NODE),-1) Q
  1. . . S SEGLINE=$G(ZELSEG(1,NODE))
  1. . S DATA=$P(SEGLINE,HLFS,I-OFFSET)
  1. . I I=3 S ELIG=DATA
  1. . I I=9 S VET=DATA
  1. . I I=24 S MSTSTAT=DATA
  1. . I I=25 S MSTDATE=DATA,DATA=MSTSTAT_"^"_MSTDATE
  1. . I I=38 S CVET=DATA
  1. . I I=39 S DATA=CVET_"^"_DATA
  1. . D VALIDATE^SCMSVUT0(SEG,DATA,$P($T(@(I)),";",3),VALERR,.CNT)
  1. . Q
  1. ;
  1. S DATA=ELIG_"^"_VET
  1. F LP=32,91 D VALIDATE^SCMSVUT0(SEG,$S(LP=32:ELIG,LP=91:VET,1:DATA),$P($T(@(LP)),";",3),VALERR,.CNT)
  1. ;
  1. ENQ Q $S($D(@VALERR@(SEG)):MSG,1:1)
  1. ;
  1. ;
  1. ;
  1. ERR ;;Invalid or missing patient eligibility data for encounter (HL7 ZEL segment)
  1. ;
  1. ;
  1. ;- ZEL data elements validated
  1. ;
  1. 1 ;;0035;HL7 SEGMENT NAME
  1. 3 ;;7000;ELIGIBILITY CODE MISSING
  1. 31 ;;7020;ELIGIBILITY CODE INCONSISTENT WITH VET STATUS
  1. 32 ;;7030;ELIGIBILITY CODE INACTIVE
  1. 9 ;;7050;VETERAN?
  1. 91 ;;7100;VET STATUS INCONSISTENT WITH POW
  1. 19 ;;7120;AGENT ORANGE EXPOSURE
  1. 23 ;;7150;INVALID/INCONSISTENT RADIATION EXPOSURE METHOD
  1. 20 ;;7210;RADIATION EXPOSURE INDICATED
  1. 24 ;;7040;INVALID MST CLASSIFICATION
  1. 25 ;;7060;MST STATUS DATE INVALID OR INCONSISTENT WITH MST STATUS
  1. 30 ;;7130;AGENT ORANGE EXPOSURE LOCATION
  1. 38 ;;7330;COMBAT VET INDICATOR
  1. 39 ;;7340;COMBAT VET END DATE
  1. 41 ;;7370;PROJ 112/SHAD INDICATOR