1 | IBJTU1 ;ALB/ARH - TPI UTILITIES ;2/14/95
|
---|
2 | ;;2.0;INTEGRATED BILLING;**39,80,276**;21-MAR-94
|
---|
3 | ;;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
4 | ;
|
---|
5 | PRVSCR(SCRNARR) ; called as part of a screen ACTION PROTOCOL'S ENTRY ACTION to determine if screen has already been displayed
|
---|
6 | ; returns true if screen array already exists (ie. already displayed),
|
---|
7 | ; setting IBFASTXT causes LM to back out of current screens,
|
---|
8 | ; setting IBPRVSCR causes LM to stop exiting screens when the chosen screen is reached
|
---|
9 | ; if user tries to execute a screen already displayed it will quit out of existing screens until the asked for screen is found
|
---|
10 | N X S X=0,IBPRVSCR="" I $G(SCRNARR)'="",$D(^TMP(SCRNARR,$J)) S X=1,IBPRVSCR=SCRNARR,IBFASTXT=3
|
---|
11 | Q X
|
---|
12 | ;
|
---|
13 | HDR(IBIFN,DFN,LNS) ; called by a screens's LIST TEMPLATE HEADER to get lines for header, used for all TP screens
|
---|
14 | ;input: LNS=header lines to add --- defined on exit: VALMHDR array
|
---|
15 | ;
|
---|
16 | N X,Y,Z,IBD0,IBPD0,IBDI1,IBCNT S IBIFN=+$G(IBIFN),DFN=+$G(DFN),LNS=+$G(LNS) K VALMHDR
|
---|
17 | S IBCNT=0,IBD0=$G(^DGCR(399,+IBIFN,0)),IBPD0=$G(^DPT(+DFN,0))
|
---|
18 | S IBDI1=$P(IBD0,U,21),IBDI1=$S(IBDI1="S":"I2",IBDI1="T":"I3",1:"I1"),IBDI1=$G(^DGCR(399,+IBIFN,IBDI1))
|
---|
19 | ;
|
---|
20 | 1 I LNS'[1 G 2
|
---|
21 | ; -- first line of screens: BILL NUMBER, PAT NAME, PAT ID, DOB, SUBSCRIBER ID
|
---|
22 | N IBBILL,IBPAT,IBPATID,IBDOB,IBSUB,IBPNWDTH S IBCNT=IBCNT+1,(IBSUB,IBPATID)=""
|
---|
23 | S IBBILL=$P(IBD0,U,1)_$$ECME^IBTRE(IBIFN)
|
---|
24 | S X=$$PT^IBEFUNC(DFN),IBPAT=$P(X,U,1) I $P(X,U,3)'="" S IBPATID=$E(X)_$P(X,U,3)
|
---|
25 | S IBDOB="DOB: "_$$DATE^IBJU1($P(IBPD0,U,3))
|
---|
26 | I +IBIFN S X=$P(IBDI1,U,2),X=X_$J("",(13-$L(X))),IBSUB="Subsc ID: "_X
|
---|
27 | ;
|
---|
28 | S IBPNWDTH=80-($L(IBBILL)+3+2+$L(IBPATID)+3+$L(IBDOB)+3+$L(IBSUB)),IBPAT=$E(IBPAT,1,IBPNWDTH),Z=" "
|
---|
29 | S VALMHDR(IBCNT)=IBBILL_Z_IBPAT_" "_IBPATID_$J("",(IBPNWDTH-$L(IBPAT)))_Z_IBDOB_Z_IBSUB
|
---|
30 | ;
|
---|
31 | 2 I LNS'[2 G 3
|
---|
32 | ; -- bill screens line 2: STATEMENT DATES, TIMEFRAME, ORIG AMT (AR)
|
---|
33 | N IBDU S IBCNT=IBCNT+1,IBDU=$G(^DGCR(399,+IBIFN,"U"))
|
---|
34 | S X=" "_$$DATE^IBJU1(+IBDU)_" - "_$$DATE^IBJU1(+$P(IBDU,U,2)),VALMHDR(IBCNT)=X_$J("",(28-$L(X)))
|
---|
35 | S X=$$EXSET^IBJU1(+$P(IBD0,U,6),399,.06),VALMHDR(IBCNT)=VALMHDR(IBCNT)_X_$J("",(29-$L(X)))
|
---|
36 | S X=$$BILL^RCJIBFN2(IBIFN),X="Orig Amt: "_$FN($P(X,U,1),",",2),VALMHDR(IBCNT)=VALMHDR(IBCNT)_X
|
---|
37 | ;
|
---|
38 | 3 I LNS'[3 G HDRQ
|
---|
39 | ; -- AR screens line 2: CURRENT STATUS (AR), ORIGINAL AMT (AR), CURRENT AMT (AR)
|
---|
40 | N IBST,IBOC,IBBD,IBY S IBCNT=IBCNT+1,IBY=$$BILL^RCJIBFN2(+IBIFN)
|
---|
41 | S IBST="AR Status: "_$P($$ARSTATA^IBJTU4(+IBIFN),U,1)
|
---|
42 | S IBOC="Orig Amt: "_$FN($P(IBY,U,1),",",2)
|
---|
43 | S IBBD="Balance Due: "_$FN($P(IBY,U,3),",",2)
|
---|
44 | ;
|
---|
45 | S X=" "_IBOC_$J("",(20-$L(IBOC)))_" "_IBBD_$J("",(23-$L(IBBD))),Y=80-$L(X),IBST=$E(IBST,1,Y)
|
---|
46 | S VALMHDR(IBCNT)=IBST_$J("",(Y-$L(IBST)))_X
|
---|
47 | ;
|
---|
48 | HDRQ Q
|
---|