}
/* Go back to the room we're supposed to be in */
- serv_printf("GOTO %s", WC->wc_roomname);
+ serv_printf("GOTO %s", ChrPtr(WC->wc_roomname));
serv_getln(buf, sizeof buf);
}
}
/** Go back to the room we're supposed to be in */
- serv_printf("GOTO %s", WC->wc_roomname);
+ serv_printf("GOTO %s", ChrPtr(WC->wc_roomname));
serv_getln(buf, sizeof buf);
}
StrBuf *pref_name, *pref_value;
pref_name = NewStrBuf ();
- StrBufPrintf(pref_name, "%s %s", key, WC->wc_roomname);
+ StrBufPrintf(pref_name, "%s %s", key, ChrPtr(WC->wc_roomname));
get_pref(pref_name, &pref_value);
FreeStrBuf(&pref_name);
return pref_value;
StrBuf *pref_name;
pref_name = NewStrBuf ();
- StrBufPrintf(pref_name, "%s %s", key, WC->wc_roomname);
+ StrBufPrintf(pref_name, "%s %s", key, ChrPtr(WC->wc_roomname));
set_PREFERENCE(ChrPtr(pref_name), StrLength(pref_name), value, save_to_server);
FreeStrBuf(&pref_name);
}
-/**
- * \brief display form for changing your preferences and settings
- */
-void display_preferences(void)
-{
- output_headers(1, 1, 1, 0, 0, 0);
- StrBuf *ebuf = NULL;
- int i;
- long DayEnd, DayStart, WeekStart;
- int UseSig, ShowEmptyFloors;
- int time_format;
- time_t tt;
- struct tm tm;
- char daylabel[32];
- StrBuf *Buf;
- StrBuf *Signature;
-
- time_format = get_time_format_cached ();
-
- wprintf("<div class=\"box\">\n");
- wprintf("<div class=\"boxlabel\">");
- wprintf(_("Preferences and settings"));
- wprintf("</div>");
-
- wprintf("<div class=\"boxcontent\">");
-
- /** begin form */
- wprintf("<form name=\"prefform\" action=\"set_preferences\" "
- "method=\"post\">\n");
- wprintf("<input type=\"hidden\" name=\"nonce\" value=\"%d\">\n", WC->nonce);
-
- /** begin table */
- wprintf("<table class=\"altern\">\n");
-
- /**
- * Room list view
- */
- get_preference("roomlistview", &Buf);
- wprintf("<tr class=\"even\"><td>");
- wprintf(PrefGetLocalStr(HKEY("roomlistview")));
- wprintf("</td><td>");
-
- wprintf("<input type=\"radio\" name=\"roomlistview\" VALUE=\"folders\"");
- if (!strcasecmp(ChrPtr(Buf), "folders")) wprintf(" checked");
- wprintf(">");
- wprintf(_("Tree (folders) view"));
- wprintf("</input> ");
-
- wprintf("<input type=\"radio\" name=\"roomlistview\" VALUE=\"rooms\"");
- if (IsEmptyStr(ChrPtr(Buf)) || !strcasecmp(ChrPtr(Buf), "rooms")) wprintf(" checked");
- wprintf(">");
- wprintf(_("Table (rooms) view"));
- wprintf("</input>\n");
-
- wprintf("</td></tr>\n");
-
- /**
- * Time hour format
- */
-
- wprintf("<tr class=\"odd\"><td>");
- wprintf(PrefGetLocalStr(HKEY("calhourformat")));
- wprintf("</td><td>");
-
- wprintf("<input type=\"radio\" name=\"calhourformat\" VALUE=\"12\"");
- if (time_format == WC_TIMEFORMAT_AMPM)
- wprintf(" checked");
- wprintf(">");
- wprintf(_("12 hour (am/pm)"));
- wprintf("</input> ");
-
- wprintf("<input type=\"radio\" name=\"calhourformat\" VALUE=\"24\"");
- if (time_format == WC_TIMEFORMAT_24)
- wprintf(" checked");
- wprintf(">");
- wprintf(_("24 hour"));
- wprintf("</input>\n");
-
- wprintf("</td></tr>\n");
-
- /**
- * Calendar day view -- day start time
- */
- get_pref_long("daystart", &DayStart, 8);
-
- wprintf("<tr class=\"even\"><td>");
- wprintf(PrefGetLocalStr(HKEY("daystart")));
- wprintf("</td><td>");
-
- wprintf("<select name=\"daystart\" size=\"1\">\n");
- for (i=0; i<=23; ++i) {
-
- if (time_format == WC_TIMEFORMAT_24) {
- wprintf("<option %s value=\"%d\">%d:00</option>\n",
- ((DayStart == i) ? "selected" : ""),
- i, i
- );
- }
- else {
- wprintf("<option %s value=\"%d\">%s</option>\n",
- ((DayStart == i) ? "selected" : ""),
- i, hourname[i]
- );
- }
-
- }
- wprintf("</select>\n");
- wprintf("</td></tr>\n");
-
- /**
- * Calendar day view -- day end time
- */
- get_pref_long("dayend", &DayEnd, 17);
-
- wprintf("<tr class=\"odd\"><td>");
- wprintf(PrefGetLocalStr(HKEY("dayend")));
- wprintf("</td><td>");
-
- wprintf("<select name=\"dayend\" size=\"1\">\n");
- for (i=0; i<=23; ++i) {
-
- if (time_format == WC_TIMEFORMAT_24) {
- wprintf("<option %s value=\"%d\">%d:00</option>\n",
- ((DayEnd == i) ? "selected" : ""),
- i, i
- );
- }
- else {
- wprintf("<option %s value=\"%d\">%s</option>\n",
- ((DayEnd == i) ? "selected" : ""),
- i, hourname[i]
- );
- }
-
- }
- wprintf("</select>\n");
- wprintf("</td></tr>\n");
-
- /**
- * Day of week to begin calendar month view
- */
- get_pref_long("weekstart", &WeekStart, 17);
- wprintf("<tr class=\"even\"><td>");
- wprintf(PrefGetLocalStr(HKEY("weekstart")));
- wprintf("</td><td>");
-
- wprintf("<select name=\"weekstart\" size=\"1\">\n");
-
- for (i=0; i<=1; ++i) {
- tt = time(NULL);
- localtime_r(&tt, &tm);
- tm.tm_wday = i;
- wc_strftime(daylabel, sizeof daylabel, "%A", &tm);
-
- wprintf("<option %s value=\"%d\">%s</option>\n",
- ((WeekStart == i) ? "selected" : ""),
- i, daylabel
- );
- }
-
- wprintf("</select>\n");
- wprintf("</td></tr>\n");
-
- /**
- * Signature
- */
- get_pref_yesno("use_sig", &UseSig, 0);
- wprintf("<tr class=\"odd\"><td>");
- wprintf(_("Attach signature to email messages?"));
- wprintf("</td><td>");
-
- wprintf(" <script type=\"text/javascript\"> "
- " function show_or_hide_sigbox() { "
- " if ( $F('yes_sig') ) { "
- " $('signature_box').style.display = 'inline'; "
- " } "
- " else { "
- " $('signature_box').style.display = 'none'; "
- " } "
- " } "
- " </script> "
- );
-
- wprintf(PrefGetLocalStr(HKEY("use_sig")));
-
- wprintf("<input type=\"radio\" id=\"no_sig\" name=\"use_sig\" VALUE=\"no\"");
- if (!UseSig) wprintf(" checked");
- wprintf(" onChange=\"show_or_hide_sigbox();\" >");
- wprintf(_("No signature"));
- wprintf("</input> , \n");
-
- wprintf("<input type=\"radio\" id=\"yes_sig\" name=\"use_sig\" VALUE=\"yes\"");
- if (UseSig) wprintf(" checked");
- wprintf(" onChange=\"show_or_hide_sigbox();\" >");
- wprintf(PrefGetLocalStr(HKEY("signature")));
- wprintf("<div id=\"signature_box\">"
- "<br><textarea name=\"signature\" cols=\"40\" rows=\"5\">"
- );
-
- get_preference("signature", &Signature);
- ebuf = NewStrBuf();
- StrBufEUid_unescapize(ebuf, Signature);
- StrEscPuts(ebuf);
- FreeStrBuf(&ebuf);
- wprintf("</textarea>"
- "</div>"
- );
-
- wprintf("</input>\n");
-
- wprintf("</td></tr>\n");
-
- wprintf(" <script type=\"text/javascript\"> "
- " show_or_hide_sigbox(); "
- " </script> "
- );
-
- /** Character set to assume is in use for improperly encoded headers */
- if (!get_preference("default_header_charset", &Buf)) {
- Buf = NewStrBuf();
- StrBufPrintf(Buf, "%s", "UTF-8");
- set_preference("default_header_charset", Buf, 0);
- }
- wprintf("<tr class=\"even\"><td>");
- wprintf(PrefGetLocalStr(HKEY("default_header_charset")));
- wprintf("</td><td>");
- wprintf("<input type=\"text\" NAME=\"default_header_charset\" MAXLENGTH=\"32\" VALUE=\"");
- StrEscPuts(Buf); // here shouldn't be bad chars, so...
- wprintf("\">");
- wprintf("</td></tr>");
-
- /**
- * Show empty floors?
- */
-
- get_pref_yesno("emptyfloors", &ShowEmptyFloors, 0);
- wprintf("<tr class=\"odd\"><td>");
- wprintf(PrefGetLocalStr(HKEY("emptyfloors")));
- wprintf("</td><td>");
-
- wprintf("<input type=\"radio\" name=\"emptyfloors\" VALUE=\"yes\"");
- if (ShowEmptyFloors) wprintf(" checked");
- wprintf(">");
- wprintf(_("Yes"));
- wprintf("</input> ");
-
- wprintf("<input type=\"radio\" name=\"emptyfloors\" VALUE=\"no\"");
- if (!ShowEmptyFloors) wprintf(" checked");
- wprintf(">");
- wprintf(_("No"));
- wprintf("</input>\n");
-
- wprintf("</td></tr>\n");
-
- /** end table */
- wprintf("</table>\n");
-
- /** submit buttons */
- wprintf("<div class=\"buttons\"> ");
- wprintf("<input type=\"submit\" name=\"change_button\" value=\"%s\">"
- " "
- "<INPUT type=\"submit\" name=\"cancel_button\" value=\"%s\">\n",
- _("Change"),
- _("Cancel")
- );
- wprintf("</div>\n");
-
- /** end form */
- wprintf("</form>\n");
- wprintf("</div>\n");
- wDumpContent(1);
-}
-
-
-
-
/*
* Offer to make any page the user's "start page."
*/
-void offer_start_page(StrBuf *Target, int nArgs, WCTemplateToken *Token, void *Context, int ContextType) {
+void offer_start_page(StrBuf *Target, WCTemplputParams *TP)
+{
wprintf("<a href=\"change_start_page?startpage=");
urlescputs(WC->this_page);
wprintf("\">");
wprintf("</a>");
#ifdef TECH_PREVIEW
wprintf("<br/><a href=\"rss?room=");
- urlescputs(WC->wc_roomname);
+ urlescputs(ChrPtr(WC->wc_roomname));
wprintf("\" title=\"RSS 2.0 feed for ");
- escputs(WC->wc_roomname);
+ escputs(ChrPtr(WC->wc_roomname));
wprintf("\"><img alt=\"RSS\" border=\"0\" src=\"static/xml_button.gif\"/></a>\n");
#endif
}
set_preference("defaultfrom", NewStrBufDup(sbstr("defaultfrom")), 0);
set_preference("defaultname", NewStrBufDup(sbstr("defaultname")), 0);
set_preference("defaulthandle", NewStrBufDup(sbstr("defaulthandle")), 0);
+ set_preference("mailbox", NewStrBufDup(sbstr("mailbox")), 0);
buf = NewStrBufPlain(bstr("signature"), -1);
#define PRF_YESNO 4
-void tmplput_CFG_Value(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType)
+void tmplput_CFG_Value(StrBuf *Target, WCTemplputParams *TP)
{
StrBuf *Setting;
if (get_PREFERENCE(TKEY(0), &Setting))
- StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Setting, 1);
+ StrBufAppendTemplate(Target, TP, Setting, 1);
}
-void tmplput_CFG_Descr(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType)
+void tmplput_CFG_Descr(StrBuf *Target, WCTemplputParams *TP)
{
const char *SettingStr;
SettingStr = PrefGetLocalStr(TKEY(0));
if (SettingStr != NULL)
StrBufAppendBufPlain(Target, SettingStr, -1, 0);
}
-
-
-void CfgZoneTempl(StrBuf *TemplBuffer, void *vContext, WCTemplateToken *Token)
+void tmplput_CFG_RoomValue(StrBuf *Target, WCTemplputParams *TP)
{
- StrBuf *Zone = (StrBuf*) vContext;
+ StrBuf *pref = get_ROOM_PREFS(TKEY(0));
+ if (pref != NULL)
+ StrBufAppendBuf(Target, pref, 0);
+}
+int ConditionalHasRoomPreference(WCTemplateToken *Tokens, void *Context, int ContextType) {
+ if (get_ROOM_PREFS(Tokens->Params[0]->Start, Tokens->Params[0]->len) != NULL)
+ return 1;
+
+ return 0;
+}
+void CfgZoneTempl(StrBuf *TemplBuffer, WCTemplputParams *TP)
+{
+ StrBuf *Zone = (StrBuf*) CTX;
SVPutBuf("ZONENAME", Zone, 1);
}
-int ConditionalPreference(WCTemplateToken *Tokens, void *Context, int ContextType)
+int ConditionalPreference(StrBuf *Target, WCTemplputParams *TP)
{
StrBuf *Pref;
if (!get_PREFERENCE(TKEY(2), &Pref))
return 0;
- if (Tokens->nParameters == 3) {
+ if (TP->Tokens->nParameters == 3) {
return 1;
}
- else if (Tokens->Params[3]->Type == TYPE_STR)
- return ((Tokens->Params[3]->len == StrLength(Pref)) &&
- (strcmp(Tokens->Params[3]->Start, ChrPtr(Pref)) == 0));
+ else if (TP->Tokens->Params[3]->Type == TYPE_STR)
+ return ((TP->Tokens->Params[3]->len == StrLength(Pref)) &&
+ (strcmp(TP->Tokens->Params[3]->Start, ChrPtr(Pref)) == 0));
else
- return (StrTol(Pref) == Tokens->Params[3]->lvalue);
+ return (StrTol(Pref) == TP->Tokens->Params[3]->lvalue);
}
-int ConditionalHazePreference(WCTemplateToken *Tokens, void *Context, int ContextType)
+int ConditionalHasPreference(StrBuf *Target, WCTemplputParams *TP)
{
StrBuf *Pref;
return 1;
}
-HashList *GetGVEAHash(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType)
+HashList *GetGVEAHash(StrBuf *Target, WCTemplputParams *TP)
{
StrBuf *Rcp;
HashList *List = NULL;
Rcp = NewStrBuf();
serv_puts("GVEA");
StrBuf_ServGetln(Rcp);
- if (ChrPtr(Rcp)[0] == '1') {
+ if (GetServerStatus(Rcp, NULL) == 1) {
FlushStrBuf(Rcp);
List = NewHash(1, NULL);
while (!Done && (StrBuf_ServGetln(Rcp)>=0)) {
DeleteHash(KillMe);
}
-HashList *GetGVSNHash(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType)
+HashList *GetGVSNHash(StrBuf *Target, WCTemplputParams *TP)
{
StrBuf *Rcp;
HashList *List = NULL;
Rcp = NewStrBuf();
serv_puts("GVSN");
StrBuf_ServGetln(Rcp);
- if (ChrPtr(Rcp)[0] == '1') {
+ if (GetServerStatus(Rcp, NULL) == 1) {
FlushStrBuf(Rcp);
List = NewHash(1, NULL);
while (!Done && (StrBuf_ServGetln(Rcp)>=0)) {
InitModule_PREFERENCES
(void)
{
- WebcitAddUrlHandler(HKEY("display_preferences"), display_preferences, 0);
WebcitAddUrlHandler(HKEY("set_preferences"), set_preferences, 0);
WebcitAddUrlHandler(HKEY("change_start_page"), change_start_page, 0);
RegisterPreference("signature",_("Use this signature:"),PRF_QP_STRING);
RegisterPreference("default_header_charset", _("Default character set for email headers:") ,PRF_STRING);
RegisterPreference("emptyfloors", _("Show empty floors"), PRF_YESNO);
- RegisterPreference("defaultfrom", _("Prefered Email Address"), PRF_STRING);
- RegisterPreference("defaultname", _("Prefered Email Sendername"), PRF_STRING);
- RegisterPreference("defaulthandle", _("Prefered Name for posting messages"), PRF_STRING);
-
-
+ RegisterPreference("defaultfrom", _("Preferred email address"), PRF_STRING);
+ RegisterPreference("defaultname", _("Preferred display name for email messages"), PRF_STRING);
+ RegisterPreference("defaulthandle", _("Preferred display name for bulletin board posts"), PRF_STRING);
+ RegisterNamespace("OFFERSTARTPAGE", 0, 0, offer_start_page, CTX_NONE);
+ RegisterPreference("mailbox",_("Mailbox view mode"), PRF_STRING);
+ RegisterNamespace("PREF:ROOM:VALUE", 1, 2, tmplput_CFG_RoomValue, CTX_NONE);
RegisterNamespace("PREF:VALUE", 1, 2, tmplput_CFG_Value, CTX_NONE);
RegisterNamespace("PREF:DESCR", 1, 1, tmplput_CFG_Descr, CTX_NONE);
- RegisterIterator("PREF:ZONE", 0, ZoneHash, NULL, CfgZoneTempl, NULL, CTX_PREF, CTX_NONE);
+ RegisterIterator("PREF:ZONE", 0, ZoneHash, NULL, CfgZoneTempl, NULL, CTX_PREF, CTX_NONE, IT_NOFLAG);
RegisterConditional(HKEY("COND:PREF"), 4, ConditionalPreference, CTX_NONE);
- RegisterConditional(HKEY("COND:PREF:SET"), 4, ConditionalHazePreference, CTX_NONE);
+ RegisterConditional(HKEY("COND:PREF:SET"), 4, ConditionalHasPreference, CTX_NONE);
+ RegisterConditional(HKEY("COND:ROOM:SET"), 4, ConditionalHasRoomPreference, CTX_NONE);
RegisterIterator("PREF:VALID:EMAIL:ADDR", 0, NULL,
- GetGVEAHash, NULL, DeleteGVEAHash, CTX_STRBUF, CTX_NONE);
+ GetGVEAHash, NULL, DeleteGVEAHash, CTX_STRBUF, CTX_NONE, IT_NOFLAG);
RegisterIterator("PREF:VALID:EMAIL:NAME", 0, NULL,
- GetGVSNHash, NULL, DeleteGVSNHash, CTX_STRBUF, CTX_NONE);
+ GetGVSNHash, NULL, DeleteGVSNHash, CTX_STRBUF, CTX_NONE, IT_NOFLAG);
}
/*@}*/