| 1 | BPSECMP2 ;BHAM ISC/FCS/DRS - Parse Claim Response ;06/15/2004
 | 
|---|
| 2 |  ;;1.0;E CLAIMS MGMT ENGINE;**1,5**;JUN 2004;Build 45
 | 
|---|
| 3 |  ;;Per VHA Directive 2004-038, this routine should not be modified.
 | 
|---|
| 4 |  ;Reference to STORESP^IBNCPDP supported by DBIA 4299
 | 
|---|
| 5 |  Q
 | 
|---|
| 6 |  ; Parameters:
 | 
|---|
| 7 |  ;    CLAIMIEN: IEN from BPS Claims
 | 
|---|
| 8 |  ;    RESPIEN:  IEN from BPS Response
 | 
|---|
| 9 |  ;    EVENT:    This is used by PSO to create specific events (BILL).
 | 
|---|
| 10 |  ;    USER:     User who is creating the event.  This is required when EVENT is sent.
 | 
|---|
| 11 | IBSEND(CLAIMIEN,RESPIEN,EVENT,USER) ;
 | 
|---|
| 12 |  N BPSARRY,RXIEN,FILLNUM,IND,TRNDX,RELDATE,X,Y,%DT
 | 
|---|
| 13 |  N CLAIMNFO,RESPNFO,RXINFO,RFINFO,TRANINFO
 | 
|---|
| 14 |  N RESPONSE,RXACT,CLREAS,BILLNUM,DFN,REQCLAIM
 | 
|---|
| 15 |  N DIE,DA,DR
 | 
|---|
| 16 |  ;
 | 
|---|
| 17 |  ; Quit if there is not a Response or Claim IEN
 | 
|---|
| 18 |  I '$G(RESPIEN) Q
 | 
|---|
| 19 |  I '$G(CLAIMIEN) Q
 | 
|---|
| 20 |  ;
 | 
|---|
| 21 |  ; Get Claims and Response Data
 | 
|---|
| 22 |  D GETS^DIQ("9002313.02",CLAIMIEN,"103;400*;401;402;403;426","","CLAIMNFO")
 | 
|---|
| 23 |  D GETS^DIQ("9002313.0301","1,"_RESPIEN,"112;503;509","I","RESPNFO")
 | 
|---|
| 24 |  ;
 | 
|---|
| 25 |  ; Get the Transaction IEN and Data
 | 
|---|
| 26 |  S IND=$S(CLAIMNFO("9002313.02",CLAIMIEN_",","103")="B2":"AER",1:"AE")
 | 
|---|
| 27 |  S TRNDX=$O(^BPST(IND,CLAIMIEN,""))
 | 
|---|
| 28 |  I TRNDX="" Q
 | 
|---|
| 29 |  D GETS^DIQ("9002313.59",TRNDX,"3;13;404;501;1201","I","TRANINFO")
 | 
|---|
| 30 |  ;
 | 
|---|
| 31 |  ; Determine Prescription IEN
 | 
|---|
| 32 |  S RXIEN=$P(^BPSC(CLAIMIEN,400,1,0),"^",5)
 | 
|---|
| 33 |  ;
 | 
|---|
| 34 |  ; If Certify Mode is On, don't send to IB
 | 
|---|
| 35 |  I $$GET1^DIQ(9002313.59902,"1,"_TRNDX_",","902.22")["MODE ON" Q
 | 
|---|
| 36 |  ;
 | 
|---|
| 37 |  ; Testing for Certification Only - DLF
 | 
|---|
| 38 |  I $$RXAPI1^BPSUTIL1(RXIEN,.01)="" Q
 | 
|---|
| 39 |  ;
 | 
|---|
| 40 |  ; Store RXACT into a local variable as it is will be used a lot
 | 
|---|
| 41 |  S RXACT=TRANINFO("9002313.59",TRNDX_",",1201,"I")
 | 
|---|
| 42 |  ;
 | 
|---|
| 43 |  ; Setup User data
 | 
|---|
| 44 |  ; If event is passed in, the user should be passed in as well
 | 
|---|
| 45 |  ; If no Event, but action is Auto-Reversal (AREV) or CMOP (CR*/PC/RL),
 | 
|---|
| 46 |  ;     user postmaster (.5)
 | 
|---|
| 47 |  ; Else use the user from BPS Transaction
 | 
|---|
| 48 |  I EVENT]"" S BPSARRY("USER")=USER
 | 
