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

BATRPT9.m

Go to the documentation of this file.
  1. BATRPT9 ; IHS/CMI/LAB - master list of all active patients ;
  1. ;;1.0;IHS ASTHMA REGISTER;;FEB 19, 2003
  1. ;
  1. ;
  1. START ;
  1. D EXIT
  1. W:$D(IOF) @IOF
  1. W !!,$$CTR^BATU("% OF PERSISTENT PATIENTS WITH CONTROLLER OR INHALED STEROID PERSCRIPTIONS")
  1. W !,$$CTR^BATU("FILLED IN A DATE RANGE SPECIFIED BY THE USER")
  1. W !!,"This report give a % of persistent patients who have had at least",!,"one fill of controller meds and the % of severe persistent patients",!,"who have had at least one fill of inhaled steroids.",!
  1. STAT ;
  1. S BATS=""
  1. S DIR(0)="90181.01,.02",DIR("A")="List Patients with which Register Status",DIR("B")="A" KILL DA D ^DIR KILL DIR
  1. I $D(DIRUT) D EXIT Q
  1. I Y="" D EXIT Q
  1. S BATS=Y,BATSF=Y(0)
  1. AGE ;Age Screening
  1. K BATAGE,BATAGET
  1. W ! S DIR(0)="YO",DIR("A")="Would you like to restrict the report by Patient age range",DIR("B")="YES"
  1. S DIR("?")="If you wish to include visits from ALL age ranges, answer No. If you wish to include visits for only patients within a particular age range, enter 'Yes'."
  1. D ^DIR K DIR
  1. G:$D(DIRUT) STAT
  1. I 'Y G DATES
  1. ;
  1. AGER ;Age Screening
  1. W !
  1. S DIR(0)="FO^1:7",DIR("A")="Enter an Age Range (e.g. 5-12,1-1)" D ^DIR
  1. I Y="" W !!,"No age range entered." G AGE
  1. I Y'?1.3N1"-"1.3N W !!,$C(7),$C(7),"Enter a numeric range in the format nnn-nnn. e.g. 0-5, 0-99, 5-20." G AGER
  1. S BATAGET=Y
  1. ;
  1. ;
  1. DATES ;
  1. S (BATBD,BATED)=""
  1. BD ;get beginning date
  1. W ! S DIR(0)="D^::EP",DIR("A")="Enter Beginning Date of Date Range" D ^DIR K DIR S:$D(DUOUT) DIRUT=1
  1. I $D(DIRUT) G STAT
  1. S BATBD=Y
  1. ED ;get ending date
  1. W ! S DIR(0)="DA^::EP",DIR("A")="Enter Ending Date of Date Range: " S Y=BATBD D DD^%DT S Y="" D ^DIR K DIR S:$D(DUOUT) DIRUT=1
  1. I $D(DIRUT) G BD
  1. S BATED=Y
  1. S X1=BATBD,X2=-1 D C^%DTC S BATSD=X
  1. ZIS ;
  1. W ! S DIR(0)="S^P:PRINT Output;B:BROWSE Output on Screen",DIR("A")="Do you wish to",DIR("B")="P" K DA D ^DIR K DIR
  1. I $D(DIRUT) D EXIT Q
  1. S BATOPT=Y
  1. I Y="B" D BROWSE,EXIT Q
  1. S XBRP="PRINT^BATRPT9",XBRC="PROC^BATRPT9",XBRX="EXIT^BATRPT9",XBNS="BAT"
  1. D ^XBDBQUE
  1. D EXIT
  1. Q
  1. BROWSE ;
  1. S XBRP="VIEWR^XBLM(""PRINT^BATRPT9"")"
  1. S XBRC="PROC^BATRPT9",XBRX="EXIT^BATRPT9",XBIOP=0 D ^XBDBQUE
  1. Q
  1. EXIT ;
  1. D EN^XBVK("BAT")
  1. Q
  1. PROC ;
  1. S (BAT1D,BAT1N,BAT2D,BAT2N)=0
  1. S BATJ=$J,BATH=$H
  1. S BATX=0 F S BATX=$O(^BATREG(BATX)) Q:BATX'=+BATX D
  1. .I $$DOD^AUPNPAT(BATX)]"" Q ;DECEASED
  1. .I $P(^BATREG(BATX,0),U,2)'=BATS Q
  1. .I $$LASTSEVD^BATU(BATX,1,BATED)=""!($$LASTSEVD^BATU(BATX,1,BATED)=1) Q
  1. .S BATAGE=$$AGE^AUPNPAT(BATX,BATBD)
  1. .I $D(BATAGET),BATAGE>$P(BATAGET,"-",2) Q
  1. .I $D(BATAGET),BATAGE<$P(BATAGET,"-") Q
  1. .S BAT1D=BAT1D+1
  1. .S X=$$CONTR(BATX,BATBD,BATED)
  1. .I X S BAT1N=BAT1N+1
  1. .I $$LASTSEV^BATU(BATX)=2 Q
  1. .S BAT2D=BAT2D+1
  1. .S X=$$INHALED(BATX,BATBD,BATED)
  1. .I X S BAT2N=BAT2N+1
  1. Q
  1. PRINT ;EP
  1. S BATQUIT=0,BATPG=0
  1. D HEADER
  1. W !!,"Controller Med Use"
  1. W !," Total Number of Patients (sev 2,3,4): ",?40,$J(BAT1D,7)
  1. W !," Total Number with Controller Med Fill: ",?40,$J(BAT1N,7)
  1. S X=""
  1. I BAT1D S X=$J(((BAT1N/BAT1D)*100),5,1)
  1. W !?40,$J(X,7),"%"
  1. W !!,"Inhaled Steroid Med Use"
  1. W !,"Total Number of Patients (severity 3,4): ",?40,$J(BAT2D,7)
  1. W !," Total Number with Inhaled Steroid Fill: ",?40,$J(BAT2N,7)
  1. S X=""
  1. I BAT2D S X=$J(((BAT2N/BAT2D)*100),5,1)
  1. W !?40,$J(X,7),"%"
  1. EOJ ;
  1. I BATOPT'="B",$E(IOST)="C",IO=IO(0) W !! S DIR(0)="EO",DIR("A")="End of report. Press ENTER" D ^DIR K DIR S:$D(DUOUT) DIRUT=1
  1. W:$D(IOF) @IOF
  1. Q
  1. CONTR(P,BDATE,EDATE) ;EP
  1. NEW X,BATL,E
  1. S X=P_"^LAST MEDS [BAT ASTHMA CONTROLLER MEDS"_";DURING "_$$FMTE^XLFDT(BDATE)_"-"_$$FMTE^XLFDT(EDATE) S E=$$START1^APCLDF(X,"BATL(")
  1. I $D(BATL(1)) Q 1
  1. S X=P_"^LAST MEDS [BAT ASTHMA INHALED STEROIDS"_";DURING "_$$FMTE^XLFDT(BDATE)_"-"_$$FMTE^XLFDT(EDATE) S E=$$START1^APCLDF(X,"BATL(")
  1. I $D(BATL(1)) Q 1
  1. Q ""
  1. INHALED(P,BDATE,EDATE) ;
  1. NEW X,BATL,E
  1. S X=P_"^LAST MEDS [BAT ASTHMA INHALED STEROIDS"_";DURING "_$$FMTE^XLFDT(BDATE)_"-"_$$FMTE^XLFDT(EDATE) S E=$$START1^APCLDF(X,"BATL(")
  1. I $D(BATL(1)) Q 1
  1. Q ""
  1. ;
  1. G:'BATPG 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 BATQUIT=1 Q
  1. HEADER1 ;
  1. W:$D(IOF) @IOF S BATPG=BATPG+1
  1. W !,$P(^VA(200,DUZ,0),U,2),?35,$$FMTE^XLFDT(DT),?70,"Page ",BATPG,!
  1. W $$CTR^BATU($$LOC^BATU),!
  1. W !,$$CTR^BATU("*** % OF PERSISTENT PATIENTS AND CONTROLLER/INHALED STEROID USE ***",80),!
  1. S X="Register Status: "_BATSF W $$CTR^BATU(X,80),!
  1. I $D(BATAGET) S X="Ages: "_BATAGET W $$CTR^BATU(X,80),!
  1. S X="Date Range: "_$$FMTE^XLFDT(BATBD)_" - "_$$FMTE^XLFDT(BATED) W $$CTR^BATU(X,80),!
  1. W !,$TR($J("",80)," ","-")
  1. Q