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

IBJTU1.m

Go to the documentation of this file.
  1. IBJTU1 ;ALB/ARH - TPI UTILITIES ;2/14/95
  1. ;;2.0;INTEGRATED BILLING;**39,80,276,451,516,530,745**;21-MAR-94;Build 8
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;
  1. PRVSCR(SCRNARR) ; called as part of a screen ACTION PROTOCOL'S ENTRY ACTION to determine if screen has already been displayed
  1. ; returns true if screen array already exists (ie. already displayed),
  1. ; setting IBFASTXT causes LM to back out of current screens,
  1. ; setting IBPRVSCR causes LM to stop exiting screens when the chosen screen is reached
  1. ; if user tries to execute a screen already displayed it will quit out of existing screens until the asked for screen is found
  1. N X S X=0,IBPRVSCR="" I $G(SCRNARR)'="",$D(^TMP(SCRNARR,$J)) S X=1,IBPRVSCR=SCRNARR,IBFASTXT=3
  1. Q X
  1. ;
  1. HDR(IBIFN,DFN,LNS) ; called by a screens's LIST TEMPLATE HEADER to get lines for header, used for all TP screens
  1. ;input: LNS=header lines to add --- defined on exit: VALMHDR array
  1. ;
  1. N X,Y,Z,IBD0,IBPD0,IBDI1,IBCNT S IBIFN=+$G(IBIFN),DFN=+$G(DFN),LNS=+$G(LNS) K VALMHDR
  1. S IBCNT=0,IBD0=$G(^DGCR(399,+IBIFN,0)),IBPD0=$G(^DPT(+DFN,0))
  1. ;IB*2.0*516/TAZ - Call $$POLICY^IBCEF to insert HIPAA compliant fields into variable IBDI1. Data will
  1. ;continue to be extracted from IBDI1 original location.
  1. ;S IBDI1=$P(IBD0,U,21),IBDI1=$S(IBDI1="S":"I2",IBDI1="T":"I3",1:"I1"),IBDI1=$G(^DGCR(399,+IBIFN,IBDI1))
  1. S IBDI1=$P(IBD0,U,21),IBDI1=$$POLICY^IBCEF(IBIFN,,IBDI1) ; 516 - baa
  1. ;
  1. 1 I LNS'[1 G 2
  1. ; -- first line of screens: BILL NUMBER, PAT NAME, PAT ID, DOB, SUBSCRIBER ID
  1. N IBBILL,IBPAT,IBPATID,IBDOB,IBSUB,IBPNWDTH,REJFLG S IBCNT=IBCNT+1,(IBSUB,IBPATID)=""
  1. S IBBILL=$P(IBD0,U,1)_$$ECME^IBTRE(IBIFN)
  1. S X=$$PT^IBEFUNC(DFN),IBPAT=$P(X,U,1) ;I $P(X,U,3)'="" S IBPATID=$E(X)_$P(X,U,3) IB*2.0*745 - SSN Removal
  1. ;S X=$$PT^IBEFUNC(DFN),IBPAT=$P(X,U,1) I $P(X,U,3)'="" S IBPATID=$E(X)_$P(X,U,3) ;IB*2.0*745 - SSN Removal
  1. S IBDOB="DOB: "_$$DATE^IBJU1($P(IBPD0,U,3))
  1. I +IBIFN S X=$P(IBDI1,U,2),X=X_$J("",(13-$L(X))),IBSUB="Subsc ID: "_X
  1. ;
  1. ; IB*2.0*530 - Reject Indicator
  1. I ($G(NAME)="IBJT BILL CHARGES")!($G(NAME)="IBJT CLAIM INFO") S REJFLG=$S($$BILLREJ^IBJTU6($P(IBBILL,"e")):"c",1:"")
  1. ; IB*2.0*451 - get EEOB indicator for bill #
  1. S IBPFLAG=$$EEOB^IBJTLA1(IBIFN)
  1. S IBBILL=$G(IBPFLAG)_$G(REJFLG)_IBBILL
  1. S IBPNWDTH=80-($L(IBBILL)+3+2+$L(IBPATID)+3+$L(IBDOB)+3+$L(IBSUB)),IBPAT=$E(IBPAT,1,IBPNWDTH),Z=" "
  1. S VALMHDR(IBCNT)=IBBILL_Z_IBPAT_" "_IBPATID_$J("",(IBPNWDTH-$L(IBPAT)))_Z_IBDOB_Z_IBSUB
  1. ; IB*2.0*451 - add explanation of '%' indicator for the user
  1. S VALMSG="|% EEOB | Enter ?? for more actions|"
  1. 2 I LNS'[2 G 3
  1. ; -- bill screens line 2: STATEMENT DATES, TIMEFRAME, ORIG AMT (AR)
  1. N IBDU S IBCNT=IBCNT+1,IBDU=$G(^DGCR(399,+IBIFN,"U"))
  1. S X=" "_$$DATE^IBJU1(+IBDU)_" - "_$$DATE^IBJU1(+$P(IBDU,U,2)),VALMHDR(IBCNT)=X_$J("",(28-$L(X)))
  1. S X=$$EXSET^IBJU1(+$P(IBD0,U,6),399,.06),VALMHDR(IBCNT)=VALMHDR(IBCNT)_X_$J("",(29-$L(X)))
  1. S X=$$BILL^RCJIBFN2(IBIFN),X="Orig Amt: "_$FN($P(X,U,1),",",2),VALMHDR(IBCNT)=VALMHDR(IBCNT)_X
  1. ; IB*2.0*451 - add explanation of '%' indicator for the user
  1. S VALMSG="|% EEOB | Enter ?? for more actions|"
  1. 3 I LNS'[3 G HDRQ
  1. ; -- AR screens line 2: CURRENT STATUS (AR), ORIGINAL AMT (AR), CURRENT AMT (AR)
  1. N IBST,IBOC,IBBD,IBY S IBCNT=IBCNT+1,IBY=$$BILL^RCJIBFN2(+IBIFN)
  1. S IBST="AR Status: "_$P($$ARSTATA^IBJTU4(+IBIFN),U,1)
  1. S IBOC="Orig Amt: "_$FN($P(IBY,U,1),",",2)
  1. S IBBD="Balance Due: "_$FN($P(IBY,U,3),",",2)
  1. ;
  1. S X=" "_IBOC_$J("",(20-$L(IBOC)))_" "_IBBD_$J("",(23-$L(IBBD))),Y=80-$L(X),IBST=$E(IBST,1,Y)
  1. S VALMHDR(IBCNT)=IBST_$J("",(Y-$L(IBST)))_X
  1. ;
  1. HDRQ Q