* have an abstract function print the menu boxes in the config area.
authorWilfried Göesgens <willi@citadel.org>
Mon, 6 Aug 2007 21:58:44 +0000 (21:58 +0000)
committerWilfried Göesgens <willi@citadel.org>
Mon, 6 Aug 2007 21:58:44 +0000 (21:58 +0000)
* first draft of the shutdown menu.

webcit/mainmenu.c
webcit/siteconfig.c
webcit/webcit.c
webcit/webcit.h

index a11dc66ae54dc046f0afc8f08af58fd14d543e08..4373c76a2d02fc33b4b4282bf3251b97bd703fe9 100644 (file)
@@ -14,6 +14,7 @@
  */
 void display_main_menu(void)
 {
+       char buf[SIZ];
        output_headers(1, 1, 1, 0, 0, 0);
 
        wprintf("<div class=\"fix_scrollbar_bug\">"
@@ -120,71 +121,31 @@ void display_main_menu(void)
        wprintf("</td></tr>"
                "<tr valign=top><td width=50%%>");
 
-       svprintf("BOXTITLE", WCS_STRING, _("Your info"));
-       do_template("beginbox");
-
-       wprintf("<ul class=\"adminitems\">");
-
-       wprintf("<li><a href=\"display_preferences\">");
-       wprintf(_("Change your preferences and settings"));
-       wprintf("</a></li>\n");
-
-       wprintf("<li><a href=\"display_reg\">");
-       wprintf(_("Update your contact information"));
-       wprintf("</a></li>\n");
-
-       wprintf("<li><a href=\"display_changepw\">");
-       wprintf(_("Change your password"));
-       wprintf("</a></li>\n");
-
-       wprintf("<li><a href=\"display_editbio\">");
-       wprintf(_("Enter your 'bio'"));
-       wprintf("</a></li>\n");
-
-       wprintf("<li><a href=\"display_editpic\">");
-       wprintf(_("Edit your online photo"));
-       wprintf("</a></li>\n");
-
-       wprintf("<li><a href=\"display_sieve\">");
-       wprintf(_("View/edit server-side mail filters"));
-       wprintf("</a></li>\n");
-
-       wprintf("</ul>\n");
-
-       do_template("endbox");
+       print_menu_box(_("Your info"), "adminitems", 6,
+                      "display_preferences", _("Change your preferences and settings"),
+                      "display_reg", _("Update your contact information"),
+                      "display_changepw", _("Change your password"),
+                      "display_editbio", _("Enter your 'bio'"),
+                      "display_editpic", _("Edit your online photo"), 
+                      "display_sieve", _("View/edit server-side mail filters"));
 
        wprintf("</td><td width=50%%>");
 
-       svprintf("BOXTITLE", WCS_STRING, _("Advanced room commands"));
-       do_template("beginbox");
-
-       wprintf("<ul class=\"adminitems\">");
-
-       if ((WC->axlevel >= 6) || (WC->is_room_aide)) {
-               wprintf("<li><a href=\"display_editroom\">");
-               wprintf(_("Edit or delete this room"));
-               wprintf("</a></li>\n");
-       }
-
-       wprintf("<li><a href=\"display_private\">");
-       wprintf(_("Go to a 'hidden' room"));
-       wprintf("</a></li>\n");
-
-       wprintf("<li><a href=\"display_entroom\">");
-       wprintf(_("Create a new room"));
-       wprintf("</a></li>\n");
-
-       wprintf("<li><a href=\"display_zap\">");
-       wprintf(_("Zap (forget) this room (%s)"), WC->wc_roomname);
-       wprintf("</a></li>\n");
-
-       wprintf("<li><a href=\"zapped_list\">");
-       wprintf(_("List all forgotten rooms"));
-       wprintf("</a></li>\n");
-
-       wprintf("</ul>\n");
-
-       do_template("endbox");
+       snprintf(buf, SIZ, _("Zap (forget) this room (%s)"), WC->wc_roomname);
+
+       if ((WC->axlevel >= 6) || (WC->is_room_aide)) 
+               print_menu_box(_("Advanced room commands"),"adminitems", 5,
+                              "display_editroom", _("Edit or delete this room"),
+                              "display_private", _("Go to a 'hidden' room"),
+                              "display_entroom", _("Create a new room"),
+                              "display_zap",buf,
+                              "zapped_list",_("List all forgotten rooms"));
+       else
+               print_menu_box(_("Advanced room commands"),"adminitems", 4,
+                              "display_private", _("Go to a 'hidden' room"),
+                              "display_entroom", _("Create a new room"),
+                              "display_zap",buf,
+                              "zapped_list",_("List all forgotten rooms"));
 
        wprintf("</td></tr></table></div>");
        wDumpContent(2);
@@ -210,64 +171,28 @@ void display_aide_menu(void)
                "<table border=0 width=99%%> "
                "<tr valign=top><td width=50%% rowspan=2>");
 
-       svprintf("BOXTITLE", WCS_STRING, _("Global Configuration"));
-       do_template("beginbox");
-
-       wprintf("<ul class=\"adminitems\">");
-
-       wprintf("<li><a href=\"display_siteconfig\">");
-       wprintf(_("Edit site-wide configuration"));
-       wprintf("</a></li>\n");
-
-       wprintf("<li><a href=\"display_inetconf\">");
-       wprintf(_("Domain names and Internet mail configuration"));
-       wprintf("</a></li>\n");
-
-       wprintf("<li><a href=\"display_netconf\">");
-       wprintf(_("Configure replication with other Citadel servers"));
-       wprintf("</a></li>\n");
 
-       wprintf("<li><a href=\"display_smtpqueue\">");
-       wprintf(_("View the outbound SMTP queue"));
-       wprintf("</a></li>\n");
-
-       wprintf("</ul>");
-
-       do_template("endbox");
+       print_menu_box(_("Global Configuration"), "adminitems", 4,
+                      "display_siteconfig", _("Edit site-wide configuration"), 
+                      "display_inetconf",_("Domain names and Internet mail configuration"),
+                      "display_netconf", _("Configure replication with other Citadel servers"), 
+                      "display_smtpqueue", _("View the outbound SMTP queue"));
+       
+       print_menu_box(_("Shutdown Citadel"), "adminitems", 3, 
+                      "server_shutdown?when=now", _("Restart Imediate"),
+                      "server_shutdown?when=page", _("Restart after paging Users"),
+                      "server_shutdown?when=idle", _("Restart when everybody is idle."));
 
        wprintf("</td><td width=50%%>");
 
-       svprintf("BOXTITLE", WCS_STRING, _("User account management"));
-       do_template("beginbox");
-
-       wprintf("<ul class=\"adminitems\">");
-
-       wprintf("<li><a href=\"select_user_to_edit\">");
-       wprintf(_("Add, change, delete user accounts"));
-       wprintf("</a></li>\n");
-
-       wprintf("<li><a href=\"validate\">");
-       wprintf(_("Validate new users"));
-       wprintf("</a></li>\n");
-
-       wprintf("</ul>");
-
-       do_template("endbox");
+       print_menu_box(_("User account management"), "adminitems", 2, 
+                      "select_user_to_edit", _("Add, change, delete user accounts"),
+                      "validate", _("Validate new users"));
 
        wprintf("</td></tr><tr><td width=50%%>");
 
-       svprintf("BOXTITLE", WCS_STRING, _("Rooms and Floors"));
-       do_template("beginbox");
-
-       wprintf("<ul class=\"adminitems\">");
-
-       wprintf("<li><a href=\"display_floorconfig\">");
-       wprintf(_("Add, change, or delete floors"));
-       wprintf("</a></li>\n");
-
-       wprintf("</ul>");
-
-       do_template("endbox");
+       print_menu_box(_("Rooms and Floors"), "adminitems", 1, 
+                      "display_floorconfig", _("Add, change, or delete floors"));
 
        wprintf("</td></tr></table></div>");
        wDumpContent(2);
index ac50269ce8bfeb4dad039643be4967002d45a66a..61593d39174c71c99c8bfc514441120a6455ff36 100644 (file)
@@ -561,7 +561,7 @@ void display_siteconfig(void)
                        sprintf(&funambol[strlen(funambol)], "<TR><TD>");
                        sprintf(&funambol[strlen(funambol)], _("Funambol auth details (user:pass in Base64)"));
                        sprintf(&funambol[strlen(funambol)], "</TD><TD>");
-                       sprintf(&funambol[strlen(funambol)], "<input type=\"text\" NAME=\"c_funambol_auth\" MAXLENGTH=\"255\" VALUE=\"%s\">", buf);
+                       sprintf(&funambol[strlen(funambol)], "<input type=\"text\" NAME=\"c_funambol_auth\" MAXLENGTH=\"255\" VAUE=\"%s\">", buf);
                        sprintf(&funambol[strlen(funambol)], "</TD></TR>\n");
                        break;
                }
