1 | IBCEF78 ;ALB/WCJ - Provider ID functions ;13 May 2007
|
---|
2 | ;;2.0;INTEGRATED BILLING;**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 | PAYERIDS(IBXIEN,IBRET) ; This function returns all the PAYER IDS for the current and other insurance(s)
|
---|
9 | ;
|
---|
10 | D PRIPAYID(IBXIEN,.IBRET)
|
---|
11 | D SECPAYID(IBXIEN,.IBRET)
|
---|
12 | Q
|
---|
13 | ;
|
---|
14 | PRIPAYID(IBXIEN,IBXRET) ; Primary Payer IDs
|
---|
15 | ; Incoming:
|
---|
16 | ; IBXIEN = IEN for File # 399
|
---|
17 | ; IBXRET = Return Array for Qualifiers and IDs
|
---|
18 | ;
|
---|
19 | ; Outgoing
|
---|
20 | ; IBXRET("CI_PID",1)=QUAL^ID
|
---|
21 | ; IBXRET("OI_PID",#)=QUAL^ID
|
---|
22 | ;
|
---|
23 | N RET,I
|
---|
24 | S RET=$$PAYERID^IBCEF2(IBXIEN)
|
---|
25 | I RET]"" S IBXRET("CI_PID",1)="PI"_U_RET
|
---|
26 | ;
|
---|
27 | D OTHINSID^IBCEF72(IBXIEN,.RET)
|
---|
28 | F I=1,2 I $G(RET(I))]"" S IBXRET("OI_PID",I)="PI"_U_RET(I)
|
---|
29 | Q
|
---|
30 | ;
|
---|
31 | ;
|
---|
32 | SECPAYID(IBXIEN,IBXRET) ; This returns all of the secondary payer IDs from file #36
|
---|
33 | ; for the insurance companies on a given claim
|
---|
34 | ;
|
---|
35 | ; Incoming:
|
---|
36 | ; IBXIEN = IEN for File # 399
|
---|
37 | ; IBXRET = Return Array for Qualifiers and IDs
|
---|
38 | ;
|
---|
39 | ; Outgoing
|
---|
40 | ; IBXRET("CI_PSIDS",1)=QUAL^ID^QUAL^ID
|
---|
41 | ; IBXRET("OI_PSIDS",#)=QUAL^ID^QUAL^ID
|
---|
42 | ;
|
---|
43 | N Z,C,IBZ,Z0,FT
|
---|
44 | F Z=1:1:3 S IBZ(Z)=$$POLICY^IBCEF(IBXIEN,1,Z)
|
---|
45 | S Z0=0,C=$$COBN^IBCEF(IBXIEN),FT=$$FT^IBCEF(IBXIEN)
|
---|
46 | F Z=1:1:3 S:C'=Z Z0=Z0+1 S IBXRET($S(C=Z:"CI_PSIDS",1:"OI_PSIDS"),$S(C=Z:1,1:Z0))=$$SPIDS(+IBZ(Z),FT)
|
---|
47 | Q
|
---|
48 | ;
|
---|
49 | SPIDS(INS,FT) ;
|
---|
50 | ; FT = FORM TYPE (2 PROFESSIONAL 3 INSTITUTIONAL)
|
---|
51 | ; INS = INSURANCE COMPANY (FILE #36) IEN
|
---|
52 | ; Returns String (^ delimited)
|
---|
53 | ; [1] = QUAL 1
|
---|
54 | ; [2] = PAYER ID 1
|
---|
55 | ; [3] = QUAL 2
|
---|
56 | ; [4] = PAYER ID 2
|
---|
57 | Q:'+INS ""
|
---|
58 | ;
|
---|
59 | N DATA,PCE
|
---|
60 | S DATA=$S(FT=3:$P($G(^DIC(36,+INS,6)),U,1,4),FT=2:$P($G(^DIC(36,+INS,6)),U,5,8),1:"")
|
---|
61 | ;
|
---|
62 | ; Check for dangling IDs/Qualifiers
|
---|
63 | F PCE=1,3 D
|
---|
64 | . I $P(DATA,U,PCE)'="",$P(DATA,U,PCE+1)'="" Q
|
---|
65 | . S ($P(DATA,U,PCE),$P(DATA,U,PCE+1))=""
|
---|
66 | ;
|
---|
67 | ; fill in the gap if there is one
|
---|
68 | I $P(DATA,U,1)="",$P(DATA,U,3)'="" D
|
---|
69 | . S $P(DATA,U,1)=$P(DATA,U,3)
|
---|
70 | . S $P(DATA,U,2)=$P(DATA,U,4)
|
---|
71 | . S ($P(DATA,U,3),$P(DATA,U,4))=""
|
---|
72 | ;
|
---|
73 | Q DATA
|
---|
74 | ;
|
---|
75 | CLEANUP(IBRET) ;
|
---|
76 | K IBRET("CI_PID"),IBRET("OI_PID"),IBRET("CI_PSIDS"),IBRET("OI_PSIDS")
|
---|
77 | Q
|
---|
78 | ;
|
---|