[613] | 1 | IBCEMQA ;DAOU/ESG - MRA QUIET BILL AUTHORIZATION ;25-MAR-2003
|
---|
| 2 | ;;2.0;INTEGRATED BILLING;**155**;21-MAR-94
|
---|
| 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
| 4 | ;
|
---|
| 5 | Q ; must be called at proper entry point
|
---|
| 6 | ;
|
---|
| 7 | ;
|
---|
| 8 | AUTOCOB(IBIFN,IBEOB,ERRMSG) ; This procedure mimics and automates the
|
---|
| 9 | ; Process COB action on the MRA management screen. This is intended
|
---|
| 10 | ; to be called in background mode (no user interface).
|
---|
| 11 | ;
|
---|
| 12 | ; Input
|
---|
| 13 | ; IBIFN - bill#
|
---|
| 14 | ; IBEOB - ien of entry in file 361.1 (MRA)
|
---|
| 15 | ;
|
---|
| 16 | ; Output
|
---|
| 17 | ; ERRMSG - optional output parameter, passed by reference
|
---|
| 18 | ; - error message text
|
---|
| 19 | ;
|
---|
| 20 | NEW MRADATA,IB364,IBCBASK,IBCBCOPY,IBCAN,IBIFNH,IBAUTO,IBDA
|
---|
| 21 | NEW IBCE,IBSILENT,IBPRCOB,IBERRMSG
|
---|
| 22 | NEW IBCOB,IBCOBIL,IBCOBN,IBINS,IBINSN,IBINSOLD,IBMRAIO,IBMRAO,IBNMOLD
|
---|
| 23 | S (IBIFN,IBIFNH)=+$G(IBIFN),IBEOB=+$G(IBEOB),ERRMSG=""
|
---|
| 24 | ;
|
---|
| 25 | S MRADATA=$G(^IBM(361.1,IBEOB,0))
|
---|
| 26 | I $P(MRADATA,U,1)'=IBIFN S ERRMSG="Incorrect Bill or MRA EOB" G AUCOBX
|
---|
| 27 | I $P(MRADATA,U,4)'=1 S ERRMSG="EOB is not a Medicare MRA" G AUCOBX
|
---|
| 28 | S IB364=+$P(MRADATA,U,19)
|
---|
| 29 | I 'IB364 S ERRMSG="Missing or incorrect Transmission record" G AUCOBX
|
---|
| 30 | ;
|
---|
| 31 | I '$P($G(^DGCR(399,IBIFN,"I"_($$COBN^IBCEF(IBIFN)+1))),U,1) D G AUCOBX
|
---|
| 32 | . S ERRMSG="No next payer for this bill"
|
---|
| 33 | . Q
|
---|
| 34 | ;
|
---|
| 35 | ; Make sure that Medicare WNR is the current insurance for this bill
|
---|
| 36 | I '$$WNRBILL^IBEFUNC(IBIFN) D G AUCOBX
|
---|
| 37 | . S ERRMSG="Medicare (WNR) is not the current payer for this bill"
|
---|
| 38 | . Q
|
---|
| 39 | ;
|
---|
| 40 | ; Set variable flags for use in IBCCCB/IBCCC2
|
---|
| 41 | S (IBCBASK,IBCBCOPY,IBCAN,IBAUTO,IBCE("EDI"),IBSILENT,IBPRCOB)=1
|
---|
| 42 | S IBDA=IBEOB
|
---|
| 43 | ;
|
---|
| 44 | D CHKB1^IBCCCB
|
---|
| 45 | ;
|
---|
| 46 | S IBIFN=IBIFNH ; restore bill#
|
---|
| 47 | I $G(IBERRMSG)'="" S ERRMSG=IBERRMSG G AUCOBX ; error message
|
---|
| 48 | D UPDEDI^IBCEM(IB364,"Z") ; status updates
|
---|
| 49 | AUCOBX ;
|
---|
| 50 | Q
|
---|
| 51 | ;
|
---|
| 52 | ;
|
---|
| 53 | AUTH(IBIFN,ERRMSG) ; Entry Point
|
---|
| 54 | ; This procedure's job is to authorize this bill. The manual
|
---|
| 55 | ; process to authorize a bill is found in routine IBCB1. This
|
---|
| 56 | ; routine borrows heavily from that routine.
|
---|
| 57 | ;
|
---|
| 58 | ; *** Any changes here should be considered also in IBCB1 ***
|
---|
| 59 | ;
|
---|
| 60 | ; This routine is called when receiving an incoming MRA from
|
---|
| 61 | ; Medicare. If that MRA/EOB meets certain criteria, then the bill
|
---|
| 62 | ; will become a secondary bill and we will try to authorize it (using
|
---|
| 63 | ; this procedure) and put it in the EDI queue ready for extract.
|
---|
| 64 | ;
|
---|
| 65 | ; Input
|
---|
| 66 | ; IBIFN - internal bill#
|
---|
| 67 | ;
|
---|
| 68 | ; Output
|
---|
| 69 | ; ERRMSG - optional output parameter, passed by reference
|
---|
| 70 | ; - error message text
|
---|
| 71 | ;
|
---|
| 72 | NEW CST,IBTXSTAT,IB364,PRCASV,DFN,STSMSG
|
---|
| 73 | NEW DIE,DA,DR,IBYY
|
---|
| 74 | ;
|
---|
| 75 | ; Check the bill, make sure the current status is valid
|
---|
| 76 | S IBIFN=+$G(IBIFN),ERRMSG=""
|
---|
| 77 | S CST=$P($G(^DGCR(399,IBIFN,0)),U,13)
|
---|
| 78 | I CST="" S ERRMSG="Bill has no current status defined." G AUTHX
|
---|
| 79 | I CST'=2 S ERRMSG="This bill's status is "_$$GET1^DIQ(399,IBIFN_",",.13)_". It must be REQUEST MRA." G AUTHX
|
---|
| 80 | ;
|
---|
| 81 | ; authorize the bill quietly
|
---|
| 82 | S DIE=399,DA=IBIFN,DR="[IB STATUS]",IBYY="@902" D ^DIE
|
---|
| 83 | ;
|
---|
| 84 | ; Update the review status for all EOB's on file
|
---|
| 85 | D STAT^IBCEMU2(IBIFN,3) ; Accepted - Complete EOB
|
---|
| 86 | ;
|
---|
| 87 | ; Checks for need to add any codes to bill for EDI (call in quiet mode)
|
---|
| 88 | D AUTOCK^IBCEU2(IBIFN,1)
|
---|
| 89 | ;
|
---|
| 90 | ; Calculate transmittable status
|
---|
| 91 | ; 0 = not transmittable
|
---|
| 92 | ; 1 = yes, live transmittable
|
---|
| 93 | ; 2 = yes, test transmittable
|
---|
| 94 | S IBTXSTAT=+$$TXMT^IBCEF4(IBIFN)
|
---|
| 95 | ;
|
---|
| 96 | ; If transmittable, add this bill to the bill transmission file
|
---|
| 97 | I IBTXSTAT D I ERRMSG'="" G AUTHX
|
---|
| 98 | . S IB364=$$ADDTBILL^IBCB1(IBIFN,IBTXSTAT)
|
---|
| 99 | . I '$P(IB364,U,3) S ERRMSG="Error loading bill into transmit file."
|
---|
| 100 | . Q
|
---|
| 101 | ;
|
---|
| 102 | ; Pass completed bill to Accounts Receivable (quietly)
|
---|
| 103 | D ARPASS^IBCB1(IBIFN,0)
|
---|
| 104 | I '$G(PRCASV("OKAY")) S ERRMSG="Error while passing bill to A/R." G AUTHX
|
---|
| 105 | ;
|
---|
| 106 | ; Find and process any IB charges on hold
|
---|
| 107 | S DFN=+$P($G(^DGCR(399,IBIFN,0)),U,2)
|
---|
| 108 | D FIND^IBOHCK(DFN,IBIFN)
|
---|
| 109 | ;
|
---|
| 110 | ; If transmittable, check for unreviewed items & update 364 status
|
---|
| 111 | I IBTXSTAT D
|
---|
| 112 | . S STSMSG=$$STATUS^IBCEF4(IBIFN)
|
---|
| 113 | . I $P(STSMSG,U,1) D UPDEDI^IBCEM($P(STSMSG,U,1),"E")
|
---|
| 114 | . I $P(STSMSG,U,2),$P(STSMSG,U,2)'=$P(STSMSG,U,1) D UPDEDI^IBCEM($P(STSMSG,U,2),"E")
|
---|
| 115 | . Q
|
---|
| 116 | ;
|
---|
| 117 | AUTHX ;
|
---|
| 118 | Q
|
---|
| 119 | ;
|
---|