Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: IBRFN4

IBRFN4.m

Go to the documentation of this file.
  1. IBRFN4 ;ALB/TMK - Supported functions for AR/IB DATA EXTRACT ;15-FEB-2005
  1. ;;2.0;INTEGRATED BILLING;**301,305,389,516**;21-MAR-94;Build 123
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;
  1. IBAREXT(IBIFN,IBD) ; Returns data for claim IBIFN for IB/AR Extract
  1. ; Data returned (pieces):
  1. ; 1-MEDICARE Status (0=not MRA secondary, 1=MRA secondary)
  1. ; 2-Last MRA requested date "S";7 (7 - INTERNAL)
  1. ; 3-Last Electronic extract date "TX";2 (21 - INTERNAL)
  1. ; 4-Printed via EDI "TX";7 (26 - EXTERNAL)
  1. ; 5-Force Claim to Print "TX";8 (27 - EXTERNAL)
  1. ; 6-Claim MRA Status "TX";5 (24 - EXTERNAL)
  1. ; 7-MRA recorded date "TX";3 (22 - INTERNAL)
  1. ; 8-Bill cancelled date "S";17 (17 - INTERNAL)
  1. ; 9-form type 0;19 (.19 - EXTERNAL)
  1. ; 10-Current Payer $$CURR^IBCEF2(IBIFN) returns IEN;NAME (file 36)
  1. ; 11-DRG 0;8==> file 45 (9 - EXTERNAL)
  1. ; 12-ECME # "M1";8 (460 - EXTERNAL)
  1. ; 13-NON-VA Facility
  1. ; 14-#Days Site Not Responsible for MRA ($$DAYS(IBIFN))
  1. ; 15-National VA id number for Ins Verification (365.12;.02 - INTERNAL)
  1. ; 16-Payer name (file 365.12;.01)
  1. ; 17-Offset Amount (202-INTERNAL)
  1. ;
  1. ; IBD("PRD",seq #)=prosthetic item name^date^bill ien
  1. ; IBD("IN")= TYPE OF PLAN NAME ^ GROUP NUMBER ^ RELATIONSHIP TO INSURED
  1. ; ^ SOURCE OF INFO ^ EDI ID NUMBER - INST ^ EDI ID NUMBER - PROF
  1. ; ^ INSURANCE REIMBURSE
  1. ; IBD("IN","MMA")= MAILING STREET ADDRESS [LINE 1] ^
  1. ; ^ MAILING STREET ADDRESS [LINE 2] ^ CITY ^ STATE NAME ^ ZIP
  1. ;
  1. N IB,IBI,IBJ,IBK,IBX,IBNODE,IBTMP,IBIN,Z
  1. F IBNODE=0,"S","TX","M","U1" S IB(IBNODE)=$G(^DGCR(399,IBIFN,IBNODE))
  1. S IBD=$S($$MRASEC^IBCEF4(IBIFN):1,1:0)
  1. S $P(IBD,U,2)=$P(IB("S"),U,7),$P(IBD,U,3)=$P(IB("TX"),U,2)
  1. S $P(IBD,U,4)=$$GET1^DIQ(399,IBIFN_",",26,"E"),$P(IBD,U,5)=$$GET1^DIQ(399,IBIFN_",",27,"E")
  1. S $P(IBD,U,6)=$$GET1^DIQ(399,IBIFN_",",24,"E"),$P(IBD,U,7)=$P(IB("TX"),U,3)
  1. S $P(IBD,U,8)=$P(IB("S"),U,17),$P(IBD,U,9)=$$GET1^DIQ(399,IBIFN_",",.19,"E")
  1. S Z=$$CURR^IBCEF2(IBIFN),$P(IBD,U,10)=Z_$S(Z:";"_$P($G(^DIC(36,Z,0)),U),1:"")
  1. S Z=$P($G(^DIC(36,+Z,3)),U,10),$P(IBD,U,15)=$P($G(^IBE(365.12,+Z,0)),U,2),$P(IBD,U,16)=$P($G(^(0)),U)
  1. S Z=$P(IB(0),U,8),$P(IBD,U,11)=$S(Z:$$GET1^DIQ(45,Z_",",9,"E"),1:"")
  1. S $P(IBD,U,12)=$$GET1^DIQ(399,IBIFN_",",460,"E")
  1. S Z=$P($G(^DGCR(399,IBIFN,"U2")),U,10),$P(IBD,U,13)=$S(Z:$P($G(^IBA(355.93,Z,0)),U,1),1:"")
  1. ;
  1. S $P(IBD,U,14)=$$DAYS(IBIFN)
  1. S $P(IBD,U,17)=$P(IB("U1"),U,2)
  1. ;
  1. K IBTMP D SET^IBCSC5B(IBIFN,.IBTMP)
  1. S (IBI,IBJ)=0 F S IBI=$O(IBTMP(IBI)) Q:'IBI D
  1. . S IBK=0 F S IBK=$O(IBTMP(IBI,IBK)) Q:'IBK D
  1. .. S IBX=IBTMP(IBI,IBK)
  1. .. S IBJ=IBJ+1
  1. .. S IBD("PRD",IBJ)=$$PINB^IBCSC5B(+IBX)_U_IBI_U_+IBTMP
  1. ;
  1. S Z=" ",IBD("IN")="",DFN=+$P(IB(0),U,2)
  1. F S Z=$O(^DPT(DFN,.312,Z),-1) Q:Z="" D Q:Z=""
  1. . ;IB*2.0*516/TAZ - Use HIPAA compliant fields
  1. . ;S IBIN=$G(^DPT(DFN,.312,Z,0)) ; 516 - baa
  1. . S IBIN=$$ZND^IBCNS1(DFN,Z) ; 516 - baa
  1. . I +IB("M")=+IBIN D
  1. .. N IBQ,IBP
  1. .. S IBP=+$P(IBIN,U,18),IBQ=$G(^IBA(355.3,+IBP,0))
  1. .. ;S IBD("IN")=$S($P(IBQ,U,9):$$GET1^DIQ(355.3,IBP_",",.09,"E"),1:"")_U_$P(IBQ,U,4)_U_$P(IBIN,U,6)_U_$P($G(^DPT(DFN,.312,Z,1)),U,9)
  1. .. S IBD("IN")=$$GET1^DIQ(355.3,IBP_",",.09,"E")_U_$P(IBIN,U,3)_U_$P(IBIN,U,6)_U_$P($G(^DPT(DFN,.312,Z,1)),U,9)
  1. .. S Z=""
  1. ;
  1. S Z=$G(^DIC(36,+IB("M"),3))
  1. S $P(IBD("IN"),U,5)=$P(Z,U,4),$P(IBD("IN"),U,6)=$P(Z,U,2)
  1. S $P(IBD("IN"),U,7)=$$GET1^DIQ(36,+IB("M")_",",1,"I")
  1. S Z=$G(^DIC(36,+IB("M"),.11))
  1. S IBD("IN","MMA")=$P(Z,U,1)_U_$P(Z,U,2)_U_$P(Z,U,4)_U_$S($P(Z,U,5):$P($G(^DIC(5,$P(Z,U,5),0)),U,1),1:"")_U_$P(Z,U,6)
  1. ;
  1. Q IBD
  1. ;
  1. IBACT(IBIFN,IBARRY) ; Returns IB actions for bill ien IBIFN
  1. ;IBARRY should be passed by reference and returns:
  1. ;
  1. ; IBARRY(seq)=AR bill #^reference #^external STATUS^IB ACTION TYPE NAME
  1. ; ^UNITS^TOTAL CHARGE^DT BILLD FROM^DT BILLD TO^AR BILL IEN
  1. ; ^DT ENTRY ADDED^PATIENT SSN^EVENT DATE^RESULTING FROM
  1. ; ^INSTITUTION IEN
  1. ;
  1. N IBNA,IB,IB0,DFN,IBCT,Z
  1. S IBNA=$$BN1^PRCAFN(IBIFN),IB="",IBCT=0
  1. F S IB=$O(^IB("ABIL",IBNA,IB)) Q:IB="" D
  1. . S IBCT=IBCT+1
  1. . S IB0=$G(^IB(IB,0))
  1. . I $G(DFN)="" S DFN=$P(IB0,U,2)
  1. . ;
  1. . S IBARRY=IBNA_U_$P(IB0,U,1)_U_$$GET1^DIQ(350,IB_",",.05,"E")
  1. . S Z=$P(IB0,U,3)
  1. . S IBARRY=IBARRY_U_$S(Z'="":$P($G(^IBE(350.1,Z,0)),U,1),1:"")
  1. . S IBARRY=IBARRY_U_$P(IB0,U,6) ; UNITS
  1. . S IBARRY=IBARRY_U_$P(IB0,U,7) ; TOTAL CHARGE
  1. . S IBARRY=IBARRY_U_$P(IB0,U,14) ; DT BILLD FROM
  1. . S IBARRY=IBARRY_U_$P(IB0,U,15) ; DT BILLD TO
  1. . S IBARRY=IBARRY_U_$P(IB0,U,11) ; AR BILL #
  1. . S IBARRY=IBARRY_U_$P($P($G(^IB(IB,1)),U,2),".",1) ; DT ENTRY ADDED
  1. . S IBARRY=IBARRY_U_$P(^DPT(DFN,0),U,9) ; SSN
  1. . S IBARRY=IBARRY_U_$P(IB0,U,17) ; EVENT DT
  1. . S IBARRY=IBARRY_U_$P(IB0,U,4) ;RESULTING FROM
  1. . S IBARRY=IBARRY_U_$P(IB0,U,13) ; Institution
  1. . S IBARRY(IBCT)=IBARRY,IBARRY=""
  1. Q
  1. ;
  1. PREREG(IBBDT,IBEDT) ;Returns Pre-registration data
  1. N IBDATA
  1. S IBDATA=$$IBAR^IBJDIPR(IBBDT,IBEDT)
  1. Q IBDATA
  1. ;
  1. BUFFER(IBBDT,IBEDT) ;Returns Buffer data
  1. N IBDATA
  1. S IBDATA=$$IBAR^IBCNBOA(IBBDT,IBEDT)
  1. Q IBDATA
  1. ;
  1. DAYS(IBIFN) ; Returns # days site not responsible for MRA
  1. N X,X1,X2,D0
  1. S X="" ;No. of days
  1. G:'$P(IBD,U,2) DAYSQ
  1. S X2=$P(IBD,U,2) ;MRA Request Date
  1. S X1=$P(IBD,U,7) ;MRA Recorded Date
  1. G:'$$MRASEC^IBCEF4(IBIFN) DAYSQ ; Not MEDICARE secondary
  1. I 'X1!(X1<X2) S X1=DT
  1. D ^%DTC
  1. DAYSQ Q X
  1. ;
  1. REJ(IBIFN) ; Returns 1 if any rejects found for MRA secondary claim or for
  1. ; any preceding claims it was cancelled/cloned from
  1. N X,Y,I,X1,X2,X3,D0,CURSEQ
  1. S Y=0 ;Y=REJECT FLAG
  1. G:'$$MRASEC^IBCEF4(IBIFN) REJQ ; Not MEDICARE secondary
  1. S CURSEQ=$$COBN^IBCEF(IBIFN),X1=+$P($G(^DGCR(399,IBIFN,0)),U,15)
  1. S D0=IBIFN
  1. F D Q:'D0!Y
  1. . ; claim copied from not cancelled and not MRA secondary claim
  1. . I X1,$P($G(^DGCR(399,X1,0)),U,13)'=7,X1'=IBIFN S D0="" Q
  1. . I X1,$P($G(^DGCR(399,X1,0)),U,19)'=$P($G(^DGCR(399,D0,0)),U,19) S D0="" Q
  1. . S I=0 F S I=$O(^IBM(361,"B",D0,I)) Q:'I D Q:Y
  1. .. S X2=$G(^IBM(361,I,0))
  1. .. Q:$P(X2,U,3)'="R"!'$P(X2,U,11) ;No reject or no transmit bill
  1. .. S X3=$TR($P($G(^IBA(364,+$P(X2,U,11),0)),U,8),"PST","123") ;status msg seq
  1. .. Q:X3'=(CURSEQ-1)
  1. .. S Y=1
  1. . I 'Y S D0=X1,X1=+$P($G(^DGCR(399,X1,0)),U,15) S:X1=D0 D0="" Q
  1. REJQ Q Y