| 1 | IBCEMU2 ;ALB/DSM - IB MRA Utility ;01-MAY-2003
 | 
|---|
| 2 |  ;;2.0;INTEGRATED BILLING;**155,320,349**;21-MAR-94;Build 46
 | 
|---|
| 3 |  ;;Per VHA Directive 2004-038, this routine should not be modified.
 | 
|---|
| 4 |  ;
 | 
|---|
| 5 |  Q
 | 
|---|
| 6 |  ;
 | 
|---|
| 7 | QMRA ; This is a background procedure that is spun off of the IB BATCH
 | 
|---|
| 8 |  ; Print option. This process scans a queue in ^XTMP("IBMRA"_#,$J) and checks
 | 
|---|
| 9 |  ; each Bill to see if a printable MRA exist, if so, prints them. MRA's print
 | 
|---|
| 10 |  ; on the device associated with the 'Bill Addendum' Form Type.
 | 
|---|
| 11 |  ; This process doesn't interact with users.
 | 
|---|
| 12 |  ;
 | 
|---|
| 13 |  ; IB*2*320:  MCS - Resubmit by Print produces a scratch global also
 | 
|---|
| 14 |  ;            ^XTMP("IBCFP6",$J,.... for MRA's to print here
 | 
|---|
| 15 |  ;
 | 
|---|
| 16 |  ; Input:
 | 
|---|
| 17 |  ;      IBJ   = $J of starting job
 | 
|---|
| 18 |  ;      IBFTP = "IBMRA"_# (ien of form type) or "IBCFP6"
 | 
|---|
| 19 |  ;
 | 
|---|
| 20 |  N IBS1,IBS2,IBS3,IBIFN,IBQ,IBPGN
 | 
|---|
| 21 |  S (IBS1,IBIFN,IBQ)=0
 | 
|---|
| 22 |  F  S IBS1=$O(^XTMP(IBFTP,IBJ,IBS1)) Q:IBS1=""  D  I IBQ Q
 | 
|---|
| 23 |  . S IBS2=0 F  S IBS2=$O(^XTMP(IBFTP,IBJ,IBS1,IBS2)) Q:IBS2=""  D  I IBQ Q
 | 
|---|
| 24 |  . . S IBS3=0 F  S IBS3=$O(^XTMP(IBFTP,IBJ,IBS1,IBS2,IBS3)) Q:IBS3=""  D  I IBQ Q
 | 
|---|
| 25 |  . . . S IBIFN=0 F  S IBIFN=$O(^XTMP(IBFTP,IBJ,IBS1,IBS2,IBS3,IBIFN)) Q:IBIFN=""  D  I $$STOP S IBQ=1 Q
 | 
|---|
| 26 |  . . . . I $$MRAEXIST^IBCEMU1(IBIFN) D PROC^IBCEMRAA W @IOF ;must have IBIFN set
 | 
|---|
| 27 |  K ^XTMP(IBFTP,IBJ) S ZTREQ="@"
 | 
|---|
| 28 |  Q  ;QMRA
 | 
|---|
| 29 |  ;
 | 
|---|
| 30 | STOP() ;determine if user has requested the queued report to stop
 | 
|---|
| 31 |  I $D(ZTQUEUED),$$S^%ZTLOAD S ZTSTOP=1 K ZTREQ I +$G(IBPGN) W !,"***TASK STOPPED BY USER***"
 | 
|---|
| 32 |  Q +$G(ZTSTOP)
 | 
|---|
| 33 |  ;
 | 
|---|
| 34 |  ;
 | 
|---|
| 35 | STAT(IBIFN,STATUS,MRAONLY) ; Update the review status in the EOB file
 | 
|---|
| 36 |  ; This procedure updates field .16 in file 361.1 for all EOB's for
 | 
|---|
| 37 |  ; the given bill#
 | 
|---|
| 38 |  ; 
 | 
|---|
| 39 |  ;   IBIFN   - Internal Bill# (required)
 | 
|---|
| 40 |  ;   STATUS  - Internal Value of the Review Status field (required)
 | 
|---|
| 41 |  ;   MRAONLY - Optional Flag with a default of 0 if not passed in
 | 
|---|
| 42 |  ;             1:only update MRA EOB's for this bill
 | 
|---|
| 43 |  ;             0:update all EOB's for this bill
 | 
|---|
| 44 |  ;
 | 
|---|
| 45 |  NEW RESULT,IBEOB,IBM
 | 
|---|
| 46 |  NEW DIE,DA,DR,D,D0,DI,DIC,DICR,DIG,DIH,DISYS,DIU,DIV,DIW,DQ,DIERR,X,Y
 | 
|---|
| 47 |  S IBIFN=+$G(IBIFN),STATUS=$G(STATUS)
 | 
|---|
| 48 |  S MRAONLY=$G(MRAONLY,0)
 | 
|---|
| 49 |  ;
 | 
|---|
| 50 |  I '$D(^IBM(361.1,"B",IBIFN)) G STATX    ; no EOB's for this bill
 | 
|---|
| 51 |  D CHK^DIE(361.1,.16,,STATUS,.RESULT)
 | 
|---|
| 52 |  I RESULT="^" G STATX                    ; invalid status passed in
 | 
|---|
| 53 |  ;
 | 
|---|
| 54 |  S IBEOB=0        ; loop thru all EOB's for the bill
 | 
|---|
| 55 |  F  S IBEOB=$O(^IBM(361.1,"B",IBIFN,IBEOB)) Q:'IBEOB  D
 | 
|---|
| 56 |  . S IBM=$G(^IBM(361.1,IBEOB,0))
 | 
|---|
| 57 |  . I $P(IBM,U,16)=STATUS Q           ; no change
 | 
|---|
| 58 |  . I MRAONLY,'$P(IBM,U,4) Q          ; skip because of parameter
 | 
|---|
| 59 |  . S DIE=361.1,DA=IBEOB,DR=".16////"_STATUS D ^DIE
 | 
|---|
| 60 |  . Q
 | 
|---|
| 61 |  ;
 | 
|---|
| 62 | STATX ;
 | 
|---|
| 63 |  Q
 | 
|---|
| 64 |  ;
 | 
|---|
| 65 | MRAWL(IBIFN) ; Do any MRA EOB's for this bill appear on the worklist?
 | 
|---|
| 66 |  ;
 | 
|---|
| 67 |  ; This function returns 1 if at least one MRA EOB for the given bill
 | 
|---|
| 68 |  ; appears on the MRA management worklist.  Otherwise, this function
 | 
|---|
| 69 |  ; returns 0.
 | 
|---|
| 70 |  ;
 | 
|---|
| 71 |  NEW OK,IBEOB
 | 
|---|
| 72 |  S OK=0,IBIFN=+$G(IBIFN)
 | 
|---|
| 73 |  I '$D(^IBM(361.1,"B",IBIFN)) G MRAWLX     ; no EOB's for this bill
 | 
|---|
| 74 |  S IBEOB=0        ; loop thru all EOB's for the bill
 | 
|---|
| 75 |  F  S IBEOB=$O(^IBM(361.1,"B",IBIFN,IBEOB)) Q:'IBEOB  D  Q:OK
 | 
|---|
| 76 |  . I $$ELIG^IBCECOB1(IBEOB) S OK=1
 | 
|---|
| 77 |  . Q
 | 
|---|
| 78 | MRAWLX ;
 | 
|---|
| 79 |  Q OK
 | 
|---|
| 80 |  ;
 | 
|---|
| 81 | TXSTS(IBIFN,IB364,REJFLG,IBZ) ; Claim transmission status information
 | 
|---|
| 82 |  ; Input   IBIFN - required
 | 
|---|
| 83 |  ;         IB364 - optional (defaults to most recent transmission#)
 | 
|---|
| 84 |  ; Output  REJFLG (pass by reference) - 1/0 flag if any rejection status
 | 
|---|
| 85 |  ;                                      messages on file
 | 
|---|
| 86 |  ;         IBZ (pass by reference) - array of information
 | 
|---|
| 87 |  ;
 | 
|---|
| 88 |  NEW IEN,SMCNT,SEV,BCH,BCHD0,BCHD1
 | 
|---|
| 89 |  S REJFLG=0 K IBZ
 | 
|---|
| 90 |  S IBIFN=+$G(IBIFN) I 'IBIFN G TXSTSX
 | 
|---|
| 91 |  S IB364=+$G(IB364)
 | 
|---|
| 92 |  I 'IB364 S IB364=$$LAST364^IBCEF4(IBIFN) I 'IB364 G TXSTSX
 | 
|---|
| 93 |  I $P($G(^IBA(364,IB364,0)),U,1)'=IBIFN G TXSTSX
 | 
|---|
| 94 |  S IEN=0,SMCNT=0
 | 
|---|
| 95 |  F  S IEN=$O(^IBM(361,"AERR",IB364,IEN)) Q:'IEN  D
 | 
|---|
| 96 |  . S SMCNT=SMCNT+1
 | 
|---|
| 97 |  . S SEV=$P($G(^IBM(361,IEN,0)),U,3)   ; status message severity
 | 
|---|
| 98 |  . I SEV="R" S REJFLG=1
 | 
|---|
| 99 |  . Q
 | 
|---|
| 100 |  S BCH=+$P($G(^IBA(364,IB364,0)),U,2)  ; batch ien
 | 
|---|
| 101 |  S BCHD0=$G(^IBA(364.1,BCH,0))
 | 
|---|
| 102 |  S BCHD1=$G(^IBA(364.1,BCH,1))
 | 
|---|
| 103 |  S IBZ("DATE LAST SENT")=$P(BCHD1,U,3)
 | 
|---|
| 104 |  S IBZ("NUMBER OF STATUS MESSAGES")=SMCNT
 | 
|---|
| 105 |  S IBZ("BATCH NUMBER")=$P(BCHD0,U,1)
 | 
|---|
| 106 |  S IBZ("TRANSMISSION STATUS")=$P($G(^IBA(364,IB364,0)),U,3)
 | 
|---|
| 107 | TXSTSX ;
 | 
|---|
| 108 |  Q
 | 
|---|
| 109 |  ;
 | 
|---|
| 110 | MRACALC(IBEOB,IBIFN,AR,PRCASV) ; Calculates Two Amounts:
 | 
|---|
| 111 |  ;  Unreimbursable Medicare Expense and Medicare Contract Adjustment
 | 
|---|
| 112 |  ;  Amount for a given EOB.
 | 
|---|
| 113 |  ;
 | 
|---|
| 114 |  ; Input   IBIFN= ien of Claim file 399 - Required
 | 
|---|
| 115 |  ;         IBEOB= ien of EOB file 361.1 - Required
 | 
|---|
| 116 |  ;         AR=    Flag indicating this was called from AR function
 | 
|---|
| 117 |  ; Input/Output  PRCASV= array with the two calculated values
 | 
|---|
| 118 |  ;         PRCASV("MEDURE")=Unreimbursable Medicare Expense
 | 
|---|
| 119 |  ;         PRCASV("MEDCA")=Medicare Contract Adjustment Amount
 | 
|---|
| 120 |  ;
 | 
|---|
| 121 |  ; For multiple EOB's, add up the calculated values across EOB's
 | 
|---|
| 122 |  ;
 | 
|---|
| 123 |  N I,LNLVL,EOBADJ,IBCOBN,INPAT,FRMTYP
 | 
|---|
| 124 |  ;
 | 
|---|
| 125 |  S FRMTYP=$$FT^IBCEF(IBIFN)       ;Form Type 2=1500; 3=UB
 | 
|---|
| 126 |  S INPAT=$$INPAT^IBCEF(IBIFN)     ;Inpat/Outpat Flag
 | 
|---|
| 127 |  S AR=$G(AR,0)    ;initialize AR flag
 | 
|---|
| 128 |  F I=0,1,2 S IBEOB(I)=$G(^IBM(361.1,IBEOB,I))
 | 
|---|
| 129 |  I $P(IBEOB(0),U,4)'=1 Q  ;make sure it's an MRA
 | 
|---|
| 130 |  S IBCOBN=$$COBN^IBCEF(IBIFN) ;get current bill sequence
 | 
|---|
| 131 |  ; Make sure we're on the right insurance sequence when AR flag is on
 | 
|---|
| 132 |  I AR I $P(IBEOB(0),U,15)'=(IBCOBN-1) Q
 | 
|---|
| 133 |  ;
 | 
|---|
| 134 |  ; Unreimburseable Medicare Expense (same calc regardless of form type)
 | 
|---|
| 135 |  ; For multiple EOB's, add up the amounts across EOB's
 | 
|---|
| 136 |  S PRCASV("MEDURE")=$G(PRCASV("MEDURE"))+IBEOB(1)
 | 
|---|
| 137 |  ;
 | 
|---|
| 138 |  ; Handle CMS-1500 Form Type Next:
 | 
|---|
| 139 |  I FRMTYP=2 D MEDCARE(IBEOB,.PRCASV) Q
 | 
|---|
| 140 |  ;
 | 
|---|
| 141 |  ; Handle UB Form Type Next:
 | 
|---|
| 142 |  ; If Inpatient Calculate from Claim level data
 | 
|---|
| 143 |  I INPAT D  Q  ;
 | 
|---|
| 144 |  . K EOBADJ M EOBADJ=^IBM(361.1,IBEOB,10)
 | 
|---|
| 145 |  . S PRCASV("MEDCA")=$G(PRCASV("MEDCA"))+$$CALCMCA(.EOBADJ)
 | 
|---|
| 146 |  ;
 | 
|---|
| 147 |  ; If Outpatient Calculate from Service Line level data
 | 
|---|
| 148 |  D MEDCARE(IBEOB,.PRCASV)
 | 
|---|
| 149 |  Q  ;MRACALC
 | 
|---|
| 150 |  ;
 | 
|---|
| 151 | MEDCARE(IBEOB,PRCASV) ; If Outpatient Calculate from Service Line level data
 | 
|---|
| 152 |  N LNLVL,EOBADJ
 | 
|---|
| 153 |  S LNLVL=0
 | 
|---|
| 154 |  F  S LNLVL=$O(^IBM(361.1,IBEOB,15,LNLVL)) Q:'LNLVL  D  ;
 | 
|---|
| 155 |  . K EOBADJ
 | 
|---|
| 156 |  . M EOBADJ=^IBM(361.1,IBEOB,15,LNLVL,1)
 | 
|---|
| 157 |  . ; Total up the Medicare Contract Adjustment across ALL Service Lines
 | 
|---|
| 158 |  . S PRCASV("MEDCA")=$G(PRCASV("MEDCA"))+$$CALCMCA(.EOBADJ)
 | 
|---|
| 159 |  Q  ;MEDCARE
 | 
|---|
| 160 |  ;
 | 
|---|
| 161 | CALCMCA(EOBADJ) ; FUNCTION - Calculate Medicare Contract Adjustment
 | 
|---|
| 162 |  ; Sums up Amounts on ALL Reason Codes under ALL Group Codes = 'CO' and
 | 
|---|
| 163 |  ; returns that value (which is Medicare Contract Adjustment).
 | 
|---|
| 164 |  ;
 | 
|---|
| 165 |  ; Input  EOBADJ = Array of Group Codes & Reason Codes from either the Claim 
 | 
|---|
| 166 |  ;                 Level (10) or Service Line Level (15) of EOB file (#361.1)
 | 
|---|
| 167 |  ; Output  returns Medicare Contract Adjustment
 | 
|---|
| 168 |  ;
 | 
|---|
| 169 |  N GRPLVL,RSNLVL,RSNAMT,MCA
 | 
|---|
| 170 |  S (GRPLVL,MCA)=0
 | 
|---|
| 171 |  F  S GRPLVL=$O(EOBADJ(GRPLVL)) Q:'GRPLVL  D  ;
 | 
|---|
| 172 |  . I $P($G(EOBADJ(GRPLVL,0)),U)'="CO" Q
 | 
|---|
| 173 |  . S RSNLVL=0
 | 
|---|
| 174 |  . F  S RSNLVL=$O(EOBADJ(GRPLVL,1,RSNLVL)) Q:'RSNLVL  D  ;
 | 
|---|
| 175 |  . . S RSNAMT=$P($G(EOBADJ(GRPLVL,1,RSNLVL,0)),U,2)
 | 
|---|
| 176 |  . . S MCA=MCA+RSNAMT
 | 
|---|
| 177 |  Q MCA  ;CALCMCA
 | 
|---|
| 178 |  ;
 | 
|---|
| 179 | ALLOWED(IBEOB) ; Returns Total Allowed Amount by summing up all Allowed Amounts 
 | 
|---|
| 180 |  ; from Line Level Adjustment
 | 
|---|
| 181 |  ; Input: IBEOB = ien of EOB file (361.1)
 | 
|---|
| 182 |  ; 
 | 
|---|
| 183 |  N LNLVL,LNLVLD,ALWD,TOTALWD
 | 
|---|
| 184 |  S (LNLVL,TOTALWD)=0
 | 
|---|
| 185 |  F  S LNLVL=$O(^IBM(361.1,IBEOB,15,LNLVL)) Q:'LNLVL  S LNLVLD=^(LNLVL,0) D
 | 
|---|
| 186 |  . S ALWD=$P(LNLVLD,U,13),TOTALWD=TOTALWD+ALWD   ; Allowed Amount
 | 
|---|
| 187 |  Q TOTALWD  ;ALLOWED
 | 
|---|
| 188 |  ;
 | 
|---|
| 189 | MRATYPE(BILL,ARDATE) ; Function - determines the MRA Receivable Type for a Third
 | 
|---|
| 190 |  ; Party Receivable. This is accomplished by comparing DATE MRA FIRST ACTIVATED
 | 
|---|
| 191 |  ; with AR Activation Date for the Bill.
 | 
|---|
| 192 |  ; 
 | 
|---|
| 193 |  ; Input     BILL= ien of a given Bill Number (Required)
 | 
|---|
| 194 |  ;         ARDATE= Date Account Receivable was Activated - date only  (Required)
 | 
|---|
| 195 |  ;
 | 
|---|
| 196 |  ; Output - Possible Types:
 | 
|---|
| 197 |  ;          1 = Pre-MRA implementation
 | 
|---|
| 198 |  ;          2 = Post MRA Medicare Receivable
 | 
|---|
| 199 |  ;          3 = Post MRA non-Medicare Receivable
 | 
|---|
| 200 |  ;
 | 
|---|
| 201 |  N MRADTACT,MRAMT
 | 
|---|
| 202 |  I '$G(ARDATE)!'$G(BILL) Q 1
 | 
|---|
| 203 |  ;
 | 
|---|
| 204 |  ; get DATE MRA FIRST ACTIVATED at site
 | 
|---|
| 205 |  S MRADTACT=$$MRADTACT()
 | 
|---|
| 206 |  ;
 | 
|---|
| 207 |  ; MRA not Activated at site
 | 
|---|
| 208 |  I MRADTACT="" Q 1 ;MRATYPE
 | 
|---|
| 209 |  ; 
 | 
|---|
| 210 |  ; Bill from pre-MRA implementation era
 | 
|---|
| 211 |  I ARDATE<MRADTACT Q 1 ;MRATYPE
 | 
|---|
| 212 |  ;
 | 
|---|
| 213 |  ; Post-MRA Medicare bill; get Medicare amounts
 | 
|---|
| 214 |  S MRAMT=$G(^PRCA(430,BILL,13))
 | 
|---|
| 215 |  ; check Medicare Contractual Adjustment Amount
 | 
|---|
| 216 |  I $P(MRAMT,U,1) Q 2 ;MRATYPE
 | 
|---|
| 217 |  ; check Medicare Unreimburseable Amout
 | 
|---|
| 218 |  I $P(MRAMT,U,2) Q 2 ;MRATYPE
 | 
|---|
| 219 |  ; check if bill is a Medicare one
 | 
|---|
| 220 |  I $$MRAEXIST^IBCEMU1(BILL) Q 2 ;MRATYPE
 | 
|---|
| 221 |  ; check if bill is a Medicare Supplemental one
 | 
|---|
| 222 |  I $P($$CRIT^IBRFN2(BILL),U)=2 Q 2 ;MRATYPE
 | 
|---|
| 223 |  ;
 | 
|---|
| 224 |  ; all others are Post-MRA non-Medicare bills
 | 
|---|
| 225 |  Q 3 ;MRATYPE
 | 
|---|
| 226 |  ;
 | 
|---|
| 227 | MRADTACT() ; Function - returns DATE MRA FIRST ACTIVATED at site
 | 
|---|
| 228 |  Q $P($G(^IBE(350.9,1,8)),U,13)
 | 
|---|
| 229 |  ;
 | 
|---|