source: FOIAVistA/tag/r/DIETETICS-FH/FHDMP.m@ 824

Last change on this file since 824 was 628, checked in by George Lilly, 15 years ago

initial load of FOIAVistA 6/30/08 version

File size: 4.4 KB
Line 
1FHDMP ; HISC/REL/NCA/JH/RK/FAI - Patient Data Log ;10/19/04 13:26
2 ;;5.5;DIETETICS;**1,2**;Jan 28, 2005
3BEGIN S ADM="",FHALL=1 D ^FHOMDPA
4 G:'FHDFN CLEAN
5 I $O(^FHPT(FHDFN,"A",0))<1 W !!,"NO ADMISSIONS ON FILE!" G OMDATE
6 S DIC="^FHPT(FHDFN,""A"",",DIC(0)="Q",DA=FHDFN,X="??" D ^DIC
7 S WARD="" I $G(DFN)'="" S WARD=$G(^DPT(DFN,.1))
8 K ADM
9A0 W !!,"Select ADMISSION or RETURN for OUTPATIENT ",$S(WARD'="":" (or C for CURRENT)",1:""),": " R X:DTIME G:X["^" KIL D:X="c" TR^FH
10 I (X="")&'($D(^FHPT(FHDFN,"OP"))!$D(^FHPT(FHDFN,"GM"))!$D(^FHPT(FHDFN,"SM"))) W !!,"NO OUTPATIENT DATA ON FILE!" G FHDMP
11 I (X="")&($D(^FHPT(FHDFN,"OP"))!$D(^FHPT(FHDFN,"GM"))!$D(^FHPT(FHDFN,"SM"))) G OMDATE
12 I WARD'="",X="C" S ADM=$G(^DPT("CN",WARD,DFN)) G CAD:ADM
13 S DIC="^FHPT(FHDFN,""A"",",DIC(0)="EQM" D ^DIC G:Y<1 A0 S ADM=+Y
14CAD I ADM,$G(^FHPT(FHDFN,"A",ADM,0)) S (SDT,STDT)=$P(^FHPT(FHDFN,"A",ADM,0),U,1),ENDT=DT G P0:SDT
15 ;
16OMDATE I '($D(^FHPT(FHDFN,"OP"))!$D(^FHPT(FHDFN,"GM"))!$D(^FHPT(FHDFN,"SM"))) W !!,"NO OUTPATIENT DATA ON FILE!" G FHDMP
17 W !!,"This report will also display any existing outpatient meals data."
18 W !,"Enter the Start Date and End Date for outpatient data.",!
19 D STDATE^FHOMUTL S SDT=STDT I STDT="" Q
20 S X="T+30" D ^%DT S ENDT=Y
21 D DD^%DT S FHDTDF=Y K DIR
22 S DIR("A")="Select End Date: ",DIR("B")=FHDTDF,DIR(0)="DAO^"_STDT
23 D ^DIR
24 Q:$D(DIRUT) S ENDT=Y S Y=ENDT D DD^%DT W " ",Y
25 D P0
26 Q
27P0 K IOP S %ZIS="MQ",%ZIS("B")="HOME" W ! D ^%ZIS K %ZIS,IOP G:POP KIL
28 I $D(IO("Q")) S FHPGM="INOUT^FHDMP",FHLST="ADM^FHDFN^DFN^IEN200^PID^OPSD^STDT^ENDT^SDT" D EN2^FH G KIL
29 U IO D INOUT D ^%ZISC K %ZIS,IOP G FHDMP
30 Q
31INOUT D F0
32 Q:QT="^" I IOST?1"C".E W ! K DIR S DIR(0)="E" D ^DIR I 'Y S EX=U Q
33 Q:$G(ADM)
34 W:QT'="^" !,LN,!,?15,"*** O U T P A T I E N T M E A L D A T A ***"
35 Q:QT="^" D DISP^FHOMRMD I EX=U Q
36 I IOST?1"C".E W ! K DIR S DIR(0)="E" D ^DIR I 'Y S EX=U Q
37 Q:QT="^" D ^FHDPSM I EX=U Q
38 I IOST?1"C".E W ! K DIR S DIR(0)="E" D ^DIR I 'Y S EX=U Q
39 Q:QT="^" D ^FHDPGM I EX=U Q
40CLEAN G KILL^XUSCLEAN
41F0 D NOW^%DTC S DT=%\1,DTP=% D DTP^FH S NOW=DTP,S1=$S(IOST?1"C".E:IOSL,1:IOSL-6)
42 D PATNAME^FHOMUTL
43 ;S Y(0)=^DPT(DFN,0)
44 S NAM=FHPTNM,SEX=FHSEX,DOB=FHDOB,PID=$G(PID),AGE=FHAGE,PG=0,QT=""
45 S PRTFM=STDT_" TO "_ENDT
46 S DTP=STDT D DTP^FH S SDT1=DTP
47 S DTP=ENDT D DTP^FH S EDT1=DTP
48 S PRTFM=SDT1_" TO "_EDT1
49 S LN="",$P(LN,"-",80)=""
50 D HDR
51 D ALG^FHCLN W !!,"Allergies: " S ALG=$S(ALG="":"None on file",1:ALG) D LNE
52 W !!,"Food Preferences Currently on file:",!!?26,"Likes",?58,"Dislikes",!
53 K N S P1=1 F K=0:0 S K=$O(^FHPT(FHDFN,"P",K)) Q:K<1 S X=^(K,0) D SP
54 W ! S (M1,MM)="",L=0 F S M1=$O(N(M1)) Q:M1="" I $D(N(M1)) W $P(M1,"~",2) D S MM=M1
55 . S (P1,P2)=0 F S:P1'="" P1=$O(N(M1,"L",P1)) S X1=$S(P1>0:N(M1,"L",P1),1:"") S:P2'="" P2=$O(N(M1,"D",P2)) S X2=$S(P2>0:N(M1,"D",P2),1:"") Q:P1=""&(P2="") D W0 W:MM'=M1 !
56 . Q
57 I $O(N(""))="" W !!,"No Food Preferences on file",! D ^FHDMP1 Q
58 W ! K L,N,M,M1,M2 D ^FHDMP1 Q
59W0 I X1'="" W ?12 S X=X1 D W1 S X1=X
60 I X2'="" W ?46 S X=X2 D W1 S X2=X
61 Q:X1=""&(X2="") S:$Y'<S1 L=1 D:$Y'<S1 HDR G:QT="^" KIL W ! W:L ! S L=0 G W0
62W1 I $L(X)<34 W X S X="" Q
63 F KK=35:-1:1 Q:$E(X,KK-1,KK)=", "
64 W $E(X,1,KK-2) S X=$E(X,KK+1,999) Q
65SP S M=$P(X,"^",2) S:M="A" M="BNE" S Z=$G(^FH(115.2,+X,0)),L1=$P(Z,"^",1),KK=$P(Z,"^",2),M1="",DAS=$P(X,"^",4)
66 I KK="L" S Q=$P(X,"^",3),L1=$S(Q:Q,1:1)_" "_L1
67 I M="BNE" S M1="1~All Meals" G SP1
68 S Z1=$E(M,1) I Z1'="" S M1=$S(Z1="B":"2~Break",Z1="N":"3~Noon",1:"4~Even")
69 S Z1=$E(M,2) I Z1'="" S M1=M1_","_$S(Z1="B":"Break",Z1="N":"Noon",1:"Even")
70SP1 S:'$D(N(M1,KK,P1)) N(M1,KK,P1)="" I $L(N(M1,KK,P1))+$L(L1)<255 S N(M1,KK,P1)=N(M1,KK,P1)_$S(N(M1,KK,P1)="":"",1:", ")_L1_$S(DAS="Y":" (D)",1:"")
71 E S:'$D(N(M1,KK,K)) N(M1,KK,K)="" S N(M1,KK,K)=L1_$S(DAS="Y":" (D)",1:"") S P1=K
72 Q
73LNE ; Break Line if longer than 65 chars
74 I $L(ALG)<66 W ALG Q
75 F L=67:-1:1 Q:$E(ALG,L-1,L)=", "
76 W $E(ALG,1,L-2)
77 S ALG=$E(ALG,L+1,999)
78 Q:ALG="" W !?11
79 G LNE
80HDR ; Print Header
81 S (EX,QT)="" I PG,IOST?1"C".E W:$X>1 ! W *7 R QT:DTIME S:'$T QT="^" Q:QT="^"
82 W:'($E(IOST,1,2)'="C-"&'PG) @IOF S PG=PG+1
83 W !,?15,"P A T I E N T D A T A L O G",!
84 W !,"Date Range: ",PRTFM,?62,NOW,!!,PID,?17,NAM,?49,$S(SEX="M":"Male",SEX="F":"Female",1:""),?58,"Age ",AGE,?72,"Page ",PG Q
85DTP ; Printable Date/Time
86 Q:Y<1 W $J(+$E(Y,6,7),2)_"-"_$P("Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec"," ",+$E(Y,4,5))_"-"_$E(Y,2,3)
87 I Y["." S %=+$E(Y_"0",9,10) W $J($S(%>12:%-12,1:%),3)_":"_$E(Y_"000",11,12)_$S(%<12:"am",%<24:"pm",1:"m")
88 K % Q
89KIL ; User exit
90 Q
Note: See TracBrowser for help on using the repository browser.