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

BATRP11.m

Go to the documentation of this file.
  1. BATRP11 ; 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("PERSISTENT PATIENTS WITHOUT SPIROMETRY [FEF25-75] DOCUMENTED IN PAST YEAR")
  1. W !!,"This report will list all persistent patients who have not had a ",!,"spirometry [FEF 25-75] documented in the past year.",!!
  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, anwser 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 SORT
  1. ;
  1. AGER ;Age Screening
  1. W !
  1. S DIR(0)="FO^1:7",DIR("A")="Enter an Age Range (e.g. 6-19,6-99)" 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. SORT ;
  1. S BATSORT=""
  1. S DIR(0)="S^N:Patient Name;D:Patient AGE;V:Patient's Next Asthma Visit Due Date;A:Last Asthma Severity;L:Last Asthma Visit",DIR("A")="Sort List by",DIR("B")="N" KILL DA D ^DIR KILL DIR
  1. I $D(DIRUT) D EXIT Q
  1. S BATSORT=Y
  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^BATRP11",XBRC="PROC^BATRP11",XBRX="EXIT^BATRP11",XBNS="BAT"
  1. D ^XBDBQUE
  1. D EXIT
  1. Q
  1. BROWSE ;
  1. S XBRP="VIEWR^XBLM(""PRINT^BATRP11"")"
  1. S XBRC="PROC^BATRP11",XBRX="EXIT^BATRP11",XBIOP=0 D ^XBDBQUE
  1. Q
  1. EXIT ;
  1. D EN^XBVK("BAT")
  1. Q
  1. PROC ;
  1. S BATJ=$J,BATH=$H
  1. D XTMP^BATU("BATRP11","ASTHMA REGISTER DUE LIST")
  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 $$LASTSEV^BATU(BATX)=""!($$LASTSEV^BATU(BATX)=1) Q
  1. .S BATAGE=$$AGE^AUPNPAT(BATX,DT)
  1. .I $D(BATAGET),BATAGE>$P(BATAGET,"-",2) Q
  1. .I $D(BATAGET),BATAGE<$P(BATAGET,"-") Q
  1. .S X=$$LASTFV2^BATU(BATX,3)
  1. .I X]"",X>($$FMADD^XLFDT(DT,-(1*365))) Q
  1. .D GETSORT
  1. .S ^XTMP("BATRP11",BATJ,BATH,"PATIENTS",BATSRTV,BATX)=""
  1. .Q
  1. Q
  1. GETSORT ;
  1. S BATSRTV=""
  1. I BATSORT="N" S BATSRTV=$P(^DPT(BATX,0),U) Q
  1. I BATSORT="D" S BATSRTV=$$AGE^AUPNPAT(BATX) I BATSRTV="" S BATSRTV="--" Q
  1. I BATSORT="A" S BATSRTV=$$LASTSEV^BATU(BATX) I BATSRTV="" S BATSRTV="--" Q
  1. I BATSORT="V" S BATSRTV=$P(^BATREG(BATX,0),U,7) I BATSRTV="" S BATSRTV="--"
  1. I BATSORT="L" S BATSRTV=$P(^BATREG(BATX,0),U,6) I BATSRTV="" S BATSRTV="--"
  1. Q
  1. PRINT ;EP
  1. S BATQUIT=0,BATPG=0
  1. D HEADER
  1. I '$D(^XTMP("BATRP11",BATJ,BATH,"PATIENTS")) W !!,"No patients to list" G EOJ
  1. S BATST="" F S BATST=$O(^XTMP("BATRP11",BATJ,BATH,"PATIENTS",BATST)) Q:BATST=""!(BATQUIT) D
  1. .S BATX=0 F S BATX=$O(^XTMP("BATRP11",BATJ,BATH,"PATIENTS",BATST,BATX)) Q:BATX'=+BATX!(BATQUIT) D
  1. ..I $Y>(IOSL-4) D HEADER Q:BATQUIT
  1. ..W !,$E($P(^DPT(BATX,0),U),1,22),?23,$$HRN^AUPNPAT(BATX,DUZ(2)),?30,$$AGE^AUPNPAT(BATX,DT,"R")
  1. ..W ?37,$E($$LASTSEV^BATU(BATX,5),1,17),?55,$$FMTE^XLFDT($P($P(^BATREG(BATX,0),U,6),".")),?68,$$FMTE^XLFDT($P($P(^BATREG(BATX,0),U,7),"."))
  1. ..W !?5,"Last Spirometry [FEF 25-75]: ",$$LASTFV2^BATU(BATX,1) I $$LASTFV2^BATU(BATX,1)]"" W " documented on ",$$LASTFV2^BATU(BATX,2)
  1. ..Q
  1. .Q
  1. EOJ ;
  1. I BATOPT'="B",$E(IOST)="C",IO=IO(0) S DIR(0)="EO",DIR("A")="End of report. Press ENTER" D ^DIR K DIR S:$D(DUOUT) DIRUT=1
  1. K ^XTMP("BATRP11",BATJ,BATH),BATX
  1. W:$D(IOF) @IOF
  1. Q
  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("*** PERSISTENT PATIENTS WITHOUT SPIROMETRY [FEF 25-75] DOCUMENTED IN PAST YEAR",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. W !,"PATIENT NAME",?24,"HRN",?31,"AGE",?37,"LAST SEVERITY",?55,"LAST VISIT",?68,"NEXT DUE"
  1. W !,$TR($J("",80)," ","-")
  1. Q