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

IBDFOSG2.m

Go to the documentation of this file.
  1. IBDFOSG2 ;ALB/TMP - ENCOUNTERS WITH BILLING DATA CONT. - SEP 11, 1995
  1. ;;3.0;AUTOMATED INFO COLLECTION SYS;;APR 24, 1997
  1. TOT2 ; #2a,b
  1. N IBDHD,IBBY,IBFLDS
  1. I '$D(DT) D DT^DICRW
  1. S (IBFLDS,IBBY)="OPT AMT BILLED & # GEN"
  1. S IBDHD="(#2a,2b) OUTPT DOLLARS BILLED, # OF OUTPT BILLS GENERATED"
  1. D PRT("2a,b",IBFLDS,IBBY,IBDHD)
  1. K IOP,DQTIME
  1. Q
  1. ;
  1. TOT3 ; #3a,b
  1. N IBDHD,IBBY,IBFLDS
  1. I '$D(DT) D DT^DICRW
  1. S (IBFLDS,IBBY)="OPT NUM BILLS GEN < 65"
  1. S IBDHD="(#3a) # OF OUTPT BILLS FOR PATIENTS < 65 YEARS OF AGE DATE: "
  1. D PRT("3a",IBFLDS,IBBY,IBDHD)
  1. ;
  1. I '$D(IOP) W !,"#3b" D SELDEV Q:'$D(IOP)!('$D(DQTIME))
  1. S (IBFLDS,IBBY)="OPT NUM BILLS GEN 65 & UP"
  1. S IBDHD="(#3b) # OF OUTPT BILLS FOR PATIENTS AGE 65 AND OVER"
  1. D PRT("3b",IBFLDS,IBBY,IBDHD)
  1. K IOP,DQTIME
  1. Q
  1. ;
  1. TOT4 ; #4
  1. N IBDHD,IBBY,IBFLDS
  1. I '$D(DT) D DT^DICRW
  1. S (IBFLDS,IBBY)="OPT # BILLS GEN < 30 DYS"
  1. S IBDHD="(#4) # BILLS GENERATED < 30 DAYS FROM DT OF SERVICE"
  1. D PRT(4,IBFLDS,IBBY,IBDHD)
  1. K IOP,DQTIME
  1. Q
  1. ;
  1. TOT7 ; #7
  1. N IBDHD,IBBY,IBFLDS
  1. I '$D(DT) D DT^DICRW
  1. S (IBFLDS,IBBY)="CPT CODE - MNTH OPT BILLS"
  1. S IBDHD="(#7) TOTAL # CPT CODES ON OUTPATIENT BILLS FOR A MONTH"
  1. D PRT(7,IBFLDS,IBBY,IBDHD)
  1. K IOP,DQTIME
  1. Q
  1. ;
  1. TOT10 ; #10a,b
  1. N IBDHD,IBBY,IBFLDS
  1. I '$D(DT) D DT^DICRW
  1. S (IBFLDS,IBBY)="LAG ENC DT TO CREAT & PRT"
  1. S IBDHD="(#10a,10b) AVG LAG FROM ENC DATE TO CREATE AND PRINT DATES"
  1. D PRT(10,IBFLDS,IBBY,IBDHD)
  1. K IOP,DQTIME
  1. Q
  1. ;
  1. TOT11 ; #11
  1. N DTRNG,DTRNG1
  1. I '$D(DT) D DT^DICRW
  1. D END
  1. W !,"#11"
  1. W !!,"Scanned Encounter Forms with Outpatient Bills Generated."
  1. ;I $D(^DG(43,1,"GL")) S IBDFMUL=$P(^DG(43,1,"GL"),"^",2)
  1. ;I $D(IBDFMUL),IBDFMUL D DIVISION^VAUTOMA I Y=-1 G END
  1. ;I 'IBDFMUL S IBDFDV=$O(^DG(40.8,0))
  1. S (VAUTD,IBDFMUL)=1
  1. ;
  1. W !!,"You will need a 132 column printer for this report!",!
  1. D SELDEV I '$D(IOP)!('$D(DQTIME)) G END
  1. ;
  1. D DTRNG ;,SELMONTH
  1. S IBZ=$G(DTRNG1($E(Y,1,5)_"01"))
  1. I IBZ,$D(DTRNG(IBZ)) S IBBDT=$P(DTRNG(IBZ),U),IBEDT=$P(DTRNG(IBZ),U,2) D PRT11
  1. S DIR(0)="SB^A:ALL 24 MONTHS;S:SELECTED MONTH ONLY",DIR("A")="INCLUDE ALL MONTHS OR A SELECTED MONTH",DIR("B")="A" D ^DIR K DIR
  1. G:$D(DIRUT) TOT11Q
  1. I Y="A" D G TOT11Q
  1. .F IBZ=1:1:24 D PRT11
  1. D SELMONTH
  1. S IBZ=$G(DTRNG1($E(Y,1,5)_"01")) I IBZ D PRT11
  1. ;
  1. TOT11Q G END
  1. ;
  1. PRT11 ;
  1. I IBZ,$D(DTRNG(IBZ)) S IBBDT=$P(DTRNG(IBZ),U),IBEDT=$P(DTRNG(IBZ),U,2)
  1. S DIPA("DTFR")=IBBDT
  1. W !,"#11 MONTH: "_$$DT()
  1. S IBDFL="CLN",VAUTC=1
  1. S IBDFDAT=$$HTE^XLFDT($H)
  1. S IBDFBEG=IBBDT,IBDFEND=IBEDT
  1. S ZTDTH=$TR(DQTIME,"@",".")
  1. S ZTRTN="DQ^IBDFOSG",ZTSAVE("IB*")="",ZTSAVE("VAU*")="",ZTSAVE("VAD*")="",ZTDESC="Scanned Encntr Forms Totals" D ^%ZTLOAD
  1. W !,$S($D(ZTSK):"Request Queued Task="_ZTSK,1:"Request Canceled")
  1. Q
  1. ;
  1. END D END^IBDFOSG
  1. K DQTIME,IOP
  1. Q
  1. ;
  1. PRT(IBTOT,IBFLDS,IBBY,IBDHD,DIOBEG,DIOEND) ; Prt rpt
  1. N IBZ,DTRNG,DTRNG1,DIPA,Y,X
  1. W !,"#",IBTOT
  1. D:'$D(IOP) SELDEV G:'$D(IOP)!('$D(DQTIME)) PRTQ
  1. D DTRNG
  1. S DIR(0)="SB^A:ALL 24 MONTHS;S:SELECTED MONTH ONLY",DIR("A")="INCLUDE ALL MONTHS OR A SELECTED MONTH",DIR("B")="A" D ^DIR K DIR
  1. G:$D(DIRUT) PRTQ
  1. I Y="A" D G PRTQ
  1. .F IBZ=1:1:24 D PRT1
  1. D SELMONTH
  1. S IBZ=$G(DTRNG1($E(Y,1,5)_"01")) I IBZ D PRT1
  1. PRTQ Q
  1. ;
  1. PRT1 I $G(IBTOT)=10 S DIOBEG="D BEG10^IBDFOSG2",DIOEND="D END10^IBDFOSG2"
  1. S DIPA("DTTO")=$P(DTRNG(IBZ),U,2),DIPA("DTFR")=$P(DTRNG(IBZ),U),FLDS="[EFDP "_IBFLDS_"]",BY="[EFDP "_IBBY_"]"
  1. S FR="3,"_DIPA("DTFR"),TO="4,"_DIPA("DTTO"),L=0,DHD=IBDHD_" MONTH: "_$$DT(),DIC="^DGCR(399,",DIS(0)="I $O(^DGCR(399,D0,""OP"",0))'="""""
  1. W !,"TOTALS FOR #"_IBTOT_" ("_$$DT()_")"
  1. D EN1^DIP
  1. Q
  1. ;
  1. BEG10 ; DIOBEG
  1. S ^TMP($J,"EFDPTOT",1)=0,^(2)=0,^TMP($J,"EFDPTOT",3)=0,^(4)=0
  1. Q
  1. ;
  1. END10 ; DIOEND
  1. W !!,"(10a) AVERAGE # DAYS LAG FROM ENCOUNTER TO BILL CREATE: ",$J($S(^TMP($J,"EFDPTOT",2):^TMP($J,"EFDPTOT",1)/^TMP($J,"EFDPTOT",2),1:0),10,2)
  1. W !,"(10b) AVERAGE # DAYS LAG FROM ENCOUNTER TO BILL PRINT : ",$J($S(^TMP($J,"EFDPTOT",4):^TMP($J,"EFDPTOT",3)/^TMP($J,"EFDPTOT",4),1:0),10,2)
  1. K ^TMP($J,"EFDPTOT")
  1. Q
  1. ;
  1. LAG ; Set up lag time accumulators-from computed fld
  1. N X1,X2,Z,Z0,Z1
  1. S (Z,X)=0,Z0=+$G(^DGCR(399,D0,"S")),Z1=+$P($G(^("S")),U,12)
  1. F S Z=$O(^DGCR(399,D0,"OP",Z)) S:'Z X=0 Q:'Z D ;loop thru opt visits
  1. .S X1=Z0,X2=+$G(^DGCR(399,D0,"OP",Z,0)) I X2,X1 D ^%DTC S ^TMP($J,"EFDPTOT",1)=$G(^TMP($J,"EFDPTOT",1))+X,^TMP($J,"EFDPTOT",2)=$G(^TMP($J,"EFDPTOT",2))+1 ;elapsed time and count - encounter to bill create
  1. .S X1=Z1,X2=+$G(^DGCR(399,D0,"OP",Z,0)) I X2,X1 D ^%DTC S ^TMP($J,"EFDPTOT",3)=$G(^TMP($J,"EFDPTOT",3))+X,^TMP($J,"EFDPTOT",4)=$G(^TMP($J,"EFDPTOT",4))+1 ;elapsed tm,ct (encntr-bill 1st prt)
  1. Q
  1. ;
  1. GEN30 ; Was printed within 30 days of any visit on bill
  1. N X1,X2,Z,Z0
  1. S (Z,X)=0,Z0=+$P($G(^DGCR(399,D0,"S")),U,12) Q:'Z0
  1. F S Z=$O(^DGCR(399,D0,"OP",Z)) S:'Z X=0 Q:'Z D Q:X ;loop thru opt visits
  1. .S X1=Z0,X2=+$G(^DGCR(399,D0,"OP",Z,0)) I X2,X1 D ^%DTC S X=$S(X<30:1,1:0)
  1. Q
  1. ;
  1. DTRNG ;
  1. N Z,Z0,X1,X2,X
  1. ;S Z=2931001 F Z0=1:1:23 D
  1. S Z=2940401 F Z0=1:1:24 D
  1. .S X2=-1,Z1=$E(Z,1,5)+1_"01" S:$E(Z1,4,5)=13 Z1=Z1+8800
  1. .S X1=Z1 D C^%DTC S DTRNG(Z0)=Z_U_X,DTRNG1(Z)=Z0,Z=Z1
  1. Q
  1. ;
  1. SELDEV ; Device/queue tm (IOP,DQTIME returned)
  1. K IOP,DQTIME
  1. S %ZIS("A")="Select device the output will be queued to: ",%ZIS="NQ",%ZIS("B")=""
  1. D ^%ZIS K %ZIS
  1. I IO=IO(0) W !,$C(7),"CANNOT BE YOUR HOME DEVICE" G SELDEV
  1. I POP D HOME^%ZIS G SELDEVQ
  1. S IOP="Q;"_IO
  1. S %DT("A")="Select date/time to queue these reports to run: ",%DT="AEXRF",%DT("B")="NOW",%DT(0)="NOW" D ^%DT K %DT
  1. I Y>0 S DQTIME=$TR(Y,".","@") I $L($P(Y,"@",2))<4 S DQTIME=DQTIME_$E("0000",1,4-$L($P(DQTIME,"@",2)))
  1. SELDEVQ Q
  1. ;
  1. DT() ; Display date format
  1. S Y=$E(DIPA("DTFR"),1,5)_"00"
  1. D DD^%DT
  1. Q Y
  1. ;
  1. SELMONTH ;
  1. F S %DT="AEPN",%DT(0)=-2960300,%DT("A")="SELECT MONTH: " D ^%DT K %DT Q:X="^"!($D(DTOUT))!($D(DTRNG1($E(Y,1,5)_"01"))) W !,$C(7),"Must choose a month from 4/94 thru 3/96"
  1. Q
  1. ;