| 1 | IBCE835 ;ALB/TMP - 835 EDI EXPLANATION OF BENEFITS MSG PROCESSING ;19-JAN-99
 | 
|---|
| 2 |  ;;2.0;INTEGRATED BILLING;**137,135,155**;21-MAR-94
 | 
|---|
| 3 |  Q
 | 
|---|
| 4 |  ;
 | 
|---|
| 5 |  ; MESSAGE HEADER DATA STRING =
 | 
|---|
| 6 |  ;   type of message^msg queue^msg #^bill #^^date/time
 | 
|---|
| 7 |  ;
 | 
|---|
| 8 | HDR(IBCLNO,IBD) ;Process header data
 | 
|---|
| 9 |  ; INPUT:
 | 
|---|
| 10 |  ;   IBCLNO = claim #
 | 
|---|
| 11 |  ;
 | 
|---|
| 12 |  ;   ^TMP("IBMSGH",$J,0) = header message text
 | 
|---|
| 13 |  ;
 | 
|---|
| 14 |  ; OUTPUT:
 | 
|---|
| 15 |  ;   IBD array returned with processed data
 | 
|---|
| 16 |  ;      "LINE"  = The last line # populated in the message
 | 
|---|
| 17 |  ;      "DATE"  = Date/Time of EOB (Fileman format)
 | 
|---|
| 18 |  ;      "MRA"   = 1 if MRA, 0 if not
 | 
|---|
| 19 |  ;      "X12"   = 1 if X12, 0 if not
 | 
|---|
| 20 |  ;
 | 
|---|
| 21 |  ;   ^TMP("IBMSG",$J,"CLAIM",claim #,0)=MESSAGE HEADER DATA STRING
 | 
|---|
| 22 |  ;                                  ,"D",0,1)=header record raw data
 | 
|---|
| 23 |  ;                                  ,"D1",1,0)=header record raw data
 | 
|---|
| 24 |  ;                                  ,line #)=EOB message lines
 | 
|---|
| 25 |  ;
 | 
|---|
| 26 |  N CT,IB399,IBD0,IBBILL,LINE,L,X,Y,Z,%DT
 | 
|---|
| 27 |  S IBD0=$G(^TMP("IBMSGH",$J,0)),IBD("LINE")=0
 | 
|---|
| 28 |  Q:IBD0=""
 | 
|---|
| 29 |  S X=$P(IBD0,U,3),X=$E(X,5,8)_$E(X,1,4)_"@"_$P(IBD0,U,4)
 | 
|---|
| 30 |  I X S %DT="XTS" D ^%DT
 | 
|---|
| 31 |  S IBD("DATE")=$S(Y>0:Y,1:"")
 | 
|---|
| 32 |  S IBD("MRA")=$P(IBD0,U,5)
 | 
|---|
| 33 |  S IBD("X12")=($P(IBD0,U,2)="X")
 | 
|---|
| 34 |  S CT=0
 | 
|---|
| 35 |  ;
 | 
|---|
| 36 |  I $P(IBD0,U,6)'="" S CT=CT+1 S LINE(CT)=$G(LINE(CT))_"Payer Name: "_$P(IBD0,U,6)
 | 
|---|
| 37 |  ;
 | 
|---|
| 38 |  I CT D
 | 
|---|
| 39 |  . S (L,Z)=0
 | 
|---|
| 40 |  . F  S Z=$O(LINE(Z)) Q:'Z  S L=L+1,^TMP("IBMSG",$J,"CLAIM",IBCLNO,L)=LINE(Z)
 | 
|---|
| 41 |  . S IBD("LINE")=IBD("LINE")+CT
 | 
|---|
| 42 |  ;
 | 
|---|
| 43 |  S IB399=+$O(^DGCR(399,"B",$$GETCLM^IBCE277(IBCLNO),""),-1)
 | 
|---|
| 44 |  ;
 | 
|---|
| 45 |  S IBBILL=$$LAST364^IBCEF4(IB399)
 | 
|---|
| 46 |  ;
 | 
