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

BGP8DS.m

Go to the documentation of this file.
  1. BGP8DS ; IHS/CMI/LAB - IHS gpra print ;
  1. ;;18.1;IHS CLINICAL REPORTING;;MAY 25, 2018;Build 66
  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 BGPORDSE=0 F S BGPORDSE=$O(^BGPINDR("AOI",BGPORDSE)) Q:BGPORDSE'=+BGPORDSE!(BGPQUIT) S BGPL=$O(^BGPINDR("AOI",BGPORDSE,0)) I $D(BGPLIST(BGPL)) 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^BGP8DP(BGPL) ;W !,$P(^BGPINDR(BGPL,0),U,3),!
  1. .I $G(BGPDNT) G CALC
  1. .D W^BGP8DP("Denominator(s):",0,1,BGPPTYPE)
  1. .S BGPNODE=$S(BGPRTYPE=1:81,BGPRTYPE=4:61,BGPRTYPE=7:83,BGPRTYPE=9:85,BGPRTYPE=2:94,1:61)
  1. .I BGPRTYPE=4 S BGPNODE=$S(BGPINDG="D":87,BGPINDG="C":89,BGPINDG="W":92,BGPINDG="I":94,BGPINDG="P":96,1:BGPNODE)
  1. .S BGPX=0 F S BGPX=$O(^BGPINDR(BGPL,BGPNODE,"B",BGPX)) Q:BGPX'=+BGPX!(BGPQUIT) D
  1. ..S BGPY=0 F S BGPY=$O(^BGPINDR(BGPL,BGPNODE,"B",BGPX,BGPY)) Q:BGPY'=+BGPY!(BGPQUIT) D
  1. ...;I '$D(^BGPINDR(BGPL,BGPNODE,BGPY,11,"B",BGPRTYPE)) Q ;not this report type
  1. ...;I BGPRTYPE=4,'$D(^BGPINDR(BGPL,BGPNODE,BGPY,12,"B",BGPINDR)) Q ;not this measure type on selected
  1. ...D WP
  1. .I BGPPTYPE="P",$Y>(BGPIOSL-3) D HEADER^BGP8DPH Q:BGPQUIT
  1. .D W^BGP8DP("Numerator(s):",0,2,BGPPTYPE)
  1. .S BGPNODE=$S(BGPRTYPE=1:82,BGPRTYPE=4:62,BGPRTYPE=7:84,BGPRTYPE=9:86,BGPRTYPE=2:95,1:62)
  1. .I BGPRTYPE=4 S BGPNODE=$S(BGPINDG="D":88,BGPINDG="C":91,BGPINDG="W":93,BGPINDG="I":95,BGPINDG="P":97,1:BGPNODE)
  1. .S BGPX=0 F S BGPX=$O(^BGPINDR(BGPL,BGPNODE,"B",BGPX)) Q:BGPX'=+BGPX!(BGPQUIT) D
  1. ..S BGPY=0 F S BGPY=$O(^BGPINDR(BGPL,BGPNODE,"B",BGPX,BGPY)) Q:BGPY'=+BGPY!(BGPQUIT) D
  1. ...;I '$D(^BGPINDR(BGPL,62,BGPY,11,"B",BGPRTYPE)) Q ;not this report type
  1. ...;I BGPRTYPE=4,'$D(^BGPINDR(BGPL,BGPNODE,BGPY,12,"B",BGPINDR)) Q ;not this measure type on selected
  1. ...D WP
  1. .S BGPNODE=11
  1. .I BGPRTYPE=1,$O(^BGPINDR(BGPL,54,0)) S BGPNODE=54
  1. .I BGPRTYPE=7,$O(^BGPINDR(BGPL,56,0)) S BGPNODE=56
  1. .I BGPRTYPE=9,$O(^BGPINDR(BGPL,58,0)) S BGPNODE=58
  1. .I BGPRTYPE=2,$O(^BGPINDR(BGPL,21,0)) S BGPNODE=21
  1. .D W^BGP8DP("Logic:",0,2,BGPPTYPE) S BGPX=0 F S BGPX=$O(^BGPINDR(BGPL,BGPNODE,BGPX)) Q:BGPX'=+BGPX D
  1. ..I BGPPTYPE="P",$Y>(BGPIOSL-3) D HEADER^BGP8DPH Q:BGPQUIT
  1. ..D W^BGP8DP(^BGPINDR(BGPL,BGPNODE,BGPX,0),0,1,BGPPTYPE)
  1. .I $O(^BGPINDR(BGPL,51,0)) D W^BGP8DP("Performance Measure Description:",0,2,BGPPTYPE) S BGPX=0 F S BGPX=$O(^BGPINDR(BGPL,$S($G(BGPNGR09):57,1:51),BGPX)) Q:BGPX'=+BGPX D
  1. ..I BGPPTYPE="P",$Y>(BGPIOSL-3) D HEADER^BGP8DPH Q:BGPQUIT
  1. ..D W^BGP8DP(^BGPINDR(BGPL,$S($G(BGPNGR09):57,1:51),BGPX,0),0,1,BGPPTYPE)
  1. .I $O(^BGPINDR(BGPL,52,0)) D W^BGP8DP("Past Performance and/or Target:",0,2,BGPPTYPE) S BGPX=0 F S BGPX=$O(^BGPINDR(BGPL,52,BGPX)) Q:BGPX'=+BGPX D
  1. ..I BGPPTYPE="P",$Y>(BGPIOSL-3) D HEADER^BGP8DPH Q:BGPQUIT
  1. ..D W^BGP8DP(^BGPINDR(BGPL,52,BGPX,0),0,1,BGPPTYPE)
  1. .I $O(^BGPINDR(BGPL,55,0)) D W^BGP8DP("Source:",0,2,BGPPTYPE) S BGPX=0 F S BGPX=$O(^BGPINDR(BGPL,55,BGPX)) Q:BGPX'=+BGPX D
  1. ..I BGPPTYPE="P",$Y>(BGPIOSL-3) D HEADER^BGP8DPH Q:BGPQUIT
  1. ..D W^BGP8DP(^BGPINDR(BGPL,55,BGPX,0),0,1,BGPPTYPE)
  1. .I '$O(^BGPINDR(BGPL,55,0)) D W^BGP8DP("",0,1,BGPPTYPE)
  1. CALC .D H1
  1. .Q:BGPQUIT
  1. .S BGPCOM="" F S BGPCOM=$O(^XTMP("BGP8D",BGPJ,BGPH,"LIST",BGPL,BGPCOM)) Q:BGPCOM=""!(BGPQUIT) D
  1. ..S BGPSEX="" F S BGPSEX=$O(^XTMP("BGP8D",BGPJ,BGPH,"LIST",BGPL,BGPCOM,BGPSEX)) Q:BGPSEX=""!(BGPQUIT) D
  1. ...S BGPAGE="" F S BGPAGE=$O(^XTMP("BGP8D",BGPJ,BGPH,"LIST",BGPL,BGPCOM,BGPSEX,BGPAGE)) Q:BGPAGE=""!(BGPQUIT) D
  1. ....S DFN=0 F S DFN=$O(^XTMP("BGP8D",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 BGPPTYPE="P",$Y>(BGPIOSL-3) D HEADER Q:BGPQUIT
  1. .D W^BGP8DP("Total # of Patients on list: "_+$G(BGPPCNT),0,2,BGPPTYPE)
  1. .D W^BGP8DP("",0,1,BGPPTYPE)
  1. D W^BGP8DP("",0,1,BGPPTYPE)
  1. Q
  1. WP ;
  1. K ^UTILITY($J,"W")
  1. S BGPZ=0,BGPLCNT=0
  1. S DIWL=1,DIWR=80,DIWF="",BGPZ=0 F S BGPZ=$O(^BGPINDR(BGPL,BGPNODE,BGPY,1,BGPZ)) Q:BGPZ'=+BGPZ D
  1. .S BGPLCNT=BGPLCNT+1
  1. .S X=^BGPINDR(BGPL,BGPNODE,BGPY,1,BGPZ,0) S:BGPLCNT=1 X=" - "_X D ^DIWP
  1. .Q
  1. WPS ;
  1. S Z=0 F S Z=$O(^UTILITY($J,"W",DIWL,Z)) Q:Z'=+Z D
  1. .I BGPPTYPE="P",$Y>(BGPIOSL-3) D HEADER^BGP8DPH Q:BGPQUIT
  1. .D W^BGP8DP(^UTILITY($J,"W",DIWL,Z,0),0,1,BGPPTYPE)
  1. K DIWL,DIWR,DIWF,Z
  1. K ^UTILITY($J,"W"),X
  1. Q
  1. ;
  1. PRINTL ;print one line
  1. Q:(BGPCOUNT#BGPCNT)
  1. I BGPPTYPE="P",$Y>(BGPIOSL-3) D HEADER Q:BGPQUIT D
  1. .;S X=0 F S X=$O(^BGPINDR(BGPL,72,X)) Q:X'=+X W !,^BGPINDR(BGPL,72,X,0)
  1. .D H1
  1. Q:BGPQUIT
  1. S BGPPCNT=BGPPCNT+1
  1. I BGPPTYPE="P" W !,$E($P(^DPT(DFN,0),U),1,22),?24,$$HRN^AUPNPAT(DFN,DUZ(2)),?31,$E(BGPCOM,1,14),?46,BGPSEX,?49,BGPAGE,?54,$$DATE^BGP8UTL($$DOB^AUPNPAT(DFN)) D
  1. .W !,$P(^XTMP("BGP8D",BGPJ,BGPH,"LIST",BGPL,BGPCOM,BGPSEX,BGPAGE,DFN),"|||",1)
  1. .;W:BGPL=43 " NUMERATOR: "
  1. .W ?30,$P(^XTMP("BGP8D",BGPJ,BGPH,"LIST",BGPL,BGPCOM,BGPSEX,BGPAGE,DFN),"|||",2)
  1. I BGPPTYPE="D" D
  1. .S X=$E($P(^DPT(DFN,0),U),1,22)_U_$$HRN^AUPNPAT(DFN,DUZ(2))_U_$E(BGPCOM,1,14)_U_BGPSEX_U_BGPAGE_U_$$EDT^BGP8UTL($$DOB^AUPNPAT(DFN))
  1. .S Y=$P(^XTMP("BGP8D",BGPJ,BGPH,"LIST",BGPL,BGPCOM,BGPSEX,BGPAGE,DFN),"|||",1) S $P(X,U,7)=Y
  1. .S Y=$P(^XTMP("BGP8D",BGPJ,BGPH,"LIST",BGPL,BGPCOM,BGPSEX,BGPAGE,DFN),"|||",2) S $P(X,U,8)=Y
  1. .D W^BGP8DP(X,0,1,BGPPTYPE)
  1. Q
  1. ;
  1. I BGPPTYPE'="P" G HEADER1
  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. I BGPPTYPE="P" W:$D(IOF) @IOF S BGPGPG=BGPGPG+1
  1. I $G(BGPGUI),BGPPTYPE="P" D W^BGP8DP("ZZZZZZZ",0,1,BGPPTYPE) ;! ;maw
  1. D W^BGP8DP("***** CONFIDENTIAL PATIENT INFORMATION, COVERED BY THE PRIVACY ACT *****",1,1,BGPPTYPE)
  1. I BGPPTYPE="P" S X=$P(^VA(200,DUZ,0),U,2),$E(X,35)=$$FMTE^XLFDT(DT),$E(X,70)="Page "_BGPGPG D W^BGP8DP(X,1,1,BGPPTYPE)
  1. I BGPPTYPE'="P" S X=$P(^VA(200,DUZ,0),U,2),$P(X,U,2)=$$FMTE^XLFDT(DT) D W^BGP8DP(X,0,1,BGPPTYPE)
  1. I BGPRTYPE'=2 D W^BGP8DP("*** IHS 2018 Clinical Performance Measure Patient List ***",1,1,BGPPTYPE)
  1. I BGPRTYPE=2 D W^BGP8DP("*** IHS 2018 IPC Measure Patient List ***",1,1,BGPPTYPE)
  1. D W^BGP8DP($P(^DIC(4,DUZ(2),0),U),1,1,BGPPTYPE)
  1. S X="Report Period: "_$$FMTE^XLFDT(BGPBD)_" to "_$$FMTE^XLFDT(BGPED) D W^BGP8DP(X,1,1,BGPPTYPE)
  1. D W^BGP8DP($S(BGPLIST="A":"Entire Patient List",BGPLIST="R":"Random Patient List",1:"Patient List by Provider: "_BGPLPROV),1,1,BGPPTYPE)
  1. D W^BGP8DP($TR($J("",80)," ","-"),0,1,BGPPTYPE)
  1. Q
  1. H1 ;
  1. S BGPTSUB=$S(BGPFIRSP:71,1:72)
  1. S X=0,C=0 F S X=$O(^BGPINDR(BGPL,BGPTSUB,X)) Q:X'=+X S C=C+1
  1. I BGPPTYPE="P",$Y>(BGPIOSL-(C+6)) D HEADER Q:BGPQUIT
  1. I BGPRTYPE=2 D W^BGP8DP("*** indicates the patient met the measure",0,1,BGPPTYPE) G H1N
  1. D W^BGP8DP("UP=User Pop; AC=Active Clinical; UPDM=User Pop Diabetic; AD=Active Diabetic;",0,1,BGPPTYPE)
  1. D W^BGP8DP("AAD=Active Adult Diabetic; PREG=Pregnant Female; IMM=Active IMM Pkg Pt; ",0,1,BGPPTYPE)
  1. D W^BGP8DP("CHD=Active Coronary Heart Disease; HR=High Risk Patient",0,1,BGPPTYPE)
  1. H1N D W^BGP8DP("",0,1,BGPPTYPE)
  1. S X=0 F S X=$O(^BGPINDR(BGPL,BGPTSUB,X)) Q:X'=+X D W^BGP8DP(^BGPINDR(BGPL,BGPTSUB,X,0),0,1,BGPPTYPE)
  1. D W^BGP8DP("",0,1,BGPPTYPE)
  1. D W^BGP8DP("PATIENT NAME",0,1,BGPPTYPE,1)
  1. D W^BGP8DP("HRN",0,0,BGPPTYPE,2,24) ;,?24,"HRN",
  1. D W^BGP8DP("COMMUNITY",0,0,BGPPTYPE,3,31) ;?31,"COMMUNITY",
  1. D W^BGP8DP("SEX",0,0,BGPPTYPE,4,45) ;?45,"SEX",
  1. D W^BGP8DP("AGE",0,0,BGPPTYPE,5,49) ;?49,"AGE",
  1. D W^BGP8DP("DOB",0,0,BGPPTYPE,6,54)
  1. D W^BGP8DP("DENOMINATOR",0,$S(BGPPTYPE="P":1,1:0),BGPPTYPE,7,1) ;?53,"DENOMINATOR",
  1. D W^BGP8DP("NUMERATOR",0,0,BGPPTYPE,8,30) ;?65,"NUMERATOR"
  1. D W^BGP8DP($TR($J("",80)," ","-"),0,1,BGPPTYPE)
  1. S BGPFIRSP=0
  1. Q