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

BPCBHRP8.m

Go to the documentation of this file.
  1. BPCBHRP8 ; IHS/OIT/MJL - behavioral health display for GUI ;
  1. ;;1.5;BPC;;MAY 26, 2005
  1. ;
  1. ;
  1. ;
  1. TEST ;
  1. D LISTDATE(.RETVAL,87,"D",,"01/01/1995","01/20/2003")
  1. Q
  1. LISTDATE(BGUARRAY,BPCPAT,BPCTYPE,BPCNUM,BPCBD,BPCED,BPCPROG) ;EP - BPCBH RPT LIST VISIT DATES
  1. NEW AMHR
  1. S JOB=$J,BPCGUI=1,XWBWRAP=1
  1. S ZTIO="",ZTQUEUED=1
  1. S BGUARRAY="^XTMP(""BPCRPT"","_$J_")"
  1. K ^XTMP("BPCRPT",$J)
  1. I $G(BPCPAT)="" S ^XTMP("BPCRPT",JOB,.5)=2,^XTMP("BPCRPT",JOB,1)="Invalid DFN of patient passed" D KILL Q
  1. I $G(BPCTYPE)="" S ^XTMP("BPCRPT",JOB,.5)=2,^XTMP("BPCRPT",JOB,1)="Invalid type of report type passed" D KILL Q
  1. I "LNADPS"'[BPCTYPE S ^XTMP("BPCRPT",JOB,.5)=2,^XTMP("BPCRPT",JOB,1)="Invalid report type passed" D KILL Q
  1. I $G(BPCTYPE)="N",$G(BPCNUM)="" S ^XTMP("BPCRPT",JOB,.5)=2,^XTMP("BPCRPT",JOB,1)="Number of visits not passed for N type" D KILL Q
  1. I $G(BPCTYPE)="D",$G(BPCBD)="" S ^XTMP("BPCRPT",JOB,.5)=2,^XTMP("BPCRPT",JOB,1)="Beginning date not passed and type is date range" D KILL Q
  1. I BPCBD]"" D DT^DILF("X",BPCBD,.AMHBD) I $G(AMHBD)=-1 S ^XTMP("BPCRPT",JOB,.5)=2,^XTMP("BPCRPT",JOB,1)="Invalid beginning date passed" D KILL Q
  1. I $G(BPCTYPE)="D",$G(BPCED)="" S ^XTMP("BPCRPT",JOB,.5)=2,^XTMP("BPCRPT",JOB,1)="Ending date not passed and type is date range" D KILL Q
  1. I BPCED]"" D DT^DILF("X",BPCED,.AMHED) I $G(AMHED)=-1 S ^XTMP("BPCRPT",JOB,.5)=2,^XTMP("BPCRPT",JOB,1)="Invalid ending date passed" D KILL Q
  1. I $G(BPCTYPE)="P",$G(BPCPROG)="" S ^XTMP("BPCRPT",JOB,.5)=2,^XTMP("BPCRPT",JOB,1)="Program type not passed and type is program" D KILL Q
  1. S (DFN,AMHPAT,AUPNPAT)=BPCPAT
  1. K AMHV D @BPCTYPE
  1. I '$O(AMHV(0)) S ^XTMP("BPCRPT",JOB,.5)=2,^XTMP("BPCRPT",JOB,1)="No visits found" D KILL Q
  1. K ^XTMP("BPCRPT",JOB)
  1. S ^XTMP("BPCRPTRUN",JOB)=""
  1. D ^XBKSET
  1. S ZTRTN="TSK^BPCBHRP8",ZTIO="",ZTDESC="BPC LIST VISITS DISPLAY",ZTSAVE("DFN")="",ZTSAVE("AMH*")="",ZTSAVE("JOB")="",ZTDTH=$H D ^%ZTLOAD
  1. F I=1:1:120 Q:$G(^XTMP("BPCRPTRUN",$J))="DONE" H 1
  1. D KILL
  1. Q
  1. ;
  1. TSK ;
  1. D ^XBKSET
  1. S ^XTMP("BPCRPTRUN",JOB)="START"
  1. D GUIR^XBLM("PRINT^AMHVDL","^XTMP(""BPCRPT"",JOB)")
  1. S ^XTMP("BPCRPT",JOB,.5)=$O(^XTMP("BPCRPT",JOB,""),-1)+1
  1. S ^XTMP("BPCRPTRUN",JOB)="DONE"
  1. Q
  1. ;
  1. KILL ;
  1. K DFN,AMHPAT,AUPNPAT
  1. K AMHOA,AMHBT,AMHTOT
  1. K BPCCTR,BPCGUI,AMHSF,DIC,JOB,X,Y,ZTDESC,ZTDTH,ZTIO,ZTRTN,ZTSAVE
  1. D EN^XBVK("AMH")
  1. Q
  1. L ;get patients last visit
  1. ;AMHV array
  1. I '$D(^AMHREC("AE",DFN)) Q
  1. S D=$O(^AMHREC("AE",DFN,"")),R=$O(^AMHREC("AE",DFN,D,""))
  1. I R S AMHV(D,R)=""
  1. Q
  1. S ;san only
  1. S D=0,V=0
  1. F S D=$O(^AMHREC("AE",DFN,D)) Q:D'=+D S V=0 F S V=$O(^AMHREC("AE",DFN,D,V)) Q:V'=+V I $P(^AMHREC(V,0),U,33)="S" S AMHV(D,V)=""
  1. Q
  1. N ;patients last N visits
  1. S (C,D)=0 F S D=$O(^AMHREC("AE",DFN,D)) Q:D'=+D!(C=BPCNUM) S V=0 F S V=$O(^AMHREC("AE",DFN,D,V)) Q:V'=+V!(C=BPCNUM) S C=C+1,AMHV(D,V)=""
  1. Q
  1. P ;on program
  1. S D=0 F S D=$O(^AMHREC("AE",DFN,D)) Q:D'=+D S V=0 F S V=$O(^AMHREC("AE",DFN,D,V)) Q:V'=+V I $P(^AMHREC(V,0),U,2)=BPCPROG S AMHV(D,V)=""
  1. Q
  1. A ;all visits
  1. S D=0,V=0
  1. F S D=$O(^AMHREC("AE",DFN,D)) Q:D'=+D S V=0 F S V=$O(^AMHREC("AE",DFN,D,V)) Q:V'=+V S AMHV(D,V)=""
  1. Q
  1. D ;date rante
  1. S E=9999999-AMHBD,D=9999999-AMHED-1_".99" F S D=$O(^AMHREC("AE",DFN,D)) Q:D'=+D!($P(D,".")>E) S V=0 F S V=$O(^AMHREC("AE",DFN,D,V)) Q:V'=+V S AMHV(D,V)=""
  1. Q