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

BDMPD13.m

Go to the documentation of this file.
  1. BDMPD13 ; IHS/CMI/LAB - 2003 DIABETES AUDIT ;
  1. ;;2.0;DIABETES MANAGEMENT SYSTEM;**9**;JUN 14, 2007;Build 78
  1. ;
  1. ;
  1. ;cmi/anch/maw 9/12/2007 code set versioning in PLDMDXS,IFG,IGT,MS,ABNG
  1. ;
  1. LASTWT(P,EDATE,F) ;PEP - return last wt
  1. I 'P Q ""
  1. I $G(F)="" S F="E"
  1. S BDATE=$$FMADD^XLFDT(EDATE,-365)
  1. NEW %,BDMARRY,E,BDMW,X,BDMN,BDM,BDMD,BDMZ,BDMX,W,H,BDMC
  1. ;NEW BDMV221 S BDMV221=$O(^ICD9("BA","V22.1 ",""))
  1. K BDM S BDMW="" S BDMX=P_"^LAST 30 MEAS WT;DURING "_BDATE_"-"_EDATE S E=$$START1^APCLDF(BDMX,"BDM(")
  1. S BDMC=0,BDMN=0 F S BDMN=$O(BDM(BDMN)) Q:BDMN'=+BDMN!(BDMC>2) D
  1. . S BDMZ=$P(BDM(BDMN),U,5)
  1. . I '$D(^AUPNVPOV("AD",BDMZ)) S BDMC=BDMC+1,BDMW=BDMW_"|"_$P(BDM(BDMN),U,2)_" lbs "_$$FMTE^XLFDT($P(BDM(BDMN),U)) Q
  1. . S BDMD=0 F S BDMD=$O(^AUPNVPOV("AD",BDMZ,BDMD)) Q:'BDMD!(BDMW]"") D
  1. .. ;lets change this code here to look at the taxonomy p8 06/04/2014
  1. .. N TAX,CODE
  1. .. S TAX=$O(^ATXAX("B","BGP PREGNANCY DIAGNOSES 2",0))
  1. .. S CODE=$P($G(^AUPNVPOV(BDMD,0)),U)
  1. .. I '$$ICD^BDMUTL(CODE,"BGP PREGNANCY DIAGNOSES 2",9) S BDMC=BDMC+1,BDMW=BDMW_"|"_$P(BDM(BDMN),U,2)_" lbs "_$$FMTE^XLFDT($P(BDM(BDMN),U))
  1. ..Q
  1. Q $S(F="E":BDMW,1:+BDMW)
  1. LASTWC(P,EDATE,F) ;PEP - return last ht and date
  1. I 'P Q ""
  1. I $G(F)="" S F="E"
  1. I '$D(^AUPNVSIT("AC",P)) Q ""
  1. S BDATE=$$FMADD^XLFDT(EDATE,-365)
  1. NEW %,BDMARRY,H,E,W
  1. S %=P_"^LAST MEAS WC;DURING "_BDATE_"-"_EDATE NEW X S E=$$START1^APCLDF(%,"BDMARRY(") S H=$P($G(BDMARRY(1)),U,2)
  1. Q H_" "_$$FMTE^XLFDT($P($G(BDMARRY(1)),U))
  1. ;
  1. IFG(P,BDMRET) ;EP
  1. K BDMRET
  1. NEW BDMC,BDM
  1. S BDMC=0
  1. K BDM
  1. ;look at problem list then povs
  1. ;return where found^dx code^provider narr^date (either visit date or doo from pl)
  1. ;look for first and last pov
  1. S X=0 F S X=$O(^AUPNPROB("AC",P,X)) Q:X'=+X D
  1. .S I=$P(^AUPNPROB(X,0),U)
  1. .Q:$P(^AUPNPROB(X,0),U,12)="D"
  1. .;ihs/cmi/maw 06/04/2014 p8
  1. .;S I=$P($$ICDDX^BDMUTL(I),U,2)
  1. .;Q:I'="790.21"
  1. .Q:'$$ICD^BDMUTL(I,"BGP IMPAIRED FASTING GLUCOSE",9)
  1. .S BDMC=BDMC+1,BDMRET(BDMC)="Problem List: "_$P($$ICDDX^BDMUTL(I),U,2)_" Date of Onset: "_$$VAL^XBDIQ1(9000011,X,.13)
  1. .Q
  1. ;now look at first and last pov
  1. S Y="BDM("
  1. S X=P_"^LAST DX [BGP IMPAIRED FASTING GLUCOSE;DURING "_$$DOB^AUPNPAT(P,"E")_"-"_DT S E=$$START1^APCLDF(X,Y)
  1. I $D(BDM(1)) S BDMC=BDMC+1,BDMRET(BDMC)="Last POV in PCC: "_$P(BDM(1),U,2)_" Date: "_$$FMTE^XLFDT($P(BDM(1),U))
  1. K BDM S X=P_"^FIRST DX [BGP IMPAIRED FASTING GLUCOSE;DURING "_$$DOB^AUPNPAT(P,"E")_"-"_DT S E=$$START1^APCLDF(X,Y)
  1. I $D(BDM(1)) S BDMC=BDMC+1,BDMRET(BDMC)="First POV in PCC: "_$P(BDM(1),U,2)_" Date: "_$$FMTE^XLFDT($P(BDM(1),U))
  1. Q
  1. IGT(P,BDMRET) ;EP
  1. K BDMRET
  1. NEW BDMC,BDM
  1. S BDMC=0
  1. K BDM
  1. ;look at problem list then povs
  1. ;return where found^dx code^provider narr^date (either visit date or doo from pl)
  1. ;look for first and last pov
  1. S X=0 F S X=$O(^AUPNPROB("AC",P,X)) Q:X'=+X D
  1. .S I=$P(^AUPNPROB(X,0),U)
  1. .Q:$P(^AUPNPROB(X,0),U,12)="D"
  1. .;ihs/cmi/maw 06/04/2014 p8
  1. .;S I=$P($$ICDDX^BDMUTL(I),U,2) ;cmi/anch/maw 9/12/2007 csv
  1. .;Q:I'="790.22"
  1. .Q:'$$ICD^BDMUTL(I,"DM AUDIT IGT DXS",9)
  1. .S BDMC=BDMC+1,BDMRET(BDMC)="Problem List: "_$P($$ICDDX^BDMUTL(I),U,2)_" Date of Onset: "_$$VAL^XBDIQ1(9000011,X,.13)
  1. .Q
  1. ;now look at first and last pov
  1. S Y="BDM("
  1. S X=P_"^LAST DX [DM AUDIT IGT DXS;DURING "_$$DOB^AUPNPAT(P,"E")_"-"_DT S E=$$START1^APCLDF(X,Y)
  1. I $D(BDM(1)) S BDMC=BDMC+1,BDMRET(BDMC)="Last POV in PCC: "_$P(BDM(1),U,2)_" Date: "_$$FMTE^XLFDT($P(BDM(1),U))
  1. K BDM S X=P_"^FIRST DX [DM AUDIT IGT DXS;DURING "_$$DOB^AUPNPAT(P,"E")_"-"_DT S E=$$START1^APCLDF(X,Y)
  1. I $D(BDM(1)) S BDMC=BDMC+1,BDMRET(BDMC)="First POV in PCC: "_$P(BDM(1),U,2)_" Date: "_$$FMTE^XLFDT($P(BDM(1),U))
  1. Q
  1. MS(P,BDMRET) ;EP
  1. K BDMRET
  1. NEW BDMC,BDM
  1. S BDMC=0
  1. K BDM
  1. ;look at problem list then povs
  1. ;return where found^dx code^provider narr^date (either visit date or doo from pl)
  1. ;look for first and last pov
  1. S X=0 F S X=$O(^AUPNPROB("AC",P,X)) Q:X'=+X D
  1. .S I=$P(^AUPNPROB(X,0),U)
  1. .Q:$P(^AUPNPROB(X,0),U,12)="D"
  1. .;ihs/cmi/maw 06/04/2014 p8
  1. .;S I=$P($$ICDDX^BDMUTL(I),U,2) ;cmi/anch/maw 9/12/2007 csv
  1. .;Q:I'="277.7"
  1. .Q:'$$ICD^BDMUTL(I,"DM AUDIT METABOLIC SYNDROME",9)
  1. .S BDMC=BDMC+1,BDMRET(BDMC)="Problem List: "_$P($$ICDDX^BDMUTL(I),U,2)_" Date of Onset: "_$$VAL^XBDIQ1(9000011,X,.13)
  1. .Q
  1. ;now look at first and last pov
  1. S Y="BDM("
  1. S X=P_"^LAST DX [DM AUDIT METABOLIC SYNDROME;DURING "_$$DOB^AUPNPAT(P,"E")_"-"_DT S E=$$START1^APCLDF(X,Y)
  1. I $D(BDM(1)) S BDMC=BDMC+1,BDMRET(BDMC)="Last POV in PCC: "_$P(BDM(1),U,2)_" Date: "_$$FMTE^XLFDT($P(BDM(1),U))
  1. K BDM S X=P_"^FIRST DX [DM AUDIT METABOLIC SYNDROME;DURING "_$$DOB^AUPNPAT(P,"E")_"-"_DT S E=$$START1^APCLDF(X,Y)
  1. I $D(BDM(1)) S BDMC=BDMC+1,BDMRET(BDMC)="First POV in PCC: "_$P(BDM(1),U,2)_" Date: "_$$FMTE^XLFDT($P(BDM(1),U))
  1. Q
  1. ABNG(P,BDMRET) ;EP
  1. K BDMRET
  1. NEW BDMC
  1. S BDMC=0
  1. ;look at problem list then povs
  1. ;return where found^dx code^provider narr^date (either visit date or doo from pl)
  1. ;look for first and last pov
  1. S X=0 F S X=$O(^AUPNPROB("AC",P,X)) Q:X'=+X D
  1. .S I=$P(^AUPNPROB(X,0),U)
  1. .Q:$P(^AUPNPROB(X,0),U,12)="D"
  1. .;ihs/cmi/maw 06/04/2014 p8
  1. .;S I=$P($$ICDDX^BDMUTL(I),U,2) ;cmi/anch/maw 9/12/2007 csv
  1. .;Q:I'="790.29"
  1. .Q:'$$ICD^BDMUTL(I,"DM AUDIT ABNORMAL GLUCOSE",9)
  1. .S BDMC=BDMC+1,BDMRET(BDMC)="Problem List: "_$P($$ICDDX^BDMUTL(I),U,2)_" Date of Onset: "_$$VAL^XBDIQ1(9000011,X,.13)
  1. .Q
  1. ;now look at first and last pov
  1. S Y="BDM("
  1. S X=P_"^LAST DX [DM AUDIT ABNORMAL GLUCOSE;DURING "_$$DOB^AUPNPAT(P,"E")_"-"_DT S E=$$START1^APCLDF(X,Y)
  1. I $D(BDM(1)) S BDMC=BDMC+1,BDMRET(BDMC)="Last POV in PCC: "_$P(BDM(1),U,2)_" Date: "_$$FMTE^XLFDT($P(BDM(1),U))
  1. K BDM S X=P_"^FIRST DX [DM AUDIT ABNORMAL GLUCOSE;DURING "_$$DOB^AUPNPAT(P,"E")_"-"_DT S E=$$START1^APCLDF(X,Y)
  1. I $D(BDM(1)) S BDMC=BDMC+1,BDMRET(BDMC)="First POV in PCC: "_$P(BDM(1),U,2)_" Date: "_$$FMTE^XLFDT($P(BDM(1),U))
  1. Q