source: FOIAVistA/tag/r/DIETETICS-FH/FHMADM3.m@ 1641

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

initial load of FOIAVistA 6/30/08 version

File size: 4.2 KB
Line 
1FHMADM3 ; HISC/REL/AAC - Additional Meals Report ;10/9/03 16:07
2 ;;5.5;DIETETICS;;Jan 28, 2005
3EN1 ; Print Meal Report
4 D DT G:"^"[X KIL
5 ;
6 ;Get Communication Offices data
7 F K=1:1:22 S SS(K)=0,S(K)=0
8 S CONUM="",ZCO="",COXX="",CO="",CONAME="",CONAM="",COUNT=0
9 ;S ZZOUT=$G(^FH(119.73,0)),ZOUT=$P(ZZOUT,"^",4)
10 S ZZCOUNT=0 F ZZCOUNT=0:0 S ZZCOUNT=$O(^FH(119.73,ZZCOUNT)) Q:ZZCOUNT'>0 S ZOUT=ZZCOUNT
11 ;
12 R !,"Print report for all Communications Offices Y or N: ",ZCO:DTIME W ! S ZCO=$TR(ZCO,"y","Y") I ZCO'="Y" D N2 G KIL Q
13 ;
14PRINT W !!,"The report requires a 132 column printer.",!
15 K IOP,%ZIS S %ZIS("A")="Print on Device: ",%ZIS="MQ" W ! D ^%ZIS K %ZIS,IOP G:POP KIL
16 I $D(IO("Q")) S FHPGM="Q1^FHMADM3",FHLST="CONAME^CO^CONUMX^EDT^SDT^ZCO^COUNT^ZOUT^S(^SS(" D EN2^FH G KIL
17 U IO D Q1 D ^%ZISC K %ZIS,IOP G KIL
18 ;
19Q1 ; Process Printing the Meal Report
20 ;
21 S DTP=SDT\1 D DTP^FH S DTE=DTP_" to " S DTP=EDT\1 D DTP^FH S DTE=DTE_DTP
22 S X=SDT D DOW^%DTC S DOW=Y+1
23 D NOW^%DTC S DTP=% D DTP^FH S HDT=DTP,PG=0
24 ;
25Q2 ;
26 ;Get Specific Communication Offices
27 I ZCO'="Y" S CONUMX=CONUMX-1 G:CONUMX=0 QUIT S COXX=$P(CO,"^",CONUMX),NAME=$P(CONAME,"^",CONUMX) G:$D(^FH(119.73,COXX,"I")) Q2 G:'$D(^FH(119.73,COXX,0)) Q2
28 I ZCO="Y" S COUNT=COUNT+1 G:COUNT>ZOUT QUIT S NAME=$G(^FH(119.73,COUNT,0)),NAME=$P(NAME,"^") G:$D(^FH(119.73,COUNT,"I")) Q2 G:'$D(^FH(119.73,COUNT,0)) Q2
29 ;W @IOF
30 D HDR
31 S DOW=Y+1 D Q3
32 I ZCO'="Y" I CONUMX>0 G Q2
33 I ZCO="Y" G Q2
34 Q
35 ;
36QUIT ;
37 ;W @IOF
38 S NAME="Total All Communications Offices "
39 D HDR
40 D FTOTALS
41 D LN,LN
42 Q
43 ;
44Q3 F L1=19:1:22 S N(L1)=0
45 S D1=SDT F L1=0:0 D N1 S X1=D1,X2=1 D C^%DTC Q:X>EDT S D1=X,DOW=DOW+1 S:DOW=8 DOW=1
46 ;
47TOTALS ;
48 ;Print Totals
49 F K=1:1:22 S Z=$S(K<19:5,1:6),S(K)=$S(S(K)<1:$J("",Z),S(K)<10000:$J(S(K),Z-1)_" ",1:$J(S(K),Z))
50 ;
51 D LN W !," Total",?10,"|",S(1),S(2),S(3),S(4),S(5),S(6),S(19)," |",S(7),S(8),S(9),S(10),S(11),S(12),S(20)," |",S(13),S(14),S(15),S(16),S(17),S(18),S(21)," |",S(22),!
52 Q
53 ;
54FTOTALS ; Final Totals
55 ;
56 F K=1:1:22 S Z=$S(K<19:5,1:6),SS(K)=$S(SS(K)<1:$J("",Z),SS(K)<10000:$J(SS(K),Z-1)_" ",1:$J(SS(K),Z))
57 ;
58 W !,"ALL Total",?10,"|",SS(1),SS(2),SS(3),SS(4),SS(5),SS(6),SS(19)," |",SS(7),SS(8),SS(9),SS(10),SS(11),SS(12),SS(20)," |",SS(13),SS(14),SS(15),SS(16),SS(17),SS(18),SS(21)," |",SS(22),!
59 Q
60 ;
61HDR ;Print page headers
62 W:'($E(IOST,1,2)'="C-"&'PG) @IOF S PG=PG+1 W !,HDT,?50,"A D D I T I O N A L M E A L S",?125,"Page ",PG
63 W !!,?1,NAME
64 W !!?(131-$L(DTE)\2),DTE
65 W !!,?10,"|",?21,"B R E A K F A S T",?48,"|",?64,"N O O N",?86,"|",?99,"E V E N I N G",?124,"| TOTAL"
66 W !,?10,"| Opt. Emp. Paid OOD Vol. Grt. Total | Opt. Emp. Paid OOD Vol. Grt. Total | Opt. Emp. Paid OOD Vol. Grt. Total |"
67LN W !,"-----------------------------------------------------------------------------------------------------------------------------------"
68 Q
69 ;
70N1 ;Get specific records based on Communications Offices,Start/End Dates, etc
71 I ZCO'="Y" F CONUM=1:1 Q:CONUM>ZOUT S Y0=$G(^FH(117,D1,2,CONUM,0)),Y2=$P(Y0,"^"),Y1=$P(Y0,"^",2,99) Q:COXX=Y2
72 ;
73 I ZCO="Y" F CONUM=1:1 Q:CONUM>ZOUT S Y0=$G(^FH(117,D1,2,CONUM,0)),Y2=$P(Y0,"^"),Y1=$P(Y0,"^",2,99) Q:COUNT=Y2
74 ;
75 S K=0 F L1=1:1:6 F L2=1:1:3 S K=K+1,N=L2-1*6+L1,Z=$P(Y1,"^",K),N(N)=Z,N(18+L2)=N(18+L2)+Z
76 S N(22)=N(19)+N(20)+N(21)
77 ;
78 F K=1:1:22 S S(K)=S(K)+N(K),SS(K)=SS(K)+N(K),N(K)=$J($S(N(K)<1:"",1:N(K)),$S(K<19:4,1:5))_" "
79 ;
80 S DTP=D1 D DTP^FH D:$Y>(IOSL-8) HDR
81 W !,$P("Sun Mon Tue Wed Thu Fri Sat"," ",DOW)," ",$E(DTP,1,6)
82 W "|",N(1),N(2),N(3),N(4),N(5),N(6),N(19)," |",N(7),N(8),N(9),N(10),N(11),N(12),N(20)," |",N(13),N(14),N(15),N(16),N(17),N(18),N(21)," |",N(22) Q
83 ;
84N2 ;Get Communciation Offices
85 S DIC=119.73,DIC(0)="AEQ",DIC("A")="Select Communication Offices: "
86 D ^DIC I (Y=-1)&(CO="") Q
87 I Y=-1 G PRINT Q
88 S CON=$P(Y,"^",1),CO=CON_"^"_CO,CONAM=$P(Y,"^",2),CONAME=CONAM_"^"_CONAME S CONUMX=$L(CO,"^") G N2 Q
89 I Y=-1 K DIC Q
90 ;
91DT ; Get From/To Dates
92D1 S %DT="AEPX",%DT("A")="Starting Date: " W ! D ^%DT S:$D(DTOUT) X="^" Q:U[X G:Y<1 D1 S SDT=+Y
93 I SDT'<DT W *7," [Must Start before Today!] " G D1
94 ;
95D2 ;
96 S %DT="AEPX",%DT("A")=" Ending Date: " D ^%DT S:$D(DTOUT) X="^" Q:U[X G:Y<1 D2 S EDT=+Y
97 I EDT'<DT W *7," [Must End before Today!] " G D2
98 I EDT<SDT W *7," [End before Start?] " G D1
99 Q
100 ;
101KIL G KILL^XUSCLEAN Q
102EXIT Q
Note: See TracBrowser for help on using the repository browser.