13 #include <sys/types.h>
15 #include <sys/socket.h>
17 #include <netinet/in.h>
27 #include "webserver.h"
31 void do_calendar_view(void) { /* stub for non-libical builds */
32 wprintf("<CENTER><I>Calendar view not available</I></CENTER><BR>\n");
35 #else /* HAVE_ICAL_H */
37 /****************************************************************************/
39 void calendar_month_view_display_events(time_t thetime) {
43 struct icaltimetype t;
45 int all_day_event = 0;
47 if (WC->num_cal == 0) {
48 wprintf("<BR><BR><BR>\n");
52 tm = localtime(&thetime);
53 month = tm->tm_mon + 1;
55 year = tm->tm_year + 1900;
57 for (i=0; i<(WC->num_cal); ++i) {
58 p = icalcomponent_get_first_property(WC->disp_cal[i],
59 ICAL_DTSTART_PROPERTY);
61 t = icalproperty_get_dtstart(p);
66 if (t.is_date) all_day_event = 1;
68 p = icalcomponent_get_first_property(
70 ICAL_SUMMARY_PROPERTY);
74 wprintf("<TABLE border=1 cellpadding=2><TR>"
75 "<TD BGCOLOR=#CCCCCC>"
79 wprintf("<FONT SIZE=-1>"
80 "<A HREF=\"/display_edit_event?msgnum=%ld&calview=%s&year=%s&month=%s&day=%s\">",
88 icalproperty_get_comment(p));
89 wprintf("</A></FONT><BR>\n");
92 wprintf("</TD></TR></TABLE>");
106 void calendar_month_view(int year, int month, int day) {
107 struct tm starting_tm;
111 time_t previous_month;
114 /* Determine what day to start.
115 * First, back up to the 1st of the month...
117 memset(&starting_tm, 0, sizeof(struct tm));
118 starting_tm.tm_year = year - 1900;
119 starting_tm.tm_mon = month - 1;
120 starting_tm.tm_mday = day;
121 thetime = mktime(&starting_tm);
124 while (tm->tm_mday != 1) {
125 thetime = thetime - (time_t)86400; /* go back 24 hours */
126 tm = localtime(&thetime);
129 /* Determine previous and next months ... for links */
130 previous_month = thetime - (time_t)864000L; /* back 10 days */
131 next_month = thetime + (time_t)(31L * 86400L); /* ahead 31 days */
133 /* Now back up until we're on a Sunday */
134 tm = localtime(&thetime);
135 while (tm->tm_wday != 0) {
136 thetime = thetime - (time_t)86400; /* go back 24 hours */
137 tm = localtime(&thetime);
140 /* Outer table (to get the background color) */
141 wprintf("<TABLE width=100%% border=0 cellpadding=0 cellspacing=0 "
142 "bgcolor=#4444FF><TR><TD>\n");
144 wprintf("<TABLE width=100%% border=0 cellpadding=0 cellspacing=0>"
145 "<TR><TD align=left><font color=#FFFFFF>"
146 " <A HREF=\"/display_edit_event?msgnum=0\">"
147 "Add new calendar event</A>"
150 wprintf("<TD><CENTER><H3>");
152 tm = localtime(&previous_month);
153 wprintf("<A HREF=\"readfwd?calview=month&year=%d&month=%d&day=1\">",
154 (int)(tm->tm_year)+1900, tm->tm_mon + 1);
155 wprintf("<IMG ALIGN=MIDDLE SRC=\"/static/back.gif\" BORDER=0></A>\n");
157 wprintf(" "
158 "<FONT COLOR=#FFFFFF>"
161 " ", months[month-1], year);
163 tm = localtime(&next_month);
164 wprintf("<A HREF=\"readfwd?calview=month&year=%d&month=%d&day=1\">",
165 (int)(tm->tm_year)+1900, tm->tm_mon + 1);
166 wprintf("<IMG ALIGN=MIDDLE SRC=\"/static/forward.gif\" BORDER=0></A>\n");
168 wprintf("</H3></TD><TD align=right><font color=#FFFFFF size=-2>"
169 "Click on any date for day view "
170 "</FONT></TD></TR></TABLE>\n");
172 /* Inner table (the real one) */
173 wprintf("<TABLE width=100%% border=0 cellpadding=1 cellspacing=1 "
175 for (i=0; i<7; ++i) {
176 wprintf("<TH><FONT COLOR=#FFFFFF>%s</FONT></TH>", days[i]);
180 for (i = 0; i < 35; ++i) {
181 tm = localtime(&thetime);
182 if (tm->tm_wday == 0) {
186 wprintf("<TD BGCOLOR=FFFFFF WIDTH=14%% HEIGHT=60 VALIGN=TOP>"
188 if ((i==0) || (tm->tm_mday == 1)) {
189 wprintf("%s ", months[tm->tm_mon]);
191 wprintf("<A HREF=\"readfwd?calview=day&year=%d&month=%d&day=%d\">"
198 /* put the data here, stupid */
199 calendar_month_view_display_events(thetime);
203 if (tm->tm_wday == 6) {
207 thetime += (time_t)86400; /* ahead 24 hours */
210 wprintf("</TABLE>" /* end of inner table */
211 "</TD></TR></TABLE>" /* end of outer table */
216 void calendar_week_view(int year, int month, int day) {
217 wprintf("<CENTER><I>week view FIXME</I></CENTER><BR>\n");
222 * Display events for a particular hour of a particular day.
223 * (Specify hour < 0 to show "all day" events)
225 void calendar_day_view_display_events(int year, int month,
229 struct icaltimetype t;
230 int all_day_event = 0;
232 if (WC->num_cal == 0) {
233 wprintf("<BR><BR><BR>\n");
237 for (i=0; i<(WC->num_cal); ++i) {
238 p = icalcomponent_get_first_property(WC->disp_cal[i],
239 ICAL_DTSTART_PROPERTY);
241 t = icalproperty_get_dtstart(p);
243 && (t.month == month)
245 && ( ((t.hour == hour)&&(!t.is_date)) || ((hour<0)&&(t.is_date)) )
248 if (t.is_date) all_day_event = 1;
250 p = icalcomponent_get_first_property(
252 ICAL_SUMMARY_PROPERTY);
256 wprintf("<TABLE border=1 cellpadding=2><TR>"
257 "<TD BGCOLOR=#CCCCCC>"
261 wprintf("<FONT SIZE=-1>"
262 "<A HREF=\"/display_edit_event?msgnum=%ld&calview=day&year=%d&month=%d&day=%d\">",
267 icalproperty_get_comment(p));
268 wprintf("</A></FONT><BR>\n");
271 wprintf("</TD></TR></TABLE>");
284 void calendar_day_view(int year, int month, int day) {
287 /* Outer table (to get the background color) */
288 wprintf("<TABLE width=100%% border=0 cellpadding=0 cellspacing=0 "
289 "bgcolor=#4444FF><TR><TD>\n");
291 /* Inner table (the real one) */
292 wprintf("<TABLE width=100%% border=0 cellpadding=1 cellspacing=1 "
293 "bgcolor=#4444FF><TR>\n");
295 wprintf("<TD WIDTH=50%% VALIGN=top>"); /* begin stuff-on-the-left */
297 wprintf("<CENTER><H3><FONT COLOR=#FFFFFF>"
299 "</FONT></H3></CENTER>\n",
300 months[month-1], day, year);
302 wprintf("<CENTER><font color=#FFFFFF>"
303 " <A HREF=\"/display_edit_event?msgnum=0\">"
304 "Add new calendar event</A>"
307 wprintf("<A HREF=\"readfwd?calview=month&year=%d&month=%d&day=1\">"
308 "Back to month view</A>\n", year, month);
310 wprintf("</FONT></CENTER>\n");
312 wprintf("</TD>"); /* end stuff-on-the-left */
314 /* Innermost table (contains hours etc.) */
315 wprintf("<TD WIDTH=50%%>"
316 "<TABLE width=100%% border=0 cellpadding=1 cellspacing=1 "
317 "bgcolor=#4444FF>\n");
319 /* Display events before 8:00 (hour=-1 is all-day events) */
320 wprintf("<TR><TD BGCOLOR=FFFFFF VALIGN=TOP>");
321 for (hour = (-1); hour <= 7; ++hour) {
322 calendar_day_view_display_events(year, month, day, hour);
324 wprintf("</TD></TR>\n");
326 /* Now the middle of the day... */
327 for (hour = 8; hour <= 17; ++hour) { /* could do HEIGHT=xx */
328 wprintf("<TR><TD BGCOLOR=FFFFFF VALIGN=TOP>");
330 (hour <= 12 ? hour : hour-12),
331 (hour < 12 ? "am" : "pm")
334 /* put the data here, stupid */
335 calendar_day_view_display_events(year, month, day, hour);
337 wprintf("</TD></TR>\n");
340 /* Display events after 5:00... */
341 wprintf("<TR><TD BGCOLOR=FFFFFF VALIGN=TOP>");
342 for (hour = 18; hour <= 23; ++hour) {
343 calendar_day_view_display_events(year, month, day, hour);
345 wprintf("</TD></TR>\n");
348 wprintf("</TABLE>" /* end of innermost table */
349 "</TD></TR></TABLE>" /* end of inner table */
350 "</TD></TR></TABLE>" /* end of outer table */
360 void do_calendar_view(void) {
364 int year, month, day;
367 /* In case no date was specified, go with today */
369 tm = localtime(&now);
370 year = tm->tm_year + 1900;
371 month = tm->tm_mon + 1;
374 /* Now see if a date was specified */
375 if (strlen(bstr("year")) > 0) year = atoi(bstr("year"));
376 if (strlen(bstr("month")) > 0) month = atoi(bstr("month"));
377 if (strlen(bstr("day")) > 0) day = atoi(bstr("day"));
379 /* How would you like that cooked? */
380 if (strlen(bstr("calview")) > 0) {
381 strcpy(calview, bstr("calview"));
384 strcpy(calview, "month");
387 /* Display the selected view */
388 if (!strcasecmp(calview, "day")) {
389 calendar_day_view(year, month, day);
391 else if (!strcasecmp(calview, "week")) {
392 calendar_week_view(year, month, day);
395 calendar_month_view(year, month, day);
398 /* Free the calendar stuff */
399 if (WC->num_cal) for (i=0; i<(WC->num_cal); ++i) {
400 icalcomponent_free(WC->disp_cal[i]);
405 free(WC->cal_msgnum);
406 WC->cal_msgnum = NULL;
410 #endif /* HAVE_ICAL_H */