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

BUDHRP7L.m

Go to the documentation of this file.
  1. BUDHRP7L ;IHS/CMI/LAB - UDS REPORT T7;
  1. ;;13.0;IHS/RPMS UNIFORM DATA SYSTEM;;OCT 12, 2018;Build 90
  1. ;
  1. ;
  1. S(V) ;
  1. S BUDDECNT=BUDDECNT+1
  1. S ^TMP($J,"BUDDEL",BUDDECNT)=$G(V)
  1. Q
  1. ;----------
  1. PAUSE ;
  1. K DIR S DIR(0)="E",DIR("A")="PRESS ENTER" KILL DA D ^DIR KILL DIR
  1. Q
  1. GENI ;general introductions
  1. D GENI^BUDHRP7I
  1. Q
  1. ;
  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. ;----------
  1. ;
  1. DMR ;EP
  1. W:$D(IOF) @IOF
  1. W !,$$CTR($$LOC,80)
  1. W !,$$CTR("UDS 2018",80)
  1. W !!,"All Patients w/DM by Race and Hispanic or Latino Identity (Table 7)",!
  1. D GENI
  1. D PAUSE
  1. W !!,"This report provides a list by race and Hispanic or Latino identity of "
  1. W !,"patients 18 to 75 years old who have had at least one medical visit "
  1. W !,"during the report period, with a diagnosis of Type I or Type II diabetes"
  1. W !,"anytime through the end of the report period, and without a diagnosis of"
  1. W !,"secondary diabetes due to another condition (such as polycystic ovaries,"
  1. W !,"gestational diabetes, or steroid-induced diabetes)."
  1. W !
  1. Q
  1. DMRL ;EP
  1. S BUDP=0,BUDQUIT=0,BUDTOT=0
  1. D DMRH Q:BUDQUIT
  1. I '$D(^XTMP("BUDHRP7",BUDJ,BUDH,"DMR")) S X="No patients to report." W:BUDROT="P" !!,X D:BUDROT="D" S(),S(X) Q
  1. D DMRL1
  1. I BUDROT="P",$Y>(IOSL-3) D DMRH G:BUDQUIT DMRLX
  1. I BUDROT="P" W !,"TOTAL DIABETES PATIENTS 18-75 BY RACE AND HISPANIC OR LATINO IDENTITY: ",BUDTOT,!
  1. I BUDROT="D" D S(),S("TOTAL DIABETES PATIENTS 18-75 BY RACE AND HISPANIC OR LATINO IDENTITY: "_BUDTOT)
  1. DMRLX ;
  1. Q
  1. DMRL1 ;
  1. I BUDROT="P",$Y>(IOSL-7) D DMRH Q:BUDQUIT
  1. S BUDTOT=0
  1. S BUDRACE="" F S BUDRACE=$O(^XTMP("BUDHRP7",BUDJ,BUDH,"DMR",BUDRACE)) Q:BUDRACE=""!(BUDQUIT) D
  1. .S BUDHTH="" F S BUDHTH=$O(^XTMP("BUDHRP7",BUDJ,BUDH,"DMR",BUDRACE,BUDHTH)) Q:BUDHTH=""!(BUDQUIT) D DMRL2
  1. Q
  1. DMRL2 ;
  1. S BUDSTOT=0
  1. S BUDRACEL=$$RACEL^BUDHRP7I(BUDRACE,BUDHTH)
  1. I BUDROT="P" W !,BUDRACEL
  1. I BUDROT="D" D S(BUDRACEL)
  1. S BUDCCOM="" F S BUDCCOM=$O(^XTMP("BUDHRP7",BUDJ,BUDH,"DMR",BUDRACE,BUDHTH,BUDCCOM)) Q:BUDCCOM=""!(BUDQUIT) D
  1. .S BUDA="" F S BUDA=$O(^XTMP("BUDHRP7",BUDJ,BUDH,"DMR",BUDRACE,BUDHTH,BUDCCOM,BUDA)) Q:BUDA=""!(BUDQUIT) D
  1. ..S BUDNAME="" F S BUDNAME=$O(^XTMP("BUDHRP7",BUDJ,BUDH,"DMR",BUDRACE,BUDHTH,BUDCCOM,BUDA,BUDNAME)) Q:BUDNAME=""!(BUDQUIT) D
  1. ...S DFN=0 F S DFN=$O(^XTMP("BUDHRP7",BUDJ,BUDH,"DMR",BUDRACE,BUDHTH,BUDCCOM,BUDA,BUDNAME,DFN)) Q:DFN'=+DFN!(BUDQUIT) D
  1. ....I BUDROT="P",$Y>(IOSL-3) D DMRH Q:BUDQUIT W !,BUDRACEL,!
  1. ....I BUDROT="P" W !?2,$E($P(^DPT(DFN,0),U,1),1,20),?24,$S($$HRN^AUPNPAT(DFN,BUDSITE)]"":$$HRN^AUPNPAT(DFN,BUDSITE,2),1:$$HRN^AUPNPAT(DFN,DUZ(2),2)),?36,$E(BUDCCOM,1,10),?47,$P(^DPT(DFN,0),U,2),?51,BUDA,! ;
  1. ....I BUDROT="D" S BUDPV="",BUDPV=$E($P(^DPT(DFN,0),U,1),1,30)_U_$S($$HRN^AUPNPAT(DFN,BUDSITE)]"":$$HRN^AUPNPAT(DFN,BUDSITE,2),1:$$HRN^AUPNPAT(DFN,DUZ(2),2))_U_$E(BUDCCOM,1,12)_U_$P(^DPT(DFN,0),U,2)_U_BUDA
  1. ....S BUDTOT=BUDTOT+1,BUDSTOT=BUDSTOT+1
  1. ....S BUDRACV=$$RACE^BUDHRPTC(DFN)
  1. ....I BUDROT="P" W ?2,$E($P(BUDRACV,U,4),1,16)_" ("_$P(BUDRACV,U,3),")" ;,?60,$E($P($$RACE^BUDHRPTC(DFN),U,3)_"-"_$P($$RACE^BUDHRPTC(DFN),U,4),1,19)
  1. ....I BUDROT="D" S BUDPV=BUDPV_U_$E($P(BUDRACV,U,4),1,16)_" ("_$P(BUDRACV,U,3)_")"
  1. ....S BUDHISV=$$HISP^BUDHRPTC(DFN)
  1. ....I BUDROT="P" W ?24,$P(BUDHISV,U,3)," (",$P(BUDHISV,U,2),")",!
  1. ....I BUDROT="D" S BUDPV=BUDPV_U_$P(BUDHISV,U,3)_" ("_$P(BUDHISV,U,2)_")"
  1. ....S BUDALL=^XTMP("BUDHRP7",BUDJ,BUDH,"DMR",BUDRACE,BUDHTH,BUDCCOM,BUDA,BUDNAME,DFN)
  1. ....S BUDPPV=$P(BUDALL,"^",1)
  1. ....F BUDX=1:1 S BUDV=$P(BUDPPV,U,BUDX) Q:BUDV=""!(BUDQUIT) D
  1. .....I BUDROT="P",$Y>(IOSL-3) D DMRH Q:BUDQUIT W !,BUDRACEL,!
  1. .....I BUDROT="P" I $E(BUDV)="P" W ?5,BUDV,! Q
  1. .....I BUDROT="D" I $E(BUDV)="P" S BUDPV=BUDPV_U_BUDV D S(BUDPV) Q
  1. .....S V=$P(BUDV,"|"),C=$P(BUDV,"|",2)
  1. .....I BUDROT="P" W ?5,$$FMTE^XLFDT($P($P(^AUPNVSIT(V,0),U),".")),?19,C,?35,$$PRIMPROV^APCLV(V,"D"),?45,$P(^AUPNVSIT(V,0),U,7),?53,$$CLINIC^APCLV(V,"C"),?65,$E($$VAL^XBDIQ1(9000010,V,.06),1,15),!
  1. .....I BUDROT="D" S X=BUDPV_U_$$FMTE^XLFDT($P($P(^AUPNVSIT(V,0),U),"."))_U_C_U_$$PRIMPROV^APCLV(V,"D")_U_$P(^AUPNVSIT(V,0),U,7)_U_$$CLINIC^APCLV(V,"C")_U_$$VAL^XBDIQ1(9000010,V,.06) D S(X)
  1. I BUDROT="P",$Y>(IOSL-4) D DMRH Q:BUDQUIT W !,BUDRACEL,!
  1. I BUDROT="P" W !,"Sub-Total ",BUDRACEL,": ",BUDSTOT,!
  1. I BUDROT="D" D S("Sub-Total "_BUDRACEL_": "_BUDSTOT)
  1. Q
  1. DMRHD ;
  1. D S("***** SENSITIVE INFORMATION *****")
  1. D S($P(^VA(200,DUZ,0),U,2)_" "_$$FMTE^XLFDT(DT))
  1. D S("*** RPMS Uniform Data System (UDS) "_$$VER^BUDHBAN()_" ***")
  1. D S("Patient List for Table 7, Section C, Diabetes Patients by Race and Hispanic or Latino Identity")
  1. D S($P(^DIC(4,BUDSITE,0),U))
  1. S X="Reporting Period: "_$$FMTE^XLFDT(BUDBD)_" to "_$$FMTE^XLFDT(BUDED) D S(X)
  1. S X="Population: "_$S($G(BUDBEN)=1:"Indian/Alaskan Native (Classification 01)",$G(BUDBEN)=2:"Not Indian Alaskan/Native (Not Classification 01)",$G(BUDBEN)=3:"All (both Indian/Alaskan Natives and Non 01)",1:"") D S(X)
  1. D S()
  1. D S("List by race and Hispanic or Latino identity of all patients 18 to 75 years ")
  1. D S("old who have had at least one medical visit during the report period and were ")
  1. D S("diagnosed with Type I or Type II diabetes anytime through the end of the ")
  1. D S("report period.")
  1. D S("Age on the patient list is calculated as of December 31.")
  1. D S("* E - denotes the value was obtained from the Ethnicity field.")
  1. D S(" R - denotes the value was obtained from the Race field")
  1. D S(" C - denotes the value was obtained from the Classification/Beneficiary field")
  1. D S()
  1. D S("PATIENT NAME^HRN^COMMUNITY^SEX^AGE^RACE*^HISPANIC OR LATINO IDENTITY^LAST DM DATE^DX OR SVC CD^PROV TYPE^SVC CAT^CLINIC^LOCATION")
  1. Q
  1. DMRH ;
  1. I BUDROT="D" D DMRHD Q
  1. G:'BUDGPG DMRH1
  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 BUDQUIT=1 Q
  1. DMRH1 ;
  1. W:$D(IOF) @IOF S BUDGPG=BUDGPG+1
  1. W !,$$CTR("***** SENSITIVE INFORMATION *****",IOM)
  1. W !?3,$P(^VA(200,DUZ,0),U,2),?35,$$FMTE^XLFDT(DT),?55,"Section "_BUDSCTC_" of "_BUDTSCTC_", Page "_BUDGPG,!
  1. W !,$$CTR("*** RPMS Uniform Data System (UDS) "_$$VER^BUDHBAN()_" ***",80)
  1. W !,$$CTR("Patient List for Table 7, Section C",80)
  1. W !,$$CTR("Diabetes Patients by Race and Hispanic or Latino Identity",80),! ;, DM Patients by Race and Hispanic or Latino Identity",80),!
  1. W $$CTR($P(^DIC(4,BUDSITE,0),U),80),!
  1. S X="Reporting Period: "_$$FMTE^XLFDT(BUDBD)_" to "_$$FMTE^XLFDT(BUDED) W $$CTR(X,80),!
  1. W $TR($J("",80)," ","-")
  1. I BUDP=0 D
  1. .W !,"List by race and Hispanic or Latino identity of all patients 18 to 75 years "
  1. .W !,"old who have had at least one medical visit during the report period and were"
  1. .W !,"diagnosed with Type I or Type II diabetes anytime through the end of the "
  1. .W !,"report period."
  1. .W !,"Age on the patient list is calculated as of December 31."
  1. .W !,"* E - denotes the value was obtained from the Ethnicity field."
  1. .W !," R - denotes the value was obtained from the Race field"
  1. .W !," C - denotes the value was obtained from the Classification/Beneficiary field"
  1. .W !
  1. W !?2,"PATIENT NAME",?24,"HRN",?36,"COMMUNITY",?47,"SEX",?51,"AGE"
  1. W !?2,"RACE*",?24,"HISPANIC OR LATINO IDENTITY*"
  1. W !?5,"LAST DM DATE",?19,"DX OR SVC CD",?35,"PROV TYPE",?45,"SVC CAT",?53,"CLINIC",?65,"LOCATION"
  1. W !,$TR($J("",80)," ","-"),!
  1. S BUDP=1
  1. Q