|---|
| 49 |  E  I ",AREV,CRLB,CRLX,CRLR,PC,RL,"[(","_RXACT_",") S BPSARRY("USER")=.5
 | 
|---|
| 50 |  E  S BPSARRY("USER")=TRANINFO("9002313.59",TRNDX_",",13,"I")
 | 
|---|
| 51 |  ;
 | 
|---|
| 52 |  ; Determine Payer Response
 | 
|---|
| 53 |  ; Treat Duplicate of Accepted Reversal ("S") as accepted
 | 
|---|
| 54 |  S RESPONSE=RESPNFO(9002313.0301,"1,"_RESPIEN_",",112,"I")
 | 
|---|
| 55 |  S RESPONSE=$S(RESPONSE="A":"ACCEPTED",RESPONSE="C":"CAPTURED",RESPONSE="D":"DUPLICATE",RESPONSE="P":"PAYABLE",RESPONSE="R":"REJECTED",RESPONSE="S":"ACCEPTED",1:"OTHER")
 | 
|---|
| 56 |  ;
 | 
|---|
| 57 |  ; Get Prescription Information
 | 
|---|
| 58 |  D RXAPI^BPSUTIL1(RXIEN,".01;4;6;8;16;27","RXINFO","IE")
 | 
|---|
| 59 |  ;
 | 
|---|
| 60 |  ; Get Refill Info if this is a refill
 | 
|---|
| 61 |  S FILLNUM=+$E($P(TRNDX,".",2),1,4)
 | 
|---|
| 62 |  I FILLNUM>0 D RXSUBF^BPSUTIL1(RXIEN,52,52.1,FILLNUM,".01;1.1;11","RFINFO","E")
 | 
|---|
| 63 |  ;
 | 
|---|
| 64 |  ; Fill Date
 | 
|---|
| 65 |  S BPSARRY("FILL DATE")=CLAIMNFO("9002313.0201","1,"_CLAIMIEN_",","401")
 | 
|---|
| 66 |  S %DT="X",X=BPSARRY("FILL DATE") D ^%DT S:Y'=-1 BPSARRY("FILL DATE")=Y
 | 
|---|
| 67 |  ;
 | 
|---|
| 68 |  ; Information needed for PAID/BILLING event
 | 
|---|
| 69 |  S BPSARRY("PAID")=0
 | 
|---|
| 70 |  I RESPONSE="PAYABLE" D
 | 
|---|
| 71 |  . S BPSARRY("PAID")=$$DFF2EXT^BPSECFM(RESPNFO(9002313.0301,"1,"_RESPIEN_",",509,"I"))
 | 
|---|
| 72 |  . S BPSARRY("AUTH #")=RESPNFO(9002313.0301,"1,"_RESPIEN_",",503,"I")
 | 
|---|
| 73 |  . S BPSARRY("RX NO")=RXINFO(52,RXIEN,.01,"E")
 | 
|---|
| 74 |  . S BPSARRY("DRUG")=$$RXAPI1^BPSUTIL1(RXIEN,6,"I")
 | 
|---|
| 75 |  . S BPSARRY("QTY")=$G(TRANINFO(9002313.59,TRNDX_",",501,"I"))
 | 
|---|
| 76 |  . I FILLNUM<1  D
 | 
|---|
| 77 |  .. S BPSARRY("DAYS SUPPLY")=RXINFO(52,RXIEN,8,"E")
 | 
|---|
| 78 |  . E  D
 | 
|---|
| 79 |  .. S BPSARRY("DAYS SUPPLY")=$G(RFINFO(52.1,FILLNUM,1.1,"E"))
 | 
|---|
| 80 |  ;
 | 
|---|
| 81 |  ; Get Plan info
 | 
|---|
| 82 |  I $D(^BPST(TRNDX,10,1,0)) S BPSARRY("PLAN")=$P(^BPST(TRNDX,10,1,0),"^")
 | 
|---|
| 83 |  ;
 | 
|---|
| 84 |  ; Setup miscellaneous values
 | 
|---|
| 85 |  S DFN=$$RXAPI1^BPSUTIL1(RXIEN,2,"I")
 | 
|---|
| 86 |  S BPSARRY("NDC")=$$GETNDC^PSONDCUT(RXIEN,FILLNUM)
 | 
|---|
| 87 |  S BPSARRY("FILL NUMBER")=FILLNUM
 | 
|---|
| 88 |  S BPSARRY("FILLED BY")=RXINFO(52,RXIEN,16,"I")
 | 
|---|
| 89 |  S BPSARRY("PRESCRIPTION")=RXIEN
 | 
|---|
| 90 |  S BPSARRY("BILLED")=$P(CLAIMNFO("9002313.0201","1,"_CLAIMIEN_",","426"),"DQ",2)
 | 
|---|
| 91 |  S BPSARRY("BILLED")=$$DFF2EXT^BPSECFM(BPSARRY("BILLED"))
 | 
|---|
| 92 |  S BPSARRY("CLAIMID")=$P(CLAIMNFO("9002313.0201","1,"_CLAIMIEN_",","402"),"D2",2)
 | 
|---|
| 93 |  S RELDATE=$S(FILLNUM=0:$$RXAPI1^BPSUTIL1(RXIEN,31,"I"),1:$$RXSUBF1^BPSUTIL1(RXIEN,52,52.1,FILLNUM,17,"I"))
 | 
|---|
| 94 |  S BPSARRY("RELEASE DATE")=$P(RELDATE,".")
 | 
|---|
| 95 |  S BPSARRY("RESPONSE")=RESPONSE
 | 
|---|
| 96 |  S BPSARRY("EPHARM")=$$GET1^DIQ(9002313.59,TRNDX,1.07,"I")
 | 
|---|
| 97 |  ;
 | 
|---|
| 98 |  ; For reversals, get reversal reason and check for closed reason
 | 
|---|
| 99 |  ; Call IB with Reversal Event
 | 
|---|
| 100 |  ; If there is a close reason, call IB with CLOSE event
 | 
|---|
| 101 |  ;    and update BPS Claim with close information
 | 
|---|
| 102 |  I EVENT="",$$ISREVERS^BPSOSU(CLAIMIEN) D  Q
 | 
|---|
| 103 |  . S REQCLAIM=TRANINFO("9002313.59",TRNDX_",",3,"I")
 | 
|---|
| 104 |  . S BPSARRY("REVERSAL REASON")=TRANINFO("9002313.59",TRNDX_",",404,"I")
 | 
|---|
| 105 |  . S BPSARRY("RTS-DEL")=0
 | 
|---|
| 106 |  . ; Get RX action, which determine close event
 | 
|---|
| 107 |  . I RXACT="RS" S CLREAS="PRESCRIPTION NOT RELEASED",BPSARRY("RTS-DEL")=1
 | 
|---|
| 108 |  . I RXACT="DE" D
 | 
|---|
| 109 |  . . S CLREAS="PRESCRIPTION DELETED",BPSARRY("RTS-DEL")=1
 | 
|---|
| 110 |  . . ; check whether RX was in fact deleted in Pharmacy
 | 
|---|
| 111 |  . . ; if not then the refill was deleted
 | 
|---|
| 112 |  . . I $$RXSTATUS^BPSSCRU2(RXIEN)'=13 S BPSARRY("CLOSE COMMENT")="DELETION OF REFILL ONLY - ORIGINAL RX MAY REMAIN ACTIVE"
 | 
|---|
| 113 |  . ; If accepted inpatient autoreversal, then close the claim
 | 
|---|
| 114 |  . I RXACT="AREV",RESPONSE="ACCEPTED",REQCLAIM,$P($G(^BPSC(REQCLAIM,0)),U,7)=2 D
 | 
|---|
| 115 |  .. S CLREAS="OTHER",BPSARRY("CLOSE COMMENT")="INPATIENT PRESCRIPTION"
 | 
|---|
| 116 |  . I $D(CLREAS) S BPSARRY("CLOSE REASON")=$O(^IBE(356.8,"B",CLREAS,0))
 | 
|---|
| 117 |  . ;
 | 
|---|
| 118 |  . ; Call IB for Reversal Event
 | 
|---|
| 119 |  . S BPSARRY("STATUS")="REVERSED",BILLNUM=$$STORESP^IBNCPDP(DFN,.BPSARRY)
 | 
|---|
| 120 |  . ; If there is no close reason, quit
 | 
|---|
| 121 |  . I '$D(BPSARRY("CLOSE REASON")) Q
 | 
|---|
| 122 |  . ; Call IB for CLOSE event
 | 
|---|
| 123 |  . ;  Note for close, user is always postmaster (.5)
 | 
|---|
| 124 |  . S BPSARRY("STATUS")="CLOSED",BPSARRY("USER")=.5
 | 
|---|
| 125 |  . S BILLNUM=$$STORESP^IBNCPDP(DFN,.BPSARRY)
 | 
|---|
| 126 |  . ;
 | 
|---|
| 127 |  . ; Populate the original claim request with the close reason
 | 
|---|
| 128 |  . I REQCLAIM D
 | 
|---|
| 129 |  .. S DIE="^BPSC(",DA=REQCLAIM
 | 
|---|
| 130 |  .. S DR="901///1;902///"_$$NOW^XLFDT()_";903///.5;904///"_BPSARRY("CLOSE REASON")
 | 
|---|
| 131 |  .. D ^DIE
 | 
|---|
| 132 |  ; 
 | 
|---|
| 133 |  ; If we got here, then it is not a reversal
 | 
|---|
| 134 |  ; If EVENT is set, send Submit event
 | 
|---|
| 135 |  I EVENT="" S BPSARRY("STATUS")="SUBMITTED",BILLNUM=$$STORESP^IBNCPDP(DFN,.BPSARRY)
 | 
|---|
| 136 |  ;
 | 
|---|
| 137 |  ; Sent Paid (Billable) event is the claim was paid and released or EVENT is BILL
 | 
|---|
| 138 |  ;   Note: User is always postmaster except for BackBilling (BB)
 | 
|---|
| 139 |  I EVENT="BILL"!(RESPONSE="PAYABLE"&(BPSARRY("RELEASE DATE")]"")) D
 | 
