source: WorldVistAEHR/trunk/r/DIETETICS-FH/FHADR6.m@ 660

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

initial load of WorldVistAEHR

File size: 4.1 KB
Line 
1FHADR6 ; HISC/NCA - Modified Diet Percentage ;1/23/98 16:06
2 ;;5.5;DIETETICS;;Jan 28, 2005
3EN1 ; Enter Snapshot Date
4 S (MD,N)=0 D QR^FHADR1 G:'PRE KIL
5 S (ANS,XX)="",TIM=$P($G(^FH(117.3,PRE,1)),"^",12) I TIM'="" S Y=TIM X ^DD("DD") S XX=Y
6F1 K %DT W !,"Select SUNDAY Date: ",$S(XX'="":XX_"// ",1:"") R X:DTIME G:'$T!(X["^") KIL
7 S:X="" X=XX
8 S %DT="EXP" D ^%DT G KIL:$D(DTOUT),F1:Y<1
9 S (TIM,X)=Y D H^%DTC G:%Y<0 F1 I %Y W *7," .. Not a Sunday" G F1
10 S TS=$E(TIM,4,5),TS=$S(TS<4:2,TS<7:3,TS<10:4,1:1) I TS'=$E(PRE,5) W *7," .. Date Not Within Qtr" G F1
11 I TS>1,$E(PRE,1,3)'=$E(TIM,1,3) W *7,"..Date Not Within Qtr" G F1
12 I TS=1,$E(PRE,1,3)-1'=$E(TIM,1,3) W *7,"..Date Not Within Qtr" G F1
13 S $P(^FH(117.3,PRE,1),"^",12)=TIM\1
14DISP ; Display the numbers of the seven days for validation
15 K DC,M,TM S D1=TIM\1 F L=1:1:7 S DC(L)=D1,X1=D1,X2=1 D C^%DTC S D1=X
16 F K=1:1:7 S R=$G(^FH(117,DC(K),1)),N=$P(R,"^",26,27) D
17 .S M(K)=$P(N,"^",1)
18 .I '$P(N,"^",2) D
19 ..F LP=21:1:25 S $P(N,"^",2)=$P(N,"^",2)+$P(R,"^",LP)
20 ..S $P(^FH(117,DC(K),1),"^",27)=$P(N,"^",2)
21 ..Q
22 .S TM(K)=$P(N,"^",2)
23 .Q
24 ; Display Data for the seven dates
25 W !!?25 S Y=DC(1) X ^DD("DD") W Y," - " S Y=DC(7) X ^DD("DD") W Y
26 W !!?12,"| X | M | T | W | R | F | S |"
27 W !?12,"| Sun | Mon | Tues | Wed | Thur | Fri | Sat | Total"
28 W !,"_____________________________________________________________________________"
29 W !,"# Mod. Diets" S TOT=0 F L=1:1:7 W "|",$J($S(M(L):M(L),1:""),7) S TOT=TOT+M(L)
30 W "|",$J($S(TOT:TOT,1:""),8) S TOT=0
31 W !,"Total Diets",?12 F L=1:1:7 W "|",$J($S(TM(L):TM(L),1:""),7) S TOT=TOT+TM(L)
32 W "|",$J($S(TOT:TOT,1:""),8)
33F2 R !!,"Change Numbers of Modified Diets and Total Diets for that week? Y// ",X:DTIME G:'$T!(X="^") KIL S:X="" X="Y" D TR^FH I $P("YES",X,1)'="",$P("NO",X,1)'="" W *7," Answer YES or NO" G F2
34 S X=$E(X,1) G:X="N" KIL
35OK W !!?10,"Sun Mon Tues Wed Thur Fri Sat"
36 W !?10," X M T W R F S"
37 W !!,"Enter string of characters for desired days of week: e.g., MWF",!
38OK1 R !!,"Select the Day of Week you wish to change the data on: ",WKDS:DTIME G:'$T!("^"[WKDS) KIL S X=WKDS D TR^FH S WKDS=X
39 S X1="" F K=1:1 S Z=$E(WKDS,K) Q:Z="" G:X1[Z MSG S X1=X1_Z I "XMTWRFS"'[Z W !,"Please enter the desired days of the week." G OK
40 F K=1:1 S Y=$E(WKDS,K) Q:Y="" S DAY=$F("XMTWRFS",Y),DAY=DAY-1,WK=$P("Sun Mon Tues Wed Thur Fri Sat"," ",DAY) D E1 Q:ANS="^"
41 G KIL:ANS="^",DISP
42E1 W !!,"Change # of Modified Diets for ",WK," from ",$S(M(DAY):M(DAY),1:"")," to: " R Y:DTIME I '$T!(Y["^") S ANS="^" Q
43 I Y="",M(DAY) S Y=M(DAY) W " ",M(DAY)
44 I Y'?1N.N!(Y'>0)!(Y>999999999) W *7,!," Enter an amount greater than 0 but less than 999999999" G E1
45 S M(DAY)=Y
46E2 W !!,"Change # of Total Diets for ",WK," from ",$S(TM(DAY):TM(DAY),1:"")," to: " R Y:DTIME I '$T!(Y["^") S ANS="^" Q
47 I Y="",TM(DAY) S Y=TM(DAY) W " ",TM(DAY)
48 I Y'?1N.N!(Y'>0)!(Y>9999999999) W *7,!," Enter an amount greater than 0 but less than 9999999999" G E2
49 S TM(DAY)=Y
50 S $P(^FH(117,DC(DAY),1),"^",26,27)=M(DAY)_"^"_TM(DAY)
51 Q
52MSG W *7,!," Error - Illegal Character or Repeated Day." G OK1
53KIL G KILL^XUSCLEAN
54EN2 ; Print the % Modified Diet and Number of Patients
55 K M,N,TD,TM S (TOT,TQ)=0 F K=1:1:4 S (M(K),TD(K),TM(K))=""
56 D:$Y'<(LIN-7) HDR^FHADRPT,HDR2^FHADR3A
57 W !!!!,"MODIFIED DIET SUMMARY"
58 W !!?35,"1st Qtr",?55,"2nd Qtr",?75,"3rd Qtr",?95,"4th Qtr",?115,"YTD Avg",!
59P1 ; Build List of dates and add the Modified Diets for the seven days
60 F QR=1:1:4 S QTR=QR,PRE=FHYR_"0"_QTR_"00" D
61 .S TIM=$P($G(^FH(117.3,PRE,1)),"^",12) Q:'TIM
62 .K DC S D1=TIM\1 F L=1:1:7 S DC(L)=D1,X1=D1,X2=1 D C^%DTC S D1=X
63 .F K=1:1:7 S R=$G(^FH(117,DC(K),1)),N=$P(R,"^",26,27) I N'="" D
64 ..Q:'$P(N,"^",1) S M(QTR)=M(QTR)+$P(N,"^",1)
65 ..I '$P(N,"^",2) D
66 ...F LP=21:1:25 S $P(N,"^",2)=$P(N,"^",2)+$P(R,"^",LP)
67 ...S $P(^FH(117,DC(K),1),"^",27)=$P(N,"^",2)
68 ...Q
69 ..Q:'$P(N,"^",2) S TM(QTR)=TM(QTR)+$P(N,"^",2)
70 ..S TD(QTR)=TD(QTR)+1
71 ..Q
72 .S:TD(QTR)'="" TQ=TQ+1
73 .Q
74 W !,"Week Average Modified Diet",?35 F QTR=1:1:4 S X=$S(+TM(QTR)'<1:M(QTR)/TM(QTR)*100,1:""),TOT=TOT+X W $S(X:$J(X,7,1),1:$J("",7))_$J("",13)
75 W $S(TQ:$J(TOT/TQ,7,1),1:$J("",7))
76 K LP,M,N,R,TD,TM Q
Note: See TracBrowser for help on using the repository browser.