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

AQAOPC52.m

Go to the documentation of this file.
  1. AQAOPC52 ; IHS/ORDC/LJF - PRINT QTR PROGRESS RPRT ;
  1. ;;1.01;QAI MANAGEMENT;;OCT 05, 1995
  1. ;
  1. ;This rtn prints occ finding/action counts by month in a matrix,
  1. ;months along the top and finding/action pairs down the side.
  1. ;Totals by month and totals by finding/action pair are also printed.
  1. ;Any action plans associated with the indicator are printed at the
  1. ;bottom of each indicator page.
  1. ;
  1. INIT ; >> initialize variables
  1. D MONTHS ;set array for all months included in report
  1. ;use wide margin if date range has more than 7 months
  1. S AQAOIOMX=80
  1. I Y>7 S AQAOIOM=IOM,(AQAOIOMX,X)=132 X:IOT'="HFS" ^%ZOSF("RM")
  1. S AQAOLIN3="",$P(AQAOLIN3,"-",AQAOIOMX-10)=""
  1. D INIT^AQAOUTIL S AQAOHCON="Patient"
  1. S AQAOTY=$S($D(AQAORPTT):AQAORPTT,1:"PROGRESS REPORT")
  1. S Y=AQAOBD X ^DD("DD") S AQAORNG="("_Y,Y=AQAOED-31 X ^DD("DD")
  1. S AQAORNG=AQAORNG_" - "_Y_")" ;date range
  1. ;
  1. LOOP ; >> loop thru ^tmp to get data then print it
  1. S AQAOF=0
  1. F S AQAOF=$O(^TMP("AQAOPC5",$J,1,AQAOF)) Q:AQAOF="" Q:AQAOSTOP=U D
  1. .S:AQAOTYP=1 AQAOIND=$O(^TMP("AQAOPC5",$J,1,AQAOF,0)),AQAOM=$$INDNAME
  1. .I AQAOPAGE=0 D HEADING^AQAOUTIL,HDG2 I 1
  1. .E D NEWPG^AQAOUTIL Q:AQAOSTOP=U D HDG2
  1. .S AQAOIND=0
  1. .F S AQAOIND=$O(^TMP("AQAOPC5",$J,1,AQAOF,AQAOIND)) Q:AQAOIND="" Q:AQAOSTOP=U D
  1. ..I $Y>(IOSL-4) D NEWPG^AQAOUTIL Q:AQAOSTOP=U D HDG2
  1. ..S AQAOM=$$INDNAME ;set indicator heading
  1. ..I AQAOTYP>1 W !!,AQAOM,!
  1. ..S AQAOIT=$G(^TMP("AQAOPC5A",$J,AQAOF,AQAOIND))
  1. ..I AQAOIT=0 W !?10,">> NO OCCURRENCES FOUND FOR THIS INDICATOR <<" Q
  1. ..E D COUNTP ;print counts by month
  1. ..D ACTION^AQAOPC54 ;include action plans
  1. ;
  1. ;
  1. EXIT ; >>> eoj
  1. I IOST["C-" D PRTOPT^AQAOVAR
  1. I $D(AQAOIOM),IOT'="HFS" S X=AQAOIOM X ^%ZOSF("RM")
  1. D ^%ZISC D KILL^AQAOUTIL
  1. K ^TMP("AQAOPC5",$J),^TMP("AQAOPC5A",$J),^TMP("AQAOPC5B",$J)
  1. Q
  1. ;
  1. ;
  1. ;
  1. COUNTP ; >> SUBRTN to print line for all find/act combos with counts by month
  1. D MONTHS ;PATCH 2
  1. S AQAOFA=0 ;get next finding
  1. F S AQAOFA=$O(^TMP("AQAOPC5A",$J,AQAOF,AQAOIND,AQAOFA)) Q:AQAOFA="" Q:AQAOSTOP=U D
  1. .S AQAOAC=0 ;get next action for this finding
  1. .F S AQAOAC=$O(^TMP("AQAOPC5A",$J,AQAOF,AQAOIND,AQAOFA,AQAOAC)) Q:AQAOAC="" Q:AQAOSTOP=U D
  1. ..S AQAOFAT=^TMP("AQAOPC5A",$J,AQAOF,AQAOIND,AQAOFA,AQAOAC) ;f/a subtl
  1. ..I $Y>(IOSL-4) D NEWPG^AQAOUTIL Q:AQAOSTOP=U D HDG2
  1. ..W !,AQAOFA,"/",AQAOAC,?8
  1. ..;
  1. ..;fill in counts for all months
  1. ..S AQAOMON=0
  1. ..F S AQAOMON=$O(AQAOARM(AQAOMON)) Q:AQAOMON="" Q:AQAOSTOP=U D
  1. ...I '$D(^TMP("AQAOPC5A",$J,AQAOF,AQAOIND,AQAOFA,AQAOAC,AQAOMON)) D Q
  1. ....S X=$X+9 W ?X
  1. ...S X=^TMP("AQAOPC5A",$J,AQAOF,AQAOIND,AQAOFA,AQAOAC,AQAOMON)
  1. ...W ?($X+1),$J(X,8) ; print count for month
  1. ...S AQAOARM(AQAOMON)=AQAOARM(AQAOMON)+X ;increment total
  1. ..W ?AQAOIOMX-11,$J(AQAOFAT,8)
  1. ..;
  1. ..;fill in percentages for all months for this find/act combo
  1. ..I $Y>(IOSL-4) D NEWPG^AQAOUTIL Q:AQAOSTOP=U D HDG2
  1. ..W !?8 S AQAOMON=0
  1. ..F S AQAOMON=$O(AQAOARM(AQAOMON)) Q:AQAOMON="" Q:AQAOSTOP=U D
  1. ...I '$D(^TMP("AQAOPC5A",$J,AQAOF,AQAOIND,AQAOFA,AQAOAC,AQAOMON)) D Q
  1. ....S X=$X+9 W ?X
  1. ..W ?AQAOIOMX-12,$J(AQAOFAT/AQAOIT*100,8,2),"%" ;find/act as % total
  1. ;
  1. ;
  1. ;print monthly totals for this indicator
  1. I $Y>(IOSL-4) D NEWPG^AQAOUTIL Q:AQAOSTOP=U D HDG2
  1. W !?9,AQAOLIN3,!,"Monthly:" S AQAOMON=0
  1. F S AQAOMON=$O(AQAOARM(AQAOMON)) Q:AQAOMON="" Q:AQAOSTOP=U D
  1. .W ?($X+1),$J(AQAOARM(AQAOMON),8) ;# of occ by month
  1. W ?AQAOIOMX-11,$J(+AQAOIT,8)
  1. ; ;print % for each month for ind
  1. S AQAOMON=0 W !?8
  1. F S AQAOMON=$O(AQAOARM(AQAOMON)) Q:AQAOMON="" Q:AQAOSTOP=U D
  1. .W:AQAOIT>0 $J(AQAOARM(AQAOMON)/AQAOIT*100,8,2),"%" ;% of occ
  1. W !
  1. Q
  1. ;
  1. ;
  1. MONTHS ; >> SUBRTN to create array for months in report&init their counts
  1. S X=AQAOBD,Y=0 F Q:X>AQAOED D
  1. .I $E(X,4,5)=13 S X=($E(X,1,3)+1)_"0100"
  1. .S AQAOARM($E(X,1,5))=0
  1. .S X=X+100,Y=Y+1
  1. Q
  1. ;
  1. ;
  1. HDG2 ; >> SUBRTN to print 2nd half of heading
  1. W ?AQAOIOMX-$L(AQAORNG)/2,AQAORNG,!
  1. I AQAOTYP=1 W ?AQAOIOMX-$L(AQAOM)/2,AQAOM
  1. E W ?AQAOIOMX-$L(AQAOF)/2,AQAOF
  1. W !,AQAOLIN2,!,"Find/Act"
  1. S X=0
  1. F S X=$O(AQAOARM(X)) Q:X="" W ?($X+2),1700+$E(X,1,3),"/",$E(X,4,5)
  1. W ?AQAOIOMX-9," Totals"
  1. W !,AQAOLINE
  1. Q
  1. ;
  1. ;
  1. INDNAME() ;ENTRY POINT EXTR VAR - sets the indicator heading variable
  1. S AQAOT=^AQAO(2,AQAOIND,0),AQAOM=$P(AQAOT,U)_"-"_$P(AQAOT,U,2)
  1. S Y=$P(AQAOT,U,3),C=$P(^DD(9002168.2,.03,0),U,2) D Y^DIQ
  1. S AQAOZ=" ("_Y ;add on process vs. outcome
  1. S Y=$P(AQAOT,U,4),C=$P(^DD(9002168.2,.04,0),U,2) D Y^DIQ
  1. S AQAOZ=AQAOZ_"/"_Y ;add on sentinel vs. rate-based
  1. S Y=$P(AQAOT,U,5) I Y]"" S C=$P(^DD(9002168.2,.05,0),U,2) D Y^DIQ
  1. S AQAOZ=$S(Y="":AQAOZ_")",1:AQAOZ_"/"_Y_")"),AQAOM=AQAOM_AQAOZ
  1. S AQAOM="*** "_AQAOM_" ***"
  1. Q AQAOM