- IBOST ;ALB/AAS - INTEGRATED BILLING STATISTICAL REPORT ; 8-MAR-91
- ;;Version 2.0 ; INTEGRATED BILLING ;; 21-MAR-94
- ;
- EN ;
- ;***
- ;S XRTL=$ZU(0),XRTN="IBOST-1" D T0^%ZOSV ;start rt clock
- D HOME^%ZIS W @IOF,*13,?20,"Integrated Billing Statistical Report"
- W !! D DATE^IBOUTL I IBEDT="" G END
- DEV S %ZIS="QM",%ZIS("A")="Output Device: " D ^%ZIS G:POP END
- I $D(IO("Q")) S ZTRTN="DQ^IBOST",ZTDESC="IB Statistical Report",ZTSAVE("IB*")="" D ^%ZTLOAD K IO("Q"),ZTSK G END
- U IO
- ;***
- ;I $D(XRT0) S:'$D(XRTN) XRTN="IBOST" D T1^%ZOSV ;stop rt clock
- W !!
- ;
- DQ ; -entry from tasked job
- ;***
- ;S XRTL=$ZU(0),XRTN="IBOST-2" D T0^%ZOSV ;start rt clock
- K ^TMP($J)
- S IBN="" F IBDT=IBBDT:0 S IBDT=$O(^IB("D",IBDT)) Q:'IBDT!(IBDT>(IBEDT+.24)) F IBN=0:0 S IBN=$O(^IB("D",IBDT,IBN)) Q:'IBN I $D(^IB(IBN,0)) D GROSS,NET:$P(^IB(IBN,0),"^",9)=IBN
- ;
- D PRINT W !
- G END
- ;
- GROSS ; -gross count of action types, total charges
- ; -^tmp($j,"ib",ibaction type,"gcnt")=count
- ; ^tmp($j,"ib",ibaction type,"gtot")=sum of charges
- ;
- S IBND=^IB(IBN,0)
- S IBATYP=$S($D(^IBE(350.1,+$P(IBND,"^",3),0)):$P(^(0),"^"),1:"UNKNOWN"),IBSEQNO=$S($D(^IBE(350.1,+$P(IBND,"^",3),0)):$P(^(0),"^",5),1:0)
- S:'$D(^TMP($J,"IB",IBSEQNO,IBATYP,"GCNT")) ^("GCNT")=0 S ^("GCNT")=^("GCNT")+1
- S:'$D(^TMP($J,"IB",IBSEQNO,IBATYP,"GTOT")) ^("GTOT")=0 S ^("GTOT")=^("GTOT")+$P(IBND,"^",7)
- Q
- ;
- NET ; -net count of new actions that aren't cancelled
- ; -^tmp($j,"ib",ibaction type,"ncnt")=net count
- ; ^tmp($j,"ib",ibaction type,"ntot")=net total
- S IBLAST="",IBLDT=$O(^IB("APDT",IBN,"")) I +IBLDT F IBL=0:0 S IBL=$O(^IB("APDT",IBN,IBLDT,IBL)) Q:'IBL S IBLAST=IBL
- Q:'IBLAST
- Q:'$D(^IB(IBLAST,0))
- S IBCHRG=$P(^IB(IBLAST,0),"^",7),IBSEQNOL=$S($D(^IBE(350.1,$P(^IB(IBLAST,0),"^",3),0)):$P(^(0),"^",5),1:"")
- S:IBSEQNOL=2 IBCHRG=0
- S:'$D(^TMP($J,"IB",IBSEQNO,IBATYP,"NTOT")) ^("NTOT")=0 S ^("NTOT")=^("NTOT")+(IBCHRG)
- S:'$D(^TMP($J,"IB",IBSEQNO,IBATYP,"NCNT")) ^("NCNT")=0 S ^("NCNT")=^("NCNT")+$S(IBSEQNOL=2:0,1:1)
- Q
- ;
- PRINT ; -output data
- S IBQUIT=0,IBPAG=0,Y=DT D D^DIQ S IBHDT=Y D HDR
- W !!?((IOM-25)/2),"NET TOTALS BY ACTION TYPE"
- F IBSEQNO=0:0 S IBSEQNO=$O(^TMP($J,"IB",IBSEQNO)) Q:'IBSEQNO!(IBQUIT) S IBATYP="" F IBT=0:0 S IBATYP=$O(^TMP($J,"IB",IBSEQNO,IBATYP)) Q:IBATYP=""!(IBQUIT) D NETLIN
- ;
- W !!?((IOM-27)/2),"GROSS TOTALS BY ACTION TYPE"
- F IBSEQNO=0:0 S IBSEQNO=$O(^TMP($J,"IB",IBSEQNO)) Q:'IBSEQNO!(IBQUIT) S IBATYP="" F IBT=0:0 S IBATYP=$O(^TMP($J,"IB",IBSEQNO,IBATYP)) Q:IBATYP=""!(IBQUIT) D LINE
- Q
- ;
- LINE ;
- I $Y>(IOSL-5) D PAUSE^IBOUTL Q:IBQUIT D HDR
- W !!?((IOM/2)-$L($P(IBATYP," ",2,99))),$P(IBATYP," ",2,99)
- W !?((IOM/2)-12),"NUMBER ENTRIES: ",$S($D(^TMP($J,"IB",IBSEQNO,IBATYP,"GCNT")):^("GCNT"),1:0)
- W !?((IOM/2)-12),"DOLLAR AMOUNT: $",$S($D(^TMP($J,"IB",IBSEQNO,IBATYP,"GTOT")):^("GTOT"),1:0)
- Q
- ;
- NETLIN ;
- I $Y>(IOSL-5) D PAUSE^IBOUTL Q:IBQUIT D HDR
- Q:'$D(^TMP($J,"IB",IBSEQNO,IBATYP,"NCNT"))
- W !!?((IOM/2)-$L($P(IBATYP," ",2,99))),$P(IBATYP," ",2,99)
- W !?((IOM/2)-12),"NUMBER ENTRIES: ",$S($D(^TMP($J,"IB",IBSEQNO,IBATYP,"NCNT")):^("NCNT"),1:0)
- W !?((IOM/2)-12),"DOLLAR AMOUNT: $",$S($D(^TMP($J,"IB",IBSEQNO,IBATYP,"NTOT")):^("NTOT"),1:0)
- Q
- HDR ;
- W:$E(IOST,1,2)["C-"!(IBPAG>0) @IOF,*13
- W ?((IOM-37)/2),"INTEGRATED BILLING STATISTICAL REPORT"
- W !?((IOM-3)/2),"for"
- D SITE^IBAUTL S IBSNM=$S($D(^DIC(4,IBFAC,0)):$P(^(0),"^"),1:"")
- W !?((IOM-($L(IBSNM)+6))/2),IBSNM_" ("_IBSITE_")"
- W !!?(IOM-18/2),"From: " S Y=IBBDT D DT^DIQ
- W !?((IOM-16)/2),"To: " S Y=IBEDT D DT^DIQ
- W !!?(IOM-26/2),"Date Printed: ",IBHDT
- S IBPAG=IBPAG+1 W !?(IOM-8/2),"Page: ",IBPAG
- W !?(IOM-26/2),"--------------------------"
- Q
- ;
- END K ^TMP($J)
- ;***
- ;I $D(XRT0) S:'$D(XRTN) XRTN="IBOST" D T1^%ZOSV ;stop rt clock
- I $D(ZTQUEUED) S ZTREQ="@" Q
- K DUOUT,IBT,IBBDT,IBEDT,IBATYP,IBSEQNO,IBHDT,IBPAG,IBSNM,IBFAC,IBSITE,IBSEQNOL,IBLAST,IBL,IBCHRG,IBDT,IBJ,IBLDT,IBN,IBND,IBQUIT,X,Y
- D ^%ZISC
- Q
- IBOST ;ALB/AAS - INTEGRATED BILLING STATISTICAL REPORT ; 8-MAR-91
- +1 ;;Version 2.0 ; INTEGRATED BILLING ;; 21-MAR-94
- +2 ;
- EN ;
- +1 ;***
- +2 ;S XRTL=$ZU(0),XRTN="IBOST-1" D T0^%ZOSV ;start rt clock
- +3 DO HOME^%ZIS
- WRITE @IOF,*13,?20,"Integrated Billing Statistical Report"
- +4 WRITE !!
- DO DATE^IBOUTL
- IF IBEDT=""
- GOTO END
- DEV SET %ZIS="QM"
- SET %ZIS("A")="Output Device: "
- DO ^%ZIS
- IF POP
- GOTO END
- +1 IF $DATA(IO("Q"))
- SET ZTRTN="DQ^IBOST"
- SET ZTDESC="IB Statistical Report"
- SET ZTSAVE("IB*")=""
- DO ^%ZTLOAD
- KILL IO("Q"),ZTSK
- GOTO END
- +2 USE IO
- +3 ;***
- +4 ;I $D(XRT0) S:'$D(XRTN) XRTN="IBOST" D T1^%ZOSV ;stop rt clock
- +5 WRITE !!
- +6 ;
- DQ ; -entry from tasked job
- +1 ;***
- +2 ;S XRTL=$ZU(0),XRTN="IBOST-2" D T0^%ZOSV ;start rt clock
- +3 KILL ^TMP($JOB)
- +4 SET IBN=""
- FOR IBDT=IBBDT:0
- SET IBDT=$ORDER(^IB("D",IBDT))
- IF 'IBDT!(IBDT>(IBEDT+.24))
- QUIT
- FOR IBN=0:0
- SET IBN=$ORDER(^IB("D",IBDT,IBN))
- IF 'IBN
- QUIT
- IF $DATA(^IB(IBN,0))
- DO GROSS
- IF $PIECE(^IB(IBN,0),"^",9)=IBN
- DO NET
- +5 ;
- +6 DO PRINT
- WRITE !
- +7 GOTO END
- +8 ;
- GROSS ; -gross count of action types, total charges
- +1 ; -^tmp($j,"ib",ibaction type,"gcnt")=count
- +2 ; ^tmp($j,"ib",ibaction type,"gtot")=sum of charges
- +3 ;
- +4 SET IBND=^IB(IBN,0)
- +5 SET IBATYP=$SELECT($DATA(^IBE(350.1,+$PIECE(IBND,"^",3),0)):$PIECE(^(0),"^"),1:"UNKNOWN")
- SET IBSEQNO=$SELECT($DATA(^IBE(350.1,+$PIECE(IBND,"^",3),0)):$PIECE(^(0),"^",5),1:0)
- +6 IF '$DATA(^TMP($JOB,"IB",IBSEQNO,IBATYP,"GCNT"))
- SET ^("GCNT")=0
- SET ^("GCNT")=^("GCNT")+1
- +7 IF '$DATA(^TMP($JOB,"IB",IBSEQNO,IBATYP,"GTOT"))
- SET ^("GTOT")=0
- SET ^("GTOT")=^("GTOT")+$PIECE(IBND,"^",7)
- +8 QUIT
- +9 ;
- NET ; -net count of new actions that aren't cancelled
- +1 ; -^tmp($j,"ib",ibaction type,"ncnt")=net count
- +2 ; ^tmp($j,"ib",ibaction type,"ntot")=net total
- +3 SET IBLAST=""
- SET IBLDT=$ORDER(^IB("APDT",IBN,""))
- IF +IBLDT
- FOR IBL=0:0
- SET IBL=$ORDER(^IB("APDT",IBN,IBLDT,IBL))
- IF 'IBL
- QUIT
- SET IBLAST=IBL
- +4 IF 'IBLAST
- QUIT
- +5 IF '$DATA(^IB(IBLAST,0))
- QUIT
- +6 SET IBCHRG=$PIECE(^IB(IBLAST,0),"^",7)
- SET IBSEQNOL=$SELECT($DATA(^IBE(350.1,$PIECE(^IB(IBLAST,0),"^",3),0)):$PIECE(^(0),"^",5),1:"")
- +7 IF IBSEQNOL=2
- SET IBCHRG=0
- +8 IF '$DATA(^TMP($JOB,"IB",IBSEQNO,IBATYP,"NTOT"))
- SET ^("NTOT")=0
- SET ^("NTOT")=^("NTOT")+(IBCHRG)
- +9 IF '$DATA(^TMP($JOB,"IB",IBSEQNO,IBATYP,"NCNT"))
- SET ^("NCNT")=0
- SET ^("NCNT")=^("NCNT")+$SELECT(IBSEQNOL=2:0,1:1)
- +10 QUIT
- +11 ;
- PRINT ; -output data
- +1 SET IBQUIT=0
- SET IBPAG=0
- SET Y=DT
- DO D^DIQ
- SET IBHDT=Y
- DO HDR
- +2 WRITE !!?((IOM-25)/2),"NET TOTALS BY ACTION TYPE"
- +3 FOR IBSEQNO=0:0
- SET IBSEQNO=$ORDER(^TMP($JOB,"IB",IBSEQNO))
- IF 'IBSEQNO!(IBQUIT)
- QUIT
- SET IBATYP=""
- FOR IBT=0:0
- SET IBATYP=$ORDER(^TMP($JOB,"IB",IBSEQNO,IBATYP))
- IF IBATYP=""!(IBQUIT)
- QUIT
- DO NETLIN
- +4 ;
- +5 WRITE !!?((IOM-27)/2),"GROSS TOTALS BY ACTION TYPE"
- +6 FOR IBSEQNO=0:0
- SET IBSEQNO=$ORDER(^TMP($JOB,"IB",IBSEQNO))
- IF 'IBSEQNO!(IBQUIT)
- QUIT
- SET IBATYP=""
- FOR IBT=0:0
- SET IBATYP=$ORDER(^TMP($JOB,"IB",IBSEQNO,IBATYP))
- IF IBATYP=""!(IBQUIT)
- QUIT
- DO LINE
- +7 QUIT
- +8 ;
- LINE ;
- +1 IF $Y>(IOSL-5)
- DO PAUSE^IBOUTL
- IF IBQUIT
- QUIT
- DO HDR
- +2 WRITE !!?((IOM/2)-$LENGTH($PIECE(IBATYP," ",2,99))),$PIECE(IBATYP," ",2,99)
- +3 WRITE !?((IOM/2)-12),"NUMBER ENTRIES: ",$SELECT($DATA(^TMP($JOB,"IB",IBSEQNO,IBATYP,"GCNT")):^("GCNT"),1:0)
- +4 WRITE !?((IOM/2)-12),"DOLLAR AMOUNT: $",$SELECT($DATA(^TMP($JOB,"IB",IBSEQNO,IBATYP,"GTOT")):^("GTOT"),1:0)
- +5 QUIT
- +6 ;
- NETLIN ;
- +1 IF $Y>(IOSL-5)
- DO PAUSE^IBOUTL
- IF IBQUIT
- QUIT
- DO HDR
- +2 IF '$DATA(^TMP($JOB,"IB",IBSEQNO,IBATYP,"NCNT"))
- QUIT
- +3 WRITE !!?((IOM/2)-$LENGTH($PIECE(IBATYP," ",2,99))),$PIECE(IBATYP," ",2,99)
- +4 WRITE !?((IOM/2)-12),"NUMBER ENTRIES: ",$SELECT($DATA(^TMP($JOB,"IB",IBSEQNO,IBATYP,"NCNT")):^("NCNT"),1:0)
- +5 WRITE !?((IOM/2)-12),"DOLLAR AMOUNT: $",$SELECT($DATA(^TMP($JOB,"IB",IBSEQNO,IBATYP,"NTOT")):^("NTOT"),1:0)
- +6 QUIT
- HDR ;
- +1 IF $EXTRACT(IOST,1,2)["C-"!(IBPAG>0)
- WRITE @IOF,*13
- +2 WRITE ?((IOM-37)/2),"INTEGRATED BILLING STATISTICAL REPORT"
- +3 WRITE !?((IOM-3)/2),"for"
- +4 DO SITE^IBAUTL
- SET IBSNM=$SELECT($DATA(^DIC(4,IBFAC,0)):$PIECE(^(0),"^"),1:"")
- +5 WRITE !?((IOM-($LENGTH(IBSNM)+6))/2),IBSNM_" ("_IBSITE_")"
- +6 WRITE !!?(IOM-18/2),"From: "
- SET Y=IBBDT
- DO DT^DIQ
- +7 WRITE !?((IOM-16)/2),"To: "
- SET Y=IBEDT
- DO DT^DIQ
- +8 WRITE !!?(IOM-26/2),"Date Printed: ",IBHDT
- +9 SET IBPAG=IBPAG+1
- WRITE !?(IOM-8/2),"Page: ",IBPAG
- +10 WRITE !?(IOM-26/2),"--------------------------"
- +11 QUIT
- +12 ;
- END KILL ^TMP($JOB)
- +1 ;***
- +2 ;I $D(XRT0) S:'$D(XRTN) XRTN="IBOST" D T1^%ZOSV ;stop rt clock
- +3 IF $DATA(ZTQUEUED)
- SET ZTREQ="@"
- QUIT
- +4 KILL DUOUT,IBT,IBBDT,IBEDT,IBATYP,IBSEQNO,IBHDT,IBPAG,IBSNM,IBFAC,IBSITE,IBSEQNOL,IBLAST,IBL,IBCHRG,IBDT,IBJ,IBLDT,IBN,IBND,IBQUIT,X,Y
- +5 DO ^%ZISC
- +6 QUIT