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

IBJTLA1.m

Go to the documentation of this file.
  1. IBJTLA1 ;ALB/ARH - TPI ACTIVE BILLS LIST BUILD ;2/14/95
  1. ;;2.0;INTEGRATED BILLING;**39,80,61,51,153,137,183,276,451,516,530,568,592**;21-MAR-94;Build 58
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;
  1. BLDA ; build active list for third party joint inquiry active list
  1. N IBIFN,IBCNT S VALMCNT=0,IBCNT=0
  1. S IBIFN=0 F S IBIFN=$O(^DGCR(399,"C",DFN,IBIFN)) Q:'IBIFN I $$ACTIVE^IBJTU4(IBIFN) W "." D SCRN
  1. ;
  1. I VALMCNT=0 D SET(" ",0),SET("No Active Bills for this Patient",0)
  1. ;
  1. Q
  1. ;
  1. SCRN ; add bill to screen list (IBIFN,DFN must be defined)
  1. N X,IBY,IBD0,IBDU,IBDM,TYPE,REJFLAG,INDFLG,IBJTLA1 S X=""
  1. S IBCNT=IBCNT+1,IBD0=$G(^DGCR(399,+IBIFN,0)),IBDU=$G(^DGCR(399,+IBIFN,"U")),IBDM=$G(^DGCR(399,+IBIFN,"M"))
  1. S IBY=IBCNT,X=$$SETFLD^VALM1(IBY,X,"NUMBER")
  1. ; IB*2.0*451 - get EEOB indicator for bill # when applicable
  1. S IBPFLAG=$$EEOB(+IBIFN)
  1. S REJFLAG=+$$BILLREJ^IBJTU6($P(IBD0,U)) ;IB*2.0*530 Add indicator for rejects
  1. S INDFLG=$S($G(IBPFLAG)'="":"%",1:"")_$S(REJFLAG:"c",1:"") S:INDFLG="" INDFLG=" "
  1. S IBY=INDFLG_$P(IBD0,U,1)_$$ECME^IBTRE(IBIFN),X=$$SETFLD^VALM1(IBY,X,"BILL") ;add EEOB indicator '%' to bill number when applicable
  1. S IBY=$S($$REF^IBJTU31(+IBIFN):"r",1:""),X=$$SETFLD^VALM1(IBY,X,"REFER")
  1. S IBY=$S($$IB^IBRUTL(+IBIFN,0):"*",1:""),X=$$SETFLD^VALM1(IBY,X,"HD")
  1. S IBY=$$DATE($P(IBDU,U,1)),X=$$SETFLD^VALM1(IBY,X,"STFROM")
  1. S IBY=$$DATE($P(IBDU,U,2)),X=$$SETFLD^VALM1(IBY,X,"STTO")
  1. ;
  1. S IBY=$P($$LST^DGMTU(DFN,$P(IBDU,U)),U,4),IBY=$S(IBY="C":"YES",IBY="P":"PEN",IBY="R":"REQ",IBY="G":"GMT",1:"NO"),X=$$SETFLD^VALM1(IBY,X,"MT?")
  1. ;S IBY=$$TYPE($P(IBD0,U,5))_$$TF($P(IBD0,U,6))_$S($P(IBD0,U,27)=1:"I",$P(IBD0,U,27)=2:"P",1:""),X=$$SETFLD^VALM1(IBY,X,"TYPE") ; 516 - baa
  1. S TYPE=$$TYPE($P(IBD0,U,5)) I $E(TYPE,2)="P" S TYPE=$E(TYPE) ; 516 - baa
  1. ;S IBY=TYPE_"/"_$S($P(IBD0,U,27)=1:"I",$P(IBD0,U,27)=2:"P",1:""),X=$$SETFLD^VALM1(IBY,X,"TYPE") ; 516 - baa
  1. ;IB*2.0*592; If the claim is a Dental Claim, set the 2nd piece of the TYPE to "D" for Dental
  1. ;IA# 10116
  1. S IBY=TYPE_"/"_$S($$FT^IBCEF(IBIFN)=7:"D",$P(IBD0,U,27)=1:"I",$P(IBD0,U,27)=2:"P",1:" "),X=$$SETFLD^VALM1(IBY,X,"TYPE") ; 592 (vd-US14) ;568 - lmh ret space if null
  1. ;
  1. ; Return care type for (I)npat,(O)utpat, (R)x or (P)rosthetics - add under TJPI screen TYPE column - 568
  1. S IBTYP=$$TYP^IBRFN(IBIFN)
  1. S IBTYP=$S(IBTYP="":-1,IBTYP="PR":"P",IBTYP="PH":"R",1:IBTYP)
  1. S IBY=IBY_"/"_IBTYP,X=$$SETFLD^VALM1(IBY,X,"TYPE")
  1. ;
  1. S IBY=" "_$P($$ARSTATA^IBJTU4(IBIFN),U,2),X=$$SETFLD^VALM1(IBY,X,"ARST")
  1. ;
  1. S IBY=$P($G(^DGCR(399.3,+$P(IBD0,U,7),0)),U,4),X=$$SETFLD^VALM1(IBY,X,"RATE")
  1. S IBY=$S($$MINS^IBJTU31(+IBIFN):"+",1:""),X=$$SETFLD^VALM1(IBY,X,"CB")
  1. S IBY=+$G(^DGCR(399,+IBIFN,"MP"))
  1. I 'IBY,$$MCRWNR^IBEFUNC($$CURR^IBCEF2(IBIFN)) S IBY=+$$CURR^IBCEF2(IBIFN)
  1. S IBY=$P($G(^DIC(36,+IBY,0)),U,1)
  1. S X=$$SETFLD^VALM1(IBY,X,"INSUR")
  1. S IBY=$$BILL^RCJIBFN2(IBIFN)
  1. S X=$$SETFLD^VALM1($J(+$P(IBY,U,1),8,2),X,"OAMT")
  1. S X=$$SETFLD^VALM1($J(+$P(IBY,U,3),8,2),X,"CAMT")
  1. D SET(X,IBCNT)
  1. Q
  1. ;
  1. DATE(X) ; date in external format
  1. N Y S Y="" I X?7N.E S Y=$E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3)
  1. Q Y
  1. ;
  1. TYPE(X) ; return abbreviated form of Bill Classification (399,.05)
  1. Q $S(X=1:"IP",X=2:"IH",X=3:"OP",X=4:"OH",1:"")
  1. ;
  1. TF(X) ; return abbreviated form of Timeframe of Bill (399,.06)
  1. Q $S(X=2:"-F",X=3:"-C",X=4:"-L",X'=1:"-O",1:"")
  1. ;
  1. SET(X,CNT) ; set up list manager screen array
  1. S VALMCNT=VALMCNT+1
  1. S ^TMP("IBJTLA",$J,VALMCNT,0)=X Q:'CNT
  1. S ^TMP("IBJTLA",$J,"IDX",VALMCNT,+CNT)=""
  1. S ^TMP("IBJTLAX",$J,CNT)=VALMCNT_U_IBIFN
  1. Q
  1. ;
  1. EEOB(IBIFN) ; get payment information
  1. ; IB*2.0*451 - find an EOB payment for a bill
  1. ; input is the IEN for the bill # in file #399 and must be valid,
  1. ; output is the EEOB indicator '%' if a payment is found in file #361.1,
  1. ; exclude EOB type MRA (Medicare).
  1. N IBPFLAG,IBVAL,Z
  1. I $G(IBIFN)=0 Q ""
  1. I '$O(^IBM(361.1,"B",IBIFN,0)) Q "" ; no entry here
  1. I $P($G(^DGCR(399,IBIFN,0)),"^",13)=1 Q "" ;avoid 'ENTERED/NOT REVIEWED' status
  1. ; handle both single and multiple bill entries in file #361.1
  1. S Z=0 F S Z=$O(^IBM(361.1,"B",IBIFN,Z)) Q:'Z D Q:$G(IBPFLAG)="%"
  1. . S IBVAL=$G(^IBM(361.1,Z,0))
  1. . S IBPFLAG=$S($P(IBVAL,"^",4)=1:"",$P(IBVAL,"^",4)=0:"%",1:"")
  1. Q IBPFLAG ; EOB indicator for either 1st or 3rd payment on bill