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

IBCONS1.m

Go to the documentation of this file.
  1. IBCONS1 ;ALB/AAS - NSC PATIENTS W/ INS BACKGROUND PRINTS ;7 JUN 90
  1. ;;2.0;INTEGRATED BILLING;**66,80,137,516,528**;21-MAR-94;Build 163
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;
  1. ;MAP TO DGCRONS1
  1. ;
  1. EN ; Inpatient Discharge entry to que background once weekly
  1. S IBINPT=2,IBSUB="AMV3" G QUEUE
  1. ;
  1. EN1 ; Inpatient Admission entry to que background once weekly
  1. S IBINPT=1,IBSUB="AMV1" G QUEUE
  1. ;
  1. EN2 ; Outpatient entry to que background once weekly
  1. S IBINPT=0,IBSUB=""
  1. ;
  1. QUEUE ; Set up the background job to run for the previous week
  1. ; o For All Divisions
  1. ; o For Insured veterans with unbilled episodes of care
  1. ; o With the output sorted by Terminal Digit
  1. ;
  1. K ^TMP($J)
  1. S X="T",%DT="" D ^%DT S IBEND=+Y
  1. S X="T-7",%DT="" D ^%DT S IBBEG=+Y K %DT
  1. S (VAUTD,IBSELUBL,IBSELTRM,IBSELRNB)=1
  1. U IO G BEGIN^IBCONSC
  1. ;
  1. ;
  1. LOOP25 ; Print all NSC w/Insurance reports.
  1. I "^R^E^"'[(U_$G(IBOUT)_U) S IBOUT="R"
  1. S IBQUIT=0,IBFL=1,IBHDRDV="",IBSUM=0,IBPTINFO="" I +$G(IBSELCDV),IBOUT="R" D HDRDV^IBCONSC
  1. I IBOUT="E" D PHDL
  1. S IBDV="" F S IBDV=$O(^TMP($J,IBDV)) Q:IBDV="" I IBDV'="TOTAL" D LOOP3 Q:IBQUIT
  1. ;
  1. G:IBQUIT Q S IBSUM=1,IBPAGE=0 D:IBOUT="R" HEAD Q:IBQUIT
  1. S IBDV="" F S IBDV=$O(^TMP($J,"TOTAL",IBDV)) Q:IBDV="" D PRNSUM
  1. D PAUSE
  1. ;
  1. Q K %,%DT,B,I,J,K,L,M,X,X1,X2,Y,DFN,IBCNT,IBIFN,IBBILL,IBDATE,IBFLAG,IBI,IBDT,IBPAGE,IBL,IBHD,IBBEG1,IBHDRDV,IBSUM
  1. K IBBEG,IBEND,IBOUT,IBINPT,IBFLAG,IBNAME,IBAPPT,IBDC,IBDAT,IBDFN,POP,IBNEWPT,IBPTINFO,^TMP($J)
  1. Q
  1. ;
  1. ;
  1. LOOP3 ; Loop through billed, unbilled, or both types of episodes of care.
  1. I +$G(IBSELUBL) S IBBILL=1,IBNAME="",IBPAGE=0 K IBFLAG D:IBOUT="R" HEAD Q:IBQUIT D LOOP31 Q:IBQUIT
  1. I +$G(IBSELBNA)!+$G(IBSELBIL) S IBBILL=2,IBNAME="",IBPAGE=0 K IBFLAG D:IBOUT="R" HEAD Q:IBQUIT D LOOP31 Q:IBQUIT
  1. Q
  1. ;
  1. LOOP31 ; Loop through each name or terminal digit (and associated DFN).
  1. F S IBNAME=$O(^TMP($J,IBDV,IBBILL,IBNAME)) D Q:IBNAME=""!(IBQUIT)
  1. . I IBNAME="",'$D(IBFLAG) W !!,"No matches found.",!
  1. . Q:IBNAME=""
  1. . S DFN=0 F S DFN=$O(^TMP($J,IBDV,IBBILL,IBNAME,DFN)) Q:'DFN S IBNEWPT=1 D LOOP4 Q:IBQUIT
  1. Q
  1. ;
  1. LOOP4 ; Loop through each episode of care for a patient.
  1. S IBDAT="" F I=0:0 S IBDAT=$O(^TMP($J,IBDV,IBBILL,IBNAME,DFN,IBDAT)) Q:IBDAT=""!(IBQUIT) D PRINT I $Y>$S($D(IOSL):(IOSL-6),1:6),IBOUT="R" W ! D HEAD Q:IBQUIT
  1. Q
  1. ;
  1. PRINT ; Print each detail line.
  1. I '$G(IBSELRNB),$D(^TMP($J,IBDV,IBBILL,IBNAME,DFN,IBDAT,2)) Q ; exclude episodes with reason not billable
  1. I +$G(IBSELRNB)=2,'$D(^TMP($J,IBDV,IBBILL,IBNAME,DFN,IBDAT,2)) Q ; exclude episode w/o RNB ** PATCH 66
  1. I IBBILL=2,'$G(IBSELBNA),+$G(^TMP($J,IBDV,IBBILL,IBNAME,DFN,IBDAT))=1 Q ; non-auth episodes ** PATCH 66
  1. I IBBILL=2,'$G(IBSELBIL),+$G(^TMP($J,IBDV,IBBILL,IBNAME,DFN,IBDAT))=2 Q ; auth episodes ** PATCH 66
  1. ;
  1. D SUMTOT S IBFLAG=1 D PID^VADPT6
  1. I IBOUT="E" S IBPTINFO=$P($G(^DG(40.8,+IBDV,0)),"^")_U_VA("BID")_U_$P(^DPT(DFN,0),"^")_U_VA("PID")_U_$P($G(^DIC(8,+$G(^DPT(DFN,.36)),0)),"^",6)
  1. ;
  1. I +$G(IBNEWPT) W:IBOUT="R" ! D PTPRNT S IBNEWPT=0
  1. W:IBOUT="R" !,VA("BID"),?6,$E($P(^DPT(DFN,0),"^"),1,20),?28,VA("PID"),?42,$E($P($G(^DIC(8,+$G(^DPT(DFN,.36)),0)),"^",6),1,16) K VA,VAERR
  1. S Y=IBDAT X ^DD("DD") W:IBOUT="R" ?60 W:IBOUT="E" U W Y
  1. ;
  1. ; -- print insurance, use ibcns1 calls
  1. S X=$$INSP(DFN,IBDAT) W:IBOUT="R" ?82 W:IBOUT="E" U W X
  1. ;
  1. ; -- print reason not billable
  1. I $G(^TMP($J,IBDV,IBBILL,IBNAME,DFN,IBDAT,2))]"" W:IBOUT="R" ?115,$E(^(2),1,16) W:IBOUT="E" U_^(2)
  1. ;
  1. I IBOUT="E",'IBINPT W U
  1. S X=$G(^TMP($J,IBDV,IBBILL,IBNAME,DFN,IBDAT,1))
  1. I X]"" W:IBOUT="R" !?10 W $P(X,"^") I $P(X,"^",2)]"" W " with " F IBDC=2:1 Q:$P(X,"^",IBDC)="" W $P(X,"^",IBDC),", "
  1. S X=^TMP($J,IBDV,IBBILL,IBNAME,DFN,IBDAT) Q:'$L(X) F K=2:1 S IBIFN=$P(X,"^",K) Q:IBIFN="" D PRINT1
  1. Q
  1. ;
  1. PRINT1 ; If an episode of care has been billed, display billing information.
  1. D GVAR^IBCBB
  1. I IBOUT="E" D
  1. . I K>2 D XLCOLS(4,"")
  1. . W U_$P(^DGCR(399,IBIFN,0),"^")_U_$P($G(^DGCR(399.3,+IBAT,0)),"^",4),"-",$S(IBCL<3:"INPT",IBCL>2:"OUTP",1:"")
  1. . W U_$S(IBST=1:"Entered",IBST=2:"Request MRA",IBST=3:"Authorized",IBST=4:"Prnt/Trans",IBST=7:"Cancelled",IBST=0:"Closed",1:"")
  1. . W U_$E(IBFDT,4,5)_"/"_$E(IBFDT,6,7)_"/"_$E(IBFDT,2,3)_U_$E(IBTDT,4,5)_"/"_$E(IBTDT,6,7)_"/"_$E(IBTDT,2,3)
  1. . W U_$S($P(IBND0,U,21)="S":"s",$P(IBND0,U,21)="T":"t",1:"")_U
  1. I IBOUT="R" D
  1. . W !?10,$P(^DGCR(399,IBIFN,0),"^"),?20,$P($G(^DGCR(399.3,+IBAT,0)),"^",4),"-",$S(IBCL<3:"INPT",IBCL>2:"OUTP",1:"")
  1. . W ?37,$S(IBST=1:"Entered",IBST=2:"Request MRA",IBST=3:"Authorized",IBST=4:"Prnt/Trans",IBST=7:"Cancelled",IBST=0:"Closed",1:"")
  1. . W ?50,"From: ",$E(IBFDT,4,5)_"/"_$E(IBFDT,6,7)_"/"_$E(IBFDT,2,3)
  1. . W ?68,"To: ",$E(IBTDT,4,5)_"/"_$E(IBTDT,6,7)_"/"_$E(IBTDT,2,3)
  1. . W ?88,$S($P(IBND0,U,21)="S":"s",$P(IBND0,U,21)="T":"t",1:"")
  1. . W ?91,"Debtor: "
  1. I IBWHO="i",$D(^DIC(36,+IBNDMP,0)) W $P(^(0),"^")
  1. I IBWHO="o",$D(^DIC(4,+$P(IBNDM,"^",11),0)) W $P(^(0),"^")
  1. I IBWHO="p" W $P(^DPT(DFN,0),"^")
  1. D END^IBCBB1 Q
  1. ;
  1. I $D(ZTQUEUED),$$S^%ZTLOAD S (ZTSTOP,IBQUIT)=1 Q
  1. D:'IBFL PAUSE Q:IBQUIT S IBFL=0 N IBI
  1. S IBPAGE=IBPAGE+1
  1. ; -- ibformfd = skip only intial form feed, need ffs for each div.
  1. I $E(IOST,1,2)["C-"!(IBPAGE>1)!($G(IBFORMFD)) W @IOF
  1. S IBFORMFD=1
  1. S IBI=$S(IBBILL=2:"PREVIOUSLY ",1:"UN")_"BILLED PATIENTS"
  1. I '$G(IBSELCDV) S IBI=IBI_" for Division "_$P($G(^DG(40.8,+IBDV,0)),"^")
  1. I +$G(IBSELCDV) S IBI=IBI_IBHDRDV
  1. I +$G(IBSUM) S IBI="Summary"
  1. W IBHD,!,IBI W:$L(IBI)>78 ! W ?80,"Printed: ",IBDATE,?118,"Page: ",IBPAGE
  1. I +$G(IBSUM) W !,?40,"Unbilled",?53,"Unbilled w/RNB",?70,"Billed/Not Auth",?88,"Billed/Auth",?103,"# Visits",?117,"# Patients",!,IBL Q
  1. W !,"PT ID PATIENT",?28,"SSN",?42,"ELIGIBILITY",?60,"DATE OF ",$S(IBINPT=2:"DISCHARGE",1:"CARE"),?82,"INSURANCE COMPANIES"
  1. W:+$G(IBSELRNB) ?115,"NOT BILLABLE"
  1. W !,IBL
  1. Q
  1. ;
  1. INSP(DFN,IBDAT) ; -- print ins. company on report logic
  1. N X,IBDD,IBDDINS,IBCNT
  1. S IBCNT=0,IBDDINS=""
  1. I '$G(DFN)!('$G(IBDAT)) G INSPQ
  1. S IBDD="" D ALL^IBCNS1(DFN,"IBDD",4,IBDAT)
  1. S X=0 F S X=$O(IBDD(X)) Q:'X!(IBCNT>2) D
  1. .S IBCNT=IBCNT+1
  1. .I IBCNT>1 S IBDDINS=IBDDINS_","
  1. .S IBDDINS=IBDDINS_$E($P($G(^DIC(36,+$G(IBDD(X,0)),0)),"^"),1,10)
  1. S IBDDINS=$E(IBDDINS,1,30)
  1. I $G(IBDD(0))>3 S IBDDINS=IBDDINS_"*"
  1. INSPQ Q IBDDINS
  1. ;
  1. PAUSE Q:$E(IOST,1,2)'="C-"
  1. F J=$Y:1:(IOSL-5) W !
  1. S DIR(0)="E" D ^DIR K DIR I $D(DIRUT)!($D(DUOUT)) S IBQUIT=1 K DIRUT,DTOUT,DUOUT
  1. Q
  1. PRNSUM ; print 1 line of the summary
  1. N IBSUM S IBSUM=$G(^TMP($J,"TOTAL",IBDV)) Q:IBSUM=""
  1. W:IBOUT="R" !
  1. I IBOUT="E" D XLCOLS(5,"")
  1. W $S(IBDV="TOTAL":IBDV,1:$P($G(^DG(40.8,+IBDV,0)),U,1))
  1. I IBOUT="E" W U_$P(IBSUM,U,2,5)_U_$P(IBSUM,U,1)_U_$P(IBSUM,U,6) Q
  1. W ?40,$P(IBSUM,U,2),?58,$P(IBSUM,U,3),?75,$P(IBSUM,U,4),?91,$P(IBSUM,U,5),?105,$P(IBSUM,U,1),?120,$P(IBSUM,U,6)
  1. Q
  1. DATE(X) ;
  1. N Y S Y="" I +$G(X) S Y=$E(X,4,5)_"/"_$E(X,6,7)_"/"_$E(X,2,3)
  1. Q Y
  1. ;
  1. SUMTOT ; total cnt of visits ^ cnt unbilled ^ cnt unbilled w/RNB ^ cnt billed/not auth ^ cnt billed/auth ^ cnt of pats
  1. N IBSUM,IBTOT,IBBILLED,IBRMARK
  1. S IBBILLED=$G(^TMP($J,IBDV,IBBILL,IBNAME,DFN,IBDAT)),IBRMARK=$G(^TMP($J,IBDV,IBBILL,IBNAME,DFN,IBDAT,2))
  1. S IBSUM=$G(^TMP($J,"TOTAL",+IBDV)),IBTOT=$G(^TMP($J,"TOTAL","TOTAL"))
  1. S $P(IBSUM,U,1)=+$P(IBSUM,U,1)+1,$P(IBTOT,U,1)=+$P(IBTOT,U,1)+1
  1. I 'IBBILLED,IBRMARK="" S $P(IBSUM,U,2)=$P(IBSUM,U,2)+1,$P(IBTOT,U,2)=$P(IBTOT,U,2)+1
  1. I 'IBBILLED,IBRMARK'="" S $P(IBSUM,U,3)=$P(IBSUM,U,3)+1,$P(IBTOT,U,3)=$P(IBTOT,U,3)+1
  1. I +IBBILLED=1 S $P(IBSUM,U,4)=$P(IBSUM,U,4)+1,$P(IBTOT,U,4)=$P(IBTOT,U,4)+1
  1. I +IBBILLED=2 S $P(IBSUM,U,5)=$P(IBSUM,U,5)+1,$P(IBTOT,U,5)=$P(IBTOT,U,5)+1
  1. I '$D(^TMP($J,"TOTAL",+IBDV,DFN)) S $P(IBSUM,U,6)=$P(IBSUM,U,6)+1
  1. I '$D(^TMP($J,"TOTAL","TOTAL",DFN)) S $P(IBTOT,U,6)=$P(IBTOT,U,6)+1
  1. I +IBDV S ^TMP($J,"TOTAL",+IBDV)=IBSUM,^TMP($J,"TOTAL",+IBDV,DFN)=""
  1. S ^TMP($J,"TOTAL","TOTAL")=IBTOT,^TMP($J,"TOTAL","TOTAL",DFN)=""
  1. Q
  1. ;
  1. PTPRNT ; print patient specific data is requested: Rate Disabilities and expanded insurance Info
  1. ;
  1. N IBLN1,IBI,IBX,IBY,IBD,IBLN2,IBLN3,IBY1,IBJ,IBY3,IBRIDE,IBPLAN,IBCVG,IBGC1,IBCR1,IBCOMFL
  1. S IBLN1=$P($G(^DPT(+DFN,0)),U,1) I $Y>(IOSL-6),IBOUT="R" W ! D HEAD Q:IBQUIT
  1. ;
  1. I '$G(IBPRTRDS),IBOUT="E" W !,IBPTINFO
  1. I +$G(IBPRTRDS) S IBLN2="Rated Disabilities:" D Q:+$G(IBQUIT) K IBX,IBY
  1. . I '$O(^DPT(DFN,.372,0)) W:IBOUT="R" !,IBLN1,?33,IBLN2," None" W:IBOUT="E" !,IBPTINFO_"^None" S (IBLN1,IBLN2)="" Q
  1. . S IBI=0 F S IBI=$O(^DPT(DFN,.372,IBI)) Q:'IBI D I $Y>(IOSL-6),IBOUT="R" W ! D HEAD Q:IBQUIT
  1. .. S IBX=$G(^DPT(DFN,.372,IBI,0)),IBY=$G(^DIC(31,+IBX,0))
  1. .. S IBD=$S($P(IBY,U,4)="":$P(IBY,U,1),1:$P(IBY,U,4))_" ("_$P(IBX,U,2)_"%-"_$S(+$P(IBX,U,3):"SC",1:"NSC")_")"
  1. .. W:IBOUT="R" !,IBLN1,?33,IBLN2,?57,IBD W:IBOUT="E" !,IBPTINFO_U_IBD S (IBLN1,IBLN2)=""
  1. ;
  1. I '$G(IBPRTIEX),'$G(IBPRTIPC),'$G(IBPRTIGC),'$G(IBPRTICR),IBOUT="R" Q
  1. ;
  1. I IBOUT="R" W:IBLN1'="" !,IBLN1
  1. D ALL^IBCNS1(DFN,"IBX",4,IBBEG),ALL^IBCNS1(DFN,"IBX",4,IBEND)
  1. ;
  1. I IBOUT="E",'$O(IBX(0)) D XLCOLS(0,"")
  1. S IBI=0 F S IBI=$O(IBX(IBI)) Q:'IBI D Q:+$G(IBQUIT) I $Y>(IOSL-6),IBOUT="R" W ! D HEAD Q:IBQUIT
  1. . S IBY=IBX(IBI,0),IBY1=IBX(IBI,1)
  1. . S IBLN1=$P($G(^DIC(36,+IBY,0)),U,1),IBPLAN=+$P(IBY,U,18) S:IBOUT="R" IBLN1=$E(IBLN1,1,25)
  1. . ;
  1. . ;IB*2.0*516/DRF - Retrieve HIPAA compliant Group #
  1. . ;I +$G(IBPRTIEX) W !,?5,IBLN1,?33,"Group #: ",$P($G(^IBA(355.3,+IBPLAN,0)),U,4),?65,"Effective: ",$$DATE(+$P(IBY,U,8))," - ",$$DATE(+$P(IBY,U,4)),?100,"Last Ver: ",$$DATE($P(IBY1,U,3)) S IBLN1=""
  1. . I +$G(IBPRTIEX) D
  1. .. I IBOUT="E" W U_IBLN1_U_$P(IBY,U,3)_U_$$DATE(+$P(IBY,U,8))_U_$$DATE(+$P(IBY,U,4))_U_$$DATE($P(IBY1,U,3)) Q
  1. .. W !,?5,IBLN1,?33,"Group #: ",$P(IBY,U,3)
  1. .. W !,?33,"Effective: ",$$DATE(+$P(IBY,U,8))," - ",$$DATE(+$P(IBY,U,4)),?68,"Last Ver: ",$$DATE($P(IBY1,U,3)) S IBLN1=""
  1. . ;
  1. . I +$G(IBPRTIPC) S IBLN2="Policy Comment: " D I $Y>(IOSL-6),IBOUT="R" W ! D HEAD Q:IBQUIT
  1. .. I IBOUT="E" W U_$P(IBY1,U,8) Q
  1. .. I $P(IBY1,U,8)'="" W !,?5,IBLN1,?33,IBLN2,?51,$P(IBY1,U,8) S (IBLN1,IBLN2)=""
  1. . ;
  1. . I +$G(IBPRTIGC) S IBLN2="Group Comments: " D I IBOUT="E",+$G(IBGC1) W U
  1. .. S IBJ=0,IBGC1=1 F S IBJ=$O(^IBA(355.3,+IBPLAN,11,IBJ)) Q:'IBJ D I $Y>(IOSL-6),IBOUT="R" W ! D HEAD Q:IBQUIT
  1. ... S IBY3=$G(^IBA(355.3,+IBPLAN,11,IBJ,0)) D
  1. .... I IBOUT="E" D:'IBGC1 XLCOLS(1,IBLN1) W U_IBY3 S IBGC1=0 Q
  1. .... W !,?5,IBLN1,?33,IBLN2,?51,IBY3 S (IBLN1,IBLN2)=""
  1. . ;
  1. . I +$G(IBPRTICR) S IBLN2="Coverage Limits:" D I IBOUT="E",+$G(IBCR1) W "^^"
  1. .. S IBCVG=0,IBCR1=1 F S IBCVG=$O(^IBA(355.32,"B",IBPLAN,IBCVG)) Q:'IBCVG D I $Y>(IOSL-6),IBOUT="R" W ! D HEAD Q:IBQUIT
  1. ... S IBY3=$G(^IBA(355.32,IBCVG,0)) Q:IBY3=""
  1. ... S IBLN3=$P($G(^IBE(355.31,+$P(IBY3,U,2),0)),U,1) I IBOUT="R" S IBLN3=$E(IBLN3,1,20)
  1. ... S IBLN3=IBLN3_" "_$$DDSET(355.32,.04,+$P(IBY3,U,4))_" "_$$DATE(+$P(IBY3,U,3))
  1. ... S (IBJ,IBCOMFL)=0 F S IBJ=$O(^IBA(355.32,IBCVG,2,IBJ)) Q:'IBJ D I $Y>(IOSL-6),IBOUT="R" W ! D HEAD Q:IBQUIT
  1. .... I IBOUT="E" D:'IBCR1 XLCOLS(2,IBLN1) W U_IBLN3_U_$G(^IBA(355.32,IBCVG,2,IBJ,0)) S IBCR1=0,IBCOMFL=1 Q
  1. .... W !,?5,IBLN1,?33,IBLN2,?51,IBLN3,?104,$G(^IBA(355.32,IBCVG,2,IBJ,0)) S (IBLN1,IBLN2,IBLN3)=""
  1. ... I IBLN3'="",IBOUT="R" W !,?5,IBLN1,?33,IBLN2,?51,IBLN3 S (IBLN1,IBLN2,IBLN3)=""
  1. ... I 'IBCOMFL,IBOUT="E" D:'IBCR1 XLCOLS(2,IBLN1) W U_IBLN3_U S IBCR1=0
  1. . ;
  1. . I +$G(IBPRTICR) S IBLN2="Riders: " D I IBOUT="E",+$G(IBCR1) W U
  1. .. S IBRIDE=0,IBCR1=1 F S IBRIDE=$O(^IBA(355.7,"APP",DFN,IBI,IBRIDE)) Q:'IBRIDE D I $Y>(IOSL-6),IBOUT="R" W ! D HEAD Q:IBQUIT
  1. ... I IBOUT="E" D:'IBCR1 XLCOLS(3,IBLN1) W U_$P($G(^IBE(355.6,+IBRIDE,0)),U,1) S IBCR1=0 Q
  1. ... W !,?5,IBLN1,?33,IBLN2,?51,$P($G(^IBE(355.6,+IBRIDE,0)),U,1) S (IBLN1,IBLN2)=""
  1. ;
  1. I IBOUT="R" W !
  1. Q
  1. ;
  1. DDSET(FILE,FLD,X) ; returns external value for a set
  1. N Y,Z,T S Z="",Y=$G(^DD(+$G(FILE),+$G(FLD),0)) S T=$G(X)_":",Z=$P($P(Y,T,2),";",1)
  1. Q Z
  1. ;
  1. PHDL ; Print header for Excel format
  1. W "DIV^PT ID^PATIENT^SSN^ELIGIBILITY"
  1. I +$G(IBPRTRDS) W "^Rated Disabilities"
  1. I +$G(IBPRTIEX) W "^Insurance^Group #^Effective Begin Date^Effective End Date^Last Ver"
  1. I +$G(IBPRTIPC) W "^Policy Comment"
  1. I +$G(IBPRTIGC) W "^Group Comments"
  1. I +$G(IBPRTICR) W "^Coverage Limits^Limitation Comments^Riders"
  1. ;
  1. W "^DATE OF "_$S(IBINPT=2:"DISCHARGE",1:"CARE")_"^INSURANCE COMPANIES"
  1. I +$G(IBSELRNB) W "^NOT BILLABLE"
  1. I 'IBINPT W "^Encounter Add/Edits"
  1. ;
  1. W "^BILL NUMBER^LOCATION OF CARE^STATUS^From^To^Current Bill Payer Sequence^Debtor"
  1. W "^DIV TOTALS^Unbilled^Unbilled w/RNB^Billed/Not Auth^Billed/Auth^# Visits^# Patients"
  1. Q
  1. ;
  1. XLCOLS(PLACE,INS) ; Print spacers for Excel columns
  1. I +PLACE W !,IBPTINFO
  1. I +$G(IBPRTRDS),+PLACE W U
  1. I +$G(IBPRTIEX) W U_INS_"^^^^"
  1. I +$G(IBPRTIPC) W U Q:PLACE=1
  1. I +$G(IBPRTIGC) W U Q:PLACE=2
  1. I +$G(IBPRTICR) W "^^" Q:PLACE=3
  1. I +$G(IBPRTICR) W U
  1. Q:'PLACE
  1. ;
  1. W "^^"
  1. I +$G(IBSELRNB) W U
  1. I 'IBINPT W U Q:PLACE=4
  1. W "^^^^^^^^"
  1. Q