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
|
---|