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

FHOMRBL1.m

Go to the documentation of this file.
  1. FHOMRBL1 ;Hines OIFO/RVD-OUTPATIENT REPORT UTILITY2 ;2/03/04 10:05
  1. ;;5.5;DIETETICS;**5**;Jan 28, 2005;Build 53
  1. ;
  1. ;PATCH #5 - added the cancelled guest meal status and a screen for cancelled meals.
  1. ;
  1. GETGM(FHGDT,FHGCOM,FHGLOC,FHGDFN) ;get guest meals data
  1. ;ENTRY POINTS:
  1. ; GETGM - get outpatient guest meals data from starting dt.
  1. ;input variable:
  1. ; FHGDT = starting date
  1. ; FHGCOM = IEN of communication office, 'ALL' for all.
  1. ; = if NULL, considered 'ALL'
  1. ; FHGLOC = IEN of location, 'ALL' for all.
  1. ; = if NULL, considered 'ALL'
  1. ; FHGDFN = IEN of file #115, 'ALL' for all.
  1. ; = if NULL, considered 'ALL'
  1. ;
  1. ;output variable:
  1. ; ^TMP($J,"OP","G",COMM OFF,PATIENT NAME,DTE)
  1. ;
  1. ;error:
  1. ; ^TMP($J,"OP","ER")
  1. K ^TMP($J,"OP","G")
  1. D NEWVAR
  1. S:FHGDFN="" FHGDFN="ALL"
  1. S:FHGCOM="" FHGCOM="ALL"
  1. S:FHGLOC="" FHGLOC="ALL"
  1. S FHGDT=FHGDT-.000001
  1. I '$O(^FHPT("GM",FHGDT)) S ^TMP($J,"OP","ER")="NO GUEST MEALS FOR THIS DATE RANGE" Q
  1. ;
  1. F FHGMDT=FHGDT:0 S FHGMDT=$O(^FHPT("GM",FHGMDT)) Q:FHGMDT'>0 D
  1. .F FHDFN=0:0 S FHDFN=$O(^FHPT("GM",FHGMDT,FHDFN)) Q:FHDFN'>0 D
  1. ..I $G(FHGDFN),(FHGDFN'=FHDFN) Q
  1. ..S (FHGCOMN,FHPTNM,FHLOCN)=""
  1. ..S FHNODE=$G(^FHPT(FHDFN,"GM",FHGMDT,0))
  1. ..S FHCL=$P(FHNODE,U,2)
  1. ..S FHML=$P(FHNODE,U,3)
  1. ..S FHCH=$P(FHNODE,U,4)
  1. ..S FHLPT=$P(FHNODE,U,5)
  1. ..S FHDIET=$P(FHNODE,U,6)
  1. ..S FHSTAT=$P(FHNODE,U,9)
  1. ..I $G(FHGLOC),FHGLOC'=FHLPT Q ;quit if location is not the same
  1. ..S:$G(FHLPT) FHLCOM=$P($G(^FH(119.6,FHLPT,0)),U,8)
  1. ..I $G(FHGCOM),FHGCOM'=FHLCOM Q ;quit if d same communication office
  1. ..S:$G(FHLCOM) FHGCOMN=$P($G(^FH(119.73,FHLCOM,0)),U,1)
  1. ..S:FHGCOMN="" FHGCOMN="***"
  1. ..I $G(FHLPT) D
  1. ...S FHLOCN=$P($G(^FH(119.6,FHLPT,0)),U,1)
  1. ..S:FHLOCN="" FHLOCN="***"
  1. ..;
  1. ..S FHCL=$S(FHCL="E":"EMPLOYEE",FHCL="G":"GRATUITOUS",FHCL="O":"OOD",FHCL="P":"PAID",1:"VOLUNTEER")
  1. ..S FHD=$$FMTE^XLFDT(FHGMDT,"P")
  1. ..S FHD=$E(FHD,1,12)
  1. ..D PATNAME^FHOMUTL S FHPTNM=$E(FHPTNM,1,24)
  1. ..S:FHPTNM="" FHPTNM="***"
  1. ..S ^TMP($J,"OP","G",FHGCOMN,FHLOCN,FHPTNM,FHGMDT)=FHDFN_"^"_FHD_"^"_FHML_"^"_FHCL_"^"_FHCH_"^"_FHDIET_"^"_FHSTAT
  1. Q
  1. ;
  1. NEWVAR ;new all variables.
  1. N FHPTNM,FHD,FHDIET,FHMEAL,FHELTT,FHELBG,FHDAT,FHSTAT,FHLPT
  1. N FHAGE,FHCH,FHCL,FHDOB,FHGMDT,FHML,FHNODE,FHPCZN,FHSEX,FHSSN,FILE
  1. N FHDAT,FHDPT,FHEL,FHLPT,FHS,FHSMDT,FHSTAT,FHNN,FH
  1. Q
  1. ;
  1. GETOUT ;get outpatient data for TODAY.
  1. ;output variables:
  1. ; ^TMP($J,"FH",##LOCATION,PATIENT NAME,DATE)=OP or SM or GM^IEN OF 115^MEAL^
  1. ;
  1. K ^TMP($J)
  1. N FHMEAL,FHDT,DT3,FHI,I,J,FHRMD,FHRMLNM,FHSMD,FHSMSTA,DFN,FHDFN
  1. N DTTST,FHSMLNM,FHGMLNM
  1. ;recurring meals
  1. S FHDT=DT-.00001,DT3=DT+.999999
  1. F FHI=FHDT:0 S FHI=$O(^FHPT("RM",FHI)) Q:(FHI>DT3)!(FHI="") F I=0:0 S I=$O(^FHPT("RM",FHI,I)) Q:I'>0 D
  1. .F J=0:0 S J=$O(^FHPT("RM",FHI,I,J)) Q:J'>0 D
  1. ..S (FHRMD,FHMEAL)=""
  1. ..S FHRMLNM="***"
  1. ..I $D(^FHPT(I,"OP",J,0)) S FHRMD=$G(^FHPT(I,"OP",J,0))
  1. ..Q:$P(FHRMD,U,15)="C"
  1. ..I $D(FHRMD) S FHMEAL=$P(FHRMD,U,2)
  1. ..S FHDFN=I D PATNAME^FHOMUTL Q:DFN=""
  1. ..S:FHMEAL="" FHMEAL=$P(FHRMD,U,7)
  1. ..S:FHMEAL="" FHMEAL=$P(FHRMD,U,8)
  1. ..S:FHMEAL="" FHMEAL=$P(FHRMD,U,9)
  1. ..S:FHMEAL="" FHMEAL=$P(FHRMD,U,10)
  1. ..S:FHMEAL="" FHMEAL=$P(FHRMD,U,11)
  1. ..S FHRMLOC=$P(FHRMD,U,3) Q:FHRMLOC=""
  1. ..S FHML=$P(FHRMD,U,4)
  1. ..I $G(FHRMLOC),$D(^FH(119.6,FHRMLOC,0)) D
  1. ...S FHRMLNM=$P(^FH(119.6,FHRMLOC,0),U,1)
  1. ...S FHRMPR=$P(^FH(119.6,FHRMLOC,0),U,4)
  1. ...S FHRMSTA=$P(^FH(119.6,FHRMLOC,0),U,8)
  1. ...S:FHRMPR<10 FHRMPR=0_FHRMPR
  1. ...S:FHRMPR="" FHRMPR=99
  1. ..S ^TMP($J,"FH",FHRMPR_FHRMLNM,FHPTNM,FHI,J)="OP"_"^"_I_"^"_FHMEAL_"^"_FHRMSTA_"^"_FHML_"^"_FHRMLOC_"^"_J
  1. SM ;special meals
  1. S FHDT=DT-.00001,DTTST=$P(DT,".",1),DT3=DTTST+1
  1. F FHI=FHDT:0 S FHI=$O(^FHPT("SM",FHI)) Q:(FHI>DT3)!(FHI="") F I=0:0 S I=$O(^FHPT("SM",FHI,I)) Q:I'>0 D
  1. .F J=0:0 S J=$O(^FHPT("SM",FHI,I,J)) Q:J'>0 D
  1. ..S (FHSMD,FHMEAL)=""
  1. ..S FHSMSTA=""
  1. ..I $D(^FHPT(I,"SM",J,0)) S FHSMD=$G(^FHPT(I,"SM",J,0))
  1. ..Q:$P(FHSMD,U,2)'="A"
  1. ..I $D(FHSMD) S FHMEAL=$P(FHSMD,U,4)
  1. ..S FHDFN=I D PATNAME^FHOMUTL Q:DFN=""
  1. ..S FHSMLOC=$P(FHSMD,U,3) Q:FHSMLOC=""
  1. ..S FHSMSTA=$P(FHSMD,U,2)
  1. ..S FHML=$P(FHSMD,U,9)
  1. ..I $G(FHSMLOC),$D(^FH(119.6,FHSMLOC,0)) D
  1. ...S FHSMLNM=$P(^FH(119.6,FHSMLOC,0),U,1)
  1. ...S FHSMPR=$P(^FH(119.6,FHSMLOC,0),U,4)
  1. ...S FHSMSTA=$P(^FH(119.6,FHSMLOC,0),U,8)
  1. ...S:FHSMPR<10 FHSMPR=0_FHSMPR
  1. ...S:FHSMPR="" FHSMPR=99
  1. ..S ^TMP($J,"FH",FHSMPR_FHSMLNM,FHPTNM,J)="SM"_"^"_I_"^"_FHMEAL_"^"_FHSMSTA_"^"_FHML_"^"_FHSMLOC_"^"_J
  1. ;guest meals
  1. S FHDT=DT-.00001,DTTST=$P(DT,".",1),DT3=DTTST+1
  1. F FHI=FHDT:0 S FHI=$O(^FHPT("GM",FHI)) Q:(FHI>DT3)!(FHI="") F I=0:0 S I=$O(^FHPT("GM",FHI,I)) Q:I'>0 D
  1. .F J=0:0 S J=$O(^FHPT("GM",FHI,I,J)) Q:J'>0 D
  1. ..S (FHSMD,FHMEAL)=""
  1. ..S FHSMSTA=""
  1. ..S FHSMLNM="***"
  1. ..I $D(^FHPT(I,"GM",J,0)) S FHSMD=$G(^FHPT(I,"GM",J,0))
  1. ..Q:$P(FHSMD,U,9)="C"
  1. ..I $D(FHSMD) S FHMEAL=$P(FHSMD,U,6)
  1. ..S FHDFN=I D PATNAME^FHOMUTL Q:DFN=""
  1. ..S FHSMLOC=$P(FHSMD,U,5) Q:FHSMLOC=""
  1. ..S FHML=$P(FHSMD,U,3)
  1. ..I $G(FHSMLOC),$D(^FH(119.6,FHSMLOC,0)) D
  1. ...S FHSMLNM=$P(^FH(119.6,FHSMLOC,0),U,1)
  1. ...S FHSMSTA=$P(^FH(119.6,FHSMLOC,0),U,8)
  1. ...S FHSMPR=$P(^FH(119.6,FHSMLOC,0),U,4)
  1. ...S:FHSMPR<10 FHSMPR=0_FHSMPR
  1. ...S:FHSMPR="" FHSMPR=99
  1. ..S ^TMP($J,"FH",FHSMPR_FHSMLNM,FHPTNM,J)="GM"_"^"_I_"^"_FHMEAL_"^"_FHSMSTA_"^"_FHML_"^"_FHSMLOC_"^"_J
  1. Q