[613] | 1 | EASEZI1 ;ALB/jap - Database Inquiry & Record Finder for 1010EZ Processing ;10/12/00 13:08
|
---|
| 2 | ;;1.0;ENROLLMENT APPLICATION SYSTEM;**57**;Mar 15, 2001
|
---|
| 3 | ;continuation of EASEZI, split by patch 57 due to Max size limit
|
---|
| 4 | ;
|
---|
| 5 | RESET ;
|
---|
| 6 | ;set link in file #712 record
|
---|
| 7 | N FDA,ERR
|
---|
| 8 | S FDA(712,EASAPP_",",3.4)=DFN
|
---|
| 9 | I NEW D
|
---|
| 10 | . S FDA(712,EASAPP_",",3.5)=NEW
|
---|
| 11 | D FILE^DIE("","FDA","ERR")
|
---|
| 12 | ;
|
---|
| 13 | W !,"One moment please...",!
|
---|
| 14 | S EASDFN=DFN
|
---|
| 15 | ;setup tmp array for data mapping
|
---|
| 16 | D LOCAL711^EASEZU2
|
---|
| 17 | I '$G(EASVRSN) S EASVRSN=$$VERSION^EASEZU4(EASAPP)
|
---|
| 18 | ;if applicant is new to database, user accept/not accept of data elements is constrained;
|
---|
| 19 | ;if applicant is new to VistA, mark all data elements 'accepted';
|
---|
| 20 | I NEW S N=0 F S N=$O(^EAS(712,EASAPP,10,N)) Q:'N I $G(^EAS(712,EASAPP,10,N,1))'="" D
|
---|
| 21 | .S ACCEPT="",FLD="",SUBFILE="",FILE=""
|
---|
| 22 | .S KEYIEN=$P(^EAS(712,EASAPP,10,N,0),U,1)
|
---|
| 23 | .I KEYIEN S X=$G(^TMP("EZDATA",$J,KEYIEN)),FILE=$P(X,U,1),SUBFILE=$P(X,U,2),FLD=$P(X,U,3),DATAKEY=$P(X,U,4),SECT=$P(DATAKEY,";",1)
|
---|
| 24 | .I FLD S ACCEPT=1
|
---|
| 25 | .I 'FLD S ACCEPT=-1
|
---|
| 26 | .I (FILE=355.33)!(FILE>408) S ACCEPT=2
|
---|
| 27 | .I FILE=2,SUBFILE=2,((FLD=.01)!(FLD=.03)!(FLD=.09)!(FLD=.531)) S ACCEPT=-1
|
---|
| 28 | .I ((SUBFILE=2.01)!(SUBFILE=2.101)) S ACCEPT=-1
|
---|
| 29 | .I (EASVRSN>5.99),((SECT="IIC")!(SECT="IIE")) D
|
---|
| 30 | ..S QUES=$P(DATAKEY,";",2)
|
---|
| 31 | ..I SECT="IIC","1.6;2.3;3.3"[QUES S ACCEPT=-1 Q
|
---|
| 32 | ..I SECT="IIE","1.3;2.3;3.3"[QUES S ACCEPT=-1
|
---|
| 33 | .S $P(^EAS(712,EASAPP,10,N,0),U,3)=ACCEPT
|
---|
| 34 | ;for applicants matched to existing patients check for
|
---|
| 35 | ; verified eligibility and appt request on 1010 app
|
---|
| 36 | I 'NEW D
|
---|
| 37 | .K ARRAY
|
---|
| 38 | .S DA=EASDFN,DIC="^DPT(",DR=".3611;.3613;1010.159;1010.1511"
|
---|
| 39 | .S DIQ(0)="I",DIQ="ARRAY"
|
---|
| 40 | .D EN^DIQ1
|
---|
| 41 | .I ARRAY(2,EASDFN,.3611,"I")="V",ARRAY(2,EASDFN,.3613,"I")="H" S ELIGVER=1
|
---|
| 42 | .I ARRAY(2,EASDFN,1010.159,"I")'="",ARRAY(2,EASDFN,1010.1511,"I")'="" S APPTVER=1
|
---|
| 43 | ;correlate #712 data with mapping array
|
---|
| 44 | S N=0 F S N=$O(^EAS(712,EASAPP,10,N)) Q:'N S X=^(N,0) D
|
---|
| 45 | .;don't set array node if no 1010EZ data
|
---|
| 46 | .S EZDATA=$P($G(^EAS(712,EASAPP,10,N,1)),U,1)
|
---|
| 47 | .Q:EZDATA=""
|
---|
| 48 | .S IEN=$P(X,U,1),MULTIPLE=$P(X,U,2),ACCEPT=$P(X,U,3)
|
---|
| 49 | .S ^TMP("EZDATA",$J,IEN,MULTIPLE,1)=EZDATA_U_ACCEPT_U_N
|
---|
| 50 | ;
|
---|
| 51 | ;if applicant new to VistA, stop here;
|
---|
| 52 | I NEW S EASEZNEW=1
|
---|
| 53 | Q:$G(EASEZNEW)
|
---|
| 54 | ;if matched to existing patient, get all iens needed
|
---|
| 55 | W !,"Preparing for data comparison to VistA Patient database...",!
|
---|
| 56 | K ALIAS,DISPOS,ENROLL,INCREL,RACE,ETHNC
|
---|
| 57 | D I201^EASEZI(EASDFN,.ALIAS) W "."
|
---|
| 58 | I $D(ALIAS)>1 D C201^EASEZC1
|
---|
| 59 | D I2101^EASEZI(EASDFN,.DISPOS) W "."
|
---|
| 60 | I $D(DISPOS)>1 D C2101^EASEZC1
|
---|
| 61 | ;finish getting the rest of file #2 data needed for comparison
|
---|
| 62 | D C2^EASEZC1
|
---|
| 63 | D I2711^EASEZI(EASDFN,.ENROLL) W "."
|
---|
| 64 | I $D(ENROLL)>1 D C2711^EASEZC1
|
---|
| 65 | D I408^EASEZI(EASDFN,EASAPP,.INCREL) W "."
|
---|
| 66 | I $D(INCREL)>1 D C408^EASEZC1
|
---|
| 67 | D I202^EASEZI(EASDFN,.RACE) W "."
|
---|
| 68 | I $D(RACE)>1 D C202^EASEZC3
|
---|
| 69 | D I206^EASEZI(EASDFN,.ETHNC) W "."
|
---|
| 70 | I $D(ETHNC)>1 D C206^EASEZC3
|
---|
| 71 | ;set file #355.33 data to 'always accept';
|
---|
| 72 | ;set unmatched data for files #408.12, #408.13, #408.21, #408.22 to 'always accept';
|
---|
| 73 | S N=0 F S N=$O(^EAS(712,EASAPP,10,N)) Q:'N S X=^(N,0) D
|
---|
| 74 | .S KEYIEN=$P(X,U,1),MULTIPLE=$P(X,U,2)
|
---|
| 75 | .I KEYIEN S X=$G(^TMP("EZDATA",$J,KEYIEN)),FILE=$P(X,U,1),SUBFILE=$P(X,U,2),FLD=$P(X,U,3),DATAKEY=$P(X,U,4),SECT=$P(DATAKEY,";",1)
|
---|
| 76 | .S ACCEPT=""
|
---|
| 77 | .I 'FLD S ACCEPT=-1
|
---|
| 78 | .I FILE=2,SUBFILE=2,((FLD=.01)!(FLD=.03)!(FLD=.09)!(FLD=.531)) S ACCEPT=-1
|
---|
| 79 | .;set certain eligibility related data elements to 'never accept' if eligibility verified
|
---|
| 80 | .I FILE=2,FLD=.313,$G(ARRAY(2,EASDFN,.3611,"I"))="V" S ACCEPT=-1
|
---|
| 81 | .I FILE=2,$G(ELIGVER),((FLD=.301)!(FLD=.302)!(FLD=.36235)) S ACCEPT=-1
|
---|
| 82 | .;set appt requested element to 'never accept' if already exist
|
---|
| 83 | .I FILE=2,$G(APPTVER),FLD=1010.159 S ACCEPT=-1
|
---|
| 84 | .I FILE=355.33 S ACCEPT=2
|
---|
| 85 | .I FILE>408 S ACCEPT=2
|
---|
| 86 | .I (EASVRSN>5.99),((SECT="IIC")!(SECT="IIE")) D
|
---|
| 87 | ..S QUES=$P(DATAKEY,";",2)
|
---|
| 88 | ..I SECT="IIC","1.6;2.3;3.3"[QUES S ACCEPT=-1 Q
|
---|
| 89 | ..I SECT="IIE","1.3;2.3;3.3"[QUES S ACCEPT=-1
|
---|
| 90 | .S $P(^EAS(712,EASAPP,10,N,0),U,3)=ACCEPT
|
---|
| 91 | .S $P(^TMP("EZDATA",$J,KEYIEN,MULTIPLE,1),U,2)=ACCEPT
|
---|
| 92 | K ALIAS,DISPOS,ENROLL,INCREL
|
---|
| 93 | Q
|
---|
| 94 | ;
|
---|