| [623] | 1 | IBCEF75 ;ALB/WCJ - Provider ID functions ;13 Feb 2006
 | 
|---|
 | 2 |  ;;2.0;INTEGRATED BILLING;**320**;21-MAR-94
 | 
|---|
 | 3 |  ;; Per VHA Directive 10-93-142, 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 $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 $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
 | 
|---|