X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fsummary.c;h=faa4f45b2d82b02e59316919d1d2e7247ce4dc88;hb=HEAD;hp=d3457e71af395c23d9927a97fd631001eb4daa72;hpb=f43c81d6ac4e26ed2ce7e22ad7aa39be859520f7;p=citadel.git diff --git a/webcit/summary.c b/webcit/summary.c index d3457e71a..5dbe60435 100644 --- a/webcit/summary.c +++ b/webcit/summary.c @@ -1,15 +1,24 @@ /* - * $Id$ + * Displays the "Summary Page" + * + * Copyright (c) 1996-2021 by the citadel.org team + * + * This program is open source software. You can redistribute it and/or + * modify it under the terms of the GNU General Public License, version 3. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. */ -/** - * \defgroup SymaryFuncs Displays the "Summary Page" - * \ingroup WebcitDisplayItems - */ -/*@{*/ + #include "webcit.h" +#include "calendar.h" -/** - * \brief Display today's date in a friendly format +extern int calendar_summary_view(void); + +/* + * Display today's date in a friendly format */ void output_date(void) { struct tm tm; @@ -20,25 +29,26 @@ void output_date(void) { localtime_r(&now, &tm); wc_strftime(buf, 32, "%A, %x", &tm); - wprintf("%s", buf); + 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); - -/** - * \brief Dummy section - */ -void dummy_section(void) { - svprintf("BOXTITLE", WCS_STRING, "(dummy section)"); - do_template("beginbox"); - wprintf(_("(nothing)")); - do_template("endbox"); + n = wc_strftime(buf, 32, "%A, %x", &tm); + StrBufAppendBufPlain(Target, buf, n, 0); } -/** - * \brief New messages section +/* + * New messages section */ void new_messages_section(void) { char buf[SIZ]; @@ -51,7 +61,7 @@ void new_messages_section(void) { number_of_rooms_to_check = num_tokens(rooms_to_check, '|'); if (number_of_rooms_to_check == 0) return; - wprintf("\n"); + wc_printf("
\n"); for (i=0; i\n", + wc_printf("\n", extract_int(&buf[4], 1), extract_int(&buf[4], 2) ); } } - wprintf("
"); + wc_printf("\">"); escputs(room); - wprintf("%d/%d
%d/%d
\n"); - -} - - -/** - * \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); - } + wc_printf("\n"); - 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("
  • 900L) { - wprintf("inactiveuser"); - } - else { - wprintf("activeuser"); - } - wprintf("\">"); - escputs(user); - wprintf("
  • "); - } - } } -/** - * \brief Task list section +/* + * Task list section */ void tasks_section(void) { -#ifdef WEBCIT_WITH_CALENDAR_SERVICE int num_msgs = 0; - int i; -#endif - -#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; + StrBuf *Buf; + SharedMessageStatus Stat; + + memset(&Stat, 0, sizeof(SharedMessageStatus)); + Stat.maxload = 10000; + Stat.lowest_found = (-1); + Stat.highest_found = (-1); + + Buf = NewStrBufPlain(HKEY("_TASKS_")); + gotoroom(Buf); + FreeStrBuf(&Buf); + + if (WC->CurRoom.view != VIEW_TASKS) { num_msgs = 0; } else { - num_msgs = load_msg_ptrs("MSGS ALL", 0); + num_msgs = load_msg_ptrs("MSGS ALL", NULL, NULL, &Stat, NULL, NULL, NULL, NULL, 0); } - if (num_msgs < 1) { - wprintf(""); - wprintf(_("(None)")); - wprintf("
    \n"); - } - else { - for (i=0; imsgarr[i]); + if (num_msgs > 0) { + at = GetNewHashPos(WC->summ, 0); + while (GetNextHashPos(WC->summ, at, &HKLen, &HashKey, &vMsg)) { + Msg = (message_summary*) vMsg; + tasks_LoadMsgFromServer(NULL, NULL, Msg, 0, 0); } + DeleteHashPos(&at); } - calendar_summary_view(); - -#else /* WEBCIT_WITH_CALENDAR_SERVICE */ - wprintf(""); - wprintf(_("(This server does not support task lists)")); - wprintf("\n"); -#endif /* WEBCIT_WITH_CALENDAR_SERVICE */ + if (calendar_summary_view() < 1) { + wc_printf(""); + wc_printf(_("(None)")); + wc_printf("
    \n"); + } } -/** - * \brief Calendar section +/* + * Calendar section */ void calendar_section(void) { -#ifdef WEBCIT_WITH_CALENDAR_SERVICE + char cmd[SIZ]; + char filter[SIZ]; int num_msgs = 0; - int i; -#endif - -#ifdef WEBCIT_WITH_CALENDAR_SERVICE - gotoroom("_CALENDAR_"); - if ( (WC->wc_view != VIEW_CALENDAR) && (WC->wc_view != VIEW_CALBRIEF) ) { + HashPos *at; + const char *HashKey; + long HKLen; + void *vMsg; + message_summary *Msg; + StrBuf *Buf; + void *v = NULL; + SharedMessageStatus Stat; + + memset(&Stat, 0, sizeof(SharedMessageStatus)); + Stat.maxload = 10000; + Stat.lowest_found = (-1); + Stat.highest_found = (-1); + + Buf = NewStrBufPlain(HKEY("_CALENDAR_")); + gotoroom(Buf); + FreeStrBuf(&Buf); + if ( (WC->CurRoom.view != VIEW_CALENDAR) && (WC->CurRoom.view != VIEW_CALBRIEF) ) { num_msgs = 0; } else { - num_msgs = load_msg_ptrs("MSGS ALL", 0); + num_msgs = load_msg_ptrs("MSGS ALL", NULL, NULL, &Stat, NULL, NULL, NULL, NULL, 0); } - - if (num_msgs < 1) { - wprintf(""); - wprintf(_("(Nothing)")); - wprintf("
    \n"); - } - else { - for (i=0; imsgarr[i]); + calendar_GetParamsGetServerCall(&Stat, + &v, + readnew, + cmd, + sizeof(cmd), + filter, + sizeof(filter)); + + + if (num_msgs > 0) { + at = GetNewHashPos(WC->summ, 0); + while (GetNextHashPos(WC->summ, at, &HKLen, &HashKey, &vMsg)) { + Msg = (message_summary*) vMsg; + calendar_LoadMsgFromServer(NULL, &v, Msg, 0, 0); } - calendar_summary_view(); + DeleteHashPos(&at); } - -#else /* WEBCIT_WITH_CALENDAR_SERVICE */ - wprintf(""); - wprintf(_("(This server does not support calendars)")); - wprintf("\n"); -#endif /* WEBCIT_WITH_CALENDAR_SERVICE */ -} - -/** - * \brief 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."), - serv_info.serv_humannode, - serv_info.serv_software, - SERVER, - serv_info.serv_bbs_city, - serv_info.serv_sysadm); - escputs(message); + if (calendar_summary_view() < 1) { + wc_printf(""); + wc_printf(_("(Nothing)")); + wc_printf("
    \n"); + } + __calendar_Cleanup(&v); } -/** - * \brief summary of inner div???? - */ - - - -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("
    " - ""); - - /** - * Column One - */ - wprintf(""); - - /** - * Column Two - */ - wprintf(""); - - /** - * Column Three - */ - wprintf(""); - - wprintf(""); - wprintf(""); - wprintf(""); - - /** - * Row Two - Column One - */ - wprintf(""); - - /** - * Row Two - Column Two - */ - wprintf(""); - - - /** - * End of columns - */ - wprintf("
    "); - wprintf("
    "); - wprintf("
    "); - wprintf(_("Messages")); - wprintf("
    "); - wprintf("
    "); +void tmplput_new_messages_section(StrBuf *Target, WCTemplputParams *TP) { new_messages_section(); - wprintf("
    "); - wprintf("
    "); - wprintf("
    "); - wprintf("
    "); - wprintf(_("Tasks")); - wprintf("
    "); - wprintf("
    "); +} +void tmplput_tasks_section(StrBuf *Target, WCTemplputParams *TP) { tasks_section(); - wprintf("
    "); - wprintf("
    "); - wprintf("
    "); - wprintf("
    "); - wprintf(_("Today on your calendar")); - wprintf("
    "); - wprintf("
    "); +} +void tmplput_calendar_section(StrBuf *Target, WCTemplputParams *TP) { calendar_section(); - wprintf("
    "); - wprintf("

    "); - wprintf("
    "); - wprintf("
    "); - wprintf(_("Who's online now")); - wprintf("
    "); - wprintf("
    "); - who_inner_div(); - wprintf("
    "); - wprintf("
    "); - wprintf("
    "); - wprintf("
    "); - wprintf(_("About this server")); - wprintf("
    "); - wprintf("
    "); - server_info_section(); - wprintf("
    "); - wprintf("
    "); } -/** - * \brief Display this user's summary page +/* + * summary page */ -void summary(void) { - char title[256]; - - output_headers(1, 1, 2, 0, 0, 0); - wprintf("
    \n"); - wprintf("
    \n"); - wprintf(""); - wprintf("

    "); - snprintf(title, sizeof title, _("Summary page for %s"), WC->wc_fullname); - escputs(title); - wprintf("

    \n"); - output_date(); - wprintf("

    "); - wprintf("
    • "); - offer_start_page(); - wprintf("
    "); - wprintf("
    "); - - /** - * 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("
    \n"); - summary_inner_div(); - wprintf("
    \n"); - - wprintf( - " \n" - ); - +void display_summary_page(void) +{ + output_headers(1, 1, 1, 0, 0, 0); + do_template("summary_page"); wDumpContent(1); } -/*@}*/ +void +InitModule_SUMMARY +(void) +{ + RegisterNamespace("TIME:NOW", 0, 0, tmplput_output_date, NULL, CTX_NONE); + WebcitAddUrlHandler(HKEY("summary"), "", 0, display_summary_page, ANONYMOUS); + 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); +} +