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