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 /****************************************************************************/
41 void calendar_month_view_display_events(time_t thetime) {
45 struct icaltimetype t;
47 int all_day_event = 0;
49 if (WC->num_cal == 0) {
50 wprintf("<BR><BR><BR>\n");
54 tm = localtime(&thetime);
55 month = tm->tm_mon + 1;
57 year = tm->tm_year + 1900;
59 for (i=0; i<(WC->num_cal); ++i) {
60 p = icalcomponent_get_first_property(WC->disp_cal[i],
61 ICAL_DTSTART_PROPERTY);
63 t = icalproperty_get_dtstart(p);
68 if (t.is_date) all_day_event = 1;
69 else all_day_event = 0;
71 p = icalcomponent_get_first_property(
73 ICAL_SUMMARY_PROPERTY);
77 wprintf("<TABLE border=0 cellpadding=2><TR>"
78 "<TD BGCOLOR=#AAAAAA>"
82 wprintf("<FONT SIZE=-1>"
83 "<A HREF=\"/display_edit_event?msgnum=%ld&calview=%s&year=%s&month=%s&day=%s\">",
91 icalproperty_get_comment(p));
92 wprintf("</A></FONT><BR>\n");
95 wprintf("</TD></TR></TABLE>");
109 void calendar_month_view(int year, int month, int day) {
110 struct tm starting_tm;
114 time_t previous_month;
117 /* Determine what day to start.
118 * First, back up to the 1st of the month...
120 memset(&starting_tm, 0, sizeof(struct tm));
121 starting_tm.tm_year = year - 1900;
122 starting_tm.tm_mon = month - 1;
123 starting_tm.tm_mday = day;
124 thetime = mktime(&starting_tm);
127 while (tm->tm_mday != 1) {
128 thetime = thetime - (time_t)86400; /* go back 24 hours */
129 tm = localtime(&thetime);
132 /* Determine previous and next months ... for links */
133 previous_month = thetime - (time_t)864000L; /* back 10 days */
134 next_month = thetime + (time_t)(31L * 86400L); /* ahead 31 days */
136 /* Now back up until we're on a Sunday */
137 tm = localtime(&thetime);
138 while (tm->tm_wday != 0) {
139 thetime = thetime - (time_t)86400; /* go back 24 hours */
140 tm = localtime(&thetime);
143 /* Outer table (to get the background color) */
144 wprintf("<TABLE width=100%% border=0 cellpadding=0 cellspacing=0 "
145 "bgcolor=#4444FF><TR><TD>\n");
147 wprintf("<TABLE width=100%% border=0 cellpadding=0 cellspacing=0>"
148 "<TR><TD align=left><font color=#FFFFFF>"
149 " <A HREF=\"/display_edit_event?msgnum=0"
150 "&year=%d&month=%d&day=%d\">"
151 "Add new calendar event</A>"
156 wprintf("<TD><CENTER><H3>");
158 tm = localtime(&previous_month);
159 wprintf("<A HREF=\"readfwd?calview=month&year=%d&month=%d&day=1\">",
160 (int)(tm->tm_year)+1900, tm->tm_mon + 1);
161 wprintf("<IMG ALIGN=MIDDLE SRC=\"/static/back.gif\" BORDER=0></A>\n");
163 wprintf(" "
164 "<FONT COLOR=#FFFFFF>"
167 " ", months[month-1], year);
169 tm = localtime(&next_month);
170 wprintf("<A HREF=\"readfwd?calview=month&year=%d&month=%d&day=1\">",
171 (int)(tm->tm_year)+1900, tm->tm_mon + 1);
172 wprintf("<IMG ALIGN=MIDDLE SRC=\"/static/forward.gif\" BORDER=0></A>\n");
174 wprintf("</H3></TD><TD align=right><font color=#FFFFFF size=-2>"
175 "Click on any date for day view "
176 "</FONT></TD></TR></TABLE>\n");
178 /* Inner table (the real one) */
179 wprintf("<TABLE width=100%% border=0 cellpadding=1 cellspacing=1 "
181 for (i=0; i<7; ++i) {
182 wprintf("<TH><FONT COLOR=#FFFFFF>%s</FONT></TH>", days[i]);
186 for (i = 0; i < 35; ++i) {
187 tm = localtime(&thetime);
188 if (tm->tm_wday == 0) {
192 wprintf("<TD BGCOLOR=%s WIDTH=14%% HEIGHT=60 VALIGN=TOP><B>",
193 ((tm->tm_mon != month-1) ? "DDDDDD" :
194 ((tm->tm_wday==0 || tm->tm_wday==6) ? "EEEECC" :
197 if ((i==0) || (tm->tm_mday == 1)) {
198 wprintf("%s ", months[tm->tm_mon]);
200 wprintf("<A HREF=\"readfwd?calview=day&year=%d&month=%d&day=%d\">"
207 /* put the data here, stupid */
208 calendar_month_view_display_events(thetime);
212 if (tm->tm_wday == 6) {
216 thetime += (time_t)86400; /* ahead 24 hours */
219 wprintf("</TABLE>" /* end of inner table */
220 "</TD></TR></TABLE>" /* end of outer table */
225 void calendar_week_view(int year, int month, int day) {
226 wprintf("<CENTER><I>week view FIXME</I></CENTER><BR>\n");
231 * Display events for a particular hour of a particular day.
232 * (Specify hour < 0 to show "all day" events)
234 void calendar_day_view_display_events(int year, int month,
238 struct icaltimetype t;
239 int all_day_event = 0;
241 if (WC->num_cal == 0) {
242 wprintf("<BR><BR><BR>\n");
246 for (i=0; i<(WC->num_cal); ++i) {
247 p = icalcomponent_get_first_property(WC->disp_cal[i],
248 ICAL_DTSTART_PROPERTY);
250 t = icalproperty_get_dtstart(p);
252 && (t.month == month)
254 && ( ((t.hour == hour)&&(!t.is_date)) || ((hour<0)&&(t.is_date)) )
257 if (t.is_date) all_day_event = 1;
259 p = icalcomponent_get_first_property(
261 ICAL_SUMMARY_PROPERTY);
265 wprintf("<TABLE border=1 cellpadding=2><TR>"
266 "<TD BGCOLOR=#CCCCCC>"
270 wprintf("<FONT SIZE=-1>"
271 "<A HREF=\"/display_edit_event?msgnum=%ld&calview=day&year=%d&month=%d&day=%d\">",
276 icalproperty_get_comment(p));
277 wprintf("</A></FONT><BR>\n");
280 wprintf("</TD></TR></TABLE>");
293 void calendar_day_view(int year, int month, int day) {
295 struct icaltimetype today, yesterday, tomorrow;
298 /* Figure out the dates for "yesterday" and "tomorrow" links */
300 memset(&today, 0, sizeof(struct icaltimetype));
306 memcpy(&yesterday, &today, sizeof(struct icaltimetype));
308 yesterday = icaltime_normalize(yesterday);
310 memcpy(&tomorrow, &today, sizeof(struct icaltimetype));
312 tomorrow = icaltime_normalize(tomorrow);
315 /* Outer table (to get the background color) */
316 wprintf("<TABLE width=100%% border=0 cellpadding=0 cellspacing=0 "
317 "bgcolor=#4444FF><TR><TD>\n");
319 /* Inner table (the real one) */
320 wprintf("<TABLE width=100%% border=0 cellpadding=1 cellspacing=1 "
321 "bgcolor=#4444FF><TR>\n");
323 wprintf("<TD WIDTH=50%% VALIGN=top>"); /* begin stuff-on-the-left */
325 wprintf("<CENTER><H3>");
326 wprintf("<A HREF=\"readfwd?calview=day&year=%d&month=%d&day=%d\">",
327 yesterday.year, yesterday.month, yesterday.day
329 wprintf("<IMG ALIGN=MIDDLE SRC=\"/static/back.gif\" BORDER=0></A>\n");
330 wprintf(" <FONT COLOR=#FFFFFF>"
332 "</FONT> ",
333 months[month-1], day, year);
334 wprintf("<A HREF=\"readfwd?calview=day&year=%d&month=%d&day=%d\">",
335 tomorrow.year, tomorrow.month, tomorrow.day
337 wprintf("<IMG ALIGN=MIDDLE SRC=\"/static/forward.gif\""
339 wprintf("</H3></CENTER>\n");
341 wprintf("<CENTER><font color=#FFFFFF>"
342 " <A HREF=\"/display_edit_event?msgnum=0"
343 "&year=%d&month=%d&day=%d\">"
344 "Add new calendar event</A>"
349 wprintf("<A HREF=\"readfwd?calview=month&year=%d&month=%d&day=1\">"
350 "Back to month view</A>\n", year, month);
352 wprintf("</FONT></CENTER>\n");
354 wprintf("</TD>"); /* end stuff-on-the-left */
356 /* Innermost table (contains hours etc.) */
357 wprintf("<TD WIDTH=50%%>"
358 "<TABLE width=100%% border=0 cellpadding=1 cellspacing=1 "
359 "bgcolor=#4444FF>\n");
361 /* Display events before 8:00 (hour=-1 is all-day events) */
362 wprintf("<TR><TD BGCOLOR=FFFFFF VALIGN=TOP>");
363 for (hour = (-1); hour <= 7; ++hour) {
364 calendar_day_view_display_events(year, month, day, hour);
366 wprintf("</TD></TR>\n");
368 /* Now the middle of the day... */
369 for (hour = 8; hour <= 17; ++hour) { /* could do HEIGHT=xx */
370 wprintf("<TR><TD BGCOLOR=FFFFFF VALIGN=TOP>");
371 wprintf("<A HREF=\"/display_edit_event?msgnum=0"
372 "&year=%d&month=%d&day=%d&hour=%d&minute=0\">",
373 year, month, day, hour
375 wprintf("%d:00%s</A> ",
376 (hour <= 12 ? hour : hour-12),
377 (hour < 12 ? "am" : "pm")
380 /* put the data here, stupid */
381 calendar_day_view_display_events(year, month, day, hour);
383 wprintf("</TD></TR>\n");
386 /* Display events after 5:00... */
387 wprintf("<TR><TD BGCOLOR=FFFFFF VALIGN=TOP>");
388 for (hour = 18; hour <= 23; ++hour) {
389 calendar_day_view_display_events(year, month, day, hour);
391 wprintf("</TD></TR>\n");
394 wprintf("</TABLE>" /* end of innermost table */
395 "</TD></TR></TABLE>" /* end of inner table */
396 "</TD></TR></TABLE>" /* end of outer table */
406 void do_calendar_view(void) {
410 int year, month, day;
413 /* In case no date was specified, go with today */
415 tm = localtime(&now);
416 year = tm->tm_year + 1900;
417 month = tm->tm_mon + 1;
420 /* Now see if a date was specified */
421 if (strlen(bstr("year")) > 0) year = atoi(bstr("year"));
422 if (strlen(bstr("month")) > 0) month = atoi(bstr("month"));
423 if (strlen(bstr("day")) > 0) day = atoi(bstr("day"));
425 /* How would you like that cooked? */
426 if (strlen(bstr("calview")) > 0) {
427 strcpy(calview, bstr("calview"));
430 strcpy(calview, "month");
433 /* Display the selected view */
434 if (!strcasecmp(calview, "day")) {
435 calendar_day_view(year, month, day);
437 else if (!strcasecmp(calview, "week")) {
438 calendar_week_view(year, month, day);
441 calendar_month_view(year, month, day);
444 /* Free the calendar stuff */
445 if (WC->num_cal) for (i=0; i<(WC->num_cal); ++i) {
446 icalcomponent_free(WC->disp_cal[i]);
451 free(WC->cal_msgnum);
452 WC->cal_msgnum = NULL;
456 #endif /* HAVE_ICAL_H */