| 1 | IVMLDEM4 ;ALB/KCL,PJR - IVM DEMOGRAPHIC UPLOAD/DELETE FIELDS ; 11/22/04 2:27pm | 
|---|
| 2 | ;;2.0;INCOME VERIFICATION MATCH;**5,10,56,102**; 21-OCT-94 | 
|---|
| 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
| 4 | ; | 
|---|
| 5 | ; | 
|---|
| 6 | UF ; - (action) select uploadable demographic fields for filing | 
|---|
| 7 | ; | 
|---|
| 8 | ;  Input:  IVMWHERE  --  as where the action is coming from | 
|---|
| 9 | ; | 
|---|
| 10 | ;                    --  If action from UPLOADABLE list: | 
|---|
| 11 | ;                          array of uploadable fields as | 
|---|
| 12 | ;                          ^TMP("IVMUPLOAD",$J,"IDX",CTR,CTR)=dfn^da(2)^da(1)^da^ivm field value^pointer to file (#1)^dhcp field number^dhcp field name | 
|---|
| 13 | ; | 
|---|
| 14 | ; | 
|---|
| 15 | ; - generic seletor used within list manager action | 
|---|
| 16 | N VALMY,IVMDOD S IVMDOD=0 | 
|---|
| 17 | D EN^VALM2($G(XQORNOD(0))) | 
|---|
| 18 | Q:'$D(VALMY) | 
|---|
| 19 | ; | 
|---|
| 20 | N IVMPKDOD D CHECKS,CHECKDOD | 
|---|
| 21 | ; | 
|---|
| 22 | S IVMENT4=0 F  S IVMENT4=$O(VALMY(IVMENT4)) Q:'IVMENT4  D | 
|---|
| 23 | .; | 
|---|
| 24 | .S IVMINDEX=$G(^TMP("IVMUPLOAD",$J,"IDX",IVMENT4,IVMENT4)) I IVMINDEX']"" Q | 
|---|
| 25 | .; | 
|---|
| 26 | .; - check to see if selection is an address field | 
|---|
| 27 | .S IVMADDR=$$ADDR^IVMLDEM6(+IVMINDEX,$P(IVMINDEX,"^",2),$P(IVMINDEX,"^",3),$P(IVMINDEX,"^",4),IVMPPICK) | 
|---|
| 28 | .; | 
|---|
| 29 | .Q:IVMADDR | 
|---|
| 30 | .; | 
|---|
| 31 | .; - check to see if selection is a Date of Death field | 
|---|
| 32 | .I IVMPKDOD S IVMDOD=$$DOD^IVMLDEMD(+IVMINDEX,$P(IVMINDEX,"^",2),$P(IVMINDEX,"^",3),$P(IVMINDEX,"^",4)) | 
|---|
| 33 | .; | 
|---|
| 34 | .Q:IVMDOD | 
|---|
| 35 | .; | 
|---|
| 36 | .; - ask user if they are sure they want to update field | 
|---|
| 37 | .D RUSURE^IVMLDEMU($P(IVMINDEX,"^",8),"update") I IVMOUT!'IVMSURE Q | 
|---|
| 38 | .; | 
|---|
| 39 | .W !,"Updating "_$P(IVMINDEX,"^",8)_" field... " | 
|---|
| 40 | .; | 
|---|
| 41 | .; - upload value received from IVM into DHCP field | 
|---|
| 42 | .D UPLOAD^IVMLDEMU(DFN,$P(IVMINDEX,"^",6),$P(IVMINDEX,"^",7),$P(IVMINDEX,"^",5)) | 
|---|
| 43 | .; | 
|---|
| 44 | .; - remove entry from file (#301.5) | 
|---|
| 45 | .D DELENT^IVMLDEMU($P(IVMINDEX,"^",2),$P(IVMINDEX,"^",3),$P(IVMINDEX,"^",4)) W "completed." | 
|---|
| 46 | .; | 
|---|
| 47 | ; | 
|---|
| 48 | ; - hold display before building list | 
|---|
| 49 | D PAUSE^VALM1 | 
|---|
| 50 | ; | 
|---|
| 51 | ; - init the list and re-display to the user | 
|---|
| 52 | D INIT^IVMLDEM2 | 
|---|
| 53 | ; | 
|---|
| 54 | DEQ ; clean-up variables | 
|---|
| 55 | D QACTION | 
|---|
| 56 | Q | 
|---|
| 57 | ; | 
|---|
| 58 | ; | 
|---|
| 59 | DF ; - (action) select uploadable/non-uploadable demographic fields for deletion | 
|---|
| 60 | ; | 
|---|
| 61 | ;  Input:  IVMWHERE  --  as where the action is coming from | 
|---|
| 62 | ; | 
|---|
| 63 | ;                    --  If action from UPLOADABLE list: | 
|---|
| 64 | ;                          array of uploadable fields as | 
|---|
| 65 | ;                          ^TMP("IVMUPLOAD",$J,"IDX",CTR,CTR)=dfn^da(2)^da(1)^da^ivm field value^pointer to file (#1)^dhcp field number^dhcp field name | 
|---|
| 66 | ; | 
|---|
| 67 | ;                        OR | 
|---|
| 68 | ; | 
|---|
| 69 | ;                    --  If action from NON-UPLOADABLE list: | 
|---|
| 70 | ;                          array of non-uploadable fields as | 
|---|
| 71 | ;                          ^TMP("IVMNONUP",$J,"IDX",CTR,CTR)=dfn^da(2)^da(1)^da^ivm field value^pointer to file (#1)^dhcp field number^dhcp field name | 
|---|
| 72 | ; | 
|---|
| 73 | ; | 
|---|
| 74 | ; Output:  None | 
|---|
| 75 | ; | 
|---|
| 76 | ; - generic seletor used within list manager action | 
|---|
| 77 | N VALMY | 
|---|
| 78 | D EN^VALM2($G(XQORNOD(0))) | 
|---|
| 79 | Q:'$D(VALMY) | 
|---|
| 80 | ; | 
|---|
| 81 | ; - determine array depending on variable IVMWHERE | 
|---|
| 82 | S IVMARRAY=$S(IVMWHERE="UP":"IVMUPLOAD",1:"IVMNONUP") | 
|---|
| 83 | ; | 
|---|
| 84 | N IVMPKDOD D CHECKS,CHECKDOD | 
|---|
| 85 | ; | 
|---|
| 86 | S IVMENT4=0 F  S IVMENT4=$O(VALMY(IVMENT4)) Q:'IVMENT4  D | 
|---|
| 87 | .; | 
|---|
| 88 | .I IVMWHERE="NON" D DF^IVMLDEM8 Q  ; non-uploadable fields | 
|---|
| 89 | .; | 
|---|
| 90 | .; - get selected entry for uploadable fields | 
|---|
| 91 | .S IVMINDEX=$G(^TMP(IVMARRAY,$J,"IDX",IVMENT4,IVMENT4)) Q:IVMINDEX']"" | 
|---|
| 92 | .; | 
|---|
| 93 | .; - check to see if selection is an address field | 
|---|
| 94 | .S IVMADDR=$$ADDR^IVMLDEM7(+IVMINDEX,$P(IVMINDEX,"^",2),$P(IVMINDEX,"^",3),$P(IVMINDEX,"^",4),IVMPPICK) | 
|---|
| 95 | .; | 
|---|
| 96 | .Q:IVMADDR | 
|---|
| 97 | .; | 
|---|
| 98 | .; - ask user if they are sure they want to delete field | 
|---|
| 99 | .D RUSURE^IVMLDEMU($P(IVMINDEX,"^",8),"delete") I IVMOUT!'IVMSURE Q | 
|---|
| 100 | .; | 
|---|
| 101 | .W !,"Deleting "_$P(IVMINDEX,"^",8)_" field from the list... " | 
|---|
| 102 | .; | 
|---|
| 103 | .;if Date of Death is Deleted, send bulletin | 
|---|
| 104 | .I IVMPKDOD D BULLETIN S IVMPKDOD=0 | 
|---|
| 105 | .;- remove entry from file (#301.5) | 
|---|
| 106 | .D DELENT^IVMLDEMU($P(IVMINDEX,"^",2),$P(IVMINDEX,"^",3),$P(IVMINDEX,"^",4)) W "completed." | 
|---|
| 107 | ; | 
|---|
| 108 | ; - hold display before re-building list | 
|---|
| 109 | D PAUSE^VALM1 | 
|---|
| 110 | ; | 
|---|
| 111 | ; - init the list and re-display to the user | 
|---|
| 112 | D @$S(IVMWHERE="UP":"INIT^IVMLDEM2",1:"INIT^IVMLDEM3") | 
|---|
| 113 | ; | 
|---|
| 114 | DFQ ; clean-up variables | 
|---|
| 115 | D QACTION | 
|---|
| 116 | Q | 
|---|
| 117 | ; | 
|---|
| 118 | ; | 
|---|
| 119 | CHECKS ; check if residence phone number selected | 
|---|
| 120 | ; check if another address field selected | 
|---|
| 121 | ; IVMPPICK=0 phone or an address field not selected | 
|---|
| 122 | ;          1 address field(s) selected | 
|---|
| 123 | ;          2 phone selected | 
|---|
| 124 | ;          3 both address field(s) and phone selected | 
|---|
| 125 | ; | 
|---|
| 126 | N IVMPPIC1,IVMPPIC2 | 
|---|
| 127 | S (IVMPPICK,IVMPPIC2)=0 | 
|---|
| 128 | Q:IVMWHERE'="UP" | 
|---|
| 129 | S IVMENT4=0 F  S IVMENT4=$O(VALMY(IVMENT4)) Q:'IVMENT4  D | 
|---|
| 130 | .I $G(^TMP("IVMUPLOAD",$J,"IDX",IVMENT4,IVMENT4))["PHONE NUMBER [RESIDENCE]" S IVMPPICK=2 Q | 
|---|
| 131 | .S IVMINDEX=$G(^TMP("IVMUPLOAD",$J,"IDX",IVMENT4,IVMENT4)) I IVMINDEX']"" Q | 
|---|
| 132 | .S IVMPPIC1=+$G(^IVM(301.5,+$P(IVMINDEX,"^",2),"IN",+$P(IVMINDEX,"^",3),"DEM",+$P(IVMINDEX,"^",4),0)) Q:'IVMPPIC1 | 
|---|
| 133 | .S:$D(^IVM(301.92,"AD",+IVMPPIC1)) IVMPPIC2=1 | 
|---|
| 134 | .Q | 
|---|
| 135 | S IVMPPICK=IVMPPICK+IVMPPIC2 | 
|---|
| 136 | Q | 
|---|
| 137 | ; | 
|---|
| 138 | CHECKDOD ; check if date of death was selected | 
|---|
| 139 | ; IVMPKDOD=0 date of death not selected | 
|---|
| 140 | ;          1 date of death selected | 
|---|
| 141 | ; | 
|---|
| 142 | N IVMPPIC1,IVMPPIC2,CKST | 
|---|
| 143 | S (IVMPKDOD,IVMPPIC2)=0 | 
|---|
| 144 | Q:IVMWHERE'="UP" | 
|---|
| 145 | S IVMENT4=0 F  S IVMENT4=$O(VALMY(IVMENT4)) Q:'IVMENT4  D | 
|---|
| 146 | .S CKST=$G(^TMP("IVMUPLOAD",$J,"IDX",IVMENT4,IVMENT4)) | 
|---|
| 147 | .I CKST["DATE OF DEATH"!(CKST["SOURCE OF NOTIFICATION")!(CKST["DATE OF DEATH LAST UPDATED") S IVMPKDOD=1 Q | 
|---|
| 148 | Q | 
|---|
| 149 | BULLETIN ; Non-Acceptance of Date of Death Data Bulletin | 
|---|
| 150 | N DGBULL,DGLINE,DGMGRP,DGNAME,DIFROM,VA,VAERR,XMTEXT,XMSUB,XMDUZ | 
|---|
| 151 | S DGMGRP=$O(^XMB(3.8,"B","DGEN ELIGIBILITY ALERT","")) | 
|---|
| 152 | Q:'DGMGRP | 
|---|
| 153 | D XMY^DGMTUTL(DGMGRP,0,1) | 
|---|
| 154 | S DGNAME=$P($G(^DPT(DFN,0)),"^"),DGSSN=$P($G(^DPT(DFN,0)),"^",9) | 
|---|
| 155 | S XMTEXT="DGBULL(" | 
|---|
| 156 | S XMSUB="NON-ACCEPTANCE OF DATE OF DEATH DATA" | 
|---|
| 157 | S DGLINE=0 | 
|---|
| 158 | D LINE^DGEN("Patient: "_DGNAME,.DGLINE) | 
|---|
| 159 | D LINE^DGEN("SSN: "_DGSSN,.DGLINE) | 
|---|
| 160 | D LINE^DGEN("",.DGLINE) | 
|---|
| 161 | D LINE^DGEN("This Veteran's Enrollment Record contains a Date of Death,",.DGLINE) | 
|---|
| 162 | D LINE^DGEN("however, you did not upload this information into VistA.",.DGLINE) | 
|---|
| 163 | D LINE^DGEN("Contact the HEC by phone or by fax with the reason for",.DGLINE) | 
|---|
| 164 | D LINE^DGEN("non-acceptance.  The HEC will delete erroneous Date of Death",.DGLINE) | 
|---|
| 165 | D LINE^DGEN("information and update the veteran's enrollment record.",.DGLINE) | 
|---|
| 166 | D ^XMD | 
|---|
| 167 | Q | 
|---|
| 168 | QACTION ; - kill variables used from all protocols | 
|---|
| 169 | S VALMBCK="R" | 
|---|
| 170 | K IVMADDR,IVMARRAY,IVMENT4,IVMINDEX,IVMOUT,IVMPPICK,IVMSURE | 
|---|
| 171 | Q | 
|---|