void output_date(void) {
struct tm tm;
time_t now;
-
- static char *wdays[7];
- static char *months[12];
-
- wdays[0] = _("Sunday");
- wdays[1] = _("Monday");
- wdays[2] = _("Tuesday");
- wdays[3] = _("Wednesday");
- wdays[4] = _("Thursday");
- wdays[5] = _("Friday");
- wdays[6] = _("Saturday");
-
- months[0] = _("January");
- months[1] = _("February");
- months[2] = _("March");
- months[3] = _("April");
- months[4] = _("May");
- months[5] = _("June");
- months[6] = _("July");
- months[7] = _("August");
- months[8] = _("September");
- months[9] = _("October");
- months[10] = _("November");
- months[11] = _("December");
+ char buf[128];
time(&now);
localtime_r(&now, &tm);
- wprintf("%s, %s %d, %d",
- wdays[tm.tm_wday],
- months[tm.tm_mon],
- tm.tm_mday,
- tm.tm_year + 1900
- );
+ wc_strftime(buf, 32, "%A, %x", &tm);
+ wprintf("%s", buf);
}
* 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);
}
int number_of_rooms_to_check;
char *rooms_to_check = "Mail|Lobby";
- svprintf("BOXTITLE", WCS_STRING, _("Messages"));
- do_template("beginbox");
number_of_rooms_to_check = num_tokens(rooms_to_check, '|');
if (number_of_rooms_to_check == 0) return;
- wprintf("<TABLE BORDER=0 WIDTH=100%%>\n");
+ wprintf("<table border=0 width=100%%>\n");
for (i=0; i<number_of_rooms_to_check; ++i) {
extract_token(room, rooms_to_check, i, '|', sizeof room);
serv_getln(buf, sizeof buf);
if (buf[0] == '2') {
extract_token(room, &buf[4], 0, '|', sizeof room);
- wprintf("<TR><TD><a href=\"dotgoto?room=");
+ wprintf("<tr><td><a href=\"dotgoto?room=");
urlescputs(room);
wprintf("\">");
escputs(room);
- wprintf("</A></TD><TD>%d/%d</TD></TR>\n",
+ wprintf("</a></td><td>%d/%d</td></tr>\n",
extract_int(&buf[4], 1),
extract_int(&buf[4], 2)
);
}
}
- wprintf("</TABLE>\n");
- do_template("endbox");
-
-}
+ wprintf("</table>\n");
-
-/*
- * Wholist section
- */
-void wholist_section(void) {
- char buf[SIZ];
- char user[SIZ];
-
- svprintf("BOXTITLE", WCS_STRING, _("Who's online now"));
- do_template("beginbox");
- 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);
- escputs(user);
- wprintf("<br />\n");
- }
- do_template("endbox");
}
* Task list section
*/
void tasks_section(void) {
-#ifdef WEBCIT_WITH_CALENDAR_SERVICE
int num_msgs = 0;
- int i;
-#endif
-
- svprintf("BOXTITLE", WCS_STRING, _("Tasks"));
- do_template("beginbox");
-#ifdef WEBCIT_WITH_CALENDAR_SERVICE
- gotoroom("_TASKS_");
- if (WC->wc_view != VIEW_TASKS) {
+ HashPos *at;
+ const char *HashKey;
+ long HKLen;
+ void *vMsg;
+ message_summary *Msg;
+ wcsession *WCC = WC;
+ StrBuf *Buf;
+
+ Buf = NewStrBufPlain(HKEY("_TASKS_"));
+ gotoroom(Buf);
+ FreeStrBuf(&Buf);
+ if (WCC->wc_view != VIEW_TASKS) {
num_msgs = 0;
}
else {
- num_msgs = load_msg_ptrs("MSGS ALL", 0);
+ num_msgs = load_msg_ptrs("MSGS ALL", 0, NULL, NULL);
+ }
+
+ if (num_msgs > 0) {
+ at = GetNewHashPos(WCC->summ, 0);
+ while (GetNextHashPos(WCC->summ, at, &HKLen, &HashKey, &vMsg)) {
+ Msg = (message_summary*) vMsg;
+ display_task(Msg, 0);
+ }
+ DeleteHashPos(&at);
}
- if (num_msgs < 1) {
+ if (calendar_summary_view() < 1) {
wprintf("<i>");
wprintf(_("(None)"));
wprintf("</i><br />\n");
}
- else {
- for (i=0; i<num_msgs; ++i) {
- display_task(WC->msgarr[i]);
- }
- }
-
- 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 */
- do_template("endbox");
}
* Calendar section
*/
void calendar_section(void) {
-#ifdef WEBCIT_WITH_CALENDAR_SERVICE
int num_msgs = 0;
- int i;
-#endif
-
- svprintf("BOXTITLE", WCS_STRING, _("Today on your calendar"));
- do_template("beginbox");
-#ifdef WEBCIT_WITH_CALENDAR_SERVICE
- gotoroom("_CALENDAR_");
- if (WC->wc_view != VIEW_CALENDAR) {
+ HashPos *at;
+ const char *HashKey;
+ long HKLen;
+ void *vMsg;
+ message_summary *Msg;
+ wcsession *WCC = WC;
+ struct calview c;
+ StrBuf *Buf;
+
+ Buf = NewStrBufPlain(HKEY("_CALENDAR_"));
+ gotoroom(Buf);
+ FreeStrBuf(&Buf);
+ if ( (WC->wc_view != VIEW_CALENDAR) && (WC->wc_view != VIEW_CALBRIEF) ) {
num_msgs = 0;
}
else {
- num_msgs = load_msg_ptrs("MSGS ALL", 0);
+ num_msgs = load_msg_ptrs("MSGS ALL", 0, NULL, NULL);
}
- if (num_msgs < 1) {
+ parse_calendar_view_request(&c);
+
+ if (num_msgs > 0) {
+ at = GetNewHashPos(WCC->summ, 0);
+ while (GetNextHashPos(WCC->summ, at, &HKLen, &HashKey, &vMsg)) {
+ Msg = (message_summary*) vMsg;
+ load_calendar_item(Msg, 0, &c);
+ }
+ DeleteHashPos(&at);
+ }
+ if (calendar_summary_view() < 1) {
wprintf("<i>");
wprintf(_("(Nothing)"));
wprintf("</i><br />\n");
}
- else {
- for (i=0; i<num_msgs; ++i) {
- display_calendar(WC->msgarr[i]);
- }
- 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 */
- do_template("endbox");
}
/*
*/
void server_info_section(void) {
char message[512];
-
- svprintf("BOXTITLE", WCS_STRING, _("About this server"));
- do_template("beginbox");
+ wcsession *WCC = WC;
snprintf(message, sizeof message,
- _("You are connected to %s, running %s with %s, and located in %s. Your system administrator is %s."),
- serv_info.serv_humannode,
- serv_info.serv_software,
- SERVER,
- serv_info.serv_bbs_city,
- serv_info.serv_sysadm);
+ _("You are connected to %s, running %s with %s, server build %s and located in %s. Your system administrator is %s."),
+ ChrPtr(WCC->serv_info->serv_humannode),
+ ChrPtr(WCC->serv_info->serv_software),
+ PACKAGE_STRING,
+ ChrPtr(WCC->serv_info->serv_svn_revision),
+ ChrPtr(WCC->serv_info->serv_bbs_city),
+ ChrPtr(WCC->serv_info->serv_sysadm));
escputs(message);
- do_template("endbox");
}
+/*
+ * 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 id=\"fix_scrollbar_bug\">"
- "<table border=0 width=100%%><tr valign=top>");
+ wprintf("<div class=\"fix_scrollbar_bug\">"
+ "<table width=\"100%%\" cellspacing=\"10\" cellpadding=\"0\">"
+ "<tr valign=top>");
/*
* Column One
*/
wprintf("<td width=33%%>");
- wholist_section();
+ wprintf("<div class=\"box\">");
+ wprintf("<div class=\"boxlabel\">");
+ wprintf(_("Messages"));
+ wprintf("</div><div class=\"boxcontent\">");
+ wprintf("<div id=\"msg_inner\">");
+ new_messages_section();
+ wprintf("</div></div></div>");
+ wprintf("</td>");
/*
- * Column Two
+ * Column Two
*/
- wprintf("</td><td width=33%%>");
- server_info_section();
- wprintf("<br />");
+ wprintf("<td width=33%%>");
+ wprintf("<div class=\"box\">");
+ wprintf("<div class=\"boxlabel\">");
+ wprintf(_("Tasks"));
+ wprintf("</div><div class=\"boxcontent\">");
+ wprintf("<div id=\"tasks_inner\">");
tasks_section();
+ wprintf("</div></div></div>");
+ wprintf("</td>");
/*
* Column Three
*/
- wprintf("</td><td width=33%%>");
- new_messages_section();
- wprintf("<br />");
+ wprintf("<td width=33%%>");
+ wprintf("<div class=\"box\">");
+ wprintf("<div class=\"boxlabel\">");
+ wprintf(_("Today on your calendar"));
+ wprintf("</div><div class=\"boxcontent\">");
+ wprintf("<div id=\"calendar_inner\">");
calendar_section();
+ wprintf("</div></div></div>");
+ wprintf("</td>");
+
+ wprintf("</tr><tr valign=top>");
+
+ /*
+ * Row Two - Column One
+ */
+ wprintf("<td colspan=2>");
+ wprintf("<div class=\"box\">");
+ wprintf("<div class=\"boxlabel\">");
+ wprintf(_("Who's online now"));
+ wprintf("</div><div class=\"boxcontent\">");
+ wprintf("<div id=\"who_inner\">");
+ do_template("wholistsummarysection", NULL);
+ wprintf("</div></div></div>");
+ wprintf("</td>");
+
+ /*
+ * Row Two - Column Two
+ */
+ wprintf("<td width=33%%>");
+ wprintf("<div class=\"box\">");
+ wprintf("<div class=\"boxlabel\">");
+ wprintf(_("About this server"));
+ wprintf("</div><div class=\"boxcontent\">");
+ wprintf("<div id=\"info_inner\">");
+ server_info_section();
+ wprintf("</div></div></div>");
+ wprintf("</td>");
+
/*
* End of columns
*/
- wprintf("</td></tr></table>");
+ wprintf("</tr></table>");
}
output_headers(1, 1, 2, 0, 0, 0);
wprintf("<div id=\"banner\">\n");
- wprintf("<TABLE WIDTH=100%% BORDER=0 BGCOLOR=#444455><TR>"
- "<TD><img src=\"static/summscreen_48x.gif\"></TD><TD>"
- "<SPAN CLASS=\"titlebar\">"
- );
-
- snprintf(title, sizeof title, _("Summary page for %s"), WC->wc_username);
- escputs(title);
- wprintf("</SPAN></TD><TD>\n");
- wprintf("</TD><TD ALIGN=RIGHT><SPAN CLASS=\"titlebar\">");
- output_date();
- wprintf("</SPAN><br />");
- offer_start_page();
- wprintf("</TD></TR></TABLE>\n");
+ wprintf("<div class=\"room_banner\">");
+ wprintf("<img src=\"static/summscreen_48x.gif\">");
+ wprintf("<h1>");
+ snprintf(title, sizeof title, _("Summary page for %s"), ChrPtr(WC->wc_fullname));
+ escputs(title);
+ wprintf("</h1><h2>");
+ output_date();
+ wprintf("</h2></div>");
+ wprintf("<div id=\"actiondiv\">");
+ wprintf("<ul class=\"room_actions\">\n");
+ wprintf("<li class=\"start_page\">");
+ offer_start_page(NULL, &NoCtx);
+ wprintf("</li></ul>");
+ wprintf("</div>");
+ 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>\n<div id=\"content\">\n");
+ wprintf("<div id=\"content\" class=\"service\">\n");
summary_inner_div();
wprintf("</div>\n");
wprintf(
"<script type=\"text/javascript\"> "
- " new Ajax.PeriodicalUpdater('content', 'summary_inner_div', "
+ " new Ajax.PeriodicalUpdater('msg_inner', 'new_messages_html', "
" { method: 'get', frequency: 60 } ); "
+ " new Ajax.PeriodicalUpdater('tasks_inner', 'tasks_inner_html', "
+ " { method: 'get', frequency: 120 } ); "
+ " new Ajax.PeriodicalUpdater('calendar_inner', 'calendar_inner_html', "
+ " { method: 'get', frequency: 90 } ); "
+ " 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);
+}
+