X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fsysmsgs.c;h=70a46de99a846efe11543a0b50add0b8e2b64c22;hb=fb6f6fa4ec4e3277e30d84326d48e6850822d318;hp=d377a899a466630165161268e6a6439c3866c1db;hpb=f7c7f356784c08b353785ac0b66d2ac3bd1ed251;p=citadel.git
diff --git a/webcit/sysmsgs.c b/webcit/sysmsgs.c
index d377a899a..70a46de99 100644
--- a/webcit/sysmsgs.c
+++ b/webcit/sysmsgs.c
@@ -1,93 +1,128 @@
/*
- * $Id$
+ * Copyright (c) 1996-2012 by the citadel.org team
*
- * Editing of various text files on the Citadel server.
+ * 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.
*/
#include "webcit.h"
-/*
- * display the form for editing something (room info, bio, etc)
+/**
+ * display the form for editing something (room info, bio, etc)
+ * description the descriptive text for the box
+ * check_cmd command to check????
+ * read_cmd read answer from citadel server???
+ * save_cmd save comand to the citadel server??
+ * with_room_banner should we bisplay a room banner?
*/
void display_edit(char *description, char *check_cmd,
char *read_cmd, char *save_cmd, int with_room_banner)
{
- char buf[SIZ];
+ StrBuf *Line;
serv_puts(check_cmd);
- serv_getln(buf, sizeof buf);
-
- if (buf[0] != '2') {
- safestrncpy(WC->ImportantMessage, &buf[4], sizeof WC->ImportantMessage);
+ Line = NewStrBuf();
+ StrBuf_ServGetln(Line);
+ if (GetServerStatusMsg(Line, NULL, 1, 2) != 2) {
+ FreeStrBuf(&Line);
display_main_menu();
+ FreeStrBuf(&Line);
return;
}
if (with_room_banner) {
- output_headers(1, 1, 1, 0, 0, 0, 0);
+ output_headers(1, 1, 1, 0, 0, 0);
}
else {
- output_headers(1, 1, 0, 0, 0, 0, 0);
+ output_headers(1, 1, 0, 0, 0, 0);
}
- svprintf("BOXTITLE", WCS_STRING, _("Edit %s"), description);
- do_template("beginbox");
+ do_template("box_begin_1");
+ StrBufAppendPrintf (WC->WBuf, _("Edit %s"), description);
+ do_template("box_begin_2");
- wprintf("
");
- wprintf(_("Enter %s below. Text is formatted to "
- "the reader's screen width. To defeat the "
- "formatting, indent a line at least one space."), description);
- wprintf("
");
+ wc_printf(_("Enter %s below. Text is formatted to the reader's browser."
+ " A newline is forced by preceding the next line by a blank."), description);
- wprintf("
\n");
- wprintf("
\n");
- do_template("endbox");
+ do_template("box_end");
wDumpContent(1);
+ FreeStrBuf(&Line);
}
-/*
- * save a screen which was displayed with display_edit()
+/**
+ * save a screen which was displayed with display_edit()
+ * description the window title???
+ * enter_cmd which command to enter at the citadel server???
+ * regoto should we go to that room again after executing that command?
*/
void save_edit(char *description, char *enter_cmd, int regoto)
{
- char buf[SIZ];
+ StrBuf *Line;
- if (strlen(bstr("save_button")) == 0) {
- sprintf(WC->ImportantMessage,
- _("Cancelled. %s was not saved."),
- description);
+ if (!havebstr("save_button")) {
+ AppendImportantMessage(_("Cancelled. %s was not saved."), -1);
display_main_menu();
return;
}
+ Line = NewStrBuf();
serv_puts(enter_cmd);
- serv_getln(buf, sizeof buf);
- if (buf[0] != '4') {
- safestrncpy(WC->ImportantMessage, &buf[4], sizeof WC->ImportantMessage);
+ StrBuf_ServGetln(Line);
+ if (GetServerStatusMsg(Line, NULL, 1, 0) != 4) {
+ FreeStrBuf(&Line);
display_main_menu();
return;
}
- text_to_server(bstr("msgtext"), 0);
+ FreeStrBuf(&Line);
+ text_to_server(bstr("msgtext"));
serv_puts("000");
if (regoto) {
- smart_goto(WC->wc_roomname);
+ smart_goto(WC->CurRoom.name);
} else {
- sprintf(WC->ImportantMessage,
- _("%s has been saved."),
- description);
+ AppendImportantMessage(description, -1);
+ AppendImportantMessage(_(" has been saved."), -1);
display_main_menu();
return;
}
}
+
+
+void display_editinfo(void){ display_edit(_("Room info"), "EINF 0", "RINF", "editinfo", 1);}
+void editinfo(void) {save_edit(_("Room info"), "EINF 1", 1);}
+void display_editbio(void) {
+ char buf[SIZ];
+
+ snprintf(buf, SIZ, "RBIO %s", ChrPtr(WC->wc_fullname));
+ display_edit(_("Your bio"), "NOOP", buf, "editbio", 3);
+}
+void editbio(void) { save_edit(_("Your bio"), "EBIO", 0); }
+
+void
+InitModule_SYSMSG
+(void)
+{
+ WebcitAddUrlHandler(HKEY("display_editinfo"), "", 0, display_editinfo, 0);
+ WebcitAddUrlHandler(HKEY("editinfo"), "", 0, editinfo, 0);
+ WebcitAddUrlHandler(HKEY("display_editbio"), "", 0, display_editbio, 0);
+ WebcitAddUrlHandler(HKEY("editbio"), "", 0, editbio, 0);
+}