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