|---|
| 47 |  S ^TMP("IBMSG",$J,"CLAIM",IBCLNO,0)="835EOB"_U_$G(IBD("MSG#"))_U_$G(IBD("SUBJ"))_U_IBBILL_U_U_IBD("DATE")
 | 
|---|
| 48 |  ;
 | 
|---|
| 49 |  S ^TMP("IBMSG",$J,"CLAIM",IBCLNO,"D",0,1)="##RAW DATA: "_IBD0
 | 
|---|
| 50 |  S ^TMP("IBMSG",$J,"CLAIM",IBCLNO,"D1",1,0)="##RAW DATA: "_IBD0
 | 
|---|
| 51 |  Q
 | 
|---|
| 52 |  ;
 | 
|---|
| 53 | 5(IBD) ; Process claim patient ID data
 | 
|---|
| 54 |  ; INPUT:
 | 
|---|
| 55 |  ;   IBD must be passed by reference = entire message line
 | 
|---|
| 56 |  ;
 | 
|---|
| 57 |  ; OUTPUT:
 | 
|---|
| 58 |  ;   IBD array
 | 
|---|
| 59 |  ;      "LINE" = the last line # populated in the message
 | 
|---|
| 60 |  ;
 | 
|---|
| 61 |  ;   ^TMP("IBMSG",$J,"CLAIM",claim #,line#)=claim pt id message lines
 | 
|---|
| 62 |  ;                                  ,"D",5,msg seq #)=
 | 
|---|
| 63 |  ;                                  ,"D1",msg seq #,5)=
 | 
|---|
| 64 |  ;                                       claim pt id message raw data
 | 
|---|
| 65 |  ;
 | 
|---|
| 66 |  N IBBILL
 | 
|---|
| 67 |  S IBBILL=$$GETCLM^IBCE277($P(IBD,U,2))
 | 
|---|
| 68 |  ;
 | 
|---|
| 69 |  I '$D(^TMP("IBMSG",$J,"CLAIM",IBBILL)) D HDR(IBBILL,.IBD) ;Process header data if not already done for claim
 | 
|---|
| 70 |  ;
 | 
|---|
| 71 |  I $P(IBD,U,7)="Y"!($P(IBD,U,8)="Y") D  ;New patient name or id reported
 | 
|---|
| 72 |  . ;
 | 
|---|
| 73 |  . ; Alert to EDI mail group that name or ID has changed
 | 
|---|
| 74 |  . N XQA,XQAMSG
 | 
|---|
| 75 |  . S XQA("G.IB EDI")=""
 | 
|---|
| 76 |  . S XQAMSG="EOB for bill # "_IBBILL_" indicates a new name or id exists for patient"
 | 
|---|
| 77 |  . D SETUP^XQALERT
 | 
|---|
| 78 |  . ;
 | 
|---|
| 79 |  . S IBD("LINE")=$G(IBD("LINE"))+1
 | 
|---|
| 80 |  . I $P(IBD,U,7)="Y" S ^TMP("IBMSG",$J,"CLAIM",IBBILL,IBD("LINE"))="New patient name: "_$P(IBD,U,3)_","_$P(IBD,U,4)_" "_$P(IBD,U,5)_"  "
 | 
|---|
| 81 |  . I $P(IBD,U,8)="Y" S ^TMP("IBMSG",$J,"CLAIM",IBBILL,IBD("LINE"))=$G(^TMP("IBMSG",$J,"CLAIM",IBBILL,IBD("LINE")))_"New patient id: "_$P(IBD,U,6)
 | 
|---|
| 82 |  ;
 | 
|---|
| 83 |  I $P(IBD,U,9) D  ;Statement dates
 | 
|---|
| 84 |  . S IBD("LINE")=$G(IBD("LINE"))+1
 | 
|---|
| 85 |  . S ^TMP("IBMSG",$J,"CLAIM",IBBILL,IBD("LINE"))="Statement Dates: "_$$DATE^IBCE277($P(IBD,U,9))_" - "_$$DATE^IBCE277($P(IBD,U,10))
 | 
|---|
| 86 |  ;
 | 
|---|
| 87 |  S ^TMP("IBMSG",$J,"CLAIM",IBBILL,"D",5,1)="##RAW DATA: "_IBD
 | 
|---|
| 88 |  S ^TMP("IBMSG",$J,"CLAIM",IBBILL,"D1",1,5)="##RAW DATA: "_IBD
 | 
|---|
| 89 |  Q
 | 
|---|
| 90 |  ;
 | 
|---|
| 91 | 10(IBD) ; Process claim status data
 | 
|---|
| 92 |  ; INPUT:
 | 
|---|
| 93 |  ;   IBD must be passed by reference = entire message line
 | 
|---|
| 94 |  ;
 | 
|---|
| 95 |  ; OUTPUT:
 | 
|---|
| 96 |  ;   IBD array returned with processed data
 | 
|---|
| 97 |  ;      "CLAIM" = The claim #
 | 
|---|
| 98 |  ;      "LINE" = The last line # populated in the message
 | 
|---|
| 99 |  ;
 | 
|---|
| 100 |  ;   ^TMP("IBMSG",$J,"CLAIM",claim #,line#)=claim status message lines
 | 
|---|
| 101 |  ;                                  ,"D",10,msg seq #)=
 | 
|---|
| 102 |  ;                                  ,"D1",msg seq #,10)=
 | 
|---|
| 103 |  ;                                       claim status raw data
 | 
|---|
| 104 |  ;
 | 
|---|
| 105 |  N IBCLM,CT,LINE,L,Z,Z0,IBDATA,IBSTAT
 | 
|---|
| 106 |  S IBCLM=$$GETCLM^IBCE277($P(IBD,U,2))
 | 
|---|
| 107 |  Q:IBCLM=""
 | 
|---|
| 108 |  ;
 | 
|---|
| 109 |  I '$D(^TMP("IBMSG",$J,"CLAIM",IBCLM)) D HDR(IBCLM,.IBD) ;Process header data if not already done for claim
 | 
|---|
| 110 |  ;
 | 
|---|
| 111 |  S CT=0
 | 
|---|
| 112 |  F Z=3:1:6 I $P(IBD,U,Z)="Y" D  Q  ;Claim status
 | 
|---|
| 113 |  . S IBSTAT=(Z-2)
 | 
|---|
| 114 |  . S CT=CT+1,LINE(CT)="CLAIM STATUS: "_$P("PROCESSED^DENIED^PENDED^REVERSAL",U,IBSTAT)
 | 
|---|
| 115 |  I '$G(IBSTAT) D
 | 
|---|
| 116 |  . S CT=CT+1,LINE(CT)="CLAIM STATUS: "_$P(IBD,U,7)_" (OTHER)"
 | 
|---|
| 117 |  ;
 | 
|---|
| 118 |  I $P(IBD,U,8)'="" D  ;Crossed over info
 | 
|---|
| 119 |  . S LINE(CT)=LINE(CT)_"  Crossed over to: "_$P(IBD,U,9)_"  "_$P(IBD,U,8)
 | 
|---|
| 120 |  ;
 | 
|---|
| 121 |  I CT D
 | 
|---|
| 122 |  . S L=$G(IBD("LINE")),Z=0
 | 
|---|
| 123 |  . F  S Z=$O(LINE(Z)) Q:'Z  S L=L+1,^TMP("IBMSG",$J,"CLAIM",IBCLM,L)=LINE(Z)
 | 
|---|
| 124 |  . S ^TMP("IBMSG",$J,"CLAIM",IBCLM,"D",10,1)="##RAW DATA: "_IBD
 | 
|---|
| 125 |  . S ^TMP("IBMSG",$J,"CLAIM",IBCLM,"D1",1,10)="##RAW DATA: "_IBD
 | 
|---|
| 126 |  . S IBD("LINE")=$G(IBD("LINE"))+CT
 | 
|---|
| 127 |  Q
 | 
|---|
| 128 |  ;
 | 
|---|
| 129 | 15(IBD) ; Process claim status data
 | 
|---|
| 130 |  ; INPUT:
 | 
|---|
| 131 |  ;   IBD must be passed by reference = entire message line
 | 
|---|
| 132 |  ;
 | 
|---|
| 133 |  ; OUTPUT:
 | 
|---|
| 134 |  ;   IBD array
 | 
|---|
| 135 |  ;      "LINE" = The last line # populated in the message
 | 
|---|
| 136 |  ;
 | 
|---|
| 137 |  ;   ^TMP("IBMSG",$J,"CLAIM",claim #,"D",15,msg seq #)=
 | 
|---|
| 138 |  ;   ^TMP("IBMSG",$J,"CLAIM",claim #,"D1",msg seq #,15)=
 | 
|---|
| 139 |  ;                                       claim status raw data
 | 
|---|
| 140 |  ;
 | 
|---|
| 141 |  N IBCLM,Z,Z0,IBDATA
 | 
|---|
| 142 |  S IBCLM=$$GETCLM^IBCE277($P(IBD,U,2))
 | 
|---|
| 143 |  Q:IBCLM=""
 | 
|---|
| 144 |  ;
 | 
|---|
| 145 |  I '$D(^TMP("IBMSG",$J,"CLAIM",IBCLM)) D HDR(IBCLM,.IBD) ;Process header data if not already done for claim
 | 
|---|
| 146 |  ;
 | 
|---|
| 147 |  S ^TMP("IBMSG",$J,"CLAIM",IBCLM,"D",15,1)="##RAW DATA: "_IBD
 | 
|---|
| 148 |  S ^TMP("IBMSG",$J,"CLAIM",IBCLM,"D1",1,15)="##RAW DATA: "_IBD
 | 
|---|
| 149 |  Q
 | 
|---|
| 150 |  ;
 | 
|---|
| 151 | 20(IBD) ; Process claim level adjustment data
 | 
|---|
| 152 |  ; Claim must have been referenced by a previous '05' level
 | 
|---|
| 153 |  ;
 | 
|---|
| 154 |  ; INPUT:
 | 
|---|
| 155 |  ;   IBD must be passed by reference = entire message line
 | 
|---|
| 156 |  ;
 | 
|---|
| 157 |  ; OUTPUT:
 | 
|---|
| 158 |  ;    IBD("LINE") = The last line # populated in the message
 | 
|---|
| 159 |  ;   ^TMP("IBMSG",$J,"CLAIM",claim #,line #)=claim level adjustment
 | 
|---|
| 160 |  ;                                  ,"D",20,seq#)=
 | 
|---|
| 161 |  ;                                  ,"D1",seq#,20)=
 | 
|---|
| 162 |  ;                                          claim level adjust. raw data
 | 
|---|
| 163 |  ;
 | 
|---|
| 164 |  N IBCLM
 | 
|---|
| 165 |  S IBCLM=$$GETCLM^IBCE277($P(IBD,U,2))
 | 
|---|
| 166 |  Q:'$D(^TMP("IBMSG",$J,"CLAIM",IBCLM))
 | 
|---|
| 167 |  S IBD("LINE")=$G(IBD("LINE"))+1
 | 
|---|
| 168 |  S ^TMP("IBMSG",$J,"CLAIM",IBCLM,IBD("LINE"))="ADJUSTMENT GROUP: "_$P(IBD,U,3)_"  QTY: "_+$P(IBD,U,6)_", AMT: "_($P(IBD,U,5)/100)
 | 
|---|
| 169 |  S IBD("LINE")=IBD("LINE")+1
 | 
|---|
| 170 |  S ^TMP("IBMSG",$J,"CLAIM",IBCLM,IBD("LINE"))="   REASON: ("_$P(IBD,U,4)_")  "_$P(IBD,U,7)
 | 
|---|
| 171 |  S ^TMP("IBMSG",$J,"CLAIM",IBCLM,"D",20,IBD("LINE"))="##RAW DATA: "_IBD
 | 
|---|
| 172 |  S ^TMP("IBMSG",$J,"CLAIM",IBCLM,"D1",IBD("LINE"),20)="##RAW DATA: "_IBD
 | 
|---|
| 173 |  Q
 | 
|---|
| 174 |  ;
 | 
|---|
| 175 | 37(IBD) ; Process claim level adjustment data for Inpatient MEDICARE
 | 
|---|
| 176 |  D 37^IBCE835A(.IBD)
 | 
|---|
| 177 |  Q
 | 
|---|
| 178 |  ;
 | 
|---|
| 179 | 40(IBD) ; Process service line data
 | 
|---|
| 180 |  D 40^IBCE835A(.IBD)
 | 
|---|
| 181 |  Q
 | 
|---|
| 182 |  ;
 | 
|---|
| 183 | 45(IBD) ; Process service line adjustment data
 | 
|---|
| 184 |  D 45^IBCE835A(.IBD)
 | 
|---|
| 185 |  Q
 | 
|---|
| 186 |  ;
 | 
|---|
| 187 | 17(IBD) ; Process claim contact data segment
 | 
|---|
| 188 |  D XX(.IBD,17)
 | 
|---|
| 189 |  Q
 | 
|---|
| 190 |  ;
 | 
|---|
| 191 | 30(IBD) ; Process MEDICARE inpatient adjudication data (part 1)
 | 
|---|
| 192 |  D XX(.IBD,30)
 | 
|---|
| 193 |  Q
 | 
|---|
| 194 |  ;
 | 
|---|
| 195 | 35(IBD) ; Process MEDICARE inpatient adjudication data (part 2)
 | 
|---|
| 196 |  D XX(.IBD,35)
 | 
|---|
| 197 |  Q
 | 
|---|
| 198 |  ;
 | 
|---|
| 199 | 41(IBD) ; Process service line data (part 2)
 | 
|---|
| 200 |  D XX(.IBD,41)
 | 
|---|
| 201 |  Q
 | 
|---|
| 202 |  ;
 | 
|---|
| 203 | 42(IBD) ; Process service line data (part 3)
 | 
|---|
| 204 |  D XX(.IBD,42)
 | 
|---|
| 205 |  Q
 | 
|---|
| 206 |  ;
 | 
|---|
| 207 | 99(IBD) ; Process trailer record for non-MRA EOB
 | 
|---|
| 208 |  D XX(.IBD,99)
 | 
|---|
| 209 |  Q
 | 
|---|
| 210 |  ;
 | 
|---|
| 211 | XX(IBD,IBID) ; Store non-displayed data nodes in TMP array
 | 
|---|
| 212 |  ;
 | 
|---|
| 213 |  ; INPUT:
 | 
|---|
| 214 |  ;   IBD must be passed by reference = entire message line
 | 
|---|
| 215 |  ;   IBID = record id for generic store
 | 
|---|
| 216 |  ;
 | 
|---|
| 217 |  ; OUTPUT:
 | 
|---|
| 218 |  ;   ^TMP("IBMSG",$J,"CLAIM",claim #,"D",IBID,msg seq #)=
 | 
|---|
| 219 |  ;   ^TMP("IBMSG",$J,"CLAIM",claim #,"D1",msg seq #,IBID)=
 | 
|---|
| 220 |  ;                                       claim status raw data
 | 
|---|
| 221 |  ;    IBD("LINE") = The last line # populated in the message
 | 
|---|
| 222 |  ;
 | 
|---|
| 223 |  N IBCLM
 | 
|---|
| 224 |  S IBCLM=$$GETCLM^IBCE277($P(IBD,U,2))
 | 
|---|
| 225 |  ;
 | 
|---|
| 226 |  S IBD("LINE")=$G(IBD("LINE"))+1
 | 
|---|
| 227 |  S ^TMP("IBMSG",$J,"CLAIM",IBCLM,"D",IBID,IBD("LINE"))="##RAW DATA: "_IBD
 | 
|---|
| 228 |  S ^TMP("IBMSG",$J,"CLAIM",IBCLM,"D1",IBD("LINE"),IBID)="##RAW DATA: "_IBD
 | 
|---|
| 229 |  ;
 | 
|---|
| 230 |  Q
 | 
|---|
| 231 |  ;
 | 
|---|