[613] | 1 | IBCNSM2 ;ALB/AAS - INSURANCE MANAGEMENT - EDIT ROUTINE ; 22-OCT-92
|
---|
| 2 | ;;2.0;INTEGRATED BILLING;**28,103,139**; 21-MAR-94
|
---|
| 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
| 4 | ;
|
---|
| 5 | % S U="^"
|
---|
| 6 | ;
|
---|
| 7 | BU ; -- Enter Edit benefits already used
|
---|
| 8 | D FULL^VALM1
|
---|
| 9 | N I,J,IBXX,VALMY,IBCNS,IBCPOL,IBCDFN
|
---|
| 10 | D EN^VALM2($G(XQORNOD(0)))
|
---|
| 11 | I $D(VALMY) S IBXX=0 F S IBXX=$O(VALMY(IBXX)) Q:'IBXX D
|
---|
| 12 | .S IBPPOL=$G(^TMP("IBNSMDX",$J,$O(^TMP("IBNSM",$J,"IDX",IBXX,0))))
|
---|
| 13 | .Q:IBPPOL=""
|
---|
| 14 | .S IBCNS=+$P(IBPPOL,"^",5),IBCPOL=+$P(IBPPOL,"^",22),IBCDFN=+$P(IBPPOL,"^",4)
|
---|
| 15 | .D EN^VALM("IBCNS BENEFITS USED BY DATE")
|
---|
| 16 | .Q
|
---|
| 17 | S VALMBCK="R" Q
|
---|
| 18 | ;
|
---|
| 19 | EP ; -- Enter Edit Patient Insurance Policy Information
|
---|
| 20 | ;
|
---|
| 21 | S VALMBCK="R" Q
|
---|
| 22 | ;
|
---|
| 23 | EI ; -- Enter Edit Insurance Company Information
|
---|
| 24 | ; -- if coming from benefit screen
|
---|
| 25 | ; ibcns=insurance co number
|
---|
| 26 | D FULL^VALM1
|
---|
| 27 | I $G(IBCNS)>0 D EN^VALM("IBCNS INSURANCE COMPANY") G EIQ
|
---|
| 28 | ;
|
---|
| 29 | ; -- if coming from list of policies, allow selection
|
---|
| 30 | N I,J,IBXX,IBCNS,VALMY
|
---|
| 31 | D EN^VALM2($G(XQORNOD(0)))
|
---|
| 32 | I $D(VALMY) S IBXX=0 F S IBXX=$O(VALMY(IBXX)) Q:'IBXX D
|
---|
| 33 | .S I=$G(^TMP("IBNSMDX",$J,$O(^TMP("IBNSM",$J,"IDX",IBXX,0))))
|
---|
| 34 | .S IBCNS=$P(I,"^",5)
|
---|
| 35 | .D EN^VALM("IBCNS INSURANCE COMPANY")
|
---|
| 36 | EIQ S VALMBCK="R" Q
|
---|
| 37 | ;
|
---|
| 38 | VC ; -- Verify Insurance Coverage
|
---|
| 39 | D FULL^VALM1
|
---|
| 40 | N I,J,IBXX,VALMY
|
---|
| 41 | ;
|
---|
| 42 | ; -- If no effective policies ask to verify no coverage
|
---|
| 43 | I '$$EPOL(DFN) D VCN G EXIT
|
---|
| 44 | ;
|
---|
| 45 | D EN^VALM2($G(XQORNOD(0)))
|
---|
| 46 | I $D(VALMY) S IBXX=0 F S IBXX=$O(VALMY(IBXX)) Q:'IBXX D
|
---|
| 47 | .S IBPPOL=$G(^TMP("IBNSMDX",$J,$O(^TMP("IBNSM",$J,"IDX",IBXX,0))))
|
---|
| 48 | .Q:IBPPOL="" D VFY
|
---|
| 49 | ;
|
---|
| 50 | EXIT ; -- Kill variables, refresh screen
|
---|
| 51 | ;
|
---|
| 52 | D BLD^IBCNSM
|
---|
| 53 | K I,J,IBXX,DA,DR,IBDUZZ
|
---|
| 54 | S VALMBCK="R" Q
|
---|
| 55 | ;
|
---|
| 56 | VFY ; -- Display most recent verification
|
---|
| 57 | ;
|
---|
| 58 | N DA,DR,IBDUZ,IB0,IBWNR
|
---|
| 59 | D FULL^VALM1
|
---|
| 60 | S IBCH=$P(IBPPOL,U,1)
|
---|
| 61 | S IBWNR=$$GETWNR^IBCNSMM1()
|
---|
| 62 | ;
|
---|
| 63 | ; -- If Medicare WNR and Name of Insured is different from Pt. Name
|
---|
| 64 | ; display Warning message.
|
---|
| 65 | S IB0=$G(^DPT(DFN,.312,$P(IBPPOL,U,4),0))
|
---|
| 66 | I +IBWNR=+IB0 D
|
---|
| 67 | .I $P(IB0,U,17)="" Q
|
---|
| 68 | .I $P(IB0,U,17)=$P($G(^DPT(DFN,0)),U,1) Q
|
---|
| 69 | .W !!,"WARNING: Patient Name: '"_$P($G(^DPT(DFN,0)),U,1)_"' DOES NOT MATCH"
|
---|
| 70 | .W !," Name of Insured: '"_$P(IB0,U,17)_"' for this "_$P(IBWNR,U,2)_" policy."
|
---|
| 71 | ;
|
---|
| 72 | S IBDUZ=$P($G(^DPT(DFN,.312,$P(IBPPOL,U,4),1)),U,4)
|
---|
| 73 | I 'IBDUZ D REVASK Q
|
---|
| 74 | W !!," "_IBCH_" LAST VERIFIED BY "_$P($G(^VA(200,+IBDUZ,0)),U)_" ON "_$$DAT1^IBOUTL($P($G(^DPT(DFN,.312,$P(IBPPOL,U,4),1)),U,3))_". . ."
|
---|
| 75 | I $P($P($G(^DPT(DFN,.312,$P(IBPPOL,U,4),1)),U,3),".")=DT W !,"COVERAGE VERIFIED TODAY, "_$$DAT1^IBOUTL(DT) H 3
|
---|
| 76 | E D REVASK
|
---|
| 77 | Q
|
---|
| 78 | ;
|
---|
| 79 | REVASK ; -- Determine whether user wishes to re-verify
|
---|
| 80 | ;
|
---|
| 81 | N Y
|
---|
| 82 | W:'IBDUZ !
|
---|
| 83 | S DIR("B")="No",DIR(0)="YO",DIR("A")=$S('IBDUZ:" "_IBCH_" NEVER PREVIOUSLY VERIFIED. DO YOU WISH TO VERIFY COVERAGE",1:"ARE YOU RE-VERIFYING COVERAGE TODAY")
|
---|
| 84 | D ^DIR K DIR Q:$D(DIRUT)
|
---|
| 85 | I Y D REVFY
|
---|
| 86 | Q
|
---|
| 87 | ;
|
---|
| 88 | REVFY ; -- Re-verify
|
---|
| 89 | ;
|
---|
| 90 | S DA(1)=DFN,DA=$P(IBPPOL,U,4),DIE="^DPT(DFN,.312,",DR="1.03////"_DT_";1.04////"_DUZ D ^DIE K DIE
|
---|
| 91 | S IBDUZ=$P($G(^DPT(DFN,.312,$P(IBPPOL,U,4),1)),U,4)
|
---|
| 92 | W !," "_IBCH_" VERIFIED BY "_$P($G(^VA(200,+IBDUZ,0)),U)_" ON "_$$DAT1^IBOUTL($P($G(^DPT(DFN,.312,$P(IBPPOL,U,4),1)),U,3)) D PAUSE^VALM1
|
---|
| 93 | Q
|
---|
| 94 | ;
|
---|
| 95 | VCN ; -- Ask to verifiy patient has no coverage
|
---|
| 96 | ;
|
---|
| 97 | N DA,DLAYGO,DIE,DIR,DR,DIRUT,DUOUT,DIOUT,DTOUT,IBADD,IBEXERR,IBWHER,X,Y
|
---|
| 98 | W !!,?5,"Patient has no effective insurance coverage on file."
|
---|
| 99 | S DIR("B")="No",DIR(0)="Y"
|
---|
| 100 | S DIR("A")=$S(+$G(^IBA(354,DFN,60)):"Re-v",1:"V")_"erify that patient has No Insurance Coverage "
|
---|
| 101 | S DIR("?")="Enter 'Yes' to enter a Verification of No Coverage Date"
|
---|
| 102 | D ^DIR
|
---|
| 103 | I Y D
|
---|
| 104 | .I '$D(^IBA(354,DFN)) D ADDP^IBAUTL6 I '$G(IBADD) W " <Try again Later>" Q
|
---|
| 105 | .S DA=DFN,DIE="^IBA(354,",DR=60 D ^DIE I $D(Y)=0 N IBX S IBX=$P($G(^DPT(DFN,.31)),"^",11) D
|
---|
| 106 | ..I X]""&(IBX'="N") S IBX="N",$P(^DPT(DFN,.31),"^",11)="N" D MSG
|
---|
| 107 | ..I X']""&(IBX'="U") S IBX="U",$P(^DPT(DFN,.31),"^",11)="U" D MSG
|
---|
| 108 | ..Q
|
---|
| 109 | Q
|
---|
| 110 | ;
|
---|
| 111 | EPOL(DFN) ; Does the patient have any effective policies?
|
---|
| 112 | ; Input: DFN -- Pointer to the patient in file #2
|
---|
| 113 | ; Output: 0 -- The patient has no effective policies
|
---|
| 114 | ; 1 -- The patient has at least one effective policy
|
---|
| 115 | ;
|
---|
| 116 | N J,X,Y S Y=0
|
---|
| 117 | S J=0 F S J=$O(^DPT(DFN,.312,J)) Q:'J S X=$G(^(J,0)) D Q:Y
|
---|
| 118 | .I '$P(X,"^",4) S Y=1 Q
|
---|
| 119 | .I $P(X,"^",4)>DT S Y=1
|
---|
| 120 | Q Y
|
---|
| 121 | ;
|
---|
| 122 | MSG ;If there is a change in the status of the covered by health insurance
|
---|
| 123 | ;field #11 in the Patient file #2, The user is notified of the change.
|
---|
| 124 | I '$D(ZTQUEUED) S VALMSG="COVERED BY HEALTH INSURANCE changed to '"_IBX_$S(IBX="U":"NKNOWN'",1:"O'")
|
---|
| 125 | Q
|
---|