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

IBOCHK.m

Go to the documentation of this file.
  1. IBOCHK ;ALB/AAS - INTEGRATED BILLING - RX COPAY LINK CHECK ; 2-APR-91
  1. ;;2.0;INTEGRATED BILLING;**347**; 21-MAR-94;Build 24
  1. ;
  1. ; -loop through range of IB reference numbers and verify
  1. ; soft link exists and has link back to IB.
  1. ;
  1. % ;
  1. ;***
  1. ;S XRTL=$ZU(0),XRTN="IBOCHK-1" D T0^%ZOSV ;start rt clock
  1. ;
  1. D HOME^%ZIS W @IOF,?24,"Verify IB - Pharmacy Co-Pay links",!!
  1. ;
  1. ST S DIC="^IB(",DIC(0)="AEQMN",DIC("A")="START WITH REFERENCE NUMBER:",DIC("B")="" D ^DIC K DIC G:+Y<1 END S IBSTART=$P(Y,"^",2)
  1. ;
  1. TO S DIC="^IB(",DIC(0)="AEQMN",DIC("A")="GO TO REFERENCE NUMBER: ",DIC("B")="" D ^DIC K DIC G:+Y<1 END S IBEND=$P(Y,"^",2)
  1. I IBSTART>IBEND W *7,!!,"End must not be less than beginning number",! G ST
  1. ;
  1. DEV W !!,"*** Margin width of this output is 132 ***"
  1. W ! S %ZIS="QM",%ZIS("A")="Output Device: " D ^%ZIS G:POP END
  1. I $D(IO("Q")) S ZTRTN="DQ^IBOCHK",ZTDESC="IB Check Pharmacy Links",ZTSAVE("IB*")="" D ^%ZTLOAD K IO("Q") W ! G END
  1. ;
  1. U IO
  1. ;***
  1. ;I $D(XRT0) S:'$D(XRTN) XRTN="IBOCHK" D T1^%ZOSV ;stop rt clock
  1. ;
  1. DQ ; -entry point from queing
  1. ;S XRTL=$ZU(0),XRTN="IBOCHK-2" D T0^%ZOSV ;start rt clock
  1. ;
  1. S (IBCNT,IBECNT)=0,IBPAG=0,IBQUIT=0 S Y=DT D D^DIQ S IBHDT=Y D HDR
  1. S IBRNUM=IBSTART-1
  1. F S IBRNUM=$O(^IB("B",IBRNUM)) Q:'IBRNUM!(IBRNUM>IBEND)!(IBQUIT) S IBN="" F S IBN=$O(^IB("B",IBRNUM,IBN)) Q:'IBN!(IBQUIT) D CHK
  1. G END
  1. ;
  1. CHK S IBCNT=IBCNT+1
  1. N DFN,IBNODE
  1. I '$D(^IB(IBN,0))!('$D(^IB(IBN,1))) S IBOERR=1,IBND=IBN G LINE ;xref to no entry
  1. S IBND=$S($D(^IB(IBN,0)):^(0),1:"")
  1. S IBSL=$P(^IB(IBN,0),"^",4) I 'IBSL S IBOERR=2 G LINE ;no softlink
  1. I +IBSL'=52 Q ;not a pharmacy rx entry
  1. S IBRXN=$P($P(IBSL,";"),":",2),IBRXN1=$P($P(IBSL,";",2),":",2)
  1. S DFN=$P(^IB(IBN,0),"^",2)
  1. I $$FILE^IBRXUTL(IBRXN,.01)="" S IBOERR=3 G LINE ;rx deleted
  1. S IBNODE=$$IBND^IBRXUTL(DFN,IBRXN)
  1. I IBNODE'["^" S IBOERR=4 G LINE ;IB node missing
  1. I +IBNODE,'$P(IBNODE,"^",2) S IBOERR=5 G LINE ;pointer back to IB missing
  1. Q:'IBRXN1
  1. I +$$SUBFILE^IBRXUTL(IBRXN,IBRXN1,52,.01)=0 S IBOERR=6 G LINE ;refill deleted
  1. I $$IBNDFL^IBRXUTL(DFN,IBRXN,IBRXN1)'["^" S IBOERR=7 G LINE ;ib node on refill missing
  1. I +$$IBNDFL^IBRXUTL(DFN,IBRXN,IBRXN1)=0 S IBOERR=8 G LINE ;no data on node
  1. Q ;pharmacy links okay.
  1. ;
  1. HDR ;
  1. S IBPAG=IBPAG+1
  1. W:$E(IOST,1,2)["C-"!(IBPAG>1) @IOF
  1. W "Verify Integrated Billing links to Pharmacy",?IOM-22,IBHDT," Page:",IBPAG
  1. W !,"Verify IB Reference Number ",IBSTART," to ",IBEND
  1. W !,"REF. NO.",?12,"PATIENT",?34,"SSN",?40,"RX#",?50,"REFILL",?58,"IB LINK",?80,"CHARGE ID",?91,"TRANS",?97,"ERROR MESSAGE"
  1. S $P(IBLINE,"-",IOM)="" W !,IBLINE K IBLINE
  1. Q
  1. LINE ;
  1. I $Y>(IOSL-5) D PAUSE^IBOUTL Q:IBQUIT D HDR
  1. S IBECNT=IBECNT+1
  1. W !,$P(IBND,"^") S DFN=$P(IBND,"^",2)
  1. I $D(^DPT(+DFN,0)) D PID^VADPT W ?12,$E($P(^DPT(DFN,0),"^"),1,20),?34,VA("BID"),?40,$P($P(IBND,"^",8),"-"),?50,$P($P(IBSL,";",2),":",2),?58,IBSL,?80,$P(IBND,"^",11),?91,$P(IBND,"^",12)
  1. W ?97,$P($T(IBOERR+IBOERR),";;",2,99)
  1. Q
  1. ;
  1. END ;
  1. ;***
  1. I $D(XRT0) S:'$D(XRTN) XRTN="IBOCHK" D T1^%ZOSV ;stop rt clock
  1. ;
  1. Q:$D(ZTQUEUED) K IBCNT,IBECNT,IBEND,IHDT,IBN,IBND,IBPAG,IBQUIT,IBRNUM,IBRXN,IBRXN1,IBSL,IBSTART
  1. D ^%ZISC
  1. Q
  1. IBOERR ;error messages
  1. ;;IB CROSS-REFERENCE BUT NO ENTRY
  1. ;;IB ENTRY MISSING SOFTLINK
  1. ;;RX ENTRY DELETED OR ARCHIVED
  1. ;;RX ENTRY MISSING IB NODE
  1. ;;RX ENTRY MISSING IB POINTER
  1. ;;RX REFILL DELETED
  1. ;;RX REFILL MISSING IB NODE
  1. ;;RX REFILL MISSING IB LINK