strcpy(rmname, rp->rlname);
f = rp->rlflags;
- wprintf("<A HREF=\"/dotgoto&room=");
+ wprintf("<a href=\"dotgoto&room=");
urlescputs(rmname);
wprintf("\"");
wprintf(">");
serv_puts("OIMG _roompic_");
serv_getln(buf, sizeof buf);
if (buf[0] == '2') {
- wprintf("<IMG HEIGHT=64 SRC=\"/image&name=_roompic_&room=");
+ wprintf("<IMG HEIGHT=64 src=\"image&name=_roompic_&room=");
urlescputs(WC->wc_roomname);
wprintf("\">");
serv_puts("CLOS");
}
-/* Let the user know if new mail has arrived
- */
-void embed_newmail_button(void) {
- if ( (WC->new_mail > WC->remember_new_mail) && (WC->new_mail>0) ) {
- wprintf(
- "<A HREF=\"/dotgoto?room=_MAIL_\">"
- "<IMG SRC=\"/static/privatemess_32x.gif\" border=0 "
- "ALT=\"");
- wprintf(_("You have new mail"));
- wprintf("\">"
- "<br /><SPAN CLASS=\"youhavemail\">");
- wprintf(_("%d new mail"), WC->new_mail);
- wprintf("</SPAN></A>");
- WC->remember_new_mail = WC->new_mail;
- }
-}
-
-
/*
* Display the current view and offer an option to change it
void embed_view_o_matic(void) {
int i;
- wprintf("<form name=\"viewomatic\" action=\"/changeview\">\n"
+ wprintf("<form name=\"viewomatic\" action=\"changeview\">\n"
"<span class=\"room_banner_new_messages\">View as: "
"<SELECT NAME=\"newview\" SIZE=\"1\" "
"STYLE=\"font-family: Bitstream Vera Sans,Arial,Helvetica,sans-serif;"
|| ( (i == 1) && (WC->wc_default_view == 0) )
) {
- wprintf("<OPTION %s VALUE=\"/changeview?view=%d\">",
+ wprintf("<OPTION %s VALUE=\"changeview?view=%d\">",
((i == WC->wc_view) ? "SELECTED" : ""),
i );
escputs(viewdefs[i]);
* we want it to remember the URL as a "/dotskip" one instead of
* a "skip" or "gotonext" or something like that.
*/
- snprintf(WC->this_page, sizeof(WC->this_page), "/dotskip&room=%s",
+ snprintf(WC->this_page, sizeof(WC->this_page), "dotskip&room=%s",
WC->wc_roomname);
/* Check for new mail. */
svprintf("TOTALMSGS", WCS_STRING, "%d", extract_int(&got[4], 2));
svcallback("ROOMPIC", embed_room_graphic);
svcallback("ROOMINFO", readinfo);
- svcallback("YOUHAVEMAIL", embed_newmail_button);
svcallback("VIEWOMATIC", embed_view_o_matic);
svcallback("START", offer_start_page);
if (navbar_style == navbar_default) wprintf(
"<td>"
- "<a href=\"/ungoto\">"
- "<img align=\"middle\" src=\"/static/ungoto2_24x.gif\" border=\"0\">"
+ "<a href=\"ungoto\">"
+ "<img align=\"middle\" src=\"static/ungoto2_24x.gif\" border=\"0\">"
"<span class=\"navbar_link\">%s</span></A>"
"</td>\n", _("Ungoto")
);
if ( (navbar_style == navbar_default) && (WC->wc_view == VIEW_BBS) ) {
wprintf(
"<td>"
- "<A HREF=\"/readnew\">"
- "<img align=\"middle\" src=\"/static/newmess2_24x.gif\" border=\"0\">"
+ "<a href=\"readnew\">"
+ "<img align=\"middle\" src=\"static/newmess2_24x.gif\" border=\"0\">"
"<span class=\"navbar_link\">%s</span></A>"
"</td>\n", _("Read new messages")
);
case VIEW_ADDRESSBOOK:
wprintf(
"<td>"
- "<A HREF=\"/readfwd\">"
- "<img align=\"middle\" src=\"/static/viewcontacts_24x.gif\" "
+ "<a href=\"readfwd\">"
+ "<img align=\"middle\" src=\"static/viewcontacts_24x.gif\" "
"border=\"0\">"
"<span class=\"navbar_link\">"
"%s"
case VIEW_CALENDAR:
wprintf(
"<td>"
- "<A HREF=\"/readfwd?calview=day\">"
- "<img align=\"middle\" src=\"/static/taskday2_24x.gif\" "
+ "<a href=\"readfwd?calview=day\">"
+ "<img align=\"middle\" src=\"static/taskday2_24x.gif\" "
"border=\"0\">"
"<span class=\"navbar_link\">"
"%s"
);
wprintf(
"<td>"
- "<A HREF=\"/readfwd?calview=month\">"
- "<img align=\"middle\" src=\"/static/monthview2_24x.gif\" "
+ "<a href=\"readfwd?calview=month\">"
+ "<img align=\"middle\" src=\"static/monthview2_24x.gif\" "
"border=\"0\">"
"<span class=\"navbar_link\">"
"%s"
case VIEW_TASKS:
wprintf(
"<td>"
- "<A HREF=\"/readfwd\">"
- "<img align=\"middle\" src=\"/static/taskmanag_24x.gif\" "
+ "<a href=\"readfwd\">"
+ "<img align=\"middle\" src=\"static/taskmanag_24x.gif\" "
"border=\"0\">"
"<span class=\"navbar_link\">"
"%s"
case VIEW_NOTES:
wprintf(
"<td>"
- "<A HREF=\"/readfwd\">"
- "<img align=\"middle\" src=\"/static/viewnotes_24x.gif\" "
+ "<a href=\"readfwd\">"
+ "<img align=\"middle\" src=\"static/viewnotes_24x.gif\" "
"border=\"0\">"
"<span class=\"navbar_link\">"
"%s"
case VIEW_MAILBOX:
wprintf(
"<td>"
- "<A HREF=\"/readfwd\">"
- "<img align=\"middle\" src=\"/static/readallmess3_24x.gif\" "
+ "<a href=\"readfwd\">"
+ "<img align=\"middle\" src=\"static/readallmess3_24x.gif\" "
"border=\"0\">"
"<span class=\"navbar_link\">"
"%s"
default:
wprintf(
"<td>"
- "<A HREF=\"/readfwd\">"
- "<img align=\"middle\" src=\"/static/readallmess3_24x.gif\" "
+ "<a href=\"readfwd\">"
+ "<img align=\"middle\" src=\"static/readallmess3_24x.gif\" "
"border=\"0\">"
"<span class=\"navbar_link\">"
"%s"
switch(WC->wc_view) {
case VIEW_ADDRESSBOOK:
wprintf(
- "<td><A HREF=\"/display_enter\">"
- "<img align=\"middle\" src=\"/static/addnewcontact_24x.gif\" "
+ "<td><a href=\"display_enter\">"
+ "<img align=\"middle\" src=\"static/addnewcontact_24x.gif\" "
"border=\"0\"><span class=\"navbar_link\">"
"%s"
"</span></a></td>\n", _("Add new contact")
break;
case VIEW_CALENDAR:
wprintf(
- "<td><A HREF=\"/display_enter\">"
- "<img align=\"middle\" src=\"/static/addevent_24x.gif\" "
+ "<td><a href=\"display_enter\">"
+ "<img align=\"middle\" src=\"static/addevent_24x.gif\" "
"border=\"0\"><span class=\"navbar_link\">"
"%s"
"</span></a></td>\n", _("Add new event")
break;
case VIEW_TASKS:
wprintf(
- "<td><A HREF=\"/display_enter\">"
- "<img align=\"middle\" src=\"/static/newmess3_24x.gif\" "
+ "<td><a href=\"display_enter\">"
+ "<img align=\"middle\" src=\"static/newmess3_24x.gif\" "
"border=\"0\"><span class=\"navbar_link\">"
"%s"
"</span></a></td>\n", _("Add new task")
break;
case VIEW_NOTES:
wprintf(
- "<td><A HREF=\"/display_enter\">"
- "<img align=\"middle\" src=\"/static/enternewnote_24x.gif\" "
+ "<td><a href=\"display_enter\">"
+ "<img align=\"middle\" src=\"static/enternewnote_24x.gif\" "
"border=\"0\"><span class=\"navbar_link\">"
"%s"
"</span></a></td>\n", _("Add new note")
break;
default:
wprintf(
- "<td><A HREF=\"/display_enter\">"
- "<img align=\"middle\" src=\"/static/newmess3_24x.gif\" "
+ "<td><a href=\"display_enter\">"
+ "<img align=\"middle\" src=\"static/newmess3_24x.gif\" "
"border=\"0\"><span class=\"navbar_link\">"
"%s"
"</span></a></td>\n", _("Enter a message")
if (navbar_style == navbar_default) wprintf(
"<td>"
- "<A HREF=\"/skip\" "
+ "<a href=\"skip\" "
"TITLE=\"%s\">"
- "<img align=\"middle\" src=\"/static/skipthisroom_24x.gif\" border=\"0\">"
+ "<img align=\"middle\" src=\"static/skipthisroom_24x.gif\" border=\"0\">"
"<span class=\"navbar_link\">%s</span></a>"
"</td>\n",
_("Leave all messages marked as unread, go to next room with unread messages"),
if (navbar_style == navbar_default) wprintf(
"<td>"
- "<A HREF=\"/gotonext\" "
+ "<a href=\"gotonext\" "
"TITLE=\"%s\">"
- "<img align=\"middle\" src=\"/static/markngo_24x.gif\" border=\"0\">"
+ "<img align=\"middle\" src=\"static/markngo_24x.gif\" border=\"0\">"
"<span class=\"navbar_link\">%s</span></a>"
"</td>\n",
_("Mark all messages as read, go to next room with unread messages"),
WC->room_flags = extract_int(&buf[4], 4);
/* highest_msg_read = extract_int(&buf[4],6);
maxmsgnum = extract_int(&buf[4],5);
- is_mail = (char) extract_int(&buf[4],7); */
+ */
+ WC->is_mailbox = extract_int(&buf[4],7);
ls = extract_long(&buf[4], 6);
WC->wc_floor = extract_int(&buf[4], 10);
WC->wc_view = extract_int(&buf[4], 11);
wprintf("<TD BGCOLOR=\"#FFFFFF\"><SPAN CLASS=\"tablabel\">");
}
else {
- wprintf("<TD BGCOLOR=\"#CCCCCC\"><A HREF=\"/display_editroom&tab=admin\">");
+ wprintf("<TD BGCOLOR=\"#CCCCCC\"><a href=\"display_editroom&tab=admin\">");
}
wprintf(_("Administration"));
if (!strcmp(tab, "admin")) {
wprintf("<TD BGCOLOR=\"#FFFFFF\"><SPAN CLASS=\"tablabel\">");
}
else {
- wprintf("<TD BGCOLOR=\"#CCCCCC\"><A HREF=\"/display_editroom&tab=config\">");
+ wprintf("<TD BGCOLOR=\"#CCCCCC\"><a href=\"display_editroom&tab=config\">");
}
wprintf(_("Configuration"));
if (!strcmp(tab, "config")) {
wprintf("<TD BGCOLOR=\"#FFFFFF\"><SPAN CLASS=\"tablabel\">");
}
else {
- wprintf("<TD BGCOLOR=\"#CCCCCC\"><A HREF=\"/display_editroom&tab=expire\">");
+ wprintf("<TD BGCOLOR=\"#CCCCCC\"><a href=\"display_editroom&tab=expire\">");
}
wprintf(_("Message expire policy"));
if (!strcmp(tab, "expire")) {
wprintf("<TD BGCOLOR=\"#FFFFFF\"><SPAN CLASS=\"tablabel\">");
}
else {
- wprintf("<TD BGCOLOR=\"#CCCCCC\"><A HREF=\"/display_editroom&tab=access\">");
+ wprintf("<TD BGCOLOR=\"#CCCCCC\"><a href=\"display_editroom&tab=access\">");
}
wprintf(_("Access controls"));
if (!strcmp(tab, "access")) {
wprintf("<TD BGCOLOR=\"#FFFFFF\"><SPAN CLASS=\"tablabel\">");
}
else {
- wprintf("<TD BGCOLOR=\"#CCCCCC\"><A HREF=\"/display_editroom&tab=sharing\">");
+ wprintf("<TD BGCOLOR=\"#CCCCCC\"><a href=\"display_editroom&tab=sharing\">");
}
wprintf(_("Sharing"));
if (!strcmp(tab, "sharing")) {
wprintf("<TD BGCOLOR=\"#FFFFFF\"><SPAN CLASS=\"tablabel\">");
}
else {
- wprintf("<TD BGCOLOR=\"#CCCCCC\"><A HREF=\"/display_editroom&tab=listserv\">");
+ wprintf("<TD BGCOLOR=\"#CCCCCC\"><a href=\"display_editroom&tab=listserv\">");
}
wprintf(_("Mailing list service"));
if (!strcmp(tab, "listserv")) {
if (!strcmp(tab, "admin")) {
wprintf("<UL>"
- "<LI><A HREF=\"/delete_room\" "
+ "<LI><a href=\"delete_room\" "
"onClick=\"return confirm('");
wprintf(_("Are you sure you want to delete this room?"));
wprintf("');\">\n");
wprintf(_("Delete this room"));
wprintf("</A>\n"
- "<LI><A HREF=\"/display_editroompic\">\n");
+ "<LI><a href=\"display_editroompic\">\n");
wprintf(_("Set or change the icon for this room's banner"));
wprintf("</A>\n"
- "<LI><A HREF=\"/display_editinfo\">\n");
+ "<LI><a href=\"display_editinfo\">\n");
wprintf(_("Edit this room's Info file"));
wprintf("</A>\n"
"</UL>");
}
if (!strcmp(tab, "config")) {
- wprintf("<FORM METHOD=\"POST\" ACTION=\"/editroom\">\n");
+ wprintf("<FORM METHOD=\"POST\" action=\"editroom\">\n");
wprintf("<UL><LI>");
wprintf(_("Name of room: "));
extract_token(remote_room, buf, 1, '|', sizeof remote_room);
if (strlen(node) > 0) {
wprintf("<FORM METHOD=\"POST\" "
- "ACTION=\"/netedit\">"
+ "action=\"netedit\">"
"<TR><TD>%s</TD>\n", node);
wprintf("<TD>");
extract_token(node, not_shared_with, i, '\n', sizeof node);
if (strlen(node) > 0) {
wprintf("<FORM METHOD=\"POST\" "
- "ACTION=\"/netedit\">"
+ "action=\"netedit\">"
"<TR><TD>");
escputs(node);
wprintf("</TD><TD>"
extract_token(recp, buf, 1, '|', sizeof recp);
escputs(recp);
- wprintf(" <A HREF=\"/netedit&cmd=remove&line="
+ wprintf(" <a href=\"netedit&cmd=remove&line="
"listrecp|");
urlescputs(recp);
wprintf("&tab=listserv\">");
wprintf("</A><br />");
}
}
- wprintf("<br /><FORM METHOD=\"POST\" ACTION=\"/netedit\">\n"
+ wprintf("<br /><FORM METHOD=\"POST\" action=\"netedit\">\n"
"<INPUT TYPE=\"hidden\" NAME=\"tab\" VALUE=\"listserv\">\n"
"<INPUT TYPE=\"hidden\" NAME=\"prefix\" VALUE=\"listrecp|\">\n");
wprintf("<INPUT TYPE=\"text\" NAME=\"line\">\n");
extract_token(recp, buf, 1, '|', sizeof recp);
escputs(recp);
- wprintf(" <A HREF=\"/netedit&cmd=remove&line="
+ wprintf(" <a href=\"netedit&cmd=remove&line="
"digestrecp|");
urlescputs(recp);
wprintf("&tab=listserv\">");
wprintf("</A><br />");
}
}
- wprintf("<br /><FORM METHOD=\"POST\" ACTION=\"/netedit\">\n"
+ wprintf("<br /><FORM METHOD=\"POST\" action=\"netedit\">\n"
"<INPUT TYPE=\"hidden\" NAME=\"tab\" VALUE=\"listserv\">\n"
"<INPUT TYPE=\"hidden\" NAME=\"prefix\" VALUE=\"digestrecp|\">\n");
wprintf("<INPUT TYPE=\"text\" NAME=\"line\">\n");
if (self_service(999) == 1) {
wprintf(_("This room is configured to allow "
"self-service subscribe/unsubscribe requests."));
- wprintf("<A HREF=\"/toggle_self_service?newval=0&tab=listserv\">");
+ wprintf("<a href=\"toggle_self_service?newval=0&tab=listserv\">");
wprintf(_("Click to disable."));
wprintf("</A><br />\n");
wprintf(_("The URL for subscribe/unsubscribe is: "));
else {
wprintf(_("This room is <i>not</i> configured to allow "
"self-service subscribe/unsubscribe requests."));
- wprintf(" <A HREF=\"/toggle_self_service?newval=1&"
+ wprintf(" <a href=\"toggle_self_service?newval=1&"
"tab=listserv\">");
wprintf(_("Click to enable."));
wprintf("</A><br />\n");
floorvalue = extract_int(&buf[4], 1);
}
- wprintf("<br /><FORM METHOD=\"POST\" ACTION=\"/set_room_policy\">\n");
+ wprintf("<br /><FORM METHOD=\"POST\" action=\"set_room_policy\">\n");
wprintf("<TABLE border=0 cellspacing=5>\n");
wprintf("<TR><TD>");
wprintf(_("Message expire policy for this room"));
"name from the list and click 'Kick'."));
wprintf("<br /><br />");
- wprintf("<CENTER><FORM METHOD=\"POST\" ACTION=\"/do_invt_kick\">\n");
+ wprintf("<CENTER><FORM METHOD=\"POST\" action=\"do_invt_kick\">\n");
wprintf("<INPUT TYPE=\"hidden\" NAME=\"tab\" VALUE=\"access\">\n");
wprintf("<SELECT NAME=\"username\" SIZE=\"10\" style=\"width:100%%\">\n");
serv_puts("WHOK");
"user name in the box below and click 'Invite'."));
wprintf("<br /><br />");
- wprintf("<CENTER><FORM METHOD=\"POST\" ACTION=\"/do_invt_kick\">\n");
+ wprintf("<CENTER><FORM METHOD=\"POST\" action=\"do_invt_kick\">\n");
wprintf("<INPUT TYPE=\"hidden\" NAME=\"tab\" VALUE=\"access\">\n");
wprintf("Invite: ");
wprintf("<input type=\"text\" name=\"username\" style=\"width:100%%\"><br />\n"
wprintf("<div id=\"fix_scrollbar_bug\">"
"<table border=0 width=100%% bgcolor=\"#ffffff\"><tr><td>\n");
- wprintf("<form name=\"create_room_form\" method=\"POST\" action=\"/entroom\">\n");
+ wprintf("<form name=\"create_room_form\" method=\"POST\" action=\"entroom\">\n");
wprintf("<UL><LI>");
wprintf(_("Name of room: "));
"so you don't have to keep returning here."));
wprintf("\n<br /><br />");
- wprintf("<FORM METHOD=\"POST\" ACTION=\"/goto_private\">\n");
+ wprintf("<FORM METHOD=\"POST\" action=\"goto_private\">\n");
wprintf("<table border=\"0\" cellspacing=\"5\" "
"cellpadding=\"5\" BGCOLOR=\"#EEEEEE\">\n"
"disappear from your room list. Is this what you wish "
"to do?<br />\n"), WC->wc_roomname);
- wprintf("<FORM METHOD=\"POST\" ACTION=\"/zap\">\n");
+ wprintf("<FORM METHOD=\"POST\" action=\"zap\">\n");
wprintf("<INPUT TYPE=\"submit\" NAME=\"ok_button\" VALUE=\"%s\">", _("Zap this room"));
wprintf(" ");
wprintf("<INPUT TYPE=\"submit\" NAME=\"cancel_button\" VALUE=\"%s\">", _("Cancel"));
wprintf("var node%d = new TreeNode(%d, '", i, i);
if (fold[i].selectable) {
- wprintf("<A HREF=\"/dotgoto?room=");
+ wprintf("<a href=\"dotgoto?room=");
urlescputs(fold[i].room);
wprintf("\">");
}
* Boxes and rooms and lists ... oh my!
*/
void do_rooms_view(struct folder *fold, int max_folders, int num_floors) {
- char buf[SIZ];
- char boxtitle[SIZ];
+ char buf[256];
+ char floor_name[256];
+ char old_floor_name[256];
+ char boxtitle[256];
int levels, oldlevels;
int i, t;
int num_boxes = 0;
int current_column = 0;
int nf;
+ strcpy(floor_name, "");
+ strcpy(old_floor_name, "");
+
nf = num_floors;
while (nf % columns != 0) ++nf;
boxes_per_column = (nf / columns);
for (i=0; i<max_folders; ++i) {
levels = num_tokens(fold[i].name, '|');
+ extract_token(floor_name, fold[i].name, 0,
+ '|', sizeof floor_name);
- if ((levels == 1) && (oldlevels > 1)) {
-
+ if ( (strcasecmp(floor_name, old_floor_name))
+ && (strlen(old_floor_name) > 0) ) {
/* End inner box */
do_template("endbox");
}
}
}
+ strcpy(old_floor_name, floor_name);
if (levels == 1) {
-
/* Begin inner box */
- extract_token(buf, fold[i].name, levels-1, '|', sizeof buf);
- stresc(boxtitle, buf, 1, 0);
+ stresc(boxtitle, floor_name, 1, 0);
svprintf("BOXTITLE", WCS_STRING, boxtitle);
do_template("beginbox");
-
}
oldlevels = levels;
wprintf(" ");
if (levels>2) for (t=0; t<(levels-2); ++t) wprintf(" ");
if (fold[i].selectable) {
- wprintf("<A HREF=\"/dotgoto?room=");
+ wprintf("<a href=\"dotgoto?room=");
urlescputs(fold[i].room);
wprintf("\">");
}
"OnChange=\"location.href=roomlistomatic.newview.options"
"[selectedIndex].value\">\n");
- wprintf("<OPTION %s VALUE=\"/knrooms&view=rooms\">"
+ wprintf("<OPTION %s VALUE=\"knrooms&view=rooms\">"
"View as room list"
"</OPTION>\n",
( !strcasecmp(listviewpref, "rooms") ? "SELECTED" : "" )
);
- wprintf("<OPTION %s VALUE=\"/knrooms&view=folders\">"
+ wprintf("<OPTION %s VALUE=\"knrooms&view=folders\">"
"View as folder list"
"</OPTION>\n",
( !strcasecmp(listviewpref, "folders") ? "SELECTED" : "" )