APCLP614 ; IHS/CMI/LAB -IHS -CUMULATIVE REPORT ;
;;2.0;IHS PCC SUITE;;MAY 14, 2009
;
;
DURDM(P,R,EDATE) ;EP
NEW DATE
S DATE=""
I $G(R) S DATE=$$CMSFDX^APCLP613(P,R,"ID")
I DATE]"" Q ($$FMDIFF^XLFDT(EDATE,DATE,1)\365)
S DATE=$$PLDMDOO^APCLP613(P,"I")
I DATE]"" Q ($$FMDIFF^XLFDT(EDATE,DATE,1)\365)
Q ""
D(D) ;
I $G(D)="" Q ""
Q $S($E(D,4,5)="00":"07",1:$E(D,4,5))_"/"_$S($E(D,6,7)="00":"15",1:$E(D,6,7))_"/"_$E(D,2,3)
OB(APCLPD,BMI,D) ;EP obese
I $G(BMI)="" Q ""
NEW S S S=$P(^DPT(APCLPD,0),U,2)
I S="" Q ""
NEW A S A=$$AGE^AUPNPAT(APCLPD,D)
NEW R S R=$O(^APCLBMI("H",S,A)) I R S R=$O(^APCLBMI("H",S,R,""))
I R="" Q ""
I BMI>$P(^APCLBMI(R,0),U,7)!(BMI<$P(^APCLBMI(R,0),U,6)) Q ""
I BMI'<$P(^APCLBMI(R,0),U,5) Q 1
Q ""
OW(APCLPD,BMI,D) ;EP overweight
I $G(BMI)="" Q ""
NEW S S S=$P(^DPT(APCLPD,0),U,2)
I S="" Q ""
NEW A S A=$$AGE^AUPNPAT(APCLPD,D)
NEW R S R=$O(^APCLBMI("H",S,A)) I R S R=$O(^APCLBMI("H",S,R,""))
I R="" Q ""
I BMI>$P(^APCLBMI(R,0),U,7)!(BMI<$P(^APCLBMI(R,0),U,6)) Q ""
I BMI'<$P(^APCLBMI(R,0),U,4) Q 1
Q ""
CUML ;EP
Q:'$D(APCLCUML)
;print aggregate audit
;
;
PRINT ;
S APCLPG=0
S APCLQUIT=0
D HEADER
D PRINT1 ;print each indicator
D EXIT
Q
;
PRINT1 ;
W !!,$P(APCLCUML(10),U),!,?7,"Female",?53,$$C($P(APCLCUML(10),U,3)),?65,$$P($P(APCLCUML(10),U,2),$P(APCLCUML(10),U,3))
W !,?7,"Male",?53,$$C($P(APCLCUML(10),U,4)),?65,$$P($P(APCLCUML(10),U,2),$P(APCLCUML(10),U,4))
I $Y>(APCLIOSL-4) D HEADER Q:APCLQUIT
W !!,"Age" S V=$G(APCLCUML(20))
W !?7,"<15 yrs",?53,$$C($P(V,U,3)),?65,$$P($P(V,U,2),$P(V,U,3))
W !?7,"15-44 yrs",?53,$$C($P(V,U,4)),?65,$$P($P(V,U,2),$P(V,U,4))
W !?7,"45-64 yrs",?53,$$C($P(V,U,5)),?65,$$P($P(V,U,2),$P(V,U,5))
W !?7,"65 yrs and older",?53,$$C($P(V,U,6)),?65,$$P($P(V,U,2),$P(V,U,6))
TYPE ;
I $Y>(APCLIOSL-8) D HEADER Q:APCLQUIT
S V=$G(APCLCUML(25))
W !!,$P(V,U),?53,$$C($P(V,U,3)),?65,$$P($P(V,U,2),$P(V,U,3))
S V=$G(APCLCUML(30))
W !!,$P(V,U),?53,$$C($P(V,U,3)),?65,$$P($P(V,U,2),$P(V,U,3))
S V=$G(APCLCUML(31))
W !!,$P(V,U),?53,$$C($P(V,U,3)),?65,$$P($P(V,U,2),$P(V,U,3))
S V=$G(APCLCUML(32))
W !!,$P(V,U),?53,$$C($P(V,U,3)),?65,$$P($P(V,U,2),$P(V,U,3))
;weight control
WTCNTL ;
I $Y>(APCLIOSL-5) D HEADER Q:APCLQUIT
S V=$G(APCLCUML(40)) W !!,$P(V,U)
W !?7,"Overweight or Obese (BMI>85%ile)",?53,$$C($P(V,U,3)),?65,$$P($P(V,U,2),$P(V,U,3))
W !?7,"Obese (BMI>95%ile)",?53,$$C($P(V,U,4)),?65,$$P($P(V,U,2),$P(V,U,4))
W !?7,"BMI could not be calculated",?53,$$C($P(V,U,5)),?65,$$P($P(V,U,2),$P(V,U,5))
BPC ;
I $Y>(APCLIOSL-9) D HEADER Q:APCLQUIT
S V=$G(APCLCUML(60)) W !!,$P(V,U)
W !?7,"<120/<70",?53,$$C($P(V,U,3)),?65,$$P($P(V,U,2),$P(V,U,3))
W !?7,"120/70 - 130/80",?53,$$C($P(V,U,4)),?65,$$P($P(V,U,2),$P(V,U,4))
W !?7,"---------------------------"
W !?7,"131/81 - <140/<90",?53,$$C($P(V,U,5)),?65,$$P($P(V,U,2),$P(V,U,5))
W !?7,"140/90 - <160/<95",?53,$$C($P(V,U,6)),?65,$$P($P(V,U,2),$P(V,U,6))
W !?7,"160/95 or higher",?53,$$C($P(V,U,7)),?65,$$P($P(V,U,2),$P(V,U,7))
W !?7,"BP category Undetermined",?53,$$C($P(V,U,8)),?65,$$P($P(V,U,2),$P(V,U,8))
TOB ;
I $Y>(APCLIOSL-7) D HEADER Q:APCLQUIT
S V=$G(APCLCUML(80)) W !!,$P(V,U)
W !?7,"Current Tobacco User",?53,$$C($P(V,U,3)),?65,$$P($P(V,U,2),$P(V,U,3))
W !?9,"Counseled - Yes",?53,$$C($P(V,U,4)),?65,$$P($P(V,U,3),$P(V,U,4))
W !?9,"Counseled - No",?53,$$C($P(V,U,5)),?65,$$P($P(V,U,3),$P(V,U,5))
W !?7,"Not a current tobacco user",?53,$$C($P(V,U,6)),?65,$$P($P(V,U,2),$P(V,U,6))
W !?7,"Tobacco use not documented",?53,$$C($P(V,U,7)),?65,$$P($P(V,U,2),$P(V,U,7))
TX ;
I $Y>(APCLIOSL-7) D HEADER Q:APCLQUIT
S V=$G(APCLCUML(90)) W !!,$P(V,U)
W !?7,"Unknown/Refused/None",?53,$$C($P(V,U,3)),?65,$$P($P(V,U,2),$P(V,U,3))
W !?10,"Metformin",?53,$$C($P(V,U,4)),?65,$$P($P(V,U,2),$P(V,U,4))
W !?10,"Acarbose",?53,$$C($P(V,U,5)),?65,$$P($P(V,U,2),$P(V,U,5))
W !?10,"Glitazone",?53,$$C($P(V,U,6)),?65,$$P($P(V,U,2),$P(V,U,6))
W !?10,"Sulfonylurea",?53,$$C($P(V,U,7)),?65,$$P($P(V,U,2),$P(V,U,7))
D ^APCLP61A
Q
EXIT ;
I $E(IOST)="C",IO=IO(0) W ! S DIR(0)="EO",DIR("A")="End of report. Press ENTER" D ^DIR K DIR S:$D(DUOUT) DIRUT=1
Q
CALC(N,O) ;ENTRY POINT
;N is new
;O is old
NEW Z
I O=0!(N=0) Q "**"
NEW X,X2,X3
S X=N,X2=1,X3=0 D COMMA^%DTC S N=X
S X=O,X2=1,X3=0 D COMMA^%DTC S O=X
S Z=(((N-O)/O)*100),Z=$FN(Z,"+,",1)
Q Z
P(D,N) ;return %
I 'D Q ""
I 'N Q " 0%"
NEW X S X=N/D,X=X*100,X=$J(X,3,0)
Q X_"%"
C(X,X2,X3) ;
I '$G(X2) S X2=0
I '$G(X3) S X3=6
D COMMA^%DTC
Q X
G:'APCLPG HEADER1
K DIR I $E(IOST)="C",IO=IO(0) W ! S DIR(0)="EO" D ^DIR K DIR I Y=0!(Y="^")!($D(DTOUT)) S APCLQUIT=1 Q
I $G(APCLGUI) W !,"ZZZZZZZ"
W:$D(IOF) @IOF S APCLPG=APCLPG+1
W !?3,$P(^VA(200,DUZ,0),U,2),?35,$$FMTE^XLFDT(DT),?70,"Page ",APCLPG,!
W !,$$CTR("*** HEALTH STATUS OF PREDIABETIC/METABOLIC SYNDROME PATIENTS ***",80),!
W $$CTR($P(^DIC(4,DUZ(2),0),U)),!
S X="Reporting Period: "_$$FMTE^XLFDT(APCLBDAT)_" to "_$$FMTE^XLFDT(APCLADAT) W $$CTR(X,80),!
W !,$TR($J("",80)," ","-")
W !!,$P(APCLCUML(10),U,2)," patients were reviewed"
W ?55," n",?63,"Percent"
Q
CTR(X,Y) ;EP - Center X in a field Y wide.
Q $J("",$S($D(Y):Y,1:IOM)-$L(X)\2)_X
;----------
EOP ;EP - End of page.
Q:$E(IOST)'="C"
Q:$D(ZTQUEUED)!'(IOT="TRM")!$D(IO("S"))
NEW DIR
K DIRUT,DFOUT,DLOUT,DTOUT,DUOUT
S DIR(0)="E" D ^DIR
Q
;----------
USR() ;EP - Return name of current user from ^VA(200.
Q $S($G(DUZ):$S($D(^VA(200,DUZ,0)):$P(^(0),U),1:"UNKNOWN"),1:"DUZ UNDEFINED OR 0")
;----------
LOC() ;EP - Return location name from file 4 based on DUZ(2).
Q $S($G(DUZ(2)):$S($D(^DIC(4,DUZ(2),0)):$P(^(0),U),1:"UNKNOWN"),1:"DUZ(2) UNDEFINED OR 0")
;----------
APCLP614 ; IHS/CMI/LAB -IHS -CUMULATIVE REPORT ;
+1 ;;2.0;IHS PCC SUITE;;MAY 14, 2009
+2 ;
+3 ;
DURDM(P,R,EDATE) ;EP
+1 NEW DATE
+2 SET DATE=""
+3 IF $GET(R)
SET DATE=$$CMSFDX^APCLP613(P,R,"ID")
+4 IF DATE]""
QUIT ($$FMDIFF^XLFDT(EDATE,DATE,1)\365)
+5 SET DATE=$$PLDMDOO^APCLP613(P,"I")
+6 IF DATE]""
QUIT ($$FMDIFF^XLFDT(EDATE,DATE,1)\365)
+7 QUIT ""
D(D) ;
+1 IF $GET(D)=""
QUIT ""
+2 QUIT $SELECT($EXTRACT(D,4,5)="00":"07",1:$EXTRACT(D,4,5))_"/"_$SELECT($EXTRACT(D,6,7)="00":"15",1:$EXTRACT(D,6,7))_"/"_$EXTRACT(D,2,3)
OB(APCLPD,BMI,D) ;EP obese
+1 IF $GET(BMI)=""
QUIT ""
+2 NEW S
SET S=$PIECE(^DPT(APCLPD,0),U,2)
+3 IF S=""
QUIT ""
+4 NEW A
SET A=$$AGE^AUPNPAT(APCLPD,D)
+5 NEW R
SET R=$ORDER(^APCLBMI("H",S,A))
IF R
SET R=$ORDER(^APCLBMI("H",S,R,""))
+6 IF R=""
QUIT ""
+7 IF BMI>$PIECE(^APCLBMI(R,0),U,7)!(BMI<$PIECE(^APCLBMI(R,0),U,6))
QUIT ""
+8 IF BMI'<$PIECE(^APCLBMI(R,0),U,5)
QUIT 1
+9 QUIT ""
OW(APCLPD,BMI,D) ;EP overweight
+1 IF $GET(BMI)=""
QUIT ""
+2 NEW S
SET S=$PIECE(^DPT(APCLPD,0),U,2)
+3 IF S=""
QUIT ""
+4 NEW A
SET A=$$AGE^AUPNPAT(APCLPD,D)
+5 NEW R
SET R=$ORDER(^APCLBMI("H",S,A))
IF R
SET R=$ORDER(^APCLBMI("H",S,R,""))
+6 IF R=""
QUIT ""
+7 IF BMI>$PIECE(^APCLBMI(R,0),U,7)!(BMI<$PIECE(^APCLBMI(R,0),U,6))
QUIT ""
+8 IF BMI'<$PIECE(^APCLBMI(R,0),U,4)
QUIT 1
+9 QUIT ""
CUML ;EP
+1 IF '$DATA(APCLCUML)
QUIT
+2 ;print aggregate audit
+3 ;
+4 ;
PRINT ;
+1 SET APCLPG=0
+2 SET APCLQUIT=0
+3 DO HEADER
+4 ;print each indicator
DO PRINT1
+5 DO EXIT
+6 QUIT
+7 ;
PRINT1 ;
+1 WRITE !!,$PIECE(APCLCUML(10),U),!,?7,"Female",?53,$$C($PIECE(APCLCUML(10),U,3)),?65,$$P($PIECE(APCLCUML(10),U,2),$PIECE(APCLCUML(10),U,3))
+2 WRITE !,?7,"Male",?53,$$C($PIECE(APCLCUML(10),U,4)),?65,$$P($PIECE(APCLCUML(10),U,2),$PIECE(APCLCUML(10),U,4))
+3 IF $Y>(APCLIOSL-4)
DO HEADER
IF APCLQUIT
QUIT
+4 WRITE !!,"Age"
SET V=$GET(APCLCUML(20))
+5 WRITE !?7,"<15 yrs",?53,$$C($PIECE(V,U,3)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,3))
+6 WRITE !?7,"15-44 yrs",?53,$$C($PIECE(V,U,4)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,4))
+7 WRITE !?7,"45-64 yrs",?53,$$C($PIECE(V,U,5)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,5))
+8 WRITE !?7,"65 yrs and older",?53,$$C($PIECE(V,U,6)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,6))
TYPE ;
+1 IF $Y>(APCLIOSL-8)
DO HEADER
IF APCLQUIT
QUIT
+2 SET V=$GET(APCLCUML(25))
+3 WRITE !!,$PIECE(V,U),?53,$$C($PIECE(V,U,3)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,3))
+4 SET V=$GET(APCLCUML(30))
+5 WRITE !!,$PIECE(V,U),?53,$$C($PIECE(V,U,3)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,3))
+6 SET V=$GET(APCLCUML(31))
+7 WRITE !!,$PIECE(V,U),?53,$$C($PIECE(V,U,3)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,3))
+8 SET V=$GET(APCLCUML(32))
+9 WRITE !!,$PIECE(V,U),?53,$$C($PIECE(V,U,3)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,3))
+10 ;weight control
WTCNTL ;
+1 IF $Y>(APCLIOSL-5)
DO HEADER
IF APCLQUIT
QUIT
+2 SET V=$GET(APCLCUML(40))
WRITE !!,$PIECE(V,U)
+3 WRITE !?7,"Overweight or Obese (BMI>85%ile)",?53,$$C($PIECE(V,U,3)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,3))
+4 WRITE !?7,"Obese (BMI>95%ile)",?53,$$C($PIECE(V,U,4)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,4))
+5 WRITE !?7,"BMI could not be calculated",?53,$$C($PIECE(V,U,5)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,5))
BPC ;
+1 IF $Y>(APCLIOSL-9)
DO HEADER
IF APCLQUIT
QUIT
+2 SET V=$GET(APCLCUML(60))
WRITE !!,$PIECE(V,U)
+3 WRITE !?7,"<120/<70",?53,$$C($PIECE(V,U,3)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,3))
+4 WRITE !?7,"120/70 - 130/80",?53,$$C($PIECE(V,U,4)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,4))
+5 WRITE !?7,"---------------------------"
+6 WRITE !?7,"131/81 - <140/<90",?53,$$C($PIECE(V,U,5)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,5))
+7 WRITE !?7,"140/90 - <160/<95",?53,$$C($PIECE(V,U,6)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,6))
+8 WRITE !?7,"160/95 or higher",?53,$$C($PIECE(V,U,7)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,7))
+9 WRITE !?7,"BP category Undetermined",?53,$$C($PIECE(V,U,8)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,8))
TOB ;
+1 IF $Y>(APCLIOSL-7)
DO HEADER
IF APCLQUIT
QUIT
+2 SET V=$GET(APCLCUML(80))
WRITE !!,$PIECE(V,U)
+3 WRITE !?7,"Current Tobacco User",?53,$$C($PIECE(V,U,3)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,3))
+4 WRITE !?9,"Counseled - Yes",?53,$$C($PIECE(V,U,4)),?65,$$P($PIECE(V,U,3),$PIECE(V,U,4))
+5 WRITE !?9,"Counseled - No",?53,$$C($PIECE(V,U,5)),?65,$$P($PIECE(V,U,3),$PIECE(V,U,5))
+6 WRITE !?7,"Not a current tobacco user",?53,$$C($PIECE(V,U,6)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,6))
+7 WRITE !?7,"Tobacco use not documented",?53,$$C($PIECE(V,U,7)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,7))
TX ;
+1 IF $Y>(APCLIOSL-7)
DO HEADER
IF APCLQUIT
QUIT
+2 SET V=$GET(APCLCUML(90))
WRITE !!,$PIECE(V,U)
+3 WRITE !?7,"Unknown/Refused/None",?53,$$C($PIECE(V,U,3)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,3))
+4 WRITE !?10,"Metformin",?53,$$C($PIECE(V,U,4)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,4))
+5 WRITE !?10,"Acarbose",?53,$$C($PIECE(V,U,5)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,5))
+6 WRITE !?10,"Glitazone",?53,$$C($PIECE(V,U,6)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,6))
+7 WRITE !?10,"Sulfonylurea",?53,$$C($PIECE(V,U,7)),?65,$$P($PIECE(V,U,2),$PIECE(V,U,7))
+8 DO ^APCLP61A
+9 QUIT
EXIT ;
+1 IF $EXTRACT(IOST)="C"
IF IO=IO(0)
WRITE !
SET DIR(0)="EO"
SET DIR("A")="End of report. Press ENTER"
DO ^DIR
KILL DIR
IF $DATA(DUOUT)
SET DIRUT=1
+2 QUIT
CALC(N,O) ;ENTRY POINT
+1 ;N is new
+2 ;O is old
+3 NEW Z
+4 IF O=0!(N=0)
QUIT "**"
+5 NEW X,X2,X3
+6 SET X=N
SET X2=1
SET X3=0
DO COMMA^%DTC
SET N=X
+7 SET X=O
SET X2=1
SET X3=0
DO COMMA^%DTC
SET O=X
+8 SET Z=(((N-O)/O)*100)
SET Z=$FNUMBER(Z,"+,",1)
+9 QUIT Z
P(D,N) ;return %
+1 IF 'D
QUIT ""
+2 IF 'N
QUIT " 0%"
+3 NEW X
SET X=N/D
SET X=X*100
SET X=$JUSTIFY(X,3,0)
+4 QUIT X_"%"
C(X,X2,X3) ;
+1 IF '$GET(X2)
SET X2=0
+2 IF '$GET(X3)
SET X3=6
+3 DO COMMA^%DTC
+4 QUIT X
+1 IF 'APCLPG
GOTO HEADER1
+2 KILL DIR
IF $EXTRACT(IOST)="C"
IF IO=IO(0)
WRITE !
SET DIR(0)="EO"
DO ^DIR
KILL DIR
IF Y=0!(Y="^")!($DATA(DTOUT))
SET APCLQUIT=1
QUIT
+1 IF $GET(APCLGUI)
WRITE !,"ZZZZZZZ"
+2 IF $DATA(IOF)
WRITE @IOF
SET APCLPG=APCLPG+1
+3 WRITE !?3,$PIECE(^VA(200,DUZ,0),U,2),?35,$$FMTE^XLFDT(DT),?70,"Page ",APCLPG,!
+4 WRITE !,$$CTR("*** HEALTH STATUS OF PREDIABETIC/METABOLIC SYNDROME PATIENTS ***",80),!
+5 WRITE $$CTR($PIECE(^DIC(4,DUZ(2),0),U)),!
+6 SET X="Reporting Period: "_$$FMTE^XLFDT(APCLBDAT)_" to "_$$FMTE^XLFDT(APCLADAT)
WRITE $$CTR(X,80),!
+7 WRITE !,$TRANSLATE($JUSTIFY("",80)," ","-")
+8 WRITE !!,$PIECE(APCLCUML(10),U,2)," patients were reviewed"
+9 WRITE ?55," n",?63,"Percent"
+10 QUIT
CTR(X,Y) ;EP - Center X in a field Y wide.
+1 QUIT $JUSTIFY("",$SELECT($DATA(Y):Y,1:IOM)-$LENGTH(X)\2)_X
+2 ;----------
EOP ;EP - End of page.
+1 IF $EXTRACT(IOST)'="C"
QUIT
+2 IF $DATA(ZTQUEUED)!'(IOT="TRM")!$DATA(IO("S"))
QUIT
+3 NEW DIR
+4 KILL DIRUT,DFOUT,DLOUT,DTOUT,DUOUT
+5 SET DIR(0)="E"
DO ^DIR
+6 QUIT
+7 ;----------
USR() ;EP - Return name of current user from ^VA(200.
+1 QUIT $SELECT($GET(DUZ):$SELECT($DATA(^VA(200,DUZ,0)):$PIECE(^(0),U),1:"UNKNOWN"),1:"DUZ UNDEFINED OR 0")
+2 ;----------
LOC() ;EP - Return location name from file 4 based on DUZ(2).
+1 QUIT $SELECT($GET(DUZ(2)):$SELECT($DATA(^DIC(4,DUZ(2),0)):$PIECE(^(0),U),1:"UNKNOWN"),1:"DUZ(2) UNDEFINED OR 0")
+2 ;----------