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

BDMDMAS.m

Go to the documentation of this file.
  1. BDMDMAS ; IHS/CMI/LAB - print hs for dm patients with appts ;
  1. ;;2.0;DIABETES MANAGEMENT SYSTEM;**2,8**;JUN 14, 2007;Build 53
  1. ;
  1. ;
  1. ;this routine will go through the Diabetes Register
  1. ;and then see if the patient has an appt, if so print health sum
  1. ;
  1. ;cmi/anch/maw 3/14/2006 modified BDMG to queue report into GUI holding file
  1. ;
  1. EP ;EP - called from option interactive
  1. D EOJ
  1. W:$D(IOF) @IOF
  1. W !!,"This option will print a health summary for all patients who are on the ",!,"Diabetes Register that have an appointment on the date you specify.",!!
  1. DATE ;get appt date
  1. S BDMDATE=""
  1. S DIR(0)="D^::EF",DIR("A")="Enter the Appointment Date" KILL DA D ^DIR KILL DIR
  1. I $D(DIRUT) W !,"Goodbye" D EOJ Q
  1. S BDMDATE=Y
  1. REGISTER ;get register name
  1. S BDMREG=""
  1. S DIC="^ACM(41.1,",DIC(0)="AEMQ",DIC("A")="Enter the Official Diabetes Register: " D ^DIC
  1. I Y=-1 S BDMREG="" W !,"No Register Selected." G DATE
  1. S BDMREG=+Y
  1. HSTYPE ;get hs type
  1. K DIC S DIC=9001015,DIC("A")="Select health summary type: ",DIC(0)="AEQM"
  1. S X="" I DUZ(2),$D(^APCCCTRL(DUZ(2),0))#2 S X=$P(^(0),U,3)
  1. I $D(^DISV(DUZ,"^APCHSCTL(")) S Y=^("^APCHSCTL(") I $D(^APCHSCTL(Y,0)) S X=$P(^(0),U,1)
  1. S:X="" X="ADULT REGULAR"
  1. S DIC("B")=X
  1. D ^DIC I Y>0 S BDMTYPE=+Y
  1. ZIS ;
  1. S BDMTEMP=""
  1. S DIR(0)="S^P:PRINT the Output;B:BROWSE the Output on the Screen",DIR("A")="Output Type",DIR("B")="P" KILL DA D ^DIR KILL DIR
  1. I $D(DIRUT) D EOJ Q
  1. S BDMTEMP=Y
  1. ;call to XBDBQUE
  1. DEMO ;
  1. D DEMOCHK^BDMUTL(.BDMDEMO)
  1. I BDMDEMO=-1 G HSTYPE
  1. I BDMTEMP="B" D BROWSE,EOJ Q
  1. S XBRP="PRINT^BDMDMAS",XBRC="",XBRX="EOJ^BDMDMAS",XBNS="APCH;BDM"
  1. D ^XBDBQUE
  1. D EOJ
  1. Q
  1. BROWSE ;
  1. S XBRP="VIEWR^XBLM(""PRINT^BDMDMAS"")"
  1. S XBRC="",XBRX="EOJ^BDMDMAS",XBIOP=0 D ^XBDBQUE
  1. Q
  1. EOJ ;
  1. D ^XBFMK
  1. K DIC,DIR
  1. K APCHSTYP,BDMREG,BDMDATE,BDMTYPE
  1. D EN^XBVK("APCH")
  1. Q
  1. ;
  1. PRINT ;EP - called from xbdbque
  1. K ^TMP($J,"BDMDMAS")
  1. S BDMSDAT=$$FMADD^XLFDT(BDMDATE,-1),BDMSDAT=BDMSDAT_".9999"
  1. ;go through register, if patient has appt then print hs
  1. S BDMDMX=0 F S BDMDMX=$O(^ACM(41,"B",BDMREG,BDMDMX)) Q:BDMDMX'=+BDMDMX D
  1. .;check to see if patient has an appt
  1. .S DFN=$P(^ACM(41,BDMDMX,0),U,2)
  1. .Q:$$DEMO^BDMUTL(DFN,$G(BDMDEMO))
  1. .Q:$D(^TMP($J,"BDMDMAS",DFN)) ;already printed one for this pat
  1. .S ^TMP($J,"BDMDMAS",DFN)=""
  1. .S BDMDMY=BDMSDAT F S BDMDMY=$O(^DPT(DFN,"S",BDMDMY)) Q:BDMDMY=""!($P(BDMDMY,".")>BDMDATE) D
  1. ..I $P(^DPT(DFN,"S",BDMDMY,0),U,2)["C" Q ;cancelled
  1. ..S APCHSPAT=DFN,APCHSTYP=BDMTYPE D EN^APCHS
  1. ..Q
  1. .Q
  1. Q
  1. QUEUE ;EP - called from queued option
  1. S BDMREG=$O(^ACM(41.1,"B","IHS DIABETES",0))
  1. I BDMREG="" K BDMREG Q
  1. S BDMTYPE=$O(^APCHSTYP("B","ADULT REGULAR",0))
  1. I BDMTYPE="" K BDMREG,BDMTYPE Q
  1. S BDMDATE=DT
  1. D PRINT
  1. D EOJ
  1. Q
  1. ;
  1. BDMG(BDMREG,BDMDATE,BDMTYPE,BDMGIEN) ;EP - GUI DMS Entry Point
  1. ;cmi/anch/maw added 10/19/2004
  1. S BDMTYPE=$O(^APCHSCTL("B",BDMTYPE,0))
  1. ;create entry in fileman file to hold output
  1. N BDMOPT ;maw
  1. S BDMOPT="Print Health Summary for DM Patients w/Appt"
  1. D NOW^%DTC
  1. S BDMNOW=$G(%)
  1. K DD,D0,DIC
  1. S BDMJOB=$J,BDMBTH=$P($H,",")
  1. S X=DUZ_"."_BDMBTH
  1. S DIC("DR")=".02////"_DUZ_";.03////"_BDMNOW_";.05////"_$G(BDMPREP)_";.06///"_$G(BDMOPT)_";.07///R"
  1. S DIC="^BDMGUI(",DIC(0)="L",DIADD=1,DLAYGO=9003201.4
  1. D FILE^DICN
  1. K DIADD,DLAYGO,DIC,DA
  1. I Y=-1 S BDMIEN=-1 Q
  1. S BDMIEN=+Y
  1. S BDMGIEN=BDMIEN ;cmi/maw added
  1. D ^XBFMK
  1. K ZTSAVE S ZTSAVE("*")=""
  1. ;D GUIEP for interactive testing
  1. S ZTIO="",ZTDTH=$$NOW^XLFDT,ZTRTN="GUIEP^BDMDMAS",ZTDESC="GUI PRINT HS FOR DM" D ^%ZTLOAD
  1. D EOJ
  1. Q
  1. GUIEP ;EP - called from taskman
  1. K ^TMP($J,"BDMDMAS")
  1. S IOM=80 ;cmi/maw added
  1. D GUIR^XBLM("PRINT^BDMDMAS","^TMP($J,""BDMDMAS"",")
  1. S X=0,C=0 F S X=$O(^TMP($J,"BDMDMAS",X)) Q:X'=+X S ^BDMGUI(BDMIEN,11,X,0)=^TMP($J,"BDMDMAS",X),C=C+1
  1. S ^BDMGUI(BDMIEN,11,0)="^^"_C_"^"_C_"^"_DT_"^"
  1. S DA=BDMIEN,DIK="^BDMGUI(" D IX1^DIK
  1. D ENDLOG
  1. S ZTREQ="@"
  1. Q
  1. ;
  1. ENDLOG ;-- write the end of the log
  1. D NOW^%DTC
  1. S BDMNOW=$G(%)
  1. S DIE="^BDMGUI(",DA=BDMIEN,DR=".04////"_BDMNOW_";.07///C"
  1. D ^DIE
  1. K DIE,DR,DA
  1. Q
  1. ;