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

IBARXMQ.m

Go to the documentation of this file.
  1. IBARXMQ ;LL/ELZ-RX COPAY RPC QUERY ROUTINE (MILL BILL) ;10-OCT-2000
  1. ;;2.0;INTEGRATED BILLING;**150,156,186,199,563,676**;21-MAR-94;Build 34
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;
  1. EN ; main entry point for users to request a query of rx bills from all possible facilities
  1. N DIC,X,Y,DFN,IBT,IBTFL,%,%ZIS,ZTSAVE,POP,ZTSK,DIR,IBDT,IBPAT,IBROOT
  1. ;
  1. ; select patient, and get pt info
  1. N DPTNOFZY S DPTNOFZY=1 ;Suppress PATIENT file fuzzy lookups
  1. S DIC="^DPT(",DIC(0)="AEMNQ" D ^DIC Q:Y<1 S DFN=+Y
  1. D DEM^VADPT S IBPAT=VADM(1)_"^"_VA("BID") D KVAR^VADPT
  1. ;
  1. ; ask for month / year
  1. S DIR(0)="D^::AEMP",DIR("A")="For What Month/Year" D ^DIR Q:Y<1
  1. S IBDT=Y
  1. ;
  1. ; scan for patient to see if different facilities could be involved
  1. S IBT=$$TFL^IBARXMU(DFN,.IBTFL,2)
  1. ;
  1. ; if multiple facilities ask if we should check
  1. I IBT W !,"This patient could have Pharmacy Co-payment bills at other facilities",!,"Do you want to check those other facilities" S %=0 D YN^DICN S:%'=1 IBT=0 Q:%<0
  1. ;
  1. ; now for a device
  1. S %ZIS="MQ" D ^%ZIS Q:POP
  1. I $D(IO("Q")) D Q
  1. . N ZTDESC,ZTRTN
  1. . S ZTRTN="DQ^IBARXMQ",(ZTSAVE("DFN"),ZTSAVE("IB*"))=""
  1. . S ZTDESC="PHARMACY BILLING SUMMARY"
  1. . D ^%ZTLOAD,HOME^%ZIS K IO("Q") W !,"Task# ",ZTSK
  1. ;
  1. DQ ; tasked entry point
  1. ;
  1. N IBD,IBER,X,IBX,IBC,IBB,IBU,DIRUT,IBE,IBP,IBAR K ^TMP("IBARXM",$J)
  1. ;
  1. ; remote stuff, file locally
  1. I IBT S IBX=0 F S IBX=$O(IBTFL(IBX)) Q:IBX<1 D
  1. . W:'$D(ZTQUEUED) !,"Now sending query to ",$P(IBTFL(IBX),"^",2)," ..."
  1. . ;676;BL; Send request to Cerner Separate response message returns transactions
  1. . I $P(IBTFL(IBX),"^",1)["200CRNR" D Q
  1. . . D EN^IBARXCQR(DFN,$E(IBDT,1,5)_"00")
  1. . D QUERY^IBARXMU(DFN,IBDT,+IBTFL(IBX),.IBD)
  1. . I $P(IBD(0),"^")=-1!(-1=+IBD)!($P($G(IBD(1)),"^")=-1) S IBER=1 K IBD Q
  1. . S X=1 F S X=$O(IBD(X)) Q:X<1 S IBD=$$ADD^IBARXMN(DFN,IBD(X))
  1. . K IBD
  1. ;
  1. ; stuff on local file w/remote stuff, build tmp
  1. S (IBC,IBX)=0 F S IBX=$O(^IBAM(354.71,"AD",DFN,IBDT,IBX)) Q:IBX<1 S IBC=IBC+1,IBD=^IBAM(354.71,IBX,0),IBAR=$P($P($G(^IB(+$P(IBD,"^",4),0)),"^",11),"-",2),^TMP("IBARXM",$J,$P(IBD,"^",3),IBC)=IBD,^(IBC,"AR")=IBAR
  1. ;
  1. ;
  1. PRINT ;
  1. U IO
  1. ;
  1. S (IBP,IBE,IBB,IBU)=0 D HEAD F S IBE=$O(^TMP("IBARXM",$J,IBE)) Q:IBE<1!($D(DIRUT)) S IBX=0 F S IBX=$O(^TMP("IBARXM",$J,IBE,IBX)) Q:IBX<1!($D(DIRUT)) D
  1. . D:$Y+3>IOSL HEAD Q:$D(DIRUT)
  1. . S IBD=^TMP("IBARXM",$J,IBE,IBX)
  1. . W !,$E($P($$FAC^IBARXMU($P(IBD,"^",13)),"^"),1,9),"(",+IBD,")" ;676;BL Changed call to return Cerner name
  1. . W ?17,$G(^TMP("IBARXM",$J,IBE,IBX,"AR"))
  1. . W ?29,$$FMTE^XLFDT(IBE,"2D")
  1. . W ?40,$P(IBD,"^",20)
  1. . W ?44,$P(IBD,"^",9)
  1. . W ?67,$J($P(IBD,"^",11),6,2)
  1. . W ?74,$J($P(IBD,"^",12),6,2)
  1. . S IBB=IBB+$P(IBD,"^",11),IBU=IBU+$P(IBD,"^",12)
  1. I $D(DIRUT) G Q
  1. W !!?67,"-------",?74,"------"
  1. W !?67,$J(IBB,6,2),?75,$J(IBU,5,2)
  1. ;
  1. ; update totals in the patient's account
  1. X $S($D(IBER):"W !!,""Unable to perform all remote queries, totals will not be updated!""",IBT=0&($D(IBTFL)):"W !!,""No remote queries needed/performed, account not updated.""",1:"D ACCT^IBARXMN(DFN,IBB,IBU,IBDT,1)")
  1. ;
  1. I $E(IOST,1,2)="C-",'$D(DIRUT) N DIR,X,Y,DTOUT,DUOUT,DIROUT S DIR(0)="E" D ^DIR
  1. ;
  1. Q K ^TMP("IBARXM",$J)
  1. D ^%ZISC
  1. S:$D(ZTQUEUED) ZTREQ="@"
  1. Q
  1. ;
  1. N DIR,X,Y,DTOUT,DUOUT,DIROUT
  1. I IBP>0,$E(IOST,1,2)="C-" S DIR(0)="E" D ^DIR Q:$D(DIRUT)
  1. S IBP=IBP+1
  1. W @IOF,!,"Medication Co-Pay Billing Summary",?IOM-10,"Page: ",IBP
  1. W !,"Patient: ",$P(IBPAT,"^")," (",$P(IBPAT,"^",2),")",?IOM-11,$$FMTE^XLFDT(IBDT),!
  1. F X=0:1:IOM-1 W "-"
  1. W !,"Station AR Bill Date Tier Brief Description Billed Not B",! F X=0:1:IOM-1 W "-"
  1. Q