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

IBCECSA3.m

Go to the documentation of this file.
  1. IBCECSA3 ;ALB/CXW - CLAIMS STATUS AWAITING RESOLUTION REPORT ;23-JUL-99
  1. ;;2.0;INTEGRATED BILLING;**137,320,371,377**;21-MAR-94;Build 23
  1. ;;Per VHA Directive 2004-038, this routine should not be modified.
  1. Q
  1. EN ; Report of claims status awaiting resolution
  1. NEW %ZIS,ZTSAVE,ZTRTN,ZTDESC,DIR,X,Y,DIRUT,DTOUT,DUOUT,DIROUT,IBRVW
  1. ;
  1. D FULL^VALM1
  1. W !
  1. S DIR(0)="YO" ; IB*2*377 new question
  1. S DIR("A")="Would you like to include Review Comments with this report"
  1. S DIR("B")="No"
  1. D ^DIR K DIR
  1. I $D(DIRUT) Q
  1. S IBRVW=Y
  1. ;
  1. W !!,"You will need a 132 column printer for this report!",!
  1. ;
  1. S %ZIS="QM" D ^%ZIS Q:POP
  1. I $D(IO("Q")) K IO("Q") D Q
  1. . S ZTRTN="LIST^IBCECSA3"
  1. . S ZTSAVE("IBSORT1")=""
  1. . S ZTSAVE("IBSORT2")=""
  1. . S ZTSAVE("IBSORT3")=""
  1. . S ZTSAVE("IBSORTOR")=""
  1. . S ZTSAVE("^TMP(""IBCECSB"",$J,")=""
  1. . S ZTSAVE("IBRVW")=""
  1. . S ZTDESC="IB -Claims Status Awaiting Resolution Report" D ^%ZTLOAD K ZTSK D HOME^%ZIS
  1. U IO
  1. LIST ; display
  1. N IBSTOP,X,IBPAGE,IBX,IBDIV,IBDA,IBPAY,IB,IBZ,IBZFT,IBFST,IBX2
  1. W:$E(IOST,1,2)["C-" @IOF ;Only initial form feed for print to screen
  1. S (IBSTOP,IBPAGE,IBFST,IBDIV)=0
  1. I IBSORT1="D" S IBDIV=1
  1. I '$D(^TMP("IBCECSB",$J)) D G LISTQ
  1. . D HDR1 W !,"No entries found for this report"
  1. S IBX="" F S IBX=$O(^TMP("IBCECSB",$J,IBX)) Q:IBX=""!IBSTOP S IBX2="" F S IBX2=$O(^TMP("IBCECSB",$J,IBX,IBX2)) Q:IBX2=""!IBSTOP S IBX3="" F S IBX3=$O(^TMP("IBCECSB",$J,IBX,IBX2,IBX3)) Q:IBX3=""!IBSTOP D Q:IBSTOP
  1. . I 'IBFST S IBPAY=$$IBPAY(IBX,IBX2,IBX3) D HDR1 S:'IBDIV IBFST=1 Q:IBSTOP
  1. . S IBDA=0 F S IBDA=$O(^TMP("IBCECSB",$J,IBX,IBX2,IBX3,IBDA)) Q:'IBDA!IBSTOP S IB=$G(^TMP("IBCECSB",$J,IBX,IBX2,IBX3,IBDA)) D Q:IBSTOP
  1. .. I ($Y+3)>IOSL D HDR1 Q:IBSTOP
  1. .. W $$BN1^PRCAFN(+IB),$P(IB,U,12),?13,$E($P(IB,U,2),1,25),?40,$E($P(IB,U,3),1,30),?72,$P($P(IB,U,4),"~"),?78,$$DAT1^IBOUTL($P(IB,U,5)),?88,$E($P(IB,U,7),1,10),?100,"$"_$J($P(IB,U,6),0,2),?110,$P(IB,U,10),?122,$P(IB,U,11),!
  1. .. I $P(IB,U,12)="*" W " ***** CSA REVIEW IN PROCESS *****",!
  1. .. W " FORM TYPE: "_$P($G(^IBE(353,$P($G(^DGCR(399,+IB,0)),U,19),0)),U),!
  1. .. I 'IBDIV S X=" DIVISION: "_$P(IB,U,8) W X,$J(" ",40-$L(X))_"AUTHORIZING BILLER: "_$P($P(IB,U,9),"~",1),!
  1. .. W " MESSAGE TEXT: " S IBZFT=0
  1. .. S IBZ=0 F S IBZ=$O(^IBM(361,IBDA,1,IBZ)) Q:'IBZ D Q:IBSTOP
  1. ... W:'IBZFT ?15 S X=$G(^IBM(361,IBDA,1,IBZ,0))
  1. ... F I=1:131:$L(X) W " "_$E(X,I,I+130),!
  1. ... S IBZFT=1
  1. ... I ($Y+3)>IOSL D HDR1 Q:IBSTOP
  1. ... Q
  1. .. Q:IBSTOP
  1. .. ;
  1. .. ; Display the Review Comments if they exist based on user choice (IB*377)
  1. .. I $G(IBRVW),+$O(^IBM(361,IBDA,2,0)) D Q:IBSTOP
  1. ... N IBCM,IBT1,IBT0,IBD0,IBCL
  1. ... I ($Y+3)>IOSL D HDR1 Q:IBSTOP
  1. ... W ?3,"*** Review Comments for Claim "_$$BN1^PRCAFN(+IB)_" ***",!
  1. ... S IBCM=0 F IBT1=0:1 S IBCM=$O(^IBM(361,IBDA,2,IBCM)) Q:'IBCM ; count up # of comments
  1. ... S IBT0=0
  1. ... S IBCM=0 F S IBCM=$O(^IBM(361,IBDA,2,IBCM)) Q:'IBCM!IBSTOP D Q:IBSTOP
  1. .... S IBT0=IBT0+1
  1. .... S IBD0=$G(^IBM(361,IBDA,2,IBCM,0))
  1. .... I ($Y+3)>IOSL D HDR1 Q:IBSTOP
  1. .... W ?7,"Entered "_$$FMTE^XLFDT($P(IBD0,U,1),"5ZPM")
  1. .... I $P(IBD0,U,2) W " by "_$P($G(^VA(200,$P(IBD0,U,2),0)),U,1)
  1. .... W " ("_IBT0_" of "_IBT1_")",!
  1. .... S IBCL=0 F S IBCL=$O(^IBM(361,IBDA,2,IBCM,1,IBCL)) Q:'IBCL!IBSTOP D Q:IBSTOP
  1. ..... I ($Y+3)>IOSL D HDR1 Q:IBSTOP
  1. ..... W ?10,$G(^IBM(361,IBDA,2,IBCM,1,IBCL,0)),!
  1. ..... Q
  1. .... Q
  1. ... Q
  1. .. ;
  1. .. ; Display a line break before the next claim in this report
  1. .. I ($Y+3)>IOSL D HDR1 Q:IBSTOP
  1. .. W !
  1. .. Q
  1. . Q
  1. ;
  1. G:IBSTOP LISTQ
  1. I $E(IOST,1,2)["C-" K DIR S DIR(0)="E" D ^DIR K DIR
  1. LISTQ I $D(ZTQUEUED) S ZTREQ="@" Q
  1. W ! D ^%ZISC
  1. Q
  1. IBPAY(IBX,IBX2,IBX3) ; return biller name
  1. N X
  1. S X=$O(^TMP("IBCECSB",$J,IBX,IBX2,IBX3,0))
  1. S X=$G(^TMP("IBCECSB",$J,IBX,IBX2,IBX3,X))
  1. Q $P($P(X,U,9),"~",1)
  1. HDR1 ;
  1. N DIR,Y
  1. I IBPAGE D Q:IBSTOP
  1. . I $E(IOST,1,2)["C-" K DIR S DIR(0)="E" D ^DIR K DIR S IBSTOP=('Y) Q:IBSTOP
  1. . W @IOF
  1. S IBPAGE=IBPAGE+1
  1. W !,"Sort 1: ",$$SD^IBCECSA(IBSORT1)
  1. W ?46,"Claims Status Awaiting Resolution Report",?120,$J("Page: "_IBPAGE,11)
  1. W !,"Sort 2: ",$S($G(IBSORT2)'="":$$SD^IBCECSA(IBSORT2),1:"n/a")
  1. W ?104,$J("Run Date: "_$$HTE^XLFDT($H,"2Z"),27)
  1. W !,"Sort 3: ",$S($G(IBSORT3)'="":$$SD^IBCECSA(IBSORT3),1:"n/a")
  1. I IBDIV W !!,"Division: "_$S($G(IBX)=0:"",1:$G(IBX)),!,"Authorizing Biller: "_$G(IBPAY)
  1. W !,?72,"Last",?78,"Date of",?88,"Location",?100,"Current",?110,"Source of",?122,"Days Msg"
  1. W !,"Bill #",?13,"Payer Name",?40,"Patient Name",?72,"4 SSN",?78,"Service",?88,"of Service",?100,"Balance",?110,"Message",?122,"Pending"
  1. W !,$TR($J("",132)," ","-"),!
  1. Q
  1. ;
  1. ;
  1. RESORT ; CSA screen re-sort action
  1. NEW DIR,X,Y,Z,IBSAVE,VALMQUIT,IBCURR
  1. D FULL^VALM1 S VALMBCK="R"
  1. W !!?2,"The CSA screen is currently sorted in the following manner:"
  1. W !!?9,"Primary Sort: ",$S($G(IBSORT1)'="":$$SD^IBCECSA(IBSORT1),1:"n/a")
  1. W !?7,"Secondary Sort: ",$S($G(IBSORT2)'="":$$SD^IBCECSA(IBSORT2),1:"n/a")
  1. W !?8,"Tertiary Sort: ",$S($G(IBSORT3)'="":$$SD^IBCECSA(IBSORT3),1:"n/a")
  1. ;
  1. W !
  1. S DIR(0)="Y",DIR("A")="Would you like to change the sort criteria"
  1. S DIR("B")="Yes" D ^DIR K DIR
  1. I 'Y G RESORTX
  1. ;
  1. ; save the old sort criteria
  1. S IBSAVE=$G(IBSORT1)_U_$G(IBSORT2)_U_$G(IBSORT3)
  1. S Z="" F S Z=$O(IBSORTOR(Z)) Q:Z="" S IBSAVE=IBSAVE_U_Z_U_IBSORTOR(Z)
  1. ;
  1. W !
  1. K IBSORTOR
  1. D SORT^IBCECSA(1,$P(IBSAVE,U,1)) I $G(VALMQUIT) G RES1
  1. D SORT^IBCECSA(2) I $G(VALMQUIT) G RES1
  1. I $G(IBSORT2)'="" D SORT^IBCECSA(3) I $G(VALMQUIT) G RES1
  1. RES1 ;
  1. I $G(IBSORT1)="" S IBSORT1=$P(IBSAVE,U,1) ; need at least one
  1. ;
  1. ; see if the sort criteria changed
  1. S IBCURR=$G(IBSORT1)_U_$G(IBSORT2)_U_$G(IBSORT3)
  1. S Z="" F S Z=$O(IBSORTOR(Z)) Q:Z="" S IBCURR=IBCURR_U_Z_U_IBSORTOR(Z)
  1. I IBSAVE=IBCURR G RESORTX ; no sort changes made at all
  1. ;
  1. ; time to rebuild the list because sorts have changed
  1. I $G(IBDAYS)="" S IBDAYS=0
  1. I $G(IBSEV)="" S IBSEV="R"
  1. D BLD^IBCECSA1
  1. S VALMBCK="R",VALMBG=1
  1. ;
  1. RESORTX ;
  1. Q
  1. ;
  1. MCS ; Link to the Multiple CSA Message Management option
  1. NEW IBCSAMCS S IBCSAMCS=1
  1. D FULL^VALM1 S VALMBCK="R"
  1. I '$$KCHK^XUSRB("IB MESSAGE MANAGEMENT") D G MCSX
  1. . W !!?5,"You must hold the IB MESSAGE MANAGEMENT key to access this option."
  1. . D PAUSE^VALM1
  1. . Q
  1. ;
  1. D ; call the MCS screen
  1. . NEW IBSORT1,IBSORT2,IBSORT3,IBDAYS,IBSEV ; protect CSA vars
  1. . D EN^IBCEMCL
  1. . Q
  1. ;
  1. I $G(IBCSAMCS)=2 D BLD^IBCECSA1 S VALMBG=1 ; rebuild CSA
  1. S VALMBCK="R"
  1. MCSX ;
  1. Q
  1. ;