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

SDMHPRO.m

Go to the documentation of this file.
  1. SDMHPRO ;MAF/ALB - MENTAL HEALTH PROACTIVE HIGH RISK REPORT (BGJ);AUGUST 30, 2011
  1. ;;5.3;Scheduling;**588**;Aug 13,1993;Build 53
  1. ;
  1. EN ;entry point for the automatic generation of the Proactive Report from BGJ
  1. N SDBEG,SDEND,VAUTD,Y,SDUP,SDXFLG,SDDAT,X1,X2,SDTL,X,VAUTCL,SDPAG,SDX,TOTAL,IOM,SDNSDT,%,SDALL
  1. K ^TMP("SDMHP",$J)
  1. S SDXFLG=1 ; This flag is set to 1 when it is from the background Job
  1. D NOW^%DTC S Y=$E(%,1,12) S SDDAT=$$FMTE^XLFDT(Y,"5"),SDBEG=$P(Y,".",1)_".0000",SDEND=$P(Y,".",1)_".2359"
  1. S SDNSDT=$$FMTE^XLFDT(Y,"2")
  1. S VAUTD=1 ;All the divisions in the facility
  1. S SDTL="CLIN",SDALL="M" ; sort by clinc and only mental health clinics for the BGJ
  1. S IOM=80
  1. N SDLN
  1. S X="",SDLN=0
  1. D START^SDMHAP
  1. B N XMSUB,XMY,XMTEXT,XMDUZ,SDGRP
  1. S SDGRP=$O(^XMB(3.8,"B","SD MH NO SHOW NOTIFICATION",""))
  1. Q:'SDGRP
  1. D XMY^SDUTL2(SDGRP,0,0)
  1. S XMSUB="HRMH PROACTIVE NIGHTLY REPORT"_" MESSAGE # "
  1. S XMTEXT="^TMP(""SDMHP"",$J,"
  1. S XMDUZ="POSTMASTER"
  1. D ^XMD
  1. K ^TMP("SDMHP",$J)
  1. Q
  1. SET(X) ; SET UP THE STRING
  1. S SDLN=SDLN+1,^TMP("SDMHP",$J,SDLN,0)=X
  1. Q
  1. ;
  1. N SDX
  1. S SDX="",X=""
  1. S SDPAG=SDPAG+1,SDX=$$SETSTR^SDMHPRO1("HIGH RISK MENTAL HEALTH PROACTIVE NIGHTLY REPORT",X,1,48)_$$SETSTR^SDMHPRO1(" PAGE ",X,20,6)_$$SETSTR^SDMHPRO1(SDPAG,X,4,4) D SET1^SDMHPRO1(SDX)
  1. S SDX=$$SETSTR^SDMHPRO1("By "_$S(SDTL="MEN":"MENTAL HEALTH QUICK LIST",SDTL="STOP":"STOPCODE",1:"Patient")_" for Appointments on "_$P(SDNSDT,"@",1),X,1,50)_$$SETSTR^SDMHPRO1("Run: "_SDDAT,X,9,30) D SET1^SDMHPRO1(SDX)
  1. S SDX=$$SETSTR^SDMHPRO1("#",X,1,1)_$$SETSTR^SDMHPRO1("PATIENT",X,4,8)_$$SETSTR^SDMHPRO1("PT ID",X,14,5)_$$SETSTR^SDMHPRO1("APPT D/T",X,2,16)_$$SETSTR^SDMHPRO1("CLINIC",X,2,15) D SET1^SDMHPRO1(SDX)
  1. S SDX=$$SETSTR^SDMHPRO1($$LINE^SDMHAP(""),X,1,80) D SET1^SDMHPRO1(SDX)
  1. HEAD1 I $D(^TMP(NAMSPC1,$J)),$D(SDXDIV) S SDX=$$SETSTR^SDMHPRO1("DIVISION: "_$E(SDXDIV,1,24),X,1,80) D SET1^SDMHPRO1(SDX)
  1. I '$D(^TMP(NAMSPC1,$J)),'$D(SDXDIV) S SDX=$$SETSTR^SDMHPRO1($$LINE1^SDMHAP(">>>>>>>>>>>>> NO RECORDS <<<<<<<<<<<<<"),X,1,80) D SET1^SDMHPRO1(SDX)
  1. Q
  1. ;
  1. TOTAL ;Prints totals for the clinics by division - FOR BGJ
  1. Q:'$D(TOTAL)
  1. N SDVISN,SDCLNIC,SDFLAG,SDX,X
  1. S (SDVISN)=0
  1. S X="",SDX=""
  1. S SDX=$$SETSTR^SDMHPRO1("Division Totals",X,1,80) D SET1^SDMHPRO1(SDX)
  1. S X="",SDX=""
  1. S SDX=$$SETSTR^SDMHPRO1("Division",X,1,26)_$$SETSTR^SDMHPRO1("Unique",X,29,6) D SET1^SDMHPRO1(SDX)
  1. S X="",SDX="" S SDX=$$SETSTR^SDMHPRO1("Patients",X,54,24) D SET1^SDMHPRO1(SDX)
  1. F S SDVISN=$O(TOTAL(SDVISN)) Q:SDVISN']"" D
  1. . N SDX,X
  1. .I $D(TOTAL(SDVISN)) D
  1. ..S SDX="",X=""
  1. ..N SDTOTS
  1. ..S SDTOTS=$J($P(TOTAL(SDVISN),"^",5),3)
  1. ..S SDX=$$SETSTR^SDMHPRO1($E(SDVISN,1,24),X,1,54)_$$SETSTR^SDMHPRO1(SDTOTS,X,1,24) D SET1^SDMHPRO1(SDX)
  1. S X="",SDX="" S SDX=$$SETSTR^SDMHPRO1(" ",X,1,80) D SET1^SDMHPRO1(SDX)
  1. S X="",SDX=""
  1. Q
  1. TOTAL1 ;TOTALS FOR AD HOC
  1. Q:'$D(TOTAL)
  1. N SDVISN,SDCLNIC,SDFLAG,SDX,X
  1. S (SDVISN,SDCLNIC)=0
  1. W ?25,"Division/Clinic Appointment Totals",!!
  1. W "Division/CLinic",?50,"Unique",!
  1. W ?49,"Patients",!!
  1. F S SDVISN=$O(TOTAL(SDVISN)) Q:SDVISN']"" D
  1. .I $D(TOTAL(SDVISN)) D
  1. ..N SDTOTS
  1. ..S SDTOTS=$J($P(TOTAL(SDVISN),"^",5),3)
  1. ..W $E(SDVISN,1,30),?50,SDTOTS,! D RET^SDMHAP1 Q:SDUP
  1. W ! D RET^SDMHAP1 Q:SDUP
  1. Q
  1. COUNT ; COUNTER
  1. S SDCOUNT=SDCOUNT+1