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

FHORD81.m

Go to the documentation of this file.
  1. FHORD81 ; HISC/REL/NCA - Diet Order Lists (cont) ;11/30/00 13:55
  1. ;;5.5;DIETETICS;**1,5,17**;Jan 28, 2005;Build 9
  1. ;patch 5 - added outpatiet SOs & SFs and outpt room-bed.
  1. K C,^TMP("FH",$J) F L=0:0 S L=$O(^FH(118,L)) Q:L<1 I '$D(^FH(118,L,"I")) S C(L)=$P(^(0),"^",1)
  1. D NOW^%DTC S NOW=%,DT=NOW\1,X1=DT,X2=-14 D C^%DTC S OLN=+X S X1=NOW,X2=-3 D C^%DTC S OLD=+X
  1. S X1=DT,X2=2 D C^%DTC S K3=+X
  1. F W1=0:0 S W1=$O(^FH(119.6,W1)) Q:W1<1 S X=^(W1,0) D F0
  1. S (PG,REC)=0,NXW="" F S NXW=$O(^TMP("FH",$J,NXW)) Q:NXW="" F W1=0:0 S W1=$O(^TMP("FH",$J,NXW,W1)) Q:W1<1 D F2
  1. ;
  1. OUTP ;Outpatient data
  1. D GETOUT^FHOMRBL1
  1. S (ADM,DTP,FHPTSA,RM,FHLSAV,FHI)=""
  1. I SRT="R" D RMS ;sort by room-bed
  1. F S FHI=$O(^TMP($J,"FH",FHI)) Q:FHI="" D
  1. .S FHJ="" F S FHJ=$O(^TMP($J,"FH",FHI,FHJ)) Q:FHJ="" D
  1. ..S FHPTSA=FHJ
  1. ..F FHK=0:0 S FHK=$O(^TMP($J,"FH",FHI,FHJ,FHK)) Q:FHK'>0 D
  1. ...S FHDAT=""
  1. ...S FHL=$O(^TMP($J,"FH",FHI,FHJ,FHK,0))
  1. ...I $G(FHL) D REC Q
  1. ...D PROC
  1. W ! Q
  1. ;
  1. RMS ;SORT BY ROOM-BED
  1. M ^TMP($J,"FHR")=^TMP($J,"FH") K ^TMP($J,"FH")
  1. F S FHI=$O(^TMP($J,"FHR",FHI)) Q:FHI="" D
  1. .S FHJ="" F S FHJ=$O(^TMP($J,"FHR",FHI,FHJ)) Q:FHJ="" D
  1. ..S FHPTSA=FHJ
  1. ..F FHK=0:0 S FHK=$O(^TMP($J,"FHR",FHI,FHJ,FHK)) Q:FHK'>0 D
  1. ...S FHDAT=""
  1. ...S FHL=$O(^TMP($J,"FHR",FHI,FHJ,FHK,0))
  1. ...I $G(FHL) D RM1 Q
  1. ...D RM2
  1. K ^TMP($J,"FHR")
  1. Q
  1. RM1 F FHL=0:0 S FHL=$O(^TMP($J,"FHR",FHI,FHJ,FHK,FHL)) Q:FHL'>0 D
  1. .S FHDAT=^TMP($J,"FHR",FHI,FHJ,FHK,FHL)
  1. .S FHDFN=$P(FHDAT,U,2)
  1. .S RM=""
  1. .I $G(FHDFN),$D(^FHPT(FHDFN,"OP",FHL,0)) S RM=$P(^(0),U,18)
  1. .I $G(RM),$D(^DG(405.4,RM,0)) S RM=$P(^(0),U,1)
  1. .S:RM'="" RM=$E(RM,1,12)
  1. .S:RM="" RM=" "
  1. .S ^TMP($J,"FH",FHI,RM,FHK,FHL)=FHDAT
  1. Q
  1. RM2 S FHDAT=^TMP($J,"FHR",FHI,FHJ,FHK)
  1. S FHDFN=$P(FHDAT,U,2)
  1. S FHTYP=$P(FHDAT,U,1)
  1. S RM=""
  1. I $G(FHDFN),FHTYP="GM",$D(^FHPT(FHDFN,"GM",FHK,0)) S RM=$P(^(0),U,11)
  1. I $G(FHDFN),FHTYP="SM",$D(^FHPT(FHDFN,"SM",FHK,0)) S RM=$P(^(0),U,13)
  1. I $G(RM),$D(^DG(405.4,RM,0)) S RM=$P(^(0),U,1)
  1. S:RM'="" RM=$E(RM,1,12)
  1. S:RM="" RM=" "
  1. S ^TMP($J,"FH",FHI,RM,FHK)=FHDAT
  1. Q
  1. ;
  1. PROC ;process/print
  1. S FHPLD=0
  1. S:FHDAT="" FHDAT=^TMP($J,"FH",FHI,FHJ,FHK)
  1. S FHCAT=$P(FHDAT,U,1)
  1. S FHDFN=$P(FHDAT,U,2)
  1. S FHDIE=$P(FHDAT,U,3)
  1. S FHSTA=$P(FHDAT,U,4)
  1. S FHMEAL=$P(FHDAT,U,5)
  1. S FHLOC=$P(FHDAT,U,6)
  1. S FHDAIN=$P(FHDAT,U,7)
  1. S (FHSERT,FHSERC,FHSERD,FHSER)=""
  1. I $G(FHLOC),$D(^FH(119.6,FHLOC,0)) D
  1. .S:$P(^FH(119.6,FHLOC,0),U,5) FHSERT="T"
  1. .S:$P(^FH(119.6,FHLOC,0),U,6) FHSERC="C"
  1. .S:$P(^FH(119.6,FHLOC,0),U,7) FHSERD="D"
  1. .S FHSER=FHSERT_FHSERC_FHSERD
  1. I (FHXX="C"),(WRD>0),(WRD'=FHSTA) Q
  1. I (FHXX="L"),(WRD>0),(WRD'=FHLOC) Q
  1. I (SER'="A"),(FHSER'[SER) Q
  1. I FHI'=FHLSAV S FHLSAV=FHI,WRDN=$E(FHI,3,$L(FHI)) D HDR
  1. S FHDIET=""
  1. D PATNAME^FHOMUTL
  1. S RM=""
  1. I FHCAT="OP",$D(^FHPT(FHDFN,"OP",FHDAIN,0)) S RM=$P(^(0),U,18)
  1. I FHCAT="GM",$D(^FHPT(FHDFN,"GM",FHDAIN,0)) S RM=$P(^(0),U,11)
  1. I FHCAT="SM",$D(^FHPT(FHDFN,"SM",FHDAIN,0)) S RM=$P(^(0),U,13)
  1. I $G(RM),$D(^DG(405.4,RM,0)) S RM=$P(^DG(405.4,RM,0),U,1)
  1. I FHLSAV'=FHI S FHLSAV=FHI D HDR
  1. W !!,$E(RM,1,12),?13,$E(FHPTNM,1,24),?38,FHBID,?67,FHSER
  1. I $Y>(IOSL-6) D HDR
  1. I $D(^FH(111,FHDIE,0)) S FHDIET=$P(^FH(111,FHDIE,0),U,7)
  1. S FHTYP=$S(FHCAT="OP":"Recurring",FHCAT="GM":"Guest",FHCAT="SM":"Special",1:"")
  1. S DTP=FHK D DTP^FH
  1. W !,?14,"Diet Order: ",FHDIET,?40,"Meal: ","(",FHMEAL,")"
  1. W !,?14,"Service Type: ",FHTYP,?40,"Date: ",DTP
  1. ;S FHDAIN=$O(^FHPT(FHDFN,""_FHCAT_"","B",FHK,0))
  1. I $G(FHDAIN),$D(^FHPT(FHDFN,""_FHCAT_"",FHDAIN,"TF")) D OUTF
  1. I $G(FHDAIN),FHCAT="OP",$D(^FHPT(FHDFN,"OP",FHDAIN,"SP")) D OSO
  1. I $G(FHDAIN),FHCAT="OP",$D(^FHPT(FHDFN,"OP",FHDAIN,"SF")) D OSF
  1. S FHPLD=1
  1. D:'$G(FHL) ^FHORD83
  1. Q
  1. ;
  1. OSO ;process outpt SOs.
  1. ;
  1. K N F K=0:0 S K=$O(^FHPT(FHDFN,"OP",FHDAIN,"SP",K)) Q:K'>0 S X=^(K,0) Q:$P(X,"^",6) D
  1. .S M=$P(X,"^",3),N(M,K)=$P(X,"^",2,4),$P(N(M,K),"^",4,5)=$P(X,"^",8,9)
  1. F M="B","N","E" F K=0:0 S K=$O(N(M,K)) Q:K<1 S Z=+N(M,K) I Z D
  1. .I ($Y>(IOSL-6)) D HDR,FLNE^FHORD82
  1. .S M2=$S(M="B":"Break",M="N":"Noon",1:"Even") S QTY=$P(N(M,K),"^",4)
  1. .W !?13,"Stng. Order: ",M2,?38,$S(QTY:QTY,1:1)," ",$P($G(^FH(118.3,Z,0)),"^",1),$S($P(N(M,K),"^",5)'="Y":" (I)",1:"")
  1. .S X=$P(N(M,K),"^",3) D DT W ?72,X Q
  1. Q
  1. ;
  1. OSF ;process outpt SFs.
  1. S NM=$P($G(^FHPT(FHDFN,"OP",FHDAIN,"SF",0)),U,3) Q:'$G(NM)
  1. K L,N,M,M1,M2 Q:'NM S Y=^FHPT(FHDFN,"OP",FHDAIN,"SF",NM,0) Q:$P(Y,"^",32)
  1. S L=4 F K1=1:1:3 S K=0,N(K1)="" F K2=1:1:4 S Z=$P(Y,U,L+1),Q=$P(Y,U,L+2),L=L+2 I Z'="" S:'Q Q=1 S:N(K1)'="" N(K1)=N(K1)_"; " S N(K1)=N(K1)_Q_" "_$S($D(C(Z)):C(Z),$D(^FH(118,+Z,0)):$P(^(0),"^",1),1:" ")
  1. S LST=$P(Y,"^",30)\1,X=LST,P1=0 D DT S:LST<OLN X=X_"*"
  1. F K1=1:1:3 I N(K1)'="" W !?13,$P("10AM; 2PM; 8PM",";",K1),?19,$E(N(K1),1,52) I 'P1 S P1=1 W ?72,X
  1. Q
  1. ;
  1. REC ;set/get recurring data
  1. F FHL=0:0 S FHL=$O(^TMP($J,"FH",FHI,FHJ,FHK,FHL)) Q:FHL'>0 D
  1. .S FHDAT=^TMP($J,"FH",FHI,FHJ,FHK,FHL)
  1. .D PROC
  1. D:$G(FHPLD) ^FHORD83
  1. Q
  1. ;
  1. OUTF ;outpatient TF
  1. S REC=1
  1. S (FHTFPR,FHTFQU,FHTFST,FHTFCOM,FHTFTC,FHTFKD,FHTFCN)=""
  1. I $G(FHDAIN),$D(^FHPT(FHDFN,"OP",FHDAIN,3)) D
  1. .S FHRDAT3=$G(^FHPT(FHDFN,"OP",FHDAIN,3))
  1. .S FHTFCOM=$P(FHRDAT3,U,1)
  1. .S FHTFTC=$P(FHRDAT3,U,2)
  1. .S FHTFTKD=$P(FHRDAT3,U,3)
  1. .S FHTFCN=$P(FHRDAT3,U,5)
  1. .S:FHTFCN="C" FHTFCN="Cancelled"
  1. F FHTFDA=0:0 S FHTFDA=$O(^FHPT(FHDFN,"OP",FHDAIN,"TF",FHTFDA)) Q:FHTFDA'>0 D
  1. .S FHTFDAT=$G(^FHPT(FHDFN,"OP",FHDAIN,"TF",FHTFDA,0))
  1. .S FHTFPR=$P(FHTFDAT,U,1)
  1. .I $G(FHTFPR),$D(^FH(118.2,FHTFPR,0)) S FHTFPR=$P(^FH(118.2,FHTFPR,0),U,1)
  1. .S FHTFST=$P(FHTFDAT,U,2)
  1. .S:$G(FHTFST) FHTFST=$S(FHTFST=1:"1/4",FHTFST=2:"1/2",FHTFST=3:"3/4",FHTFST=4:"FULL",1:"")
  1. .S FHTFQU=$P(FHTFDAT,U,3)
  1. .S FHTFCC=$P(FHTFDAT,U,4)
  1. .;I FHAOT'="" S ZZ=" Additional Order: "_FHAOT_" "_FHAOCN_" By: "_FHAOC D LNE^FHORD82
  1. .;I FHELTT'="" S ZZ=" Early/Late Tray Time: "_FHELTT_" Bag Meal: "_FHELTBM D LNE^FHOR82
  1. .I $Y>(IOSL-6) D LNE^FHORD82
  1. .W !,?5,"Tubefeed.:"
  1. .S ZZ=FHTFCOM_" TF Total MLs: "_FHTFTC_" TF Total KCALS/Day: "_FHTFTKD_" "_FHTFCN W ZZ
  1. .I FHTFPR'="" D
  1. ..I $Y>(IOSL-6) D LNE^FHORD82
  1. ..W !,?5
  1. ..S ZZ="TF Product: "_FHTFPR_" TF Strength: "_FHTFST_" TF Quantity: "_FHTFQU
  1. ..W ZZ
  1. ..I $Y>(IOSL-6) D LNE^FHORD82
  1. ..W !,?5
  1. ..S ZZ="TF Product ML/Day: "_FHTFCC_" "_FHTFCN
  1. ..W ZZ
  1. Q
  1. F0 ;
  1. I $P(X,U,3)="O" Q
  1. I FHXX="C" S K1=$P(X,"^",8) I WRD,K1'=WRD Q
  1. I FHXX="L" S K1=$P(X,"^",1) I WRD,W1'=WRD Q
  1. S K1=$S(FHXX="W":"",K1<1:99,K1<10:"0"_K1,1:K1),P0=$P(X,"^",4),P0=$S(P0<1:99,P0<10:"0"_P0,1:P0)
  1. S WRDN=$P(^FH(119.6,W1,0),"^",1),^TMP("FH",$J,K1_P0_$E(WRDN,1,26),W1)="" Q
  1. F2 S WRDN=$P(^FH(119.6,W1,0),"^",1)
  1. K ^TMP($J) F FHDFN=0:0 S FHDFN=$O(^FHPT("AW",W1,FHDFN)) Q:FHDFN<1 S ADM=^(FHDFN) D RM
  1. Q:'$D(^TMP($J,"FHSRT")) S NX="" D HDR
  1. L2 S NX=$O(^TMP($J,"FHSRT",NX)) I NX="" W ! Q
  1. S FHDFN=""
  1. L3 ; Get Next Patient data
  1. S FHDFN=$O(^TMP($J,"FHSRT",NX,FHDFN)) G:FHDFN="" L2 S ADM=^(FHDFN)
  1. D PATNAME^FHOMUTL I DFN="" G L3
  1. G:ADM<1 L3 S Y(0)=^DPT(DFN,0) G:'$D(^DGPM(ADM,0)) L3
  1. G:'$D(^FHPT(FHDFN,"A",ADM,0)) L3 S LEN=0 D CUR^FHORD7 S MEAL=Y,X0=^FHPT(FHDFN,"A",ADM,0) S:$L(MEAL)>48 LEN=$L($E(MEAL,1,48),",")
  1. I SER'="A",$P(X0,"^",5)'=SER G L3
  1. D:$Y>(IOSL-6) HDR S DTP=$P(^DGPM(ADM,0),"^",1) D DTP^FH
  1. S RM=$S(SRT="R":NX,$D(^DPT(DFN,.101)):^(.101),1:"") D PID^FHDPA
  1. W !!,RM,?13,$E($P(Y(0),"^",1),1,24),?38,BID,?47,DTP
  1. S Y=$P(X0,"^",5) I Y'="" W ?67,Y
  1. D GET I Y'="" W !?13,"Nut. Status: ",Y S X=+X5 D DT W ?72,X
  1. D ALG^FHCLN I ALG'="" W !?13,"Allergies: " S ZZ=ALG D LNE^FHORD82
  1. I "NO ORDER"'[MEAL!'$P(X0,"^",4) W !?13,"Diet Order: ",$S(LEN:$P(MEAL,",",1,LEN-1)_",",1:MEAL)
  1. I I FHORD S X=$P(^FHPT(FHDFN,"A",ADM,"DI",FHORD,0),"^",9) D DT W ?72,X D:FHLD'="" NPO W:LEN !?24,$P(MEAL,",",LEN,999) D COM
  1. G ^FHORD82
  1. GET S Y="",X5=$O(^FHPT(FHDFN,"S",0)) Q:X5="" S X5=^(X5,0)
  1. Q:$P(X5,"^",1)<$P($G(^FHPT(FHDFN,"A",ADM,0)),"^",1)
  1. S Y=$P($G(^FH(115.4,+$P(X5,"^",2),0)),"^",2) Q
  1. NPO S LST=0 F K1=0:0 S K1=$O(^FHPT(FHDFN,"A",ADM,"AC",K1)) Q:K1<1!(K1>NOW) I $P(^(K1,0),"^",2)=FHORD S LST=K1
  1. W:LST<OLD "*" Q
  1. COM ; List comment if any
  1. S COM=$G(^FHPT(FHDFN,"A",ADM,"DI",FHORD,1)) Q:COM="" I $L(COM)<51 W !?16,COM Q
  1. F LEN=51:-1:1 Q:$E(COM,LEN)=" "
  1. W !?16,$E(COM,1,LEN-1) S COM=$E(COM,LEN+1,999)
  1. W:COM'="" !?19,COM Q
  1. DT S X=$J(+$E(X,6,7),2)_"-"_$P("Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec"," ",+$E(X,4,5)) Q
  1. RM ;
  1. D PATNAME^FHOMUTL I DFN="" Q
  1. I SRT="R" S RM=$G(^DPT(DFN,.101))
  1. E S RM=$P($G(^DPT(DFN,0)),"^",1)
  1. S:RM="" RM=" " S ^TMP($J,"FHSRT",RM,FHDFN)=ADM Q
  1. HDR ;W:'($E(IOST,1,2)'="C-"&'PG) @IOF S PG=PG+1,DTP=NOW D DTP^FH
  1. W @IOF S PG=PG+1,DTP=NOW D DTP^FH
  1. W !,DTP,?(67-$L(WRDN)\2),WRDN," DIET ORDERS",?72,"Page ",PG
  1. I SER'="A" S X=$S(SER="T":"TRAY",SER="C":"CAFETERIA",1:"DINING ROOM")_" Service Only" W !!?(79-$L(X)\2),X
  1. W !!,"Room",?13,"Patient",?39,"ID#",?48,"Admission Date",?66,"Svc",?71,"Ord Date" Q