| [623] | 1 | IVMCM ;ALB/SEK,KCL,RTK,AEG,BRM,AEG - PROCESS INCOME TEST (Z10) TRANSMISSIONS ; 04/23/03 1:43pm | 
|---|
|  | 2 | ;;2.0;INCOME VERIFICATION MATCH;**12,17,28,41,44,53,34,49,59,55,63,77,74**;21-OCT-94 | 
|---|
|  | 3 | ; | 
|---|
|  | 4 | ; | 
|---|
|  | 5 | ORF ; Handler for ORF type HL7 messages received from HEC | 
|---|
|  | 6 | ; | 
|---|
|  | 7 | ; Make sure POSTMASTER DUZ instead of DUZ of Person who | 
|---|
|  | 8 | ; started Incoming Logical Link. | 
|---|
|  | 9 | S DUZ=.5 | 
|---|
|  | 10 | N CNT,IVMRTN,SEGCNT | 
|---|
|  | 11 | S IVMRTN="IVMCMX"  ;USE "IVMCMX" BECAUSE "IVMCM" ALREADY USED | 
|---|
|  | 12 | K ^TMP($J,IVMRTN),DIC | 
|---|
|  | 13 | S (DGMSGF,DGMTMSG)=1  ; HL7 rtn. Don't need DG interative messages. | 
|---|
|  | 14 | S HLECH=HL("ECH"),HLQ=HL("Q"),HLMID=HL("MID") | 
|---|
|  | 15 | K %,%H,%I D NOW^%DTC S HLDT=% | 
|---|
|  | 16 | F SEGCNT=1:1 X HLNEXT Q:HLQUIT'>0  D | 
|---|
|  | 17 | . S CNT=0 | 
|---|
|  | 18 | . S ^TMP($J,IVMRTN,SEGCNT,CNT)=HLNODE | 
|---|
|  | 19 | . F  S CNT=$O(HLNODE(CNT)) Q:'CNT  D | 
|---|
|  | 20 | . . S ^TMP($J,IVMRTN,SEGCNT,CNT)=HLNODE(CNT) | 
|---|
|  | 21 | S HLDA=HLMTIEN | 
|---|
|  | 22 | ; | 
|---|
|  | 23 | N SEG,EVENT,MSGID | 
|---|
|  | 24 | S:'$D(HLEVN) HLEVN=0 | 
|---|
|  | 25 | D NXTSEG^DGENUPL(HLDA,0,.SEG) | 
|---|
|  | 26 | Q:(SEG("TYPE")'="MSH")  ;would not have reached here if this happened! | 
|---|
|  | 27 | S EVENT=$P(SEG(9),$E(HLECH),2) | 
|---|
|  | 28 | ; | 
|---|
|  | 29 | ; INITIALIZE HL7 VARIABLES | 
|---|
|  | 30 | S HLEID="VAMC "_$P($$SITE^VASITE,"^",3)_" ORF-"_EVENT_" SERVER" | 
|---|
|  | 31 | S HLEID=$O(^ORD(101,"B",HLEID,0)) | 
|---|
|  | 32 | D INIT^HLFNC2(HLEID,.HL) | 
|---|
|  | 33 | S HLEIDS=$O(^ORD(101,HLEID,775,"B",0)) | 
|---|
|  | 34 | ; | 
|---|
|  | 35 | ; Handle means test signature ORF (Z06) event | 
|---|
|  | 36 | I EVENT="Z06" D ORF^IVMPREC7 | 
|---|
|  | 37 | ; | 
|---|
|  | 38 | ; Handle income test ORF (Z10) event | 
|---|
|  | 39 | I EVENT="Z10" D Z10 | 
|---|
|  | 40 | ; | 
|---|
|  | 41 | ; Handle enrollment/elig. ORF (Z11) event | 
|---|
|  | 42 | I EVENT="Z11" D | 
|---|
|  | 43 | .S MSGID=SEG(10) | 
|---|
|  | 44 | .D ORFZ11^DGENUPL(HLDA,MSGID) | 
|---|
|  | 45 | ; | 
|---|
|  | 46 | K ^TMP($J,IVMRTN) | 
|---|
|  | 47 | Q | 
|---|
|  | 48 | ; | 
|---|
|  | 49 | ; | 
|---|
|  | 50 | Z10 ; Entry point for receipt of ORF~Z10 transmission | 
|---|
|  | 51 | ; The Income Test (Z10) transmission has the following format: | 
|---|
|  | 52 | ; | 
|---|
|  | 53 | ;       BHS           ORF msgs do not include batch header or trailer. | 
|---|
|  | 54 | ;       {MSH | 
|---|
|  | 55 | ;        PID          They will include the sequence:  MSA | 
|---|
|  | 56 | ;        ZIC                                           QRD | 
|---|
|  | 57 | ;        ZIR                                           QRF | 
|---|
|  | 58 | ;        {ZDP         These segments will follow the MSH segment. | 
|---|
|  | 59 | ;         ZIC | 
|---|
|  | 60 | ;         ZIR | 
|---|
|  | 61 | ;        } | 
|---|
|  | 62 | ;        {ZMT | 
|---|
|  | 63 | ;        } | 
|---|
|  | 64 | ;        ZBT | 
|---|
|  | 65 | ;       } | 
|---|
|  | 66 | ;       BTS | 
|---|
|  | 67 | ; | 
|---|
|  | 68 | S IVMORF=1 ; set ORF msg flag | 
|---|
|  | 69 | S (HLEVN,IVMCT,IVMERROR,IVMCNTR)=0 ; init vars | 
|---|
|  | 70 | ; | 
|---|
|  | 71 | ORU ; Entry point for receipt of ORU~Z10 trans (called by IVMPREC2) | 
|---|
|  | 72 | S IVMTYPE=5,IVMZ10F=1 | 
|---|
|  | 73 | ; | 
|---|
|  | 74 | ; - loop through the msg in (#772 file), and process (PROC) msgs | 
|---|
|  | 75 | S IVMDA=0 F  S IVMDA=$O(^TMP($J,IVMRTN,IVMDA)) Q:'IVMDA  S IVMSEG=$G(^(IVMDA,0)) I $E(IVMSEG,1,3)="MSH" D PROC Q:'IVMDA | 
|---|
|  | 76 | ; | 
|---|
|  | 77 | ; - if ORF msg flag, update the Query Tran Log and send ACK | 
|---|
|  | 78 | I $G(IVMORF) D | 
|---|
|  | 79 | .I $G(DFN),$D(IVMMCI) D | 
|---|
|  | 80 | ..N IVMCR | 
|---|
|  | 81 | ..S IVMCR=$P("1^2^3^7^5^6^4","^",IVMTYPE)  ;map reason to test type | 
|---|
|  | 82 | ..D FIND^IVMCQ2(DFN,IVMMCI,HLDT,$S($D(HLERR):5,1:IVMCR),1) | 
|---|
|  | 83 | .;D ACK^IVMPREC:'$D(HLERR) | 
|---|
|  | 84 | .;N HLRESLTA,HLP | 
|---|
|  | 85 | .;D GENACK^HLMA1(HLEID,HLMTIEN,HLEIDS,"LM",1,.HLRESLTA,"",.HLP) | 
|---|
|  | 86 | ; | 
|---|
|  | 87 | ; - if tests are uploaded, generate notification msg | 
|---|
|  | 88 | I $D(^TMP($J,"IVMBULL")) D ^IVMCMB | 
|---|
|  | 89 | ; | 
|---|
|  | 90 | ENQ ; | 
|---|
|  | 91 | K IVMDA,IVMORF,IVMSEG,IVMFLGC,IVMTYPE,IVMMTIEN,IVMMTDT,IVMDGBT,IVMMCI | 
|---|
|  | 92 | K ^TMP($J,"IVMCM"),^("IVMBULL"),DGMSGF,DGADDF,IVMCPAY,IVMBULL,DFN | 
|---|
|  | 93 | K DGMTMSG,IVMZ10F | 
|---|
|  | 94 | Q | 
|---|
|  | 95 | ; | 
|---|
|  | 96 | PROC ; Process each HL7 message from (#772) file | 
|---|
|  | 97 | ; | 
|---|
|  | 98 | N IVMFUTR,TMSTAMP,SOURCE,NODE,HSDATE,IVMZ10,DGMTP,DGMTACT,DGMTI,DGMTA | 
|---|
|  | 99 | S DGMTACT="ADD" | 
|---|
|  | 100 | D PRIOR^DGMTEVT | 
|---|
|  | 101 | S IVMZ10="UPLOAD IN PROGRESS" | 
|---|
|  | 102 | S IVMFUTR=0 ;this flag will indicate whether or not a test with a future date is being uploaded | 
|---|
|  | 103 | S IVMMTIEN=0 | 
|---|
|  | 104 | ; | 
|---|
|  | 105 | S MSGID=$P(IVMSEG,HLFS,10) ; msg control id for ACK's | 
|---|
|  | 106 | ; - check if DCD messaging is enabled | 
|---|
|  | 107 | I '$$DCDON^IVMUPAR1() D PROB^IVMCMC("Facility has DCD messaging disabled") Q | 
|---|
|  | 108 | ; | 
|---|
|  | 109 | ; - check HL7 msg structure for errors | 
|---|
|  | 110 | K HLERR,^TMP($J,"IVMCM") | 
|---|
|  | 111 | D ^IVMCMC I $D(HLERR) K:HLERR="" HLERR Q | 
|---|
|  | 112 | ; | 
|---|
|  | 113 | ; Determine type of test/transmission | 
|---|
|  | 114 | S IVMTYPE=0 | 
|---|
|  | 115 | ; | 
|---|
|  | 116 | ; - was a means test sent? | 
|---|
|  | 117 | I $P($G(^TMP($J,"IVMCM","ZMT1")),HLFS,2) S IVMTYPE=1 ; MT trans | 
|---|
|  | 118 | ; | 
|---|
|  | 119 | ; - if MT and CT transmitted, error - pt can't have both unless | 
|---|
|  | 120 | ;   one is a deletion, but HEC not currently handling that situation | 
|---|
|  | 121 | I IVMTYPE,$P($G(^TMP($J,"IVMCM","ZMT2")),HLFS,2) D PROB^IVMCMC("Patient  can not have both a Means Test and Copay Test") Q | 
|---|
|  | 122 | I $P($G(^TMP($J,"IVMCM","ZMT2")),HLFS,2) S IVMTYPE=2 ; CT trans | 
|---|
|  | 123 | ; | 
|---|
|  | 124 | ; - if no MT or CT or LTC then Income Screening | 
|---|
|  | 125 | I 'IVMTYPE,'$P($G(^TMP($J,"IVMCM","ZMT4")),HLFS,2) S IVMTYPE=3 ; IS trans | 
|---|
|  | 126 | ; | 
|---|
|  | 127 | ;send an eligibility query if no eligibility code | 
|---|
|  | 128 | I '$$ELIG^IVMCUF1(DFN),'$$PENDING^DGENQRY(DFN) I $$SEND^DGENQRY1(DFN) | 
|---|
|  | 129 | ; | 
|---|
|  | 130 | ; obtain locks used to sychronize upload with local income test options | 
|---|
|  | 131 | D GETLOCKS^IVMCUPL(DFN) | 
|---|
|  | 132 | ; | 
|---|
|  | 133 | ; | 
|---|
|  | 134 | MT ; If transmission is a Means Test | 
|---|
|  | 135 | N NODE0,RET,CODE,DATA | 
|---|
|  | 136 | S HLQ=$G(HL("Q")) | 
|---|
|  | 137 | S:HLQ="" HLQ="""""" | 
|---|
|  | 138 | I IVMTYPE=1 D  I $D(HLERR) G PROCQ | 
|---|
|  | 139 | .S IVMMTDT=$$FMDATE^HLFNC($P($G(^TMP($J,"IVMCM","ZMT1")),HLFS,2)) | 
|---|
|  | 140 | .S TMSTAMP=$$FMDATE^HLFNC($P($G(^TMP($J,"IVMCM","ZMT1")),HLFS,25)) | 
|---|
|  | 141 | .S HSDATE=$$FMDATE^HLFNC($P($G(^TMP($J,"IVMCM","ZMT1")),HLFS,24)) | 
|---|
|  | 142 | .S SOURCE=$P($G(^TMP($J,"IVMCM","ZMT1")),HLFS,22) | 
|---|
|  | 143 | .S IVMLAST=$$LST^DGMTU(DFN,$E(IVMMTDT,1,3)_1231,1) | 
|---|
|  | 144 | .I $$Z06MT^EASPTRN1(+IVMLAST) Q | 
|---|
|  | 145 | .I '$$ELIG^IVMUFNC5(DFN) S ERRMSG="Means Test upload not appropriate for current patient" | 
|---|
|  | 146 | .I $$AGE^IVMUFNC5(DT)>$$INCY^IVMUFNC5(IVMMTDT) D | 
|---|
|  | 147 | ..N CATCZMT S CATCZMT=$G(^TMP($J,"IVMCM","ZMT1")) | 
|---|
|  | 148 | ..S CATC=$$CATC^IVMUFNC5(CATCZMT) | 
|---|
|  | 149 | ..I '+$G(CATC) S ERRMSG="Only Means Tests in current/previous income years are valid (not effective)" | 
|---|
|  | 150 | .I $G(ERRMSG)'="" D PROB^IVMCMC(ERRMSG) K ERRMSG,CATC Q | 
|---|
|  | 151 | .; | 
|---|
|  | 152 | .; - perform edit checks and file MT | 
|---|
|  | 153 | .D CHKDT | 
|---|
|  | 154 | .;deletion indicator sent? | 
|---|
|  | 155 | .I $P($G(^TMP($J,"IVMCM","ZMT1")),HLFS,3)=HLQ D  Q | 
|---|
|  | 156 | ..D | 
|---|
|  | 157 | ...;if there is a future test for that income year, delete that | 
|---|
|  | 158 | ...N IEN,DATA,IVMPAT | 
|---|
|  | 159 | ...S IEN=$$FUTURE(DFN,($E(IVMMTDT,1,3)-1),1,.IVMPAT) | 
|---|
|  | 160 | ...I IEN S DATA(.06)="" I $$UPD^DGENDBS(301.5,IVMPAT,.DATA) | 
|---|
|  | 161 | ...I IEN,$D(^DGMT(408.31,IEN,0)) D | 
|---|
|  | 162 | ....S IVMMTIEN=IEN | 
|---|
|  | 163 | ....S IVMFUTR=1 | 
|---|
|  | 164 | ...E  D | 
|---|
|  | 165 | ....S IVMFUTR=0 | 
|---|
|  | 166 | ..Q:('IVMMTIEN) | 
|---|
|  | 167 | ..S NODE0=$G(^DGMT(408.31,IVMMTIEN,0)) | 
|---|
|  | 168 | ..I $$EN^IVMCMD(IVMMTIEN) D | 
|---|
|  | 169 | ...S RET=$$LST^DGMTU(DFN,DT,IVMTYPE) | 
|---|
|  | 170 | ...S CODE=$S(($E($P(RET,"^",2),1,3)=$E(DT,1,3)):$P(RET,"^",4),1:"") | 
|---|
|  | 171 | ...D ADD^IVMCMB(DFN,IVMTYPE,$S(IVMFUTR:"DELETE FUTR TEST",1:"DELETE PRMRY TEST"),+$G(NODE0),$$GETCODE^DGMTH($P(NODE0,"^",3)),CODE) | 
|---|
|  | 172 | .; | 
|---|
|  | 173 | .;check timestamp - if matches current primary test and hardship matches, then this is a duplicate and does not need to be uploaded | 
|---|
|  | 174 | .I TMSTAMP D | 
|---|
|  | 175 | ..S NODE="" | 
|---|
|  | 176 | ..I IVMFUTR N IVMMTIEN S IVMMTIEN=$$FUTURE(DFN,($E(IVMMTDT,1,3)-1),1) | 
|---|
|  | 177 | ..Q:'IVMMTIEN | 
|---|
|  | 178 | ..S NODE=$G(^DGMT(408.31,IVMMTIEN,2)) | 
|---|
|  | 179 | .S NODE0=$G(^DGMT(408.31,IVMMTIEN,0)) | 
|---|
|  | 180 | .I TMSTAMP,TMSTAMP=$P(NODE,"^",2),IVMMTDT=$P(NODE0,"^"),SOURCE=$P(NODE,"^",5),(HSDATE=$P(NODE,"^")) Q | 
|---|
|  | 181 | .; | 
|---|
|  | 182 | .D DELTYPE^IVMCMD(DFN,IVMMTDT,2) | 
|---|
|  | 183 | .D EN^IVMCM1 | 
|---|
|  | 184 | ; | 
|---|
|  | 185 | ; | 
|---|
|  | 186 | CT ; If transmission is a Copay Test | 
|---|
|  | 187 | N NODE0,RET,CODE,DATA | 
|---|
|  | 188 | I IVMTYPE=2 D  I $D(HLERR) G PROCQ | 
|---|
|  | 189 | .S IVMMTDT=$$FMDATE^HLFNC($P($G(^TMP($J,"IVMCM","ZMT2")),HLFS,2)) | 
|---|
|  | 190 | .S TMSTAMP=$$FMDATE^HLFNC($P($G(^TMP($J,"IVMCM","ZMT2")),HLFS,25)) | 
|---|
|  | 191 | .S SOURCE=$P($G(^TMP($J,"IVMCM","ZMT2")),HLFS,22) | 
|---|
|  | 192 | .S IVMLAST=$$LST^DGMTU(DFN,$E(IVMMTDT,1,3)_1231,2) | 
|---|
|  | 193 | .S IVMCPAY=$$RXST^IBARXEU(DFN) | 
|---|
|  | 194 | .I $$AGE^IVMUFNC5(DT)>$$INCY^IVMUFNC5(IVMMTDT) D PROB^IVMCMC("Only Copay Tests in the current/previous income years are valid. (Not effective)") Q | 
|---|
|  | 195 | .; - perform edit checks and file CT | 
|---|
|  | 196 | .D CHKDT | 
|---|
|  | 197 | .;deletion indicator sent? | 
|---|
|  | 198 | .I $P($G(^TMP($J,"IVMCM","ZMT2")),HLFS,3)=HLQ D  Q | 
|---|
|  | 199 | ..D | 
|---|
|  | 200 | ...;if there is a future test for that income year, delete that | 
|---|
|  | 201 | ...N IEN,DATA,IVMPAT | 
|---|
|  | 202 | ...S IEN=$$FUTURE(DFN,($E(IVMMTDT,1,3)-1),2,.IVMPAT) | 
|---|
|  | 203 | ...I IEN S DATA(.07)="" I $$UPD^DGENDBS(301.5,IVMPAT,.DATA) | 
|---|
|  | 204 | ...I IEN,$D(^DGMT(408.31,IEN,0)) D | 
|---|
|  | 205 | ....S IVMMTIEN=IEN | 
|---|
|  | 206 | ....S IVMFUTR=1 | 
|---|
|  | 207 | ...E  D | 
|---|
|  | 208 | ....S IVMFUTR=0 | 
|---|
|  | 209 | ..Q:('IVMMTIEN) | 
|---|
|  | 210 | ..S NODE0=$G(^DGMT(408.31,IVMMTIEN,0)) | 
|---|
|  | 211 | ..I $$EN^IVMCMD(IVMMTIEN) D | 
|---|
|  | 212 | ...S RET=$$LST^DGMTU(DFN,DT,IVMTYPE) | 
|---|
|  | 213 | ...S CODE=$S(($E($P(RET,"^",2),1,3)=$E(DT,1,3)):$P(RET,"^",4),1:"") | 
|---|
|  | 214 | ...D ADD^IVMCMB(DFN,IVMTYPE,$S(IVMFUTR:"DELETE FUTR TEST",1:"DELETE PRMRY TEST"),+$G(NODE0),$$GETCODE^DGMTH($P(NODE0,"^",3)),CODE) | 
|---|
|  | 215 | .; | 
|---|
|  | 216 | .;check timestamp - if matches current primary test, then this is a duplicate and does not need to be uploaded | 
|---|
|  | 217 | .I TMSTAMP D | 
|---|
|  | 218 | ..S NODE="" | 
|---|
|  | 219 | ..I IVMFUTR N IVMMTIEN S IVMMTIEN=$$FUTURE(DFN,($E(IVMMTDT,1,3)-1),2) | 
|---|
|  | 220 | ..Q:'IVMMTIEN | 
|---|
|  | 221 | ..S NODE=$G(^DGMT(408.31,IVMMTIEN,2)) | 
|---|
|  | 222 | .S NODE0=$G(^DGMT(408.31,IVMMTIEN,0)) | 
|---|
|  | 223 | .I TMSTAMP,TMSTAMP=$P(NODE,"^",2),IVMMTDT=$P(NODE0,"^"),SOURCE=$P(NODE,"^",5) Q | 
|---|
|  | 224 | .; | 
|---|
|  | 225 | .D DELTYPE^IVMCMD(DFN,IVMMTDT,1) | 
|---|
|  | 226 | .D EN^IVMCM1 | 
|---|
|  | 227 | ; | 
|---|
|  | 228 | IS ; - If transmission is income screening info only then do not process | 
|---|
|  | 229 | ; - outside of the scope of MTS | 
|---|
|  | 230 | ;I IVMTYPE=3 S IVMMTDT=0 D EN^IVMCM1 I $D(HLERR) G PROCQ | 
|---|
|  | 231 | I IVMTYPE=3 S IVMMTDT=0 | 
|---|
|  | 232 | ; | 
|---|
|  | 233 | LTC ; If transmission contains a Long Term Care Test (TYPE 4 TEST) | 
|---|
|  | 234 | I $P($G(^TMP($J,"IVMCM","ZMT4")),HLFS,2) D LTC^IVMCM1 | 
|---|
|  | 235 | ; | 
|---|
|  | 236 | PROCQ ; | 
|---|
|  | 237 | ; release locks used to sychronize upload with local income test options | 
|---|
|  | 238 | D RELLOCKS^IVMCUPL(DFN) | 
|---|
|  | 239 | Q | 
|---|
|  | 240 | ; | 
|---|
|  | 241 | CHKDT ; check date of income test being uploaded | 
|---|
|  | 242 | ; Is it a future date?  If so, set IVMFUTR=1 | 
|---|
|  | 243 | ; | 
|---|
|  | 244 | ; IVMMTIEN is the IEN of current primary test for the year | 
|---|
|  | 245 | ; | 
|---|
|  | 246 | I $E($P(IVMLAST,"^",2),1,3)=$E(IVMMTDT,1,3) S IVMMTIEN=+IVMLAST | 
|---|
|  | 247 | I IVMMTDT>DT S IVMFUTR=1 | 
|---|
|  | 248 | Q | 
|---|
|  | 249 | FUTURE(DFN,YEAR,TYPE,IVMPAT) ; | 
|---|
|  | 250 | ;Returns the ien of the future test, if there is one | 
|---|
|  | 251 | ;Inputs:  DFN | 
|---|
|  | 252 | ;         YEAR  - income year | 
|---|
|  | 253 | ;         TYPE - type of test | 
|---|
|  | 254 | ;Output: | 
|---|
|  | 255 | ;  function value - ien of future means test, if there is one, "" otherwise | 
|---|
|  | 256 | ;  IVMPAT - Pointer to the IVM Patient file for the income year if there is an entry (pass by reference) | 
|---|
|  | 257 | ; | 
|---|
|  | 258 | N RET | 
|---|
|  | 259 | S RET="" | 
|---|
|  | 260 | S IVMPAT=$$FIND^IVMPLOG(DFN,YEAR) | 
|---|
|  | 261 | I IVMPAT S RET=$P($G(^IVM(301.5,IVMPAT,0)),"^",$S(TYPE=1:6,1:7)) | 
|---|
|  | 262 | Q RET | 
|---|