|---|
| 140 |  . I RXACT'="BB" S BPSARRY("USER")=.5
 | 
|---|
| 141 |  . S BPSARRY("STATUS")="PAID",BILLNUM=$$STORESP^IBNCPDP(DFN,.BPSARRY)
 | 
|---|
| 142 |  Q
 | 
|---|
| 143 |  ;
 | 
|---|
| 144 |  ; Synch DURs between ECME and PSO
 | 
|---|
| 145 |  ; Parameters:
 | 
|---|
| 146 |  ;   IEN59 is the BPS Transaction IEN
 | 
|---|
| 147 | DURSYNC(IEN59) ;
 | 
|---|
| 148 |  N RXIEN,RXFILL
 | 
|---|
| 149 |  ;
 | 
|---|
| 150 |  ; Check Parameter
 | 
|---|
| 151 |  I IEN59="" Q
 | 
|---|
| 152 |  ;
 | 
|---|
| 153 |  ; Get Prescription and Fill number
 | 
|---|
| 154 |  S RXIEN=$$GET1^DIQ(9002313.59,IEN59_",",1.11,"I")
 | 
|---|
| 155 |  S RXFILL=$$GET1^DIQ(9002313.59902,"1,"_IEN59_",",902.17,"E")
 | 
|---|
| 156 |  I RXIEN=""!(RXFILL="") Q
 | 
