1 | IBCNSU1 ;ALB/AAS - INSURANCE UTILITY ROUTINE ;19-MAY-93
|
---|
2 | ;;2.0;INTEGRATED BILLING;**103,133,244,371**;21-MAR-94;Build 57
|
---|
3 | ;;Per VHA Directive 2004-038, this routine should not be modified.
|
---|
4 | ;
|
---|
5 | RCHK(X) ; -- Input transform for different revenue codes in file 36
|
---|
6 | ; Returns 1 if passes, 0 if not pass input transform
|
---|
7 | ;
|
---|
8 | N I,Y,RC,NO S Y=0
|
---|
9 | I $G(X)="" G RCHKQ
|
---|
10 | F I=1:1 S RC=$P(X,",",I) Q:RC="" I $S(RC?3N:0,RC?5N:0,1:1) S NO=1 Q
|
---|
11 | I '$G(NO) S Y=1
|
---|
12 | RCHKQ Q Y
|
---|
13 | ;
|
---|
14 | BU(DFN,IBCPOL,IBYR,IBCDFN,IBASK) ; -- Return entry in Benefits Used file
|
---|
15 | ; Input: IBCDFN = pointer to patient file policy (2.312)
|
---|
16 | ; DFN = patient pointer
|
---|
17 | ; IBCPOL = pointer to health insurance policy file
|
---|
18 | ; IBYR = fileman internal date, year will be calendar
|
---|
19 | ; year of the internal date, Default = dt
|
---|
20 | ; IBASK = 1 if want to ask okay to add new entry
|
---|
21 | ;
|
---|
22 | ; Output: IBCBU = pointer to Benefits Used file if added,
|
---|
23 | ; else null
|
---|
24 | ;
|
---|
25 | N DIR,IBCBU
|
---|
26 | S IBCBU=""
|
---|
27 | I $G(IBCPOL)="" G BUQ
|
---|
28 | I $G(IBYR)="" S IBYR=DT
|
---|
29 | ;
|
---|
30 | ;if no match display message
|
---|
31 | I '$O(^IBA(355.4,"APY",IBCPOL,-IBYR,0)) W !!,"You cannot add a new Benefits Used BENEFIT YEAR",!! G BUQ
|
---|
32 | ;
|
---|
33 | ; -- try to find entry for policy for year
|
---|
34 | S IBCBU=$O(^IBA(355.5,"APPY",DFN,IBCPOL,-IBYR,IBCDFN,0))
|
---|
35 | ;
|
---|
36 | ; -- if no match add new entry
|
---|
37 | I 'IBCBU D
|
---|
38 | .I $G(IBASK) S DIR(0)="Y",DIR("A")="Are you adding a new Benefits Used YEAR",DIR("B")="YES" D ^DIR I $D(DIRUT)!(Y<1) S VALMQUIT="" Q
|
---|
39 | .S IBCBU=$$ADDBU(DFN,IBCPOL,IBYR,IBCDFN)
|
---|
40 | .Q
|
---|
41 | ;
|
---|
42 | BUQ Q IBCBU
|
---|
43 | ;
|
---|
44 | ADDBU(DFN,IBCPOL,IBYR,IBCDFN) ; -- add entries to Benefits Used file
|
---|
45 | ; Input: DFN = pointer to patient file
|
---|
46 | ; IBCDFN = point to patient policy (2.312)
|
---|
47 | ; IBCPOL = pointer to health insurance policy file
|
---|
48 | ; IBYR = fileman internal date, year will be calendar
|
---|
49 | ; year of the internal date, Default = dt
|
---|
50 | ;
|
---|
51 | ; Output: IBCBU = pointer to Benefits Used file if added,
|
---|
52 | ; else null
|
---|
53 | ;
|
---|
54 | N %DT,IBN1,IBCBU,DIC,DIE,DR,DA,DLAYGO,DO,DD
|
---|
55 | S IBCBU=""
|
---|
56 | I $G(IBCDFN)="" G ADDBUQ
|
---|
57 | I $G(IBCPOL)="" G ADDBUQ
|
---|
58 | I $G(IBYR)="" S IBYR=DT
|
---|
59 | K DD,DO,DIC,DR S DIC="^IBA(355.5,",DIC(0)="L",DLAYGO=355.5
|
---|
60 | ;
|
---|
61 | ;S IBYR=$E(IBYR,1,3)_"0000"
|
---|
62 | S X=IBCPOL D FILE^DICN I +Y<0 G ADDBUQ
|
---|
63 | S (IBCBU,DA)=+Y,DIE="^IBA(355.5,",DR=".02////"_DFN_";.03////"_IBYR_";.17////"_IBCDFN_";1.01///NOW;1.02////"_DUZ
|
---|
64 | D ^DIE K DIC,DIE,DA,DR
|
---|
65 | ADDBUQ Q IBCBU
|
---|
66 | ;
|
---|
67 | VET() ; -- Input Transform for sub-file 2.312, Name of Insured (#17)
|
---|
68 | ; Quit 1 to stuff Patient Name
|
---|
69 | ; Quit 0 to not stuff and allow editing
|
---|
70 | ;
|
---|
71 | N IBY,IB0 S IBY=0
|
---|
72 | G VETQ ; IB*2*371 - Allow edits to the patient name in all cases
|
---|
73 | S IB0=$G(^DPT(+$G(DA(1)),.312,+$G(DA),0))
|
---|
74 | I $P(IB0,"^",6)'="v" G VETQ
|
---|
75 | I +IB0'=+$$GETWNR^IBCNSMM1 S IBY=1 G VETQ
|
---|
76 | I '$D(X),$P(IB0,"^",17)="" S IBY=1
|
---|
77 | VETQ Q IBY
|
---|
78 | ;
|
---|
79 | ;
|
---|
80 | SUBID ; -- Input Transform for sub-file #2.312, Subscriber ID (#1)
|
---|
81 | N NODE,L,R,CHAR,X1
|
---|
82 | S CHAR="~`!@#$%^&*()_-+={}[]|\/?.,<>;:' """
|
---|
83 | S NODE=^DPT(DA(1),.312,DA,0)
|
---|
84 | ;
|
---|
85 | ; - if the policy is a Medicare policy, make sure the subscriber ID
|
---|
86 | ; is a valid HICN number
|
---|
87 | I $P(NODE,U)=+$$GETWNR^IBCNSMM1 S X=$TR(X,"-","") I '$$VALHIC^IBCNSMM(X) D HLP^IBCNSM32 K X Q
|
---|
88 | ;
|
---|
89 | S R=$P(NODE,U,16)
|
---|
90 | S L=$TR($P(^DPT(DA(1),0),U,9),CHAR,"")
|
---|
91 | S R=$S(R="01":1,R="":1,1:0)
|
---|
92 | ;
|
---|
93 | ; - if subscriber ID is the SSN of patient, remove all extraneous
|
---|
94 | ; characters
|
---|
95 | S X1=$TR(X,CHAR,"") I X1?9N,X1=L S X=X1
|
---|
96 | ;
|
---|
97 | K:$L(X)>20!($L(X)<3) X
|
---|
98 | Q
|
---|
99 | ;
|
---|
100 | ;
|
---|
101 | HICN(DFN) ; -- return Patient's Medicare HIC number
|
---|
102 | ; Return HICN of Medicare WNR Part A or Part B
|
---|
103 | ; Return -1 if none exits
|
---|
104 | ;
|
---|
105 | N IBWNR,IBX,IBY,IB0
|
---|
106 | S IBWNR=$$GETWNR^IBCNSMM1,IBY=""
|
---|
107 | I '$O(^DPT(DFN,.312,"B",+IBWNR,0)) S IBY=-1 G HICNQ
|
---|
108 | S IBX=0 F S IBX=$O(^DPT(DFN,.312,"B",+IBWNR,IBX)) Q:('IBX)!(IBY]"") D
|
---|
109 | .S IB0=$G(^DPT(DFN,.312,IBX,0))
|
---|
110 | .I $P(IB0,U,18)'=$P(IBWNR,U,3),$P(IB0,U,18)'=$P(IBWNR,U,5) Q
|
---|
111 | .; 8/18/2003 - Added translation code to remove hyphens if they exist.
|
---|
112 | .I $P(IB0,U,2)]"" S IBY=$TR($P(IB0,U,2),"- ","")
|
---|
113 | S:IBY="" IBY=-1
|
---|
114 | HICNQ Q IBY
|
---|
115 | ;
|
---|
116 | CHKQUAL(DFN,IEN,QUAL,PC1,PC2) ; check for duplicate qualifiers for patient
|
---|
117 | ; and subscriber secondary ID's. All parameters required.
|
---|
118 | ;
|
---|
119 | ; DFN - internal patient#
|
---|
120 | ; IEN - ien of 2.312 subfile
|
---|
121 | ; QUAL - passed in response of the user (this is what is being
|
---|
122 | ; checked to see if it is valid)
|
---|
123 | ; PC1 - this is the piece# for one of the other qualifiers
|
---|
124 | ; PC2 - this is the piece# for one of the other qualifiers
|
---|
125 | ;
|
---|
126 | ; Function returns 1 if the entered qualifier is OK.
|
---|
127 | ; Function returns 0 if the entered qualifier is not OK. It is either
|
---|
128 | ; a duplicate or is otherwise invalid.
|
---|
129 | ;
|
---|
130 | NEW OK,DATA,INS
|
---|
131 | S OK=1
|
---|
132 | I $G(QUAL)="" G CHKQUALX
|
---|
133 | S DATA=$G(^DPT(+$G(DFN),.312,+$G(IEN),5))
|
---|
134 | I $G(QUAL)=$P(DATA,U,+$G(PC1)) D CQ1 G CHKQUALX ; duplicate
|
---|
135 | I $G(QUAL)=$P(DATA,U,+$G(PC2)) D CQ1 G CHKQUALX ; duplicate
|
---|
136 | ;
|
---|
137 | ; prevent the SSN qualifier when Medicare is the payer
|
---|
138 | S INS=+$G(^DPT(+$G(DFN),.312,+$G(IEN),0))
|
---|
139 | I $G(QUAL)="SY",$$MCRWNR^IBEFUNC(INS) D CQ2 G CHKQUALX
|
---|
140 | ;
|
---|
141 | CHKQUALX ;
|
---|
142 | Q OK
|
---|
143 | ;
|
---|
144 | CQ1 ; specific error message#1
|
---|
145 | S OK=0
|
---|
146 | D EN^DDIOL("You cannot use the same qualifier more than once.",,"!!")
|
---|
147 | D EN^DDIOL("",,"!!?5")
|
---|
148 | Q
|
---|
149 | ;
|
---|
150 | CQ2 ; specific error message#2
|
---|
151 | S OK=0
|
---|
152 | D EN^DDIOL("You cannot use qualifier 'SY' for Medicare.",,"!!")
|
---|
153 | D EN^DDIOL("",,"!!?5")
|
---|
154 | Q
|
---|
155 | ;
|
---|