VistA-WorldVistAEHR/r/SCHEDULING-SD-SC/SDAMOS1.m

108 lines
3.7 KiB
Mathematica

SDAMOS1 ;ALB/SCK - AM MGT REPORTS STATISTICS OUTPUT ; 5/14/93
;;5.3;Scheduling;;Aug 13, 1993
;
BLD ; build report from data stored in TMP global
N I,SDFIN,STATUS
S (TC,TA,TI,SDCO,SDAR,SDIP,SDTOT,SDFIN,TCOCNT,TARCNT,TIPCNT)=0,PAGE=1
S SDLST="",SDLST=$O(^TMP("SDAMS",$J,SDLST)),SDFIN=$$HDR(SDLST)
S SDNXT="" F S SDNXT=$O(^TMP("SDAMS",$J,SDNXT)) Q:SDNXT="" D G:SDFIN BLDQ
. I SDNXT'=SDLST S SDFIN=$$HDR(SDNXT) Q:SDFIN S SDLST=SDNXT,(TC,TI,TA)=0
. S NXTSC="" F S NXTSC=$O(^TMP("SDAMS",$J,SDNXT,NXTSC)) Q:NXTSC="" D Q:SDFIN
.. S STATUS=0 F S STATUS=$O(^TMP("SDAMS",$J,SDNXT,NXTSC,STATUS)) Q:'STATUS D Q:SDFIN
... S SDFIN=$$STCNT(STATUS,+^(STATUS)) ; ref to tmp(sdams,$j,div,stocode,status)
.. S SDFIN=$$SUBTOT(NXTSC)
. D TOTALS
D TDIV
BLDQ K SDCO,SDAR,SDIP,SDTOT,TCOCNT,TARCNT,TIPCNT,SDLST,LSTSC,SDNXT,NXTSC,ACTION,QFLAG,TC,TI,TA,TOT,PAGE,SDFIN,%
Q
;
STCNT(STAT,COUNT) ; increment action count for stopcode
; sdar = action req by stop code
; sdco = checked out by stop code
; sdip = in-pat by stop code
;
N Y S Y=0
S:STAT=14 SDAR=SDAR+COUNT
S:STAT=2 SDCO=SDCO+COUNT
S:STAT=8 SDIP=SDIP+COUNT
Q (Y)
;
SUBTOT(SDCODE) ; totals by stopcode
; tcocnt = checked out total by division (per page)
; tarcnt = action req tot by div/page
; tipcnt = In-pat tot by div/page
;
N Y,SDFIN
S Y=0
I $Y+5>IOSL D G:SDFIN SUBTOTQ
. D TOTALS
. S SDFIN=$$HDR(SDNXT) Q:SDFIN
I SDSEL=5 W !,SDCODE,?34,SDCO,?53,SDAR,?64,SDIP,?77,SDCO+SDAR+SDIP
S TCOCNT=TCOCNT+SDCO,TARCNT=TARCNT+SDAR,TIPCNT=TIPCNT+SDIP
S (SDCO,SDAR,SDIP)=0
SUBTOTQ Q (Y)
;
TOTALS ; total of actions by stopcode for division
; tc = check out total for division
; ta = action required tot for div.
; ti = in-pat tot for div.
;
N SDIV
I SDSEL=5 W !,SDTDASH,!,"TOTAL",?34,TCOCNT,?53,TARCNT,?64,TIPCNT,?77,TCOCNT+TARCNT+TIPCNT
S TC=TC+TCOCNT,TA=TA+TARCNT,TI=TI+TIPCNT
S TOT(SDNXT)=TC_U_TA_U_TI
S (TCOCNT,TARCNT,TIPCNT)=0
Q
;
HDR(SDIV) ; page header
N Y
S Y=0
G:SDSEL'=5 HDRQ
D PAUSE
W !!,"Statistics Report by Stop Code"
W !,"Division: ",SDIV,?40,"Date Range ",$$FDATE^VALM1(SDBEG)_" to "_$$FDATE^VALM1(SDEND)
D NOW^%DTC W ?95,"Run Date: ",$E($$FDTTM^VALM1(%),1,14),?125,"Page: ",PAGE S PAGE=PAGE+1
W !," Stop Code",?25,"Checked-Out",?40,"Action Required",?58,"Inpatient",?75,"Total",!,SDASH
HDRQ Q (Y)
;
TDIV ; final totals by division for med center
; reuse tc for check out total by med ctr
; ta for action req tot
; ti for in-pat tot
; tcd = check out totals by div
; tad = action req totals by div
; tip = in-pat totals by div
;
N SDIV,TC,TA,TI,TCD,TAD,TID
S (TC,TA,TI,TCD,TAD,TID)=0
D PAUSE
W !!,"Statistics Report Totals by Division"
W !,"MEDICAL CENTER",?40,"Date Range ",$$FDATE^VALM1(SDBEG)_" to "_$$FDATE^VALM1(SDEND)
D NOW^%DTC W ?95,"Run Date: ",$E($$FDTTM^VALM1(%),1,14),?125,"Page: ",PAGE S PAGE=PAGE+1
W !," Division",?25,"Checked-Out",?40,"Action Required",?58,"Inpatient",?75,"Total"
S SDIV="" F S SDIV=$O(TOT(SDIV)) Q:SDIV="" D
. W !,SDASH
. S TCD=$P(TOT(SDIV),U),TAD=$P(TOT(SDIV),U,2),TID=$P(TOT(SDIV),U,3)
. W !,SDIV,?34,TCD,?54,TAD,?65,TID,?75,TCD+TAD+TID
. S TC=TC+TCD,TA=TA+TAD,TI=TI+TID
W !,SDTDASH
W !,"TOTAL",?34,TC,?54,TA,?65,TI,?75,TC+TA+TI
K TCD,TAD,TID
TDIVQ Q
;
PAUSE ;
I $E(IOST,1,2)="C-" D
. S DIR(0)="FO",DIR("A")="Press RETURN to continue or '^' to exit"
. D ^DIR K DIR I $D(DUOUT)!($D(DTOUT)) Q
. W @IOF
E W @IOF
PAUSEQ Q
;
NOREP ; report if no data in TMP global
W !!,"Statistics Report by Stop Code"
W !,"Date Range ",$$FDATE^VALM1(SDBEG)_" to "_$$FDATE^VALM1(SDEND)
D NOW^%DTC W ?95,"Run Date: ",$E($$FDTTM^VALM1(%),1,14),?125,"Page: 1"
W !,SDASH
W !!?10,"No data found matching sort parameters"
Q