|---|
| 157 |  ;
 | 
|---|
| 158 |  ; Call PSO to sync reject codes
 | 
|---|
| 159 |  D SYNC^PSOREJUT(RXIEN,RXFILL,"")
 | 
|---|
| 160 |  Q
 | 
|---|
| 161 |  ;
 | 
|---|
| 162 | PROCOTH ;
 | 
|---|
| 163 |  Q:$G(FDATA(TRANSACT,563.01,1))=""
 | 
|---|
| 164 |  N NNDX,FILE,ROOT,FDATA3,FLDNUM
 | 
|---|
| 165 |  S FILE="9002313.1401"
 | 
|---|
| 166 |  S ROOT="FDATA3(9002313.1401)"
 | 
|---|
| 167 |  S NNDX=""
 | 
|---|
| 168 |  F  S NNDX=$O(FDATA(FDAIEN(TRANSACT),563.01,NNDX)) Q:NNDX=""  D
 | 
|---|
| 169 |  .S FLDNUM=".01" D FDA^DILF(FILE,"+"_NNDX_","_FDAIEN03(TRANSACT)_","_FDAIEN(TRANSACT),FLDNUM,"",FDATA(TRANSACT,563.01,NNDX),ROOT)
 | 
|---|
| 170 |  D UPDATE^DIE("S","FDATA3(9002313.1401)")
 | 
|---|
| 171 |  Q
 | 
|---|
| 172 | PROCDUR ;
 | 
|---|
| 173 |  Q:$G(FDATA(TRANSACT,567,1))=""
 | 
