/*
* $Id$
+ *
+ * Displays the "Summary Page"
*/
-/**
- * \defgroup SymaryFuncs Displays the "Summary Page"
- * \ingroup WebcitDisplayItems
- */
-/*@{*/
+
#include "webcit.h"
-/**
- * \brief Display today's date in a friendly format
+/*
+ * Display today's date in a friendly format
*/
void output_date(void) {
struct tm tm;
-/**
- * \brief Dummy section
+/*
+ * Dummy section
*/
void dummy_section(void) {
- svprintf("BOXTITLE", WCS_STRING, "(dummy section)");
- do_template("beginbox");
+ svput("BOXTITLE", WCS_STRING, "(dummy section)");
+ do_template("beginboxx", NULL);
wprintf(_("(nothing)"));
- do_template("endbox");
+ do_template("endbox", NULL);
}
-/**
- * \brief New messages section
+/*
+ * New messages section
*/
void new_messages_section(void) {
char buf[SIZ];
}
-/**
- * \brief Wholist section
- */
-void wholist_section(void) {
- char buf[SIZ];
- char user[SIZ];
- time_t last_activity;
- time_t now;
-
- serv_puts("TIME");
- serv_getln(buf, sizeof buf);
- if (buf[0] == '2') {
- now = extract_long(&buf[4], 0);
- }
- else {
- now = time(NULL);
- }
-
- serv_puts("RWHO");
- serv_getln(buf, sizeof buf);
- if (buf[0] == '1') while(serv_getln(buf, sizeof buf), strcmp(buf, "000")) {
- extract_token(user, buf, 1, '|', sizeof user);
- last_activity = extract_long(buf, 5);
- if (strcmp(user, NLI)) {
- wprintf("<li class=\"");
- if ((now - last_activity) > 900L) {
- wprintf("inactiveuser");
- }
- else {
- wprintf("activeuser");
- }
- wprintf("\"><a href=\"showuser?who=");
- urlescputs(user);
- wprintf("\">");
- escputs(user);
- wprintf("</a></li>");
- }
- }
-}
-
-
-/**
- * \brief Task list section
+/*
+ * Task list section
*/
void tasks_section(void) {
-#ifdef WEBCIT_WITH_CALENDAR_SERVICE
int num_msgs = 0;
- int i;
-#endif
+ HashPos *at;
+ const char *HashKey;
+ long HKLen;
+ void *vMsg;
+ message_summary *Msg;
+ struct wcsession *WCC = WC;
-#ifdef WEBCIT_WITH_CALENDAR_SERVICE
gotoroom("_TASKS_");
- if (WC->wc_view != VIEW_TASKS) {
+ if (WCC->wc_view != VIEW_TASKS) {
num_msgs = 0;
}
else {
wprintf("</i><br />\n");
}
else {
- for (i=0; i<num_msgs; ++i) {
- display_task(WC->msgarr[i]);
+ at = GetNewHashPos(WCC->summ, 0);
+ while (GetNextHashPos(WCC->summ, at, &HKLen, &HashKey, &vMsg)) {
+ Msg = (message_summary*) vMsg;
+ display_task(Msg, 0);
}
}
calendar_summary_view();
-
-#else /* WEBCIT_WITH_CALENDAR_SERVICE */
- wprintf("<i>");
- wprintf(_("(This server does not support task lists)"));
- wprintf("</i>\n");
-#endif /* WEBCIT_WITH_CALENDAR_SERVICE */
}
-/**
- * \brief Calendar section
+/*
+ * Calendar section
*/
void calendar_section(void) {
-#ifdef WEBCIT_WITH_CALENDAR_SERVICE
int num_msgs = 0;
- int i;
-#endif
+ HashPos *at;
+ const char *HashKey;
+ long HKLen;
+ void *vMsg;
+ message_summary *Msg;
+ struct wcsession *WCC = WC;
+ struct calview c;
-#ifdef WEBCIT_WITH_CALENDAR_SERVICE
gotoroom("_CALENDAR_");
if ( (WC->wc_view != VIEW_CALENDAR) && (WC->wc_view != VIEW_CALBRIEF) ) {
num_msgs = 0;
num_msgs = load_msg_ptrs("MSGS ALL", 0);
}
+ parse_calendar_view_request(&c);
+
if (num_msgs < 1) {
wprintf("<i>");
wprintf(_("(Nothing)"));
wprintf("</i><br />\n");
}
else {
- for (i=0; i<num_msgs; ++i) {
- display_calendar(WC->msgarr[i]);
+ at = GetNewHashPos(WCC->summ, 0);
+ while (GetNextHashPos(WCC->summ, at, &HKLen, &HashKey, &vMsg)) {
+ Msg = (message_summary*) vMsg;
+ load_calendar_item(Msg, 0, &c);
}
calendar_summary_view();
}
-
-#else /* WEBCIT_WITH_CALENDAR_SERVICE */
- wprintf("<i>");
- wprintf(_("(This server does not support calendars)"));
- wprintf("</i>\n");
-#endif /* WEBCIT_WITH_CALENDAR_SERVICE */
}
-/**
- * \brief Server info section (fluff, really)
+/*
+ * Server info section (fluff, really)
*/
void server_info_section(void) {
char message[512];
snprintf(message, sizeof message,
- _("You are connected to %s, running %s with %s, and located in %s. Your system administrator is %s."),
+ _("You are connected to %s, running %s with %s, server build %s and located in %s. Your system administrator is %s."),
serv_info.serv_humannode,
serv_info.serv_software,
- SERVER,
+ PACKAGE_STRING,
+ serv_info.serv_svn_revision,
serv_info.serv_bbs_city,
serv_info.serv_sysadm);
escputs(message);
}
-/**
- * \brief summary of inner div????
+/*
+ * Now let's do three columns of crap. All portals and all groupware
+ * clients seem to want to do three columns, so we'll do three
+ * columns too. Conformity is not inherently a virtue, but there are
+ * a lot of really shallow people out there, and even though they're
+ * not people I consider worthwhile, I still want them to use WebCit.
*/
-
-
-
void summary_inner_div(void) {
- /**
- * Now let's do three columns of crap. All portals and all groupware
- * clients seem to want to do three columns, so we'll do three
- * columns too. Conformity is not inherently a virtue, but there are
- * a lot of really shallow people out there, and even though they're
- * not people I consider worthwhile, I still want them to use WebCit.
- */
-
wprintf("<div class=\"fix_scrollbar_bug\">"
- "<table border=0 width=100%%><tr valign=top>");
+ "<table width=\"100%%\" cellspacing=\"10\" cellpadding=\"0\">"
+ "<tr valign=top>");
- /**
+ /*
* Column One
*/
wprintf("<td width=33%%>");
wprintf("</div></div></div>");
wprintf("</td>");
- /**
+ /*
* Column Two
*/
wprintf("<td width=33%%>");
wprintf("</div></div></div>");
wprintf("</td>");
- /**
+ /*
* Column Three
*/
wprintf("<td width=33%%>");
wprintf("</div></div></div>");
wprintf("</td>");
- wprintf("</tr><tr valign=top>");
- wprintf("<td colspan=3><br/></td>");
wprintf("</tr><tr valign=top>");
- /**
+ /*
* Row Two - Column One
*/
wprintf("<td colspan=2>");
wprintf(_("Who's online now"));
wprintf("</div><div class=\"boxcontent\">");
wprintf("<div id=\"who_inner\">");
- who_inner_div();
+ do_template("wholistsummarysection", NULL);
wprintf("</div></div></div>");
wprintf("</td>");
- /**
+ /*
* Row Two - Column Two
*/
wprintf("<td width=33%%>");
wprintf("</td>");
- /**
+ /*
* End of columns
*/
wprintf("</tr></table>");
}
-/**
- * \brief Display this user's summary page
+/*
+ * Display this user's summary page
*/
void summary(void) {
char title[256];
output_headers(1, 1, 2, 0, 0, 0);
- wprintf("<div id=\"banner\" class=\"service\">\n");
+ wprintf("<div id=\"banner\">\n");
+ wprintf("<div class=\"room_banner\">");
wprintf("<img src=\"static/summscreen_48x.gif\">");
wprintf("<h1>");
snprintf(title, sizeof title, _("Summary page for %s"), WC->wc_fullname);
escputs(title);
- wprintf("</h1><h2>\n");
+ wprintf("</h1><h2>");
output_date();
- wprintf("</h2>");
- wprintf("<ul><li class=\"start_page\">");
- offer_start_page();
+ wprintf("</h2></div>");
+ wprintf("<ul class=\"room_actions\">\n");
+ wprintf("<li class=\"start_page\">");
+ offer_start_page(NULL, 0, NULL, NULL, CTX_NONE);
wprintf("</li></ul>");
wprintf("</div>");
- /**
+ /*
* You guessed it ... we're going to refresh using ajax.
* In the future we might consider updating individual sections of the summary
* instead of the whole thing.
*/
- wprintf("<div id=\"content\">\n");
+ wprintf("<div id=\"content\" class=\"service\">\n");
summary_inner_div();
wprintf("</div>\n");
" { method: 'get', frequency: 120 } ); "
" new Ajax.PeriodicalUpdater('calendar_inner', 'calendar_inner_html', "
" { method: 'get', frequency: 90 } ); "
- " new Ajax.PeriodicalUpdater('who_inner', 'who_inner_html', "
+ " new Ajax.PeriodicalUpdater('do_template', 'template=wholistsummarysection', "
" { method: 'get', frequency: 30 } ); "
"</script> \n"
);
wDumpContent(1);
}
+void
+InitModule_SUMMARY
+(void)
+{
+ WebcitAddUrlHandler(HKEY("new_messages_html"), new_messages_section, AJAX);
+ WebcitAddUrlHandler(HKEY("tasks_inner_html"), tasks_section, AJAX);
+ WebcitAddUrlHandler(HKEY("calendar_inner_html"), calendar_section, AJAX);
+ WebcitAddUrlHandler(HKEY("mini_calendar"), ajax_mini_calendar, AJAX);
+ WebcitAddUrlHandler(HKEY("summary"), summary, 0);
+ WebcitAddUrlHandler(HKEY("summary_inner_div"), summary_inner_div, AJAX);
+}
-/*@}*/