1 | IBCEF75 ;ALB/WCJ - Provider ID functions ;13 Feb 2006
|
---|
2 | ;;2.0;INTEGRATED BILLING;**320,371**;21-MAR-94;Build 57
|
---|
3 | ;;Per VHA Directive 2004-038, this routine should not be modified.
|
---|
4 | ;
|
---|
5 | G AWAY
|
---|
6 | AWAY Q
|
---|
7 | ;
|
---|
8 | ALLIDS(IBIFN,IBXSAVE,IBSTRIP,SEG) ; Return all of the Provider IDS
|
---|
9 | I '$D(IBSTRIP) S IBSTRIP=0
|
---|
10 | I '$D(SEG) S SEG=""
|
---|
11 | N IBXIEN,ARINFO,ARID,ARQ,IBFRMTYP,ARIEN,ARINS,Z0,DAT,I,SORT1,SORT2,SORT3,COB,IBCCOB
|
---|
12 | ;
|
---|
13 | S IBXIEN=IBIFN
|
---|
14 | D ALLPROV^IBCEF7 ; Get the Person ID's (Returns IBXSAVE)
|
---|
15 | S DAT=$$PROVID^IBCEF73(IBIFN)
|
---|
16 | S DAT("QUAL")=IBXSAVE("ID") ; this value was also passed back by above function
|
---|
17 | S SORT1="" F S SORT1=$O(IBXSAVE("PROVINF",IBIFN,SORT1)) Q:SORT1="" D
|
---|
18 | . S SORT2=0 F S SORT2=$O(IBXSAVE("PROVINF",IBIFN,SORT1,SORT2)) Q:SORT2="" D
|
---|
19 | .. S SORT3=0 F S SORT3=$O(IBXSAVE("PROVINF",IBIFN,SORT1,SORT2,SORT3)) Q:SORT3="" D
|
---|
20 | ... S IBXSAVE("PROVINF",IBIFN,SORT1,SORT2,SORT3,0)="PRIMARY"_U_U_$$STRIP^IBCEF76($P(DAT("QUAL"),U,SORT3)_U_$P(DAT,U,SORT3),1,U,IBSTRIP)
|
---|
21 | ... F I=1:1 Q:'$D(IBXSAVE("PROVINF",IBIFN,SORT1,SORT2,SORT3,I)) D
|
---|
22 | .... S $P(IBXSAVE("PROVINF",IBIFN,SORT1,SORT2,SORT3,I),U,3,4)=$$STRIP^IBCEF76($P(IBXSAVE("PROVINF",IBIFN,SORT1,SORT2,SORT3,I),U,3,4),1,U,IBSTRIP)
|
---|
23 | ;
|
---|
24 | D LFIDS^IBCEF76(IBIFN,.IBXSAVE,IBSTRIP,SEG) ; Get the Lab/Facility IDs
|
---|
25 | ;
|
---|
26 | S IBFRMTYP=$$FT^IBCEF(IBIFN)
|
---|
27 | S ARIEN=$S(IBFRMTYP=2:3,1:4)
|
---|
28 | S IBCCOB=$$COBN^IBCEF(IBIFN) ; Current Insurance
|
---|
29 | F COB=1:1:3 D
|
---|
30 | . S SORT1=$S(COB=IBCCOB:"C",1:"O")
|
---|
31 | . S SORT2=$S(SORT1="C":1,COB=1:1,COB=2&(IBCCOB=1):1,1:2)
|
---|
32 | . S ARINFO=$G(IBXSAVE("PROVINF",IBIFN,SORT1,SORT2,ARIEN,1))
|
---|
33 | . ;
|
---|
34 | . D BPIDS(IBIFN,.IBXSAVE,SORT1,SORT2,COB,IBSTRIP,SEG)
|
---|
35 | Q
|
---|
36 | ;
|
---|
37 | BPIDS(IBIFN,IDS,SORT1,SORT2,COB,IBSTRIP,SEG) ; Get all the billing provider IDs and qualifiers from the claim and file 355.92
|
---|
38 | N DAT,IBFRMTYP,IBCARE,IBDIV,IBINS,MAIN,IBCCOB,USED,PLANTYPE,I,CNT,QUAL,ARF,M1,DEF,IDDIV,IBLIMIT,IEN,ID,IB2
|
---|
39 | ;
|
---|
40 | S DAT=$G(^DGCR(399,IBIFN,0))
|
---|
41 | S IBFRMTYP=$$FT^IBCEF(IBIFN),IBFRMTYP=$S(IBFRMTYP=2:2,IBFRMTYP=3:1,1:0)
|
---|
42 | S IBCARE=$S($$ISRX^IBCEF1(IBIFN):3,1:0) ;if an Rx refill bill
|
---|
43 | S:IBCARE=0 IBCARE=$$INPAT^IBCEF(IBIFN,1) S:'IBCARE IBCARE=2 ;1-inp,2-out
|
---|
44 | S IBDIV=+$P(DAT,U,22)
|
---|
45 | S MAIN=$$MAIN^IBCEP2B() ; get the IEN for main Division
|
---|
46 | S IBCCOB=$$COBN^IBCEF(IBIFN) ; Current Insurance
|
---|
47 | S IBINS=$P($G(^DGCR(399,IBIFN,"I"_COB)),U)
|
---|
48 | Q:IBINS=""
|
---|
49 | ;
|
---|
50 | S IDS("BILLING PRV",IBIFN,SORT1,SORT2)=$E("PST",COB)
|
---|
51 | ;
|
---|
52 | ; Primary ID
|
---|
53 | S IDS("BILLING PRV",IBIFN,SORT1,SORT2,0)=$$STRIP^IBCEF76($$TAXID(),1,U,IBSTRIP)
|
---|
54 | S USED($P(IDS("BILLING PRV",IBIFN,SORT1,SORT2,0),U))=""
|
---|
55 | ;
|
---|
56 | ; Secondary #1 - This is the ID Emdeon uses for sorting
|
---|
57 | S IDS("BILLING PRV",IBIFN,SORT1,SORT2,1)=$$STRIP^IBCEF76($$BPSID1(IBDIV),1,U,IBSTRIP)
|
---|
58 | S USED($P(IDS("BILLING PRV",IBIFN,SORT1,SORT2,1),U))=""
|
---|
59 | ;
|
---|
60 | ; Check if this is a plan type which gets no secondary IDs
|
---|
61 | S M1=$G(^DGCR(399,IBIFN,"M1"))
|
---|
62 | ; the following check is the current value of the flag, not when the claim was created.
|
---|
63 | S PLANTYPE=$$POLTYP^IBCEF3(IBIFN,COB)
|
---|
64 | I PLANTYPE]"",$D(^DIC(36,IBINS,13,"B",PLANTYPE)) Q
|
---|
65 | ;
|
---|
66 | ; Secondary #2
|
---|
67 | ; If there is a ID send with quailifer (stored or computed)
|
---|
68 | I $TR($P(M1,U,COB+1)," ")]"" D
|
---|
69 | . S QUAL=""
|
---|
70 | . S DAT=$P(M1,U,COB+9)
|
---|
71 | . I DAT S QUAL=$$STRIP^IBCEF76($P($G(^IBE(355.97,DAT,0)),U,3),1,,IBSTRIP)
|
---|
72 | . ; the null check is needed to be backwards compatible
|
---|
73 | . I QUAL=""!(QUAL="1J") S QUAL=$$STRIP^IBCEF76($$OLDWAY(IBIFN,COB),1,,IBSTRIP)
|
---|
74 | . S IB2=QUAL_U_$$STRIP^IBCEF76($P(M1,U,COB+1),1,,IBSTRIP)
|
---|
75 | ;
|
---|
76 | I $TR($P(M1,U,COB+1)," ")="" S IB2=$$STRIP^IBCEF76($$OLDWAY(IBIFN,COB),1,,IBSTRIP)_U_$$STRIP^IBCEF76($$GET1^DIQ(350.9,1,1.05),1,,IBSTRIP)
|
---|
77 | ;
|
---|
78 | S IDS("BILLING PRV",IBIFN,SORT1,SORT2,2)=IB2
|
---|
79 | S IDS("BILLING PRV",IBIFN,SORT1,SORT2,2,"PTQ")=$$OLDWAY(IBIFN,COB)
|
---|
80 | S USED($P(IB2,U))=""
|
---|
81 | ;
|
---|
82 | S CNT=$S('$D(IDS("BILLING PRV",IBIFN,SORT1,SORT2,2)):2,1:3)
|
---|
83 | S IBLIMIT=8
|
---|
84 | S IEN=0 F S IEN=$O(^IBA(355.92,"B",IBINS,IEN)) Q:IEN="" D Q:CNT>IBLIMIT
|
---|
85 | . S DAT=$G(^IBA(355.92,IEN,0))
|
---|
86 | . Q:$P(DAT,U,8)'="A" ; only allow additional IDs
|
---|
87 | . Q:$P(DAT,U,7)="" ; No Provider ID
|
---|
88 | . Q:$P(DAT,U,6)="" ; No ID Qualifier
|
---|
89 | . I IBFRMTYP=1 Q:$P(DAT,U,4)=2
|
---|
90 | . I IBFRMTYP=2 Q:$P(DAT,U,4)=1
|
---|
91 | . ;
|
---|
92 | . ; Check if we already have one of these
|
---|
93 | . S QUAL=$$STRIP^IBCEF76($P(DAT,U,6),1,,IBSTRIP)
|
---|
94 | . S QUAL=$P($G(^IBE(355.97,QUAL,0)),U,3)
|
---|
95 | . Q:QUAL=""
|
---|
96 | . Q:$D(USED(QUAL))
|
---|
97 | . ;
|
---|
98 | . S IDS("BILLING PRV",IBIFN,SORT1,SORT2,CNT)=QUAL_U_$$STRIP^IBCEF76($P(DAT,U,7),1,,IBSTRIP)
|
---|
99 | . S CNT=CNT+1,USED(QUAL)=""
|
---|
100 | ;
|
---|
101 | Q
|
---|
102 | ;
|
---|
103 | OLDWAY(IBIFN,COB) ; Figure out the qualifier the old way if it's not stored with the claim.
|
---|
104 | ; It's based on the plan type. This is used for Billing Provider Secondary ID #2
|
---|
105 | N PLANTYPE
|
---|
106 | S PLANTYPE=$$POLTYP^IBCEF3(IBIFN,COB)
|
---|
107 | Q $$SOP^IBCEP2B(IBIFN,PLANTYPE)
|
---|
108 | ;
|
---|
109 | BPSID1(DIV) ; Return the Billing Provider Secondary ID #1 and qualifier which Emdeon uses to sort IBIFNs
|
---|
110 | N DATA
|
---|
111 | S DATA=$P($$SITE^VASITE(DT,$S(DIV:DIV,1:+$$SITE^VASITE())),U,3)
|
---|
112 | S DATA=$E("0000",1,7-$L(DATA))_$E(DATA,4,7)
|
---|
113 | Q "G5"_U_DATA
|
---|
114 | ;
|
---|
115 | TAXID() ; Return the Billing Provider Primary ID and qualifier which is the TAXID for the site and also the qualifier
|
---|
116 | N DATA
|
---|
117 | S DATA=$P($G(^IBE(350.9,1,1)),U,5)
|
---|
118 | S DATA=$$NOPUNCT^IBCEF(DATA,1)
|
---|
119 | Q 24_U_DATA
|
---|
120 | ;
|
---|
121 | VAMCFD(IBIFN,IBRET) ;
|
---|
122 | ;
|
---|
123 | ; This procedure returns data based on flag in insurance company file which is set in the insurance co editor
|
---|
124 | ; Send VA Lab/Facility IDs or Facility Data for VAMC?
|
---|
125 | ; The return value will be set to 1 (yes) if the division in the claim is not the main division (VAMC) or
|
---|
126 | ; if the flag in the dictionary for that insurance company says to send the data.
|
---|
127 | ;
|
---|
128 | ; Input - IBFN - IEN 399
|
---|
129 | ; Output - IBRET(IBSORT1,IBSORT2)=FLAG
|
---|
130 | ; IBSORT1 = "C"urrent or "O"ther insurance
|
---|
131 | ; IBSORT2 = order with IBSORT1
|
---|
132 | ; FLAG = 0 No or 1 Yes
|
---|
133 | ;
|
---|
134 | N IBDIV,MAIN,IBCCOB,IBSORT1,IBSORT2,DAT,IBINS,COB,OUTFAC
|
---|
135 | S IBDIV=+$P($G(^DGCR(399,IBIFN,0)),U,22)
|
---|
136 | S MAIN=$$MAIN^IBCEP2B() ; get the IEN for main Division
|
---|
137 | S IBCCOB=$$COBN^IBCEF(IBIFN)
|
---|
138 | F COB=1:1:3 D
|
---|
139 | . S IBSORT1=$S(COB=IBCCOB:"C",1:"O")
|
---|
140 | . S IBSORT2=$S(IBSORT1="C":1,COB=1:1,COB=2&(IBCCOB=1):1,1:2)
|
---|
141 | . S IBINS=+$G(^DGCR(399,IBIFN,"I"_COB))
|
---|
142 | . Q:'IBINS
|
---|
143 | . S IBRET(IBSORT1,IBSORT2)=1
|
---|
144 | . S OUTFAC=$P($G(^DGCR(399,IBIFN,"U2")),U,10)
|
---|
145 | . Q:OUTFAC]""
|
---|
146 | . Q:IBDIV'=MAIN
|
---|
147 | . ; [7] Send VA Lab/Facility IDs or Facility Data for VAMC?(0 - NO, 1 - YES)
|
---|
148 | . S DAT(3647)=$P($G(^DIC(36,IBINS,4)),U,7)
|
---|
149 | . I DAT(3647) Q
|
---|
150 | . S IBRET(IBSORT1,IBSORT2)=0
|
---|
151 | Q
|
---|
152 | ;
|
---|
153 | CLEANUP(IBXSAVE) ; Clean up
|
---|
154 | K IBXSAVE("PROVINF")
|
---|
155 | K IBXSAVE("LAB/FAC")
|
---|
156 | K IBXSAVE("BILLING PRV")
|
---|
157 | K IBXSAVE("ID")
|
---|
158 | Q
|
---|