FHCTF5 ; HIOFO/REL/FAI - Check Inpatients for Monitors ;08/29/06 14:43 ;;5.5;Dietetics;**4,8**;Jan 28, 2005;Build 28 ;3/14/07 - patch 8 adds the nutrition assessment alert. D NOW^%DTC S NOW=% D CLR S FHEDT=$P(NOW,".") F WRD=0:0 S WRD=$O(^FH(119.6,WRD)) Q:WRD<1 S FHDUZ=$P($G(^(WRD,0)),"^",2) F FHDFN=0:0 S FHDFN=$O(^FHPT("AW",WRD,FHDFN)) Q:FHDFN'>0 S ADM=$G(^FHPT("AW",WRD,FHDFN)) D PAT D P5 K %,A1,A2,ADM,BMI,CLR,DA,DD,DFN,DIC,DTE,FHDUZ,FHOR,FHORD,FHTF K GMRVSTR,HT,L,LST,MONIFN,MONTX,N,NOW,PX,STOP,TF,WRD,WT,X,X0,Y K I,FHTMO,FHTFLG,FHEDT,FHTICK,FHTDFN,FHTDT1,FHWTDT,FHHTDT,WARD,FHGMDT K A,A0,AGE,BID,DEAD,FDA,FHAGE,FHBID,FHCLIN,FHDFN,FHI,FHI115,FHJ,FHJDAT,FHDFN K FHPTNM,FHPCZN,FHSEX,FHSSN,FHHDAT,FILE,HTM,IEN,IEN200,NAM,PID,SEX Q PAT ;; Check a patient D PATNAME^FHOMUTL I DFN="" Q S Y=^DPT(DFN,0),NAM=$P(Y,"^",1),SEX=$P(Y,"^",2),DOB=$P(Y,"^",3) S AGE="" I DOB'="" S AGE=$E(NOW,1,3)-$E(DOB,1,3)-($E(NOW,4,7)<$E(DOB,4,7)) S DEAD=$P($G(^DPT(DFN,.35)),"^",1) Q:DEAD'="" D ALRT^FHASM2A ;creates alert for nutrition assessment(follow-up dt & food/drug interaction. ; P0 ; Calculate BMI S GMRVSTR="WT" D EN6^GMRVUTL S WT=$P(X,"^",8),FHWTDT=$P(X,"^",1) S GMRVSTR="HT" D EN6^GMRVUTL S HT=$P(X,"^",8),FHHTDT=$P(X,"^",1) S FHGMDT=$S(FHWTDT>FHHTDT:FHWTDT,FHHTDT>FHWTDT:FHHTDT,1:FHWTDT) S BMI="" I WT,HT S A2=HT*.0254,BMI=+$J(WT/2.2/(A2*A2),0,1) I $G(BMI)=""!($G(BMI)'<18.5) G P1 S MONTX="Monitor: BMI < 18.5",DTE=NOW S N=$O(^FHPT(FHDFN,"A",ADM,"MO","B",MONTX,""),-1) I 'N,(FHGMDT>(FHEDT-7)) D FIL G P1 I 'N G P1 ; Check if been 30 days S LST=$P($G(^FHPT(FHDFN,"A",ADM,"MO",N,0)),"^",2) S X=$$FMDIFF^XLFDT(DTE,LST) I (X>30) D FIL P1 ; Check for current Tubefeeding S TF=$P($G(^FHPT(FHDFN,"A",ADM,0)),"^",4) I 'TF G P2 S MONTX="Monitor: On Tubefeeding",DTE=NOW S N=$O(^FHPT(FHDFN,"A",ADM,"MO","B",MONTX,""),-1) I 'N D FIL G P2 ; Check if been 7 days S LST=$P($G(^FHPT(FHDFN,"A",ADM,"MO",N,0)),"^",2) S X=$$FMDIFF^XLFDT(DTE,LST) I X>7 D FIL P2 ; Check for Hyperals S MONTX="",DTE=NOW D PSS435^PSS55(DFN,,"FHIV") F DA=0:0 S DA=$O(^TMP($J,"FHIV",DA)) Q:DA<1 D .S (X0,HTM)=$P($G(^TMP($J,"FHIV",DA,.02)),"^",2) I X0>NOW Q .S MONTX="Monitor: On Hyperals" D FIL Q ; P3 ; Check for Serum Albumin S MONTX="",PX=6 D LAB^FHASM4 I $D(^TMP($J,"LRTST")) D .F L=0:0 S L=$O(^TMP($J,"LRTST",L)) Q:L<1 S Y=$TR($P(^(L),"^",6)," ","") I Y'?1A.E,Y<2.8 S MONTX="Monitor: Albumin < 2.8",DTE=$P(^(L),"^",7) I MONTX="" G P4 S N=$O(^FHPT(FHDFN,"A",ADM,"MO","B",MONTX,""),-1) ;process new Albumin if old test date is within 7 days. I 'N S X=$$FMDIFF^XLFDT(NOW,DTE) I X<8 D FIL G P4 I 'N G P4 ; Check if same test S LST=$P($G(^FHPT(FHDFN,"A",ADM,"MO",N,0)),"^",2) I DTE>LST D FIL ; P4 ; Check for NPO+Clr Liq > 3 days S A1=NOW,DTE=NOW F D Q:'A1 .S A1=$O(^FHPT(FHDFN,"A",ADM,"AC",A1),-1) Q:'A1 .S FHORD=$P($G(^FHPT(FHDFN,"A",ADM,"AC",A1,0)),"^",2) I 'FHORD S A1="" Q .S FHOR=$G(^FHPT(FHDFN,"A",ADM,"DI",FHORD,0)) .I $P(FHOR,"^",7)="N" S DTE=A1 Q .I $P(FHOR,"^",2)=CLR S DTE=A1 Q .S A1="" Q I DTE'3 D FIL Q P5 ;clear personalized tickler and quit F FHI=0:0 S FHI=$O(^FH(119,FHI)) Q:FHI'>0 F FHJ=0:0 S FHJ=$O(^FH(119,FHI,"I",FHJ)) Q:FHJ'>0 D .S FHJDAT=$G(^FH(119,FHI,"I",FHJ,0)) .Q:$P(FHJDAT,U,2)'="X" .I $P(FHJDAT,U,1)0 S TK=$P($G(^FH(119.6,WRD,2,A,0)),U,1),XQA(TK)="" I '$D(XQA(FHDUZ)) S XQA(FHDUZ)="" D SETUP^XQALERT ; TFIL ; Q:$G(MONTX)="" S FHTFLG=0 F I=0:0 S I=$O(^FH(119,FHDUZ,"I",I)) Q:I'>0 D .S FHTDT1=$P(I,".",1) .S FHTICK=^FH(119,FHDUZ,"I",I,0),FHTMO=$P(FHTICK,"^",3),FHTDFN=$P(FHTICK,"^",4) .I (FHTMO=MONTX),(FHTDFN=DFN),(FHTDT1=FHEDT) S FHTFLG=1 Q:FHTFLG ;only one monitor for the same day, same clinician and same pt. L +^FHPT(FHDFN,"A",ADM,"MO",0) I '$D(^FHPT(FHDFN,"A",ADM,"MO",0)) S ^FHPT(FHDFN,"A",ADM,"MO",0)="^115.11^^" L -^FHPT(FHDFN,"A",ADM,"MO",0) K DIC,DD,DO,DINUM S DIC="^FHPT(FHDFN,""A"",ADM,""MO"",",DIC(0)="L",DA(1)=ADM,DA(2)=FHDFN,DLAYGO=115,X=MONTX D FILE^DICN K DIC,DLAYGO Q:Y<1 S MONIFN=+Y S $P(^FHPT(FHDFN,"A",ADM,"MO",MONIFN,0),"^",2)=DTE,^FHPT(FHDFN,"A",ADM,"MO","AC",DTE,MONIFN)="" CRT ;create tickler S FHTF=DTE_"^M^"_MONTX_"^"_DFN_"^"_ADM_"^"_MONIFN D:FHDUZ FILE^FHCTF2 Q