| 1 | IBOST ;ALB/AAS - INTEGRATED BILLING STATISTICAL REPORT ; 8-MAR-91 | 
|---|
| 2 | ;;Version 2.0 ; INTEGRATED BILLING ;; 21-MAR-94 | 
|---|
| 3 | ; | 
|---|
| 4 | EN ; | 
|---|
| 5 | ;*** | 
|---|
| 6 | ;S XRTL=$ZU(0),XRTN="IBOST-1" D T0^%ZOSV ;start rt clock | 
|---|
| 7 | D HOME^%ZIS W @IOF,*13,?20,"Integrated Billing Statistical Report" | 
|---|
| 8 | W !! D DATE^IBOUTL I IBEDT="" G END | 
|---|
| 9 | DEV S %ZIS="QM",%ZIS("A")="Output Device: " D ^%ZIS G:POP END | 
|---|
| 10 | I $D(IO("Q")) S ZTRTN="DQ^IBOST",ZTDESC="IB Statistical Report",ZTSAVE("IB*")="" D ^%ZTLOAD K IO("Q"),ZTSK G END | 
|---|
| 11 | U IO | 
|---|
| 12 | ;*** | 
|---|
| 13 | ;I $D(XRT0) S:'$D(XRTN) XRTN="IBOST" D T1^%ZOSV ;stop rt clock | 
|---|
| 14 | W !! | 
|---|
| 15 | ; | 
|---|
| 16 | DQ ;  -entry from tasked job | 
|---|
| 17 | ;*** | 
|---|
| 18 | ;S XRTL=$ZU(0),XRTN="IBOST-2" D T0^%ZOSV ;start rt clock | 
|---|
| 19 | K ^TMP($J) | 
|---|
| 20 | 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 | 
|---|
| 21 | ; | 
|---|
| 22 | D PRINT W ! | 
|---|
| 23 | G END | 
|---|
| 24 | ; | 
|---|
| 25 | GROSS ;  -gross count of action types, total charges | 
|---|
| 26 | ;  -^tmp($j,"ib",ibaction type,"gcnt")=count | 
|---|
| 27 | ;   ^tmp($j,"ib",ibaction type,"gtot")=sum of charges | 
|---|
| 28 | ; | 
|---|
| 29 | S IBND=^IB(IBN,0) | 
|---|
| 30 | 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) | 
|---|
| 31 | S:'$D(^TMP($J,"IB",IBSEQNO,IBATYP,"GCNT")) ^("GCNT")=0 S ^("GCNT")=^("GCNT")+1 | 
|---|
| 32 | S:'$D(^TMP($J,"IB",IBSEQNO,IBATYP,"GTOT")) ^("GTOT")=0 S ^("GTOT")=^("GTOT")+$P(IBND,"^",7) | 
|---|
| 33 | Q | 
|---|
| 34 | ; | 
|---|
| 35 | NET ; -net count of new actions that aren't cancelled | 
|---|
| 36 | ;  -^tmp($j,"ib",ibaction type,"ncnt")=net count | 
|---|
| 37 | ;   ^tmp($j,"ib",ibaction type,"ntot")=net total | 
|---|
| 38 | 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 | 
|---|
| 39 | Q:'IBLAST | 
|---|
| 40 | Q:'$D(^IB(IBLAST,0)) | 
|---|
| 41 | S IBCHRG=$P(^IB(IBLAST,0),"^",7),IBSEQNOL=$S($D(^IBE(350.1,$P(^IB(IBLAST,0),"^",3),0)):$P(^(0),"^",5),1:"") | 
|---|
| 42 | S:IBSEQNOL=2 IBCHRG=0 | 
|---|
| 43 | S:'$D(^TMP($J,"IB",IBSEQNO,IBATYP,"NTOT")) ^("NTOT")=0 S ^("NTOT")=^("NTOT")+(IBCHRG) | 
|---|
| 44 | S:'$D(^TMP($J,"IB",IBSEQNO,IBATYP,"NCNT")) ^("NCNT")=0 S ^("NCNT")=^("NCNT")+$S(IBSEQNOL=2:0,1:1) | 
|---|
| 45 | Q | 
|---|
| 46 | ; | 
|---|
| 47 | PRINT ;  -output data | 
|---|
| 48 | S IBQUIT=0,IBPAG=0,Y=DT D D^DIQ S IBHDT=Y D HDR | 
|---|
| 49 | W !!?((IOM-25)/2),"NET TOTALS BY ACTION TYPE" | 
|---|
| 50 | 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 | 
|---|
| 51 | ; | 
|---|
| 52 | W !!?((IOM-27)/2),"GROSS TOTALS BY ACTION TYPE" | 
|---|
| 53 | 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 | 
|---|
| 54 | Q | 
|---|
| 55 | ; | 
|---|
| 56 | LINE ; | 
|---|
| 57 | I $Y>(IOSL-5) D PAUSE^IBOUTL Q:IBQUIT  D HDR | 
|---|
| 58 | W !!?((IOM/2)-$L($P(IBATYP," ",2,99))),$P(IBATYP," ",2,99) | 
|---|
| 59 | W !?((IOM/2)-12),"NUMBER ENTRIES: ",$S($D(^TMP($J,"IB",IBSEQNO,IBATYP,"GCNT")):^("GCNT"),1:0) | 
|---|
| 60 | W !?((IOM/2)-12),"DOLLAR AMOUNT: $",$S($D(^TMP($J,"IB",IBSEQNO,IBATYP,"GTOT")):^("GTOT"),1:0) | 
|---|
| 61 | Q | 
|---|
| 62 | ; | 
|---|
| 63 | NETLIN ; | 
|---|
| 64 | I $Y>(IOSL-5) D PAUSE^IBOUTL Q:IBQUIT  D HDR | 
|---|
| 65 | Q:'$D(^TMP($J,"IB",IBSEQNO,IBATYP,"NCNT")) | 
|---|
| 66 | W !!?((IOM/2)-$L($P(IBATYP," ",2,99))),$P(IBATYP," ",2,99) | 
|---|
| 67 | W !?((IOM/2)-12),"NUMBER ENTRIES: ",$S($D(^TMP($J,"IB",IBSEQNO,IBATYP,"NCNT")):^("NCNT"),1:0) | 
|---|
| 68 | W !?((IOM/2)-12),"DOLLAR AMOUNT: $",$S($D(^TMP($J,"IB",IBSEQNO,IBATYP,"NTOT")):^("NTOT"),1:0) | 
|---|
| 69 | Q | 
|---|
| 70 | HDR ; | 
|---|
| 71 | W:$E(IOST,1,2)["C-"!(IBPAG>0) @IOF,*13 | 
|---|
| 72 | W ?((IOM-37)/2),"INTEGRATED BILLING STATISTICAL REPORT" | 
|---|
| 73 | W !?((IOM-3)/2),"for" | 
|---|
| 74 | D SITE^IBAUTL S IBSNM=$S($D(^DIC(4,IBFAC,0)):$P(^(0),"^"),1:"") | 
|---|
| 75 | W !?((IOM-($L(IBSNM)+6))/2),IBSNM_" ("_IBSITE_")" | 
|---|
| 76 | W !!?(IOM-18/2),"From: " S Y=IBBDT D DT^DIQ | 
|---|
| 77 | W !?((IOM-16)/2),"To: " S Y=IBEDT D DT^DIQ | 
|---|
| 78 | W !!?(IOM-26/2),"Date Printed: ",IBHDT | 
|---|
| 79 | S IBPAG=IBPAG+1 W !?(IOM-8/2),"Page: ",IBPAG | 
|---|
| 80 | W !?(IOM-26/2),"--------------------------" | 
|---|
| 81 | Q | 
|---|
| 82 | ; | 
|---|
| 83 | END K ^TMP($J) | 
|---|
| 84 | ;*** | 
|---|
| 85 | ;I $D(XRT0) S:'$D(XRTN) XRTN="IBOST" D T1^%ZOSV ;stop rt clock | 
|---|
| 86 | I $D(ZTQUEUED) S ZTREQ="@" Q | 
|---|
| 87 | K DUOUT,IBT,IBBDT,IBEDT,IBATYP,IBSEQNO,IBHDT,IBPAG,IBSNM,IBFAC,IBSITE,IBSEQNOL,IBLAST,IBL,IBCHRG,IBDT,IBJ,IBLDT,IBN,IBND,IBQUIT,X,Y | 
|---|
| 88 | D ^%ZISC | 
|---|
| 89 | Q | 
|---|