| 1 | BPSOSIY ;BHAM ISC/FCS/DRS/DLF - Updating BPS Transaction record ;06/01/2004 | 
|---|
| 2 | ;;1.0;E CLAIMS MGMT ENGINE;**1,3,5**;JUN 2004;Build 45 | 
|---|
| 3 | ;;Per VHA Directive 2004-038, this routine should not be modified. | 
|---|
| 4 | Q | 
|---|
| 5 | ; | 
|---|
| 6 | ; INIT - Update BPS Transaction | 
|---|
| 7 | ; Input | 
|---|
| 8 | ;   IEN59 - BPS Transaction | 
|---|
| 9 | ;   MOREDATA is not passed but assumed to exist | 
|---|
| 10 | ; Returns | 
|---|
| 11 | ;   ERROR - 0 or error number | 
|---|
| 12 | INIT(IEN59) ;EP - from BPSOSIZ | 
|---|
| 13 | ; | 
|---|
| 14 | ; Initialize variables | 
|---|
| 15 | N FDA,MSG,FN,IENS,REC,B1,X1,X2,X3,ERROR,SEQ | 
|---|
| 16 | N RXI,RXR,DIV | 
|---|
| 17 | S FN=9002313.59,REC=IEN59_",",ERROR=0 | 
|---|
| 18 | S RXI=$P(IEN59,".",1),RXR=+$E($P(IEN59,".",2),1,4) | 
|---|
| 19 | I RXI="" Q 11 | 
|---|
| 20 | ; | 
|---|
| 21 | ; Change status to 0% (Waiting to Start), which will reset START TIME, | 
|---|
| 22 | ;   and then to 10% (Building transaction) | 
|---|
| 23 | D SETSTAT^BPSOSU(IEN59,0) | 
|---|
| 24 | D SETSTAT^BPSOSU(IEN59,10) | 
|---|
| 25 | ; | 
|---|
| 26 | ; Get the Outpatient Site | 
|---|
| 27 | S DIV=$$GETDIV^BPSOSQC(RXI,RXR) | 
|---|
| 28 | ; | 
|---|
| 29 | ; If there are Prior Auth or Sub Clar Code override, create override | 
|---|
| 30 | ;   record.  Note that setting of MOREDATA("BPOVRIEN") in this routine | 
|---|
| 31 | ;   will not conflict with prior setting of this value of BPOVRIEN | 
|---|
| 32 | ;   since BPOVRIEN and BPSAUTH/BPSCLARF are mutually exclusive | 
|---|
| 33 | I $G(MOREDATA("BPSAUTH"))]""!($G(MOREDATA("BPSCLARF"))]"") S MOREDATA("BPOVRIEN")=$$OVERRIDE(IEN59) | 
|---|
| 34 | ; | 
|---|
| 35 | ; Set BPSDATA into local variable | 
|---|
| 36 | S B1=$G(MOREDATA("BPSDATA",1)) | 
|---|
| 37 | ; | 
|---|
| 38 | ; Get first record from MOREDATA("IBDATA") as there are some | 
|---|
| 39 | ;   non-multiple fields that need it | 
|---|
| 40 | S X2="",SEQ=$O(MOREDATA("IBDATA","")) | 
|---|
| 41 | I SEQ S X2=$G(MOREDATA("IBDATA",SEQ,2)) | 
|---|
| 42 | ; | 
|---|
| 43 | ; Set non-multiple fields | 
|---|
| 44 | S FDA(FN,REC,1.07)=$$GETPHARM^BPSUTIL(DIV) ;BPS Pharmacy | 
|---|
| 45 | S FDA(FN,REC,1.08)=1   ;PINS piece | 
|---|
| 46 | S FDA(FN,REC,1.11)=RXI ;Prescription | 
|---|
| 47 | I $P($G(^BPST(IEN59,1)),U,12)=1 S FDA(FN,REC,1.12)=2 ;Resubmit after reversal | 
|---|
| 48 | S FDA(FN,REC,1.13)=$G(MOREDATA("BPOVRIEN"))  ;NCPDP Overrides | 
|---|
| 49 | S FDA(FN,REC,5)=$$RXAPI1^BPSUTIL1(RXI,2,"I") ;Patient | 
|---|
| 50 | I '$P($G(^BPST(IEN59,1)),U,12) S FDA(FN,REC,6)=$G(MOREDATA("SUBMIT TIME")) ;Submit Date/Time | 
|---|
| 51 | S FDA(FN,REC,9)=RXR  ;Refill | 
|---|
| 52 | S FDA(FN,REC,10)=$P(B1,U,3)  ;NDC | 
|---|
| 53 | S FDA(FN,REC,11)=DIV ;Outpatient Site | 
|---|
| 54 | S FDA(FN,REC,13)=$G(MOREDATA("USER")) ;User | 
|---|
| 55 | S FDA(FN,REC,501)=$P(B1,U,1) ;Drug Quanity | 
|---|
| 56 | S FDA(FN,REC,502)=$P(B1,U,2) ;Ingredient Cost | 
|---|
| 57 | S FDA(FN,REC,504)=$P(X2,U,1) ;Dispense Fee | 
|---|
| 58 | S FDA(FN,REC,505)=$P(X2,U,3) ;Total Price | 
|---|
| 59 | S FDA(FN,REC,507)=$P(X2,U,5) ;Administrative Fee | 
|---|
| 60 | S FDA(FN,REC,508)=$E($P(B1,U,7),1,2) ;Dispense Unit | 
|---|
| 61 | S FDA(FN,REC,901)=1          ;Current VA Insurer | 
|---|
| 62 | S FDA(FN,REC,1201)=$G(MOREDATA("RX ACTION")) ;RX Action | 
|---|
| 63 | S FDA(FN,REC,1202)=$G(MOREDATA("DATE OF SERVICE")) ;Date of Service | 
|---|
| 64 | ; | 
|---|
| 65 | ; File non-multiple fields - Record is already defined | 
|---|
| 66 | D FILE^DIE("","FDA","MSG") | 
|---|
| 67 | I $D(MSG) D  Q ERROR | 
|---|
| 68 | . S ERROR=12 | 
|---|
| 69 | . D LOG^BPSOSL(IEN59,$T(+0)_"-Non-multiple fields did not file") | 
|---|
| 70 | . D LOG^BPSOSL(IEN59,"MSG Array:") | 
|---|
| 71 | . D LOGARRAY^BPSOSL(IEN59,"MSG") | 
|---|
| 72 | . D LOG^BPSOSL(IEN59,"FDA Array:") | 
|---|
| 73 | . D LOGARRAY^BPSOSL(IEN59,"FDA") | 
|---|
| 74 | ; | 
|---|
| 75 | ; Build Multiple | 
|---|
| 76 | S SEQ="" | 
|---|
| 77 | F  S SEQ=$O(MOREDATA("IBDATA",SEQ)) Q:SEQ=""  D  I ERROR Q | 
|---|
| 78 | . K FDA,MSG,IENS | 
|---|
| 79 | . S FN=9002313.59902,IENS="+1,"_REC,IENS(1)=SEQ | 
|---|
| 80 | . S X1=$G(MOREDATA("IBDATA",SEQ,1)),X2=$G(MOREDATA("IBDATA",SEQ,2)),X3=$G(MOREDATA("IBDATA",SEQ,3)) | 
|---|
| 81 | . ; | 
|---|
| 82 | . ; Update fields | 
|---|
| 83 | . S FDA(FN,IENS,.01)=$P(X1,U,1)    ;Plan ID | 
|---|
| 84 | . S FDA(FN,IENS,902.03)=$P(X1,U,2) ;BIN | 
|---|
| 85 | . S FDA(FN,IENS,902.04)=$P(X1,U,3) ;PCN | 
|---|
| 86 | . S FDA(FN,IENS,902.05)=$P(X1,U,5) ;Group ID | 
|---|
| 87 | . S FDA(FN,IENS,902.06)=$P(X1,U,6) ;Cardholder ID | 
|---|
| 88 | . S FDA(FN,IENS,902.07)=$S(+$P(X1,U,7)>4:4,1:+$P(X1,U,7)) ;Patient Relationship Code | 
|---|
| 89 | . S FDA(FN,IENS,902.08)=$P($P(X1,U,8)," ") ;Cardholder First Name | 
|---|
| 90 | . S FDA(FN,IENS,902.09)=$P(X1,U,9)  ;Cardholder Last Name | 
|---|
| 91 | . S FDA(FN,IENS,902.11)=$P(X1,U,10) ;Home Plan State | 
|---|
| 92 | . S FDA(FN,IENS,902.12)=$P(X2,U,1)  ;Dispense Fee | 
|---|
| 93 | . S FDA(FN,IENS,902.13)=$P(X2,U,2)  ;Basis of Cost Determination | 
|---|
| 94 | . S FDA(FN,IENS,902.14)=$P(X2,U,3)  ;Usual & Customary Charge | 
|---|
| 95 | . S FDA(FN,IENS,902.15)=$P(X2,U,4)  ;Gross Amt Due | 
|---|
| 96 | . S FDA(FN,IENS,902.16)=$P(X2,U,5)  ;Administrative Fee | 
|---|
| 97 | . S FDA(FN,IENS,902.17)=$P(B1,U,4)  ;VA Fill Number | 
|---|
| 98 | . S FDA(FN,IENS,902.18)=$P(X1,U,13) ;Software/Vendor Cert ID | 
|---|
| 99 | . S FDA(FN,IENS,902.22)=$P(B1,U,5)  ;Certify Mode | 
|---|
| 100 | . S FDA(FN,IENS,902.23)=$P(B1,U,6)  ;Certification IEN | 
|---|
| 101 | . S FDA(FN,IENS,902.24)=$P(X1,U,14) ;Plan Name | 
|---|
| 102 | . S FDA(FN,IENS,902.25)=$P(X3,U,1)  ;Group Name | 
|---|
| 103 | . S FDA(FN,IENS,902.26)=$P(X3,U,2)  ;Insurance Co Phone # | 
|---|
| 104 | . S FDA(FN,IENS,902.27)=$P(X3,U,3)  ;Pharmacy Plan ID | 
|---|
| 105 | . ; | 
|---|
| 106 | . ; File the data | 
|---|
| 107 | . D UPDATE^DIE("","FDA","IENS","MSG") | 
|---|
| 108 | . I $D(MSG) D | 
|---|
| 109 | .. S ERROR=13 | 
|---|
| 110 | .. D LOG^BPSOSL(IEN59,$T(+0)_"-Multiple fields did not file, SEQ="_SEQ) | 
|---|
| 111 | .. D LOG^BPSOSL(IEN59,"MSG Array:") | 
|---|
| 112 | .. D LOGARRAY^BPSOSL(IEN59,"MSG") | 
|---|
| 113 | .. D LOG^BPSOSL(IEN59,"IENS Array:") | 
|---|
| 114 | .. D LOGARRAY^BPSOSL(IEN59,"IENS") | 
|---|
| 115 | .. D LOG^BPSOSL(IEN59,"FDA Array:") | 
|---|
| 116 | .. D LOGARRAY^BPSOSL(IEN59,"FDA") | 
|---|
| 117 | . ; | 
|---|
| 118 | . ; Payer sheets are in external format | 
|---|
| 119 | . K FDA,MSG | 
|---|
| 120 | . S FN=9002313.59902,IENS=IENS(1)_","_REC | 
|---|
| 121 | . S FDA(FN,IENS,902.02)=$P(X1,U,4)  ;Payer Sheet IEN | 
|---|
| 122 | . S FDA(FN,IENS,902.19)=$P(X1,U,11) ;B2 Payer Sheet (Reversal) | 
|---|
| 123 | . S FDA(FN,IENS,902.21)=$P(X1,U,12) ;B3 Payer Sheet (Rebill) | 
|---|
| 124 | . D FILE^DIE("E","FDA","MSG") | 
|---|
| 125 | . I $D(MSG) D | 
|---|
| 126 | .. S ERROR=14 | 
|---|
| 127 | .. D LOG^BPSOSL(IEN59,$T(+0)_"-Payer sheets did not file, SEQ="_SEQ) | 
|---|
| 128 | .. D LOG^BPSOSL(IEN59,"MSG Array:") | 
|---|
| 129 | .. D LOGARRAY^BPSOSL(IEN59,"MSG") | 
|---|
| 130 | .. D LOG^BPSOSL(IEN59,"FDA Array:") | 
|---|
| 131 | .. D LOGARRAY^BPSOSL(IEN59,"FDA") | 
|---|
| 132 | ; | 
|---|
| 133 | ; Store DUR multiple if it exists | 
|---|
| 134 | N DUR,DURREC | 
|---|
| 135 | S FN=9002313.5913,DUR=0 | 
|---|
| 136 | F  S DUR=$O(MOREDATA("DUR",DUR)) Q:DUR=""  D  I ERROR Q | 
|---|
| 137 | . K FDA,MSG,IENS | 
|---|
| 138 | . S DURREC=$G(MOREDATA("DUR",DUR,0)) | 
|---|
| 139 | . S IENS="+1,"_REC,IENS(1)=DUR | 
|---|
| 140 | . S FDA(FN,IENS,.01)=DUR  ; DUR Counter | 
|---|
| 141 | . S FDA(FN,IENS,1)=$P(DURREC,U,1)    ; DUR Professional Service Code | 
|---|
| 142 | . S FDA(FN,IENS,2)=$P(DURREC,U,2)    ; DUR Reason for Service Code | 
|---|
| 143 | . S FDA(FN,IENS,3)=$P(DURREC,U,3)    ; DUR Result of Service Code | 
|---|
| 144 | . D UPDATE^DIE("","FDA","IENS","MSG") | 
|---|
| 145 | . I $D(MSG) D | 
|---|
| 146 | .. S ERROR=15 | 
|---|
| 147 | .. D LOG^BPSOSL(IEN59,$T(+0)_"-DUR fields did not file, DUR="_DUR) | 
|---|
| 148 | .. D LOG^BPSOSL(IEN59,"DURREC="_DURREC) | 
|---|
| 149 | .. D LOG^BPSOSL(IEN59,"MSG Array:") | 
|---|
| 150 | .. D LOGARRAY^BPSOSL(IEN59,"MSG") | 
|---|
| 151 | .. D LOG^BPSOSL(IEN59,"IENS Array:") | 
|---|
| 152 | .. D LOGARRAY^BPSOSL(IEN59,"IENS") | 
|---|
| 153 | .. D LOG^BPSOSL(IEN59,"FDA Array:") | 
|---|
| 154 | .. D LOGARRAY^BPSOSL(IEN59,"FDA") | 
|---|
| 155 | ; | 
|---|
| 156 | Q ERROR | 
|---|
| 157 | ; | 
|---|
| 158 | ; OVERRIDE - Function to create override record | 
|---|
| 159 | OVERRIDE(IEN59) ; | 
|---|
| 160 | ;Save values into BPS NCPDP OVERRIDES (#9002313.511) | 
|---|
| 161 | N BPSFDA,BPSFLD,BPOVRIEN,BPSMSG,BPSQ | 
|---|
| 162 | ; | 
|---|
| 163 | ; Set Name (.01) to transaction number | 
|---|
| 164 | S BPSFDA(9002313.511,"+1,",.01)=IEN59 | 
|---|
| 165 | ; | 
|---|
| 166 | ; Set Created On (.02) to current date/time | 
|---|
| 167 | S BPSFDA(9002313.511,"+1,",.02)=$$NOW^BPSOSRX() | 
|---|
| 168 | ; | 
|---|
| 169 | ; Submission Clarification Code | 
|---|
| 170 | I $G(MOREDATA("BPSCLARF"))]"" D | 
|---|
| 171 | . S BPSFLD=$O(^BPSF(9002313.91,"B",420,"")) | 
|---|
| 172 | . I BPSFLD]"" S BPSFDA(9002313.5111,"+2,+1,",.01)=BPSFLD,BPSFDA(9002313.5111,"+2,+1,",.02)=$E(MOREDATA("BPSCLARF"),1,2) | 
|---|
| 173 | ; | 
|---|
| 174 | ; Prior Auth Fields (Code and Number) | 
|---|
| 175 | I $G(MOREDATA("BPSAUTH"))]"" D | 
|---|
| 176 | . S BPSFLD=$O(^BPSF(9002313.91,"B",461,"")) | 
|---|
| 177 | . I BPSFLD]"" S BPSFDA(9002313.5111,"+3,+1,",.01)=BPSFLD,BPSFDA(9002313.5111,"+3,+1,",.02)=$E($P(MOREDATA("BPSAUTH"),U,1),1,2) | 
|---|
| 178 | . S BPSFLD=$O(^BPSF(9002313.91,"B",462,"")) | 
|---|
| 179 | . I BPSFLD]"" S BPSFDA(9002313.5111,"+4,+1,",.01)=BPSFLD,BPSFDA(9002313.5111,"+4,+1,",.02)=$E($P(MOREDATA("BPSAUTH"),U,2),1,11) | 
|---|
| 180 | ; | 
|---|
| 181 | ; Create the record | 
|---|
| 182 | D UPDATE^DIE("","BPSFDA","BPOVRIEN","BPMSG") | 
|---|
| 183 | ; | 
|---|
| 184 | I $G(BPOVRIEN(1))]"" S BPSQ=BPOVRIEN(1) | 
|---|
| 185 | E  S BPSQ="" | 
|---|
| 186 | Q BPSQ | 
|---|
| 187 | ; | 
|---|
| 188 | ; RXPAID - Check for status of previous claim | 
|---|
| 189 | ; INPUT | 
|---|
| 190 | ;   IEN59 - BPS Transaction | 
|---|
| 191 | ; Return | 
|---|
| 192 | ;   0 - OK | 
|---|
| 193 | ;   1 - Payable | 
|---|
| 194 | ;   2 - Reversal not accepted | 
|---|
| 195 | ;   3 - Duplicate | 
|---|
| 196 | RXPAID(IEN59) ;EP - from BPSOSIZ | 
|---|
| 197 | N N57 | 
|---|
| 198 | S N57=$$RXPREV(IEN59) | 
|---|
| 199 | I 'N57 Q ""  ; no ECME record of this | 
|---|
| 200 | ; If it's a reversal, then our result depends on the reversal: | 
|---|
| 201 | ;   Was the reversal accepted?   If so, then No, not paid. | 
|---|
| 202 | ;   Was the reversal rejected?   Assume Paid, since we try to | 
|---|
| 203 | ;        allow reversals only in the case of a paid original. | 
|---|
| 204 | I $$ISREVERS^BPSOS57(N57) Q $S($$REVACC^BPSOS57(N57):0,1:2) | 
|---|
| 205 | ; | 
|---|
| 206 | ; Not a reversal: | 
|---|
| 207 | N X S X=$$CATEG^BPSOSUC(N57) | 
|---|
| 208 | Q $S(X="E PAYABLE":1,X="E DUPLICATE":3,1:0) | 
|---|
| 209 | ; | 
|---|
| 210 | ; RXPREV - Has this item previously been through ECME? | 
|---|
| 211 | ; Return false if not | 
|---|
| 212 | ; Return pointer to BPS Log of Transactions if true | 
|---|
| 213 | RXPREV(IEN59) ; | 
|---|
| 214 | N RXI,RXR | 
|---|
| 215 | S RXI=$P(IEN59,".",1),RXR=+$E($P(IEN59,".",2),1,4) | 
|---|
| 216 | Q $O(^BPSTL("NON-FILEMAN","RXIRXR",RXI,RXR,""),-1) | 
|---|