| 1 | IVMLDEM3 ;ALB/KCL - IVM DEMOGRAPHIC NON-UPLOADABLE FIELDS ; 15-APR-94 | 
|---|
| 2 | ;;Version 2.0 ; INCOME VERIFICATION MATCH ;**5**; 21-OCT-94 | 
|---|
| 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
| 4 | ; | 
|---|
| 5 | ; | 
|---|
| 6 | EN ; - main entry point for IVM DEMOGRAPHIC NON-UPLOADABLE | 
|---|
| 7 | D EN^VALM("IVM DEMOGRAPHIC NON-UPLOADABLE") | 
|---|
| 8 | Q | 
|---|
| 9 | ; | 
|---|
| 10 | ; | 
|---|
| 11 | HDR ; - header code for list manager display | 
|---|
| 12 | S IVMBLNK="",$P(IVMBLNK," ",45)="" | 
|---|
| 13 | ; | 
|---|
| 14 | ; - header line 1 | 
|---|
| 15 | S VALMHDR(1)="Patient: "_$E($E($P(^DPT(DFN,0),"^"),1,20)_" "_"("_$E($P(^DPT(DFN,0),"^",9),6,9)_")"_IVMBLNK,1,35)_" "_"Non-uploadable Demographic Fields" | 
|---|
| 16 | ; | 
|---|
| 17 | ; - header line 2 | 
|---|
| 18 | S VALMHDR(2)=" " | 
|---|
| 19 | Q | 
|---|
| 20 | ; | 
|---|
| 21 | ; | 
|---|
| 22 | INIT ; - init variables and list array | 
|---|
| 23 | ; | 
|---|
| 24 | ;  Input:  IVMDA2  --  Pointer to case record in file #301.5 | 
|---|
| 25 | ;          IVMDA1  --  Pointer to PID msg in sub-file #301.501 | 
|---|
| 26 | ;             DFN  --  Pointer to patient in file #2 | 
|---|
| 27 | ; | 
|---|
| 28 | ; | 
|---|
| 29 | ; - flag used for delete demographic field action (DF) | 
|---|
| 30 | S IVMWHERE="NON" | 
|---|
| 31 | S IVMSTAT2="" | 
|---|
| 32 | K ^TMP("IVMNONUP",$J) | 
|---|
| 33 | S IVMBL="",$P(IVMBL," ",58)="",IVMCNTR=0,IVM27=0 | 
|---|
| 34 | D DEM^VADPT,ADD^VADPT S IVMSTATE=$P(VAPA(5),"^") | 
|---|
| 35 | F IVMDA=0:0 S IVMDA=$O(^IVM(301.5,IVMDA2,"IN",IVMDA1,"DEM",IVMDA)) Q:'IVMDA  D | 
|---|
| 36 | .; | 
|---|
| 37 | .; - grab node with IVM-supplied data | 
|---|
| 38 | .S IVMDEMO=$G(^IVM(301.5,IVMDA2,"IN",IVMDA1,"DEM",IVMDA,0)) I IVMDEMO="" Q | 
|---|
| 39 | .; | 
|---|
| 40 | .; - quit if data element is uploadable | 
|---|
| 41 | .S IVMTABLE=$G(^IVM(301.92,+$P(IVMDEMO,"^"),0)) | 
|---|
| 42 | .Q:$P(IVMTABLE,"^",3)=1 | 
|---|
| 43 | .; | 
|---|
| 44 | .; - if ivm state data then set IVMSTAT2 for decoding county code | 
|---|
| 45 | .I $P(IVMTABLE,"^")["STATE" S IVMSTAT2=$P(IVMDEMO,"^",2) | 
|---|
| 46 | .; | 
|---|
| 47 | .S IVMCNTR=IVMCNTR+1 | 
|---|
| 48 | .; | 
|---|
| 49 | .; - primary eligibility code | 
|---|
| 50 | .S:$P(IVMDEMO,"^")=27 IVM27=IVM27+1 | 
|---|
| 51 | .; | 
|---|
| 52 | .; - extract DHCP value in displayable format | 
|---|
| 53 | .S IVMDHCP="" X:$D(^IVM(301.92,$P(IVMDEMO,"^"),2)) ^(2) S IVMDHCP=Y | 
|---|
| 54 | .; | 
|---|
| 55 | .; - build index record to use for processing as | 
|---|
| 56 | .;   ctr is line # and ctr1 is entry # | 
|---|
| 57 | .;    ^tmp("ivmnonup",$j,"idx",ctr,ctr1)=dfn^da(2)^da(1)^da^ivm data^pointer to file (#1)^dhcp field number^dhcp field name | 
|---|
| 58 | .; | 
|---|
| 59 | .S IVMCNTR1=$S(IVM27<2:IVMCNTR,1:IVMCNTR-IVM27+1) | 
|---|
| 60 | .S ^TMP("IVMNONUP",$J,"IDX",IVMCNTR,IVMCNTR1)=DFN_"^"_IVMDA2_"^"_IVMDA1_"^"_IVMDA_"^"_$P(IVMDEMO,"^",2)_"^"_$P(IVMTABLE,"^",4)_"^"_$P(IVMTABLE,"^",5)_"^"_$P(IVMTABLE,"^") | 
|---|
| 61 | .; | 
|---|
| 62 | .; - build list manager display line | 
|---|
| 63 | .D WRITLINE($P(IVMTABLE,"^")_"^"_IVMDHCP_"^"_$P(IVMDEMO,"^",2),IVMCNTR) | 
|---|
| 64 | ; | 
|---|
| 65 | ; | 
|---|
| 66 | I '$O(@VALMAR@(0)) D | 
|---|
| 67 | .; | 
|---|
| 68 | .; - check for uploadable fields, if no fields do DELETE | 
|---|
| 69 | .I '$$DEMO^IVMLDEM5(IVMDA2,IVMDA1,1) D DELETE^IVMLDEM5(IVMDA2,IVMDA1,IVMNAME) | 
|---|
| 70 | .; | 
|---|
| 71 | .; - if uploadable fields set array field from 'YES' to 'NO' for list manager display | 
|---|
| 72 | .I $$DEMO^IVMLDEM5(IVMDA2,IVMDA1,1) S $P(^TMP("IVMDUPL",$J,IVMNAME,IVMDA2,IVMDA1),"^",5)="NO" | 
|---|
| 73 | .; | 
|---|
| 74 | .; - display msg to user that no uploadable data to view | 
|---|
| 75 | .D KILL^VALM10(1) | 
|---|
| 76 | .D KILL^VALM10(2) | 
|---|
| 77 | .S @VALMAR@(1,0)=" " | 
|---|
| 78 | .S @VALMAR@(2,0)="There is no non-uploadable demographic information to view." | 
|---|
| 79 | .S IVMCNTR=2 | 
|---|
| 80 | ; | 
|---|
| 81 | ; - list manager variable as number of lines in the list | 
|---|
| 82 | S VALMCNT=IVMCNTR | 
|---|
| 83 | ; | 
|---|
| 84 | ; | 
|---|
| 85 | INITQ ; - clean up variables | 
|---|
| 86 | D KVA^VADPT ; kill all variables defined by VADPT routine | 
|---|
| 87 | K IVMBL,IVMBLNK,IVMCNTR,IVMCNTR1,IVMDA,IVMDEMO,IVMDHCP,IVMFIELD | 
|---|
| 88 | K IVMSTAT2,IVMSTATE,IVMTABLE,IVM27 | 
|---|
| 89 | Q | 
|---|
| 90 | ; | 
|---|
| 91 | ; | 
|---|
| 92 | WRITLINE(IVMLINE,IVMNUM) ; - write line out for list manager display | 
|---|
| 93 | ; | 
|---|
| 94 | ;  Input:  IVMLINE  --  as the line for display: | 
|---|
| 95 | ;                       dhcp field name^dhcp field value^ivm field value | 
|---|
| 96 | ;           IVMNUM  --  as the line number | 
|---|
| 97 | ; Output:  None | 
|---|
| 98 | ; | 
|---|
| 99 | N IVMLN,IVMOUT1,IVMOUT2,IVMNUM1 | 
|---|
| 100 | S IVMOUT1=$P(IVMLINE,"^",2) | 
|---|
| 101 | I $P(IVMTABLE,"^",7) S IVMOUT1=$$OUTTR^IVMUFNC(IVMOUT1,IVMTABLE,IVMSTATE) | 
|---|
| 102 | S:IVMOUT1="" IVMOUT1="(* NONE ON FILE *)" | 
|---|
| 103 | S IVMOUT2=$$OUTTR^IVMUFNC($P(IVMLINE,"^",3),IVMTABLE,IVMSTAT2) | 
|---|
| 104 | S IVMLN=$E($P(IVMLINE,"^",1)_IVMBL,1,30)_"  "_$E(IVMOUT1_IVMBL,1,20)_"  "_$E(IVMOUT2_IVMBL,1,20) | 
|---|
| 105 | ; | 
|---|
| 106 | ; - highlight IVM field value | 
|---|
| 107 | D CNTRL^VALM10(IVMNUM,58,22,IOINHI,IOINORM) | 
|---|
| 108 | I $P(IVMDEMO,"^")=27,IVM27>1 S @VALMAR@(IVMNUM,0)=IVMBL_$E(IVMOUT2_IVMBL,1,20) Q | 
|---|
| 109 | S IVMNUM1=$S(IVM27>1:IVMNUM-IVM27+1,1:IVMNUM) | 
|---|
| 110 | S @VALMAR@(IVMNUM,0)=$E(IVMNUM1_"   ",1,3)_IVMLN | 
|---|
| 111 | Q | 
|---|
| 112 | ; | 
|---|
| 113 | ; | 
|---|
| 114 | HELP ; - help code | 
|---|
| 115 | S X="?" D DISP^XQORM1 W !! | 
|---|
| 116 | Q | 
|---|
| 117 | ; | 
|---|
| 118 | EXIT ; - exit code | 
|---|
| 119 | K ^TMP("IVMNONUP",$J) | 
|---|
| 120 | Q | 
|---|