X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fsysmsgs.c;h=70a46de99a846efe11543a0b50add0b8e2b64c22;hb=fb6f6fa4ec4e3277e30d84326d48e6850822d318;hp=739b53fdb5423ae6b122b3999313e426ae253ec8;hpb=f072b76e977498d750a69b156340b6d2cf3e5bd1;p=citadel.git diff --git a/webcit/sysmsgs.c b/webcit/sysmsgs.c index 739b53fdb..70a46de99 100644 --- a/webcit/sysmsgs.c +++ b/webcit/sysmsgs.c @@ -1,87 +1,128 @@ -#include -#include -#include -#include -#include -#include -#include +/* + * Copyright (c) 1996-2012 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. + */ + #include "webcit.h" -#include "child.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) { - char buf[256]; + char *read_cmd, char *save_cmd, int with_room_banner) +{ + StrBuf *Line; serv_puts(check_cmd); - serv_gets(buf); - - if (buf[0]!='2') { - display_error(&buf[4]); + Line = NewStrBuf(); + StrBuf_ServGetln(Line); + if (GetServerStatusMsg(Line, NULL, 1, 2) != 2) { + FreeStrBuf(&Line); + display_main_menu(); + FreeStrBuf(&Line); return; - } - - printf("HTTP/1.0 200 OK\n"); - output_headers(1); - - wprintf("
"); - wprintf("Edit "); - escputs(description); - wprintf("
\n"); - - wprintf("
Enter %s below. Text is formatted to\n", description); - wprintf("the reader's screen width. To defeat the\n"); - wprintf("formatting, indent a line at least one space. \n"); - wprintf("
"); - - wprintf("
\n", save_cmd); - wprintf(""); - wprintf("
\n"); - wprintf("

\n"); + StrBuf_ServGetln(Line); + if (GetServerStatusMsg(Line, NULL, 0, 0) == 1) + server_to_text(); + wc_printf("

\n"); + wc_printf("", _("Save changes")); + wc_printf(" "); + wc_printf("
\n", _("Cancel")); + wc_printf("
\n"); - wprintf("
\n"); - wDumpContent(); - } + 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[256]; - - if (strcmp(bstr("sc"),"Save")) { - printf("HTTP/1.0 200 OK\n"); - output_headers(1); - wprintf("Cancelled. %s was not saved.
\n", description); - wDumpContent(); - return; - } +void save_edit(char *description, char *enter_cmd, int regoto) +{ + StrBuf *Line; + if (!havebstr("save_button")) { + AppendImportantMessage(_("Cancelled. %s was not saved."), -1); + display_main_menu(); + return; + } + Line = NewStrBuf(); serv_puts(enter_cmd); - serv_gets(buf); - if (buf[0]!='4') { - display_error(&buf[4]); + StrBuf_ServGetln(Line); + if (GetServerStatusMsg(Line, NULL, 1, 0) != 4) { + FreeStrBuf(&Line); + display_main_menu(); return; - } - + } + FreeStrBuf(&Line); text_to_server(bstr("msgtext")); serv_puts("000"); if (regoto) { - gotoroom(wc_roomname, 1); - } - else { - printf("HTTP/1.0 200 OK\n"); - output_headers(1); - wprintf("%s has been saved.\n", description); - wDumpContent(); - } - } + smart_goto(WC->CurRoom.name); + } else { + 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); +}