index 785d2287caaf82fec97fc798b4aa1f625c4067dc..800dc40d178ddc4ccc5b27d5bfdcf435f401982a 100644 (file)
@@ -13,6 +13,9 @@
 #include "webserver.h"
 #include "mime_parser.h"
 
+#include <stdio.h>
+#include <stdarg.h>
+
 /**
  * String to unset the cookie.
  * Any date "in the past" will work, so I chose my birthday, right down to
@@ -549,6 +552,39 @@ void http_transmit_thing(char *thing, size_t length, char *content_type,
        client_write(thing, (size_t)length);
 }
 
+/**
+ * \brief print menu box like used in the floor view or admin interface.
+ * This function takes pair of strings as va_args, 
+ * \param Title Title string of the box
+ * \param Class CSS Class for the box
+ * \param nLines How many string pairs should we print? (URL, UrlText)
+ * \param ... Pairs of URL Strings and their Names
+ */
+void print_menu_box(char* Title, char *Class, int nLines, ...)
+{
+       va_list arg_list;
+       long i;
+       
+       svprintf("BOXTITLE", WCS_STRING, Title);
+       do_template("beginbox");
+       
+       wprintf("<ul class=\"%s\">", Class);
+       
+       va_start(arg_list, (nLines * 2));
+       for (i = 0; i < nLines * 2; i += 2)
+       { 
+               wprintf("<li><a href=\"%s\">", va_arg(arg_list, char *));
+               wprintf((char *) va_arg(arg_list, char *));
+               wprintf("</a></li>\n");
+       }
+       va_end (arg_list);
+       
+       wprintf("</a></li>\n");
+       
+       wprintf("</ul>");
+       
+       do_template("endbox");
+}
 
 
 /**
index 2e1a006cf801dcbbd737c67be49219bb55f11e7c..43ecf6940b808b92afe7fbe24e9d77da242e14ee 100644 (file)
@@ -484,6 +484,7 @@ void output_headers(    int do_httpheaders,
                        int cache);
 void wprintf(const char *format,...);
 void output_static(char *what);
+void print_menu_box(char* Title, char *Class, int nLines, ...);
 void stresc(char *target, char *strbuf, int nbsp, int nolinebreaks);
 void escputs(char *strbuf);
 void url(char *buf);