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

BGP9DS.m

Go to the documentation of this file.
  1. BGP9DS ; IHS/CMI/LAB - IHS gpra print ;
  1. ;;9.0;IHS CLINICAL REPORTING;;JUL 1, 2009
  1. ;
  1. START ;
  1. Q:$G(BGPAREAA)
  1. Q:'$D(BGPLIST)
  1. I $G(BGPNPL) Q
  1. I $G(BGPCPPL) Q ;not on comprehensive pt
  1. S BGPQUIT="",BGPGPG=0
  1. ;D HEADER
  1. S BGPL=0 F S BGPL=$O(BGPLIST(BGPL)) Q:BGPL'=+BGPL!(BGPQUIT) D
  1. .S BGPFIRSP=1 S BGPCOUNT=0,BGPPCNT=0
  1. .D HEADER Q:BGPQUIT
  1. .S BGPCNT=$G(BGPLIST(BGPL))
  1. .I 'BGPCNT S BGPCNT=0 G GO
  1. .I BGPCNT<100 S BGPCNT=1 G GO
  1. .I BGPLIST'="R" S BGPCNT=1 G GO
  1. .;I BGPCNT<100 S BGPCNT=BGPCNT\10 G GO
  1. .;I BGPCNT<100 G GO
  1. .S BGPCNT=10
  1. GO .;
  1. .D WTITLE ;W !,$P(^BGPINDN(BGPL,0),U,3),!
  1. .W !,"Denominator(s):"
  1. .S BGPX=0 F S BGPX=$O(^BGPINDN(BGPL,61,"B",BGPX)) Q:BGPX'=+BGPX!(BGPQUIT) D
  1. ..S BGPY=0 F S BGPY=$O(^BGPINDN(BGPL,61,"B",BGPX,BGPY)) Q:BGPY'=+BGPY!(BGPQUIT) D
  1. ...;I $P(^BGPINDN(BGPL,61,BGPY,0),U,2)'[BGPRTYPE Q ;not a denom def for this report
  1. ...;I BGPRTYPE=4,$P(^BGPINDN(BGPL,61,BGPY,0),U,3)'[BGPINDT Q ;don't display
  1. ...I '$D(^BGPINDN(BGPL,61,BGPY,11,"B",BGPRTYPE)) Q ;not this report type
  1. ...I BGPRTYPE=4,'$D(^BGPINDN(BGPL,61,BGPY,12,"B",BGPINDT))
  1. ...S BGPZ=0 F S BGPZ=$O(^BGPINDN(BGPL,61,BGPY,1,BGPZ)) Q:BGPZ'=+BGPZ!(BGPQUIT) D
  1. ....I $Y>(BGPIOSL-3) D HEADER Q:BGPQUIT
  1. ....W !,^BGPINDN(BGPL,61,BGPY,1,BGPZ,0)
  1. ....Q
  1. ...;W !
  1. ...Q
  1. ..Q
  1. .I $Y>(BGPIOSL-3) D HEADER Q:BGPQUIT
  1. .W !!,"Numerator(s):"
  1. .S BGPX=0 F S BGPX=$O(^BGPINDN(BGPL,62,"B",BGPX)) Q:BGPX'=+BGPX!(BGPQUIT) D
  1. ..S BGPY=0 F S BGPY=$O(^BGPINDN(BGPL,62,"B",BGPX,BGPY)) Q:BGPY'=+BGPY!(BGPQUIT) D
  1. ...;I $P(^BGPINDN(BGPL,62,BGPY,0),U,2)'[BGPRTYPE Q ;not a denom def for this report
  1. ...;I BGPRTYPE=4,BGPINDT'="S",$P(^BGPINDN(BGPL,62,BGPY,0),U,3)'[BGPINDT Q ;don't display
  1. ...I '$D(^BGPINDN(BGPL,62,BGPY,11,"B",BGPRTYPE)) Q ;not this report type
  1. ...I BGPRTYPE=4,'$D(^BGPINDN(BGPL,62,BGPY,12,"B",BGPINDT)) Q ;not this measure type on selected
  1. ...S BGPZ=0 F S BGPZ=$O(^BGPINDN(BGPL,62,BGPY,1,BGPZ)) Q:BGPZ'=+BGPZ!(BGPQUIT) D
  1. ....I $Y>(BGPIOSL-3) D HEADER Q:BGPQUIT
  1. ....W !,^BGPINDN(BGPL,62,BGPY,1,BGPZ,0)
  1. ....Q
  1. ...;W !
  1. ...Q
  1. ..Q
  1. .S BGPNODE=11
  1. .I BGPRTYPE=1,$O(^BGPINDN(BGPL,54,0)) S BGPNODE=54
  1. .I BGPRTYPE=7,$O(^BGPINDN(BGPL,56,0)) S BGPNODE=56
  1. .W !!,"Logic" S BGPX=0 F S BGPX=$O(^BGPINDN(BGPL,BGPNODE,BGPX)) Q:BGPX'=+BGPX D
  1. ..I $Y>(BGPIOSL-3) D HEADER Q:BGPQUIT
  1. ..W !,^BGPINDN(BGPL,BGPNODE,BGPX,0)
  1. .W !!,"Performance Measure Description" S BGPX=0 F S BGPX=$O(^BGPINDN(BGPL,51,BGPX)) Q:BGPX'=+BGPX D
  1. ..I $Y>(BGPIOSL-3) D HEADER Q:BGPQUIT
  1. ..W !,^BGPINDN(BGPL,51,BGPX,0)
  1. .I $O(^BGPINDN(BGPL,52,0)) W !,"Past Performance and/or Target" S BGPX=0 F S BGPX=$O(^BGPINDN(BGPL,52,BGPX)) Q:BGPX'=+BGPX D
  1. ..I $Y>(BGPIOSL-3) D HEADER Q:BGPQUIT
  1. ..W !,^BGPINDN(BGPL,52,BGPX,0)
  1. .I $O(^BGPINDN(BGPL,55,0)) W !,"Source" S BGPX=0 F S BGPX=$O(^BGPINDN(BGPL,55,BGPX)) Q:BGPX'=+BGPX D
  1. ..I $Y>(BGPIOSL-3) D HEADER Q:BGPQUIT
  1. ..W !,^BGPINDN(BGPL,55,BGPX,0)
  1. .I $Y>(BGPIOSL-2) D HEADER Q:BGPQUIT
  1. .W !
  1. .D H1
  1. .Q:BGPQUIT
  1. .S BGPCOM="" F S BGPCOM=$O(^XTMP("BGP9D",BGPJ,BGPH,"LIST",BGPL,BGPCOM)) Q:BGPCOM=""!(BGPQUIT) D
  1. ..S BGPSEX="" F S BGPSEX=$O(^XTMP("BGP9D",BGPJ,BGPH,"LIST",BGPL,BGPCOM,BGPSEX)) Q:BGPSEX=""!(BGPQUIT) D
  1. ...S BGPAGE="" F S BGPAGE=$O(^XTMP("BGP9D",BGPJ,BGPH,"LIST",BGPL,BGPCOM,BGPSEX,BGPAGE)) Q:BGPAGE=""!(BGPQUIT) D
  1. ....S DFN=0 F S DFN=$O(^XTMP("BGP9D",BGPJ,BGPH,"LIST",BGPL,BGPCOM,BGPSEX,BGPAGE,DFN)) Q:DFN'=+DFN!(BGPQUIT) S BGPCOUNT=BGPCOUNT+1 D PRINTL
  1. ....Q
  1. ...Q
  1. ..Q
  1. .I $Y>(BGPIOSL-3) D HEADER Q:BGPQUIT
  1. .W !!,"Total # of Patients on list: ",+$G(BGPPCNT)
  1. Q
  1. WTITLE ;EP - write title line
  1. NEW T,X,Y,S
  1. S T=$P(^BGPINDN(BGPL,0),U,3)
  1. I $L(T)<81 W !,T,! Q
  1. F X=$E(T,1,80)
  1. S S=""
  1. F Y=80:-1:1 Q:S S I=$E(X,Y) I I=" " S S=Y
  1. W !,$E(T,1,S)
  1. W !,$E(T,(S+1),$L(T)),!
  1. Q
  1. ;
  1. PRINTL ;print one line
  1. Q:(BGPCOUNT#BGPCNT)
  1. I $Y>(BGPIOSL-3) D HEADER Q:BGPQUIT D
  1. .;S X=0 F S X=$O(^BGPINDN(BGPL,72,X)) Q:X'=+X W !,^BGPINDN(BGPL,72,X,0)
  1. .D H1
  1. Q:BGPQUIT
  1. S BGPPCNT=BGPPCNT+1
  1. W !,$E($P(^DPT(DFN,0),U),1,22),?24,$$HRN^AUPNPAT(DFN,DUZ(2)),?31,$E(BGPCOM,1,14),?46,BGPSEX,?49,BGPAGE
  1. W ?53,$P(^XTMP("BGP9D",BGPJ,BGPH,"LIST",BGPL,BGPCOM,BGPSEX,BGPAGE,DFN),"|||",1)
  1. W:BGPL=43 " NUMERATOR: "
  1. W ?65,$P(^XTMP("BGP9D",BGPJ,BGPH,"LIST",BGPL,BGPCOM,BGPSEX,BGPAGE,DFN),"|||",2)
  1. Q
  1. ;
  1. G:'BGPGPG HEADER1
  1. K DIR I $E(IOST)="C",IO=IO(0),'$D(ZTQUEUED) W ! S DIR(0)="EO" D ^DIR K DIR I Y=0!(Y="^")!($D(DTOUT)) S BGPQUIT=1 Q
  1. HEADER1 ;
  1. W:$D(IOF) @IOF S BGPGPG=BGPGPG+1
  1. I $G(BGPGUI) W "ZZZZZZZ",! ;maw
  1. W !,"***** CONFIDENTIAL PATIENT INFORMATION, COVERED BY THE PRIVACY ACT *****"
  1. W !?3,$P(^VA(200,DUZ,0),U,2),?35,$$FMTE^XLFDT(DT),?70,"Page ",BGPGPG,!
  1. W !,$$CTR("*** IHS 2009 Clinical Performance Measure Patient List ***",80),!
  1. W $$CTR($P(^DIC(4,DUZ(2),0),U),80),!
  1. S X="Report Period: "_$$FMTE^XLFDT(BGPBD)_" to "_$$FMTE^XLFDT(BGPED) W $$CTR(X,80),!
  1. W $$CTR($S(BGPLIST="A":"Entire Patient List",BGPLIST="R":"Random Patient List",1:"Patient List by Provider: "_BGPLPROV),80),!
  1. W !,$TR($J("",80)," ","-")
  1. Q
  1. H1 ;
  1. S BGPTSUB=$S(BGPFIRSP:71,1:72)
  1. S X=0,C=0 F S X=$O(^BGPINDN(BGPL,BGPTSUB,X)) Q:X'=+X S C=C+1
  1. I $Y>(BGPIOSL-(C+6)) D HEADER Q:BGPQUIT
  1. W !,"UP=User Pop; AC=Active Clinical; AD=Active Diabetic; AAD=Active Adult Diabetic",!,"PREG=Pregnant Female; IMM=Active IMM Pkg Pt; IHD=Active Ischemic Heart Disease",!
  1. S X=0 F S X=$O(^BGPINDN(BGPL,BGPTSUB,X)) Q:X'=+X W !,^BGPINDN(BGPL,BGPTSUB,X,0)
  1. W !,"PATIENT NAME",?24,"HRN",?31,"COMMUNITY",?45,"SEX",?49,"AGE",?53,"DENOMINATOR",?65,"NUMERATOR"
  1. W !,$TR($J("",80)," ","-")
  1. S BGPFIRSP=0
  1. Q
  1. CTR(X,Y) ;EP - Center X in a field Y wide.
  1. Q $J("",$S($D(Y):Y,1:IOM)-$L(X)\2)_X
  1. ;----------
  1. USR() ;EP - Return name of current user from ^VA(200.
  1. Q $S($G(DUZ):$S($D(^VA(200,DUZ,0)):$P(^(0),U),1:"UNKNOWN"),1:"DUZ UNDEFINED OR 0")
  1. ;----------
  1. LOC() ;EP - Return location name from file 4 based on DUZ(2).
  1. Q $S($G(DUZ(2)):$S($D(^DIC(4,DUZ(2),0)):$P(^(0),U),1:"UNKNOWN"),1:"DUZ(2) UNDEFINED OR 0")
  1. ;----------