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