|---|
| 174 |  N NNDX,FILE,ROOT,FDAT1101,FLDNUM
 | 
|---|
| 175 |  S FILE="9002313.1101"
 | 
|---|
| 176 |  S ROOT="FDAT1101(9002313.1101)"
 | 
|---|
| 177 |  S NNDX=""
 | 
|---|
| 178 |  F  S NNDX=$O(FDATA(TRANSACT,567,NNDX)) Q:NNDX=""  D
 | 
|---|
| 179 |  .S FLDNUM=".01" D FDA^DILF(FILE,"+"_NNDX_","_FDAIEN03(TRANSACT)_","_FDAIEN(TRANSACT),FLDNUM,"",FDATA(TRANSACT,567,NNDX),ROOT)
 | 
|---|
| 180 |  .I $D(FDATA(TRANSACT,439,NNDX))  D
 | 
|---|
| 181 |  ..S FLDNUM="439"
 | 
|---|
| 182 |  ..D FDA^DILF(FILE,"+"_NNDX_","_FDAIEN03(TRANSACT)_","_FDAIEN(TRANSACT),FLDNUM,"",FDATA(TRANSACT,439,NNDX),ROOT)
 | 
|---|
| 183 |  .I $D(FDATA(TRANSACT,528,NNDX))  D
 | 
|---|
| 184 |  ..S FLDNUM="528"
 | 
|---|
| 185 |  ..D FDA^DILF(FILE,"+"_NNDX_","_FDAIEN03(TRANSACT)_","_FDAIEN(TRANSACT),FLDNUM,"",FDATA(TRANSACT,528,NNDX),ROOT)
 | 
|---|
| 186 |  .I $D(FDATA(TRANSACT,529,NNDX))  D
 | 
|---|
| 187 |  ..S FLDNUM="529"
 | 
|---|
| 188 |  ..D FDA^DILF(FILE,"+"_NNDX_","_FDAIEN03(TRANSACT)_","_FDAIEN(TRANSACT),FLDNUM,"",FDATA(TRANSACT,529,NNDX),ROOT)
 | 
|---|
| 189 |  .I $D(FDATA(TRANSACT,530,NNDX))  D
 | 
|---|
| 190 |  ..S FLDNUM="530"
 | 
|---|
| 191 |  ..D FDA^DILF(FILE,"+"_NNDX_","_FDAIEN03(TRANSACT)_","_FDAIEN(TRANSACT),FLDNUM,"",FDATA(TRANSACT,530,NNDX),ROOT)
 | 
|---|
| 192 |  .I $D(FDATA(TRANSACT,531,NNDX))  D
 | 
|---|
| 193 |  ..S FLDNUM="531"
 | 
|---|
| 194 |  ..D FDA^DILF(FILE,"+"_NNDX_","_FDAIEN03(TRANSACT)_","_FDAIEN(TRANSACT),FLDNUM,"",FDATA(TRANSACT,531,NNDX),ROOT)
 | 
|---|
| 195 |  .I $D(FDATA(TRANSACT,532,NNDX))  D
 | 
|---|
| 196 |  ..S FLDNUM="532"
 | 
|---|
| 197 |  ..D FDA^DILF(FILE,"+"_NNDX_","_FDAIEN03(TRANSACT)_","_FDAIEN(TRANSACT),FLDNUM,"",FDATA(TRANSACT,532,NNDX),ROOT)
 | 
|---|
| 198 |  .I $D(FDATA(TRANSACT,533,NNDX))  D
 | 
|---|
| 199 |  ..S FLDNUM="533"
 | 
|---|
| 200 |  ..D FDA^DILF(FILE,"+"_NNDX_","_FDAIEN03(TRANSACT)_","_FDAIEN(TRANSACT),FLDNUM,"",FDATA(TRANSACT,533,NNDX),ROOT)
 | 
|---|
| 201 |  .I $D(FDATA(TRANSACT,544,NNDX)) D
 | 
|---|
| 202 |  ..S FLDNUM="544"
 | 
|---|
| 203 |  ..D FDA^DILF(FILE,"+"_NNDX_","_FDAIEN03(TRANSACT)_","_FDAIEN(TRANSACT),FLDNUM,"",FDATA(TRANSACT,544,NNDX),ROOT)
 | 
|---|
| 204 |  D UPDATE^DIE("S","FDAT1101(9002313.1101)")
 | 
|---|
| 205 |  Q
 | 
|---|