- BDMP810 ; IHS/CMI/LAB -IHS -GETS DATA FOR DIABETES QA REPORT ;
- ;;2.0;DIABETES MANAGEMENT SYSTEM;**2**;JUN 14, 2007
- ;
- ;
- EN ; - ENTRY POINT - from ^BDMASK
- K ^BDMDATA("BDMEPI",$J)
- S ^XTMP("BDMP81",0)=$$FMADD^XLFDT(DT,14)_"^"_DT_"^PRE DM AUDIT 2007"
- S BDMEPIN=0
- S BDMPD=0 F S BDMPD=$O(^XTMP("BDMP81",BDMJOB,BDMBTH,"PATS",BDMPD)) Q:'BDMPD D
- .I BDMTYPE'="P",BDMTYPE'="S" Q:$$DEMO^BDMUTL(BDMPD,$G(BDMDEMO))
- .;I BDMPREP=2 D EPIREC Q
- .D GATHER
- ;I BDMPREP=2 D WRITEF^BDMP81 Q
- I BDMPREP=2!(BDMPREP=3) D CUML^BDMP815
- Q
- S(P,I,V) ;
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",P,I)=V
- Q
- GATHER ;gather data for 1 patient
- S BDMER=0
- ;set report dates
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,1)=$S($G(BDMFISC)]"":BDMFISC,1:BDMRBD_" - "_BDMRED)
- ;set audit date to DT
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,2)=$$FMTE^XLFDT(DT)
- ;set area, su, facility code and name
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,4)=$P(^DIC(4,DUZ(2),0),U)
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,6)=$E($P(^AUTTLOC(DUZ(2),0),U,10),1,2)
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,8)=$E($P(^AUTTLOC(DUZ(2),0),U,10),3,4)
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,10)=$E($P(^AUTTLOC(DUZ(2),0),U,10),5,6)
- ;# pats in register
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,12)=$S(BDMDMRG:$$RSTAT^BDMDM6(BDMDMRG,"A"),1:"")
- ;reviewer
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,14)=$P(^VA(200,DUZ,0),U,2)
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,15)=$$VAL^XBDIQ1(9000001,BDMPD,.14)
- DEMO ;pat demographics
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,16)=$$HRN^AUPNPAT(BDMPD,DUZ(2))
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,18)=$$DOB^AUPNPAT(BDMPD,"E")
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,20)=$$VAL^XBDIQ1(2,BDMPD,.02)
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,120)=$$TRIBE(BDMPD)
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,121)=$$COMM(BDMPD)
- DXDT ;dates of and dm dxs
- K BDMDATA D IFG^BDMP813(BDMPD,.BDMDATA)
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,200)=$S($D(BDMDATA):"Yes",1:"No")
- S X=0 F S X=$O(BDMDATA(X)) Q:X'=+X D
- .S Y=200_"."_X
- .S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,Y)=BDMDATA(X)
- K BDMDATA D IGT^BDMP813(BDMPD,.BDMDATA)
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,210)=$S($D(BDMDATA):"Yes",1:"No")
- S X=0 F S X=$O(BDMDATA(X)) Q:X'=+X D
- .S Y=210_"."_X
- .S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,Y)=BDMDATA(X)
- K BDMDATA D MS^BDMP813(BDMPD,.BDMDATA)
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,220)=$S($D(BDMDATA):"Yes",1:"No")
- S X=0 F S X=$O(BDMDATA(X)) Q:X'=+X D
- .S Y=220_"."_X
- .S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,Y)=BDMDATA(X)
- K BDMDATA D ABNG^BDMP813(BDMPD,.BDMDATA)
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,230)=$S($D(BDMDATA):"Yes",1:"No")
- S X=0 F S X=$O(BDMDATA(X)) Q:X'=+X D
- .S Y=230_"."_X
- .S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,Y)=BDMDATA(X)
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,22)=$S(BDMDMRG:$$CMSFDX^BDMP813(BDMPD,BDMDMRG,"D"),1:"")
- S ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,24)=$S(BDMDMRG:$$CMSFDX^BDMP813(BDMPD,BDMDMRG,"DX"),1:"")
- I $$PLDMDXS^BDMP813(BDMPD)]"" D S(BDMPD,25,"PLEASE NOTE: Diabetes is on the Problem list for this patient")
- S X=$$FRSTDMDX^BDMP813(BDMPD,"E") I X]"" D S(BDMPD,26,"PLEASE NOTE: Diabetes has been used as a diagnosis in PCC: "_X)
- D S(BDMPD,27,$$TOBACCO^BDMP816(BDMPD,BDMRED))
- D S(BDMPD,28,$$CESS^BDMP811(BDMPD,BDMRBD,BDMRED))
- VITAL ;
- D S(BDMPD,30,$$LASTHT^BDMP813(BDMPD,BDMRED))
- D S(BDMPD,32,$$LASTWT^BDMP813(BDMPD,BDMRED))
- D S(BDMPD,33,$$LASTWC^BDMP813(BDMPD,BDMRED))
- ;htn dx
- D S(BDMPD,34,$$HTNDX^BDMP813(BDMPD,BDMRED))
- ;last 3 BPs
- D S(BDMPD,36,$$BPS^BDMP813(BDMPD,BDMRBD,BDMRED))
- EXAMS ;
- D S(BDMPD,44,$$DIETEDUC^BDMP817(BDMPD,BDMRBD,BDMRED))
- D S(BDMPD,46,$$EXEDUC^BDMP817(BDMPD,BDMRBD,BDMRED))
- THERAPY ;
- S BDM6MBD=$$FMADD^XLFDT(BDMADAT,-(6*31)),BDM6MBD=$$FMTE^XLFDT(BDM6MBD)
- D S(BDMPD,53,$$SULF^BDMP812(BDMPD,BDM6MBD,BDMRED))
- D S(BDMPD,54,$$MET^BDMP812(BDMPD,BDM6MBD,BDMRED))
- D S(BDMPD,55,$$ACAR^BDMP812(BDMPD,BDM6MBD,BDMRED))
- D S(BDMPD,56,$$TROG^BDMP812(BDMPD,BDM6MBD,BDMRED))
- S Y="" F X=53:1:56 I ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,X)="X" S Y=1
- D S(BDMPD,51,$S(Y:"",1:"X"))
- D S(BDMPD,60,$$ACE^BDMP816(BDMPD,BDM6MBD,BDMRED))
- IMM ;
- D S(BDMPD,62,$$ASPIRIN^BDMP816(BDMPD,BDMRBD,BDMRED))
- D S(BDMPD,61,$$LIPID^BDMP816(BDMPD,BDM6MBD,BDMRED))
- D S(BDMPD,76,$$EKG^BDMP812(BDMPD,BDMRED))
- LABS ;
- D S(BDMPD,90,$$FGLUCOSE^BDMD718(BDMPD,$P(^DPT(BDMPD,0),U,3),BDMADAT))
- D S(BDMPD,91,$$G75^BDMD718(BDMPD,$P(^DPT(BDMPD,0),U,3),BDMADAT))
- D S(BDMPD,86,$$CHOL^BDMD718(BDMPD,BDMBDAT,BDMADAT))
- D S(BDMPD,88,$$LDL^BDMD718(BDMPD,BDMBDAT,BDMADAT))
- D S(BDMPD,89,$$HDL^BDMD718(BDMPD,BDMBDAT,BDMADAT))
- D S(BDMPD,90,$$TRIG^BDMD718(BDMPD,BDMBDAT,BDMADAT))
- ;
- D S(BDMPD,112,$$BMI^BDMD718(BDMPD,BDMRBD,BDMRED))
- Q
- DATE(D) ;EP
- I $G(D)="" Q ""
- Q $E(D,4,5)_"/"_$E(D,6,7)_"/"_(1700+($E(D,1,3)))
- TRIBE(P) ;EP
- I '$G(P) Q ""
- I '$D(^AUPNPAT(P,11)) Q ""
- Q $$TRIBE^AUPNPAT(P,"C")_"^"_$$TRIBE^AUPNPAT(P,"E")
- COMM(P) ;EP
- I '$G(P) Q ""
- I '$D(^AUPNPAT(P,11)) Q ""
- Q $$COMMRES^AUPNPAT(P,"C")_"^"_$$COMMRES^AUPNPAT(P,"E")
- BDMP810 ; IHS/CMI/LAB -IHS -GETS DATA FOR DIABETES QA REPORT ;
- +1 ;;2.0;DIABETES MANAGEMENT SYSTEM;**2**;JUN 14, 2007
- +2 ;
- +3 ;
- EN ; - ENTRY POINT - from ^BDMASK
- +1 KILL ^BDMDATA("BDMEPI",$JOB)
- +2 SET ^XTMP("BDMP81",0)=$$FMADD^XLFDT(DT,14)_"^"_DT_"^PRE DM AUDIT 2007"
- +3 SET BDMEPIN=0
- +4 SET BDMPD=0
- FOR
- SET BDMPD=$ORDER(^XTMP("BDMP81",BDMJOB,BDMBTH,"PATS",BDMPD))
- IF 'BDMPD
- QUIT
- Begin DoDot:1
- +5 IF BDMTYPE'="P"
- IF BDMTYPE'="S"
- IF $$DEMO^BDMUTL(BDMPD,$GET(BDMDEMO))
- QUIT
- +6 ;I BDMPREP=2 D EPIREC Q
- +7 DO GATHER
- End DoDot:1
- +8 ;I BDMPREP=2 D WRITEF^BDMP81 Q
- +9 IF BDMPREP=2!(BDMPREP=3)
- DO CUML^BDMP815
- +10 QUIT
- S(P,I,V) ;
- +1 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",P,I)=V
- +2 QUIT
- GATHER ;gather data for 1 patient
- +1 SET BDMER=0
- +1 ;set report dates
- +2 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,1)=$SELECT($GET(BDMFISC)]"":BDMFISC,1:BDMRBD_" - "_BDMRED)
- +3 ;set audit date to DT
- +4 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,2)=$$FMTE^XLFDT(DT)
- +5 ;set area, su, facility code and name
- +6 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,4)=$PIECE(^DIC(4,DUZ(2),0),U)
- +7 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,6)=$EXTRACT($PIECE(^AUTTLOC(DUZ(2),0),U,10),1,2)
- +8 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,8)=$EXTRACT($PIECE(^AUTTLOC(DUZ(2),0),U,10),3,4)
- +9 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,10)=$EXTRACT($PIECE(^AUTTLOC(DUZ(2),0),U,10),5,6)
- +10 ;# pats in register
- +11 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,12)=$SELECT(BDMDMRG:$$RSTAT^BDMDM6(BDMDMRG,"A"),1:"")
- +12 ;reviewer
- +13 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,14)=$PIECE(^VA(200,DUZ,0),U,2)
- +14 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,15)=$$VAL^XBDIQ1(9000001,BDMPD,.14)
- DEMO ;pat demographics
- +1 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,16)=$$HRN^AUPNPAT(BDMPD,DUZ(2))
- +2 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,18)=$$DOB^AUPNPAT(BDMPD,"E")
- +3 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,20)=$$VAL^XBDIQ1(2,BDMPD,.02)
- +4 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,120)=$$TRIBE(BDMPD)
- +5 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,121)=$$COMM(BDMPD)
- DXDT ;dates of and dm dxs
- +1 KILL BDMDATA
- DO IFG^BDMP813(BDMPD,.BDMDATA)
- +2 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,200)=$SELECT($DATA(BDMDATA):"Yes",1:"No")
- +3 SET X=0
- FOR
- SET X=$ORDER(BDMDATA(X))
- IF X'=+X
- QUIT
- Begin DoDot:1
- +4 SET Y=200_"."_X
- +5 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,Y)=BDMDATA(X)
- End DoDot:1
- +6 KILL BDMDATA
- DO IGT^BDMP813(BDMPD,.BDMDATA)
- +7 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,210)=$SELECT($DATA(BDMDATA):"Yes",1:"No")
- +8 SET X=0
- FOR
- SET X=$ORDER(BDMDATA(X))
- IF X'=+X
- QUIT
- Begin DoDot:1
- +9 SET Y=210_"."_X
- +10 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,Y)=BDMDATA(X)
- End DoDot:1
- +11 KILL BDMDATA
- DO MS^BDMP813(BDMPD,.BDMDATA)
- +12 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,220)=$SELECT($DATA(BDMDATA):"Yes",1:"No")
- +13 SET X=0
- FOR
- SET X=$ORDER(BDMDATA(X))
- IF X'=+X
- QUIT
- Begin DoDot:1
- +14 SET Y=220_"."_X
- +15 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,Y)=BDMDATA(X)
- End DoDot:1
- +16 KILL BDMDATA
- DO ABNG^BDMP813(BDMPD,.BDMDATA)
- +17 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,230)=$SELECT($DATA(BDMDATA):"Yes",1:"No")
- +18 SET X=0
- FOR
- SET X=$ORDER(BDMDATA(X))
- IF X'=+X
- QUIT
- Begin DoDot:1
- +19 SET Y=230_"."_X
- +20 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,Y)=BDMDATA(X)
- End DoDot:1
- +21 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,22)=$SELECT(BDMDMRG:$$CMSFDX^BDMP813(BDMPD,BDMDMRG,"D"),1:"")
- +22 SET ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,24)=$SELECT(BDMDMRG:$$CMSFDX^BDMP813(BDMPD,BDMDMRG,"DX"),1:"")
- +23 IF $$PLDMDXS^BDMP813(BDMPD)]""
- DO S(BDMPD,25,"PLEASE NOTE: Diabetes is on the Problem list for this patient")
- +24 SET X=$$FRSTDMDX^BDMP813(BDMPD,"E")
- IF X]""
- DO S(BDMPD,26,"PLEASE NOTE: Diabetes has been used as a diagnosis in PCC: "_X)
- +25 DO S(BDMPD,27,$$TOBACCO^BDMP816(BDMPD,BDMRED))
- +26 DO S(BDMPD,28,$$CESS^BDMP811(BDMPD,BDMRBD,BDMRED))
- VITAL ;
- +1 DO S(BDMPD,30,$$LASTHT^BDMP813(BDMPD,BDMRED))
- +2 DO S(BDMPD,32,$$LASTWT^BDMP813(BDMPD,BDMRED))
- +3 DO S(BDMPD,33,$$LASTWC^BDMP813(BDMPD,BDMRED))
- +4 ;htn dx
- +5 DO S(BDMPD,34,$$HTNDX^BDMP813(BDMPD,BDMRED))
- +6 ;last 3 BPs
- +7 DO S(BDMPD,36,$$BPS^BDMP813(BDMPD,BDMRBD,BDMRED))
- EXAMS ;
- +1 DO S(BDMPD,44,$$DIETEDUC^BDMP817(BDMPD,BDMRBD,BDMRED))
- +2 DO S(BDMPD,46,$$EXEDUC^BDMP817(BDMPD,BDMRBD,BDMRED))
- THERAPY ;
- +1 SET BDM6MBD=$$FMADD^XLFDT(BDMADAT,-(6*31))
- SET BDM6MBD=$$FMTE^XLFDT(BDM6MBD)
- +2 DO S(BDMPD,53,$$SULF^BDMP812(BDMPD,BDM6MBD,BDMRED))
- +3 DO S(BDMPD,54,$$MET^BDMP812(BDMPD,BDM6MBD,BDMRED))
- +4 DO S(BDMPD,55,$$ACAR^BDMP812(BDMPD,BDM6MBD,BDMRED))
- +5 DO S(BDMPD,56,$$TROG^BDMP812(BDMPD,BDM6MBD,BDMRED))
- +6 SET Y=""
- FOR X=53:1:56
- IF ^XTMP("BDMP81",BDMJOB,BDMBTH,"AUDIT",BDMPD,X)="X"
- SET Y=1
- +7 DO S(BDMPD,51,$SELECT(Y:"",1:"X"))
- +8 DO S(BDMPD,60,$$ACE^BDMP816(BDMPD,BDM6MBD,BDMRED))
- IMM ;
- +1 DO S(BDMPD,62,$$ASPIRIN^BDMP816(BDMPD,BDMRBD,BDMRED))
- +2 DO S(BDMPD,61,$$LIPID^BDMP816(BDMPD,BDM6MBD,BDMRED))
- +3 DO S(BDMPD,76,$$EKG^BDMP812(BDMPD,BDMRED))
- LABS ;
- +1 DO S(BDMPD,90,$$FGLUCOSE^BDMD718(BDMPD,$PIECE(^DPT(BDMPD,0),U,3),BDMADAT))
- +2 DO S(BDMPD,91,$$G75^BDMD718(BDMPD,$PIECE(^DPT(BDMPD,0),U,3),BDMADAT))
- +3 DO S(BDMPD,86,$$CHOL^BDMD718(BDMPD,BDMBDAT,BDMADAT))
- +4 DO S(BDMPD,88,$$LDL^BDMD718(BDMPD,BDMBDAT,BDMADAT))
- +5 DO S(BDMPD,89,$$HDL^BDMD718(BDMPD,BDMBDAT,BDMADAT))
- +6 DO S(BDMPD,90,$$TRIG^BDMD718(BDMPD,BDMBDAT,BDMADAT))
- +7 ;
- +8 DO S(BDMPD,112,$$BMI^BDMD718(BDMPD,BDMRBD,BDMRED))
- +9 QUIT
- DATE(D) ;EP
- +1 IF $GET(D)=""
- QUIT ""
- +2 QUIT $EXTRACT(D,4,5)_"/"_$EXTRACT(D,6,7)_"/"_(1700+($EXTRACT(D,1,3)))
- TRIBE(P) ;EP
- +1 IF '$GET(P)
- QUIT ""
- +2 IF '$DATA(^AUPNPAT(P,11))
- QUIT ""
- +3 QUIT $$TRIBE^AUPNPAT(P,"C")_"^"_$$TRIBE^AUPNPAT(P,"E")
- COMM(P) ;EP
- +1 IF '$GET(P)
- QUIT ""
- +2 IF '$DATA(^AUPNPAT(P,11))
- QUIT ""
- +3 QUIT $$COMMRES^AUPNPAT(P,"C")_"^"_$$COMMRES^AUPNPAT(P,"E")