X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fsummary.c;h=172a15486703d700279a37f4ee2abac124a1dee8;hb=4b4dc864ede7c5d8d956febe4a0afb422b78e7c4;hp=1e0d8e160865175109f668dfa862a9e272d84817;hpb=fd034bea666febed8eff22cf10f2b72b8b009665;p=citadel.git diff --git a/webcit/summary.c b/webcit/summary.c index 1e0d8e160..172a15486 100644 --- a/webcit/summary.c +++ b/webcit/summary.c @@ -21,6 +21,8 @@ #include "webcit.h" #include "calendar.h" +extern int calendar_summary_view(void); + /* * Display today's date in a friendly format */ @@ -36,6 +38,21 @@ void output_date(void) { wc_printf("%s", buf); } +void tmplput_output_date(StrBuf *Target, WCTemplputParams *TP) +{ + struct tm tm; + time_t now; + char buf[128]; + size_t n; + + time(&now); + localtime_r(&now, &tm); + + n = wc_strftime(buf, 32, "%A, %x", &tm); + StrBufAppendBufPlain(Target, buf, n, 0); +} + + /* * New messages section */ @@ -50,7 +67,7 @@ void new_messages_section(void) { number_of_rooms_to_check = num_tokens(rooms_to_check, '|'); if (number_of_rooms_to_check == 0) return; - wc_printf("\n"); + wc_printf("
\n"); for (i=0; i 0) { @@ -125,6 +142,7 @@ void tasks_section(void) { */ void calendar_section(void) { char cmd[SIZ]; + char filter[SIZ]; int num_msgs = 0; HashPos *at; const char *HashKey; @@ -148,13 +166,16 @@ void calendar_section(void) { num_msgs = 0; } else { - num_msgs = load_msg_ptrs("MSGS ALL", &Stat, NULL); + num_msgs = load_msg_ptrs("MSGS ALL", NULL, &Stat, NULL); } calendar_GetParamsGetServerCall(&Stat, &v, readnew, cmd, - sizeof(cmd)); + sizeof(cmd), + filter, + sizeof(filter)); + if (num_msgs > 0) { at = GetNewHashPos(WCC->summ, 0); @@ -172,171 +193,28 @@ void calendar_section(void) { __calendar_Cleanup(&v); } -/* - * Server info section (fluff, really) - */ -void server_info_section(void) { - char message[512]; - wcsession *WCC = WC; - - snprintf(message, sizeof message, - _("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); -} - -/* - * 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) { - - wc_printf("
"); - wc_printf(""); - - /* - * Column One - */ - wc_printf(""); - - /* - * Column Two - */ - wc_printf(""); - - /* - * Column Three - */ - wc_printf(""); - - wc_printf(""); - - /* - * Row Two - Column One - */ - wc_printf(""); - - /* - * Row Two - Column Two - */ - wc_printf(""); - - - /* - * End of columns - */ - wc_printf("
"); - wc_printf("
"); - wc_printf("
"); - wc_printf(_("Messages")); - wc_printf("
"); - wc_printf("
"); +void tmplput_new_messages_section(StrBuf *Target, WCTemplputParams *TP) { new_messages_section(); - wc_printf("
"); - wc_printf("
"); - wc_printf("
"); - wc_printf("
"); - wc_printf(_("Tasks")); - wc_printf("
"); - wc_printf("
"); +} +void tmplput_tasks_section(StrBuf *Target, WCTemplputParams *TP) { tasks_section(); - wc_printf("
"); - wc_printf("
"); - wc_printf("
"); - wc_printf("
"); - wc_printf(_("Today on your calendar")); - wc_printf("
"); - wc_printf("
"); - calendar_section(); - wc_printf("
"); - wc_printf("
"); - wc_printf("
"); - wc_printf("
"); - wc_printf(_("Who's online now")); - wc_printf("
"); - wc_printf("
"); - do_template("who_summary"); - wc_printf("
"); - wc_printf("
"); - wc_printf("
"); - wc_printf("
"); - wc_printf(_("About this server")); - wc_printf("
"); - wc_printf("
"); - server_info_section(); - wc_printf("
"); - wc_printf("
"); } - - -/* - * Display this user's summary page - */ -void summary(void) { - char title[256]; - - output_headers(1, 1, 2, 0, 0, 0); - wc_printf("
\n"); - wc_printf(""); - wc_printf(""); - wc_printf("

"); - snprintf(title, sizeof title, _("Summary page for %s"), - ( (WC->logged_in) ? ChrPtr(WC->wc_fullname) : ChrPtr(WC->serv_info->serv_humannode)) - ); - escputs(title); - wc_printf("

"); - output_date(); - wc_printf("

"); - wc_printf("
"); - wc_printf(""); - wc_printf("
"); /* actiondiv */ - wc_printf("
"); /* banner */ - - /* - * 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. - */ - wc_printf("
\n"); - summary_inner_div(); - wc_printf("
\n"); - - wc_printf( - " \n" - ); - - wDumpContent(1); +void tmplput_calendar_section(StrBuf *Target, WCTemplputParams *TP) { + calendar_section(); } void InitModule_SUMMARY (void) { + RegisterNamespace("TIME:NOW", 0, 0, tmplput_output_date, NULL, CTX_NONE); + RegisterNamespace("SUMMARY:NEWMESSAGES_SELECTION", 0, 0, tmplput_new_messages_section, NULL, CTX_NONE); + RegisterNamespace("SUMMARY:TASKSSECTION", 0, 0, tmplput_tasks_section, NULL, CTX_NONE); + RegisterNamespace("SUMMARY:CALENDAR_SECTION", 0, 0, tmplput_calendar_section, NULL, CTX_NONE); + WebcitAddUrlHandler(HKEY("new_messages_html"), "", 0, new_messages_section, AJAX); WebcitAddUrlHandler(HKEY("tasks_inner_html"), "", 0, tasks_section, AJAX); WebcitAddUrlHandler(HKEY("calendar_inner_html"), "", 0, calendar_section, AJAX); - WebcitAddUrlHandler(HKEY("mini_calendar"), "", 0, ajax_mini_calendar, AJAX); - WebcitAddUrlHandler(HKEY("summary"), "", 0, summary, 0); - WebcitAddUrlHandler(HKEY("summary_inner_div"), "", 0, summary_inner_div, AJAX); + }