X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fsysmsgs.c;h=70a46de99a846efe11543a0b50add0b8e2b64c22;hb=fb6f6fa4ec4e3277e30d84326d48e6850822d318;hp=2ba2e43fbcd1eaca44615c35f61121ed5774d434;hpb=c90b9009ad3b2411389d3dad969c19ec17688268;p=citadel.git diff --git a/webcit/sysmsgs.c b/webcit/sysmsgs.c index 2ba2e43fb..70a46de99 100644 --- a/webcit/sysmsgs.c +++ b/webcit/sysmsgs.c @@ -1,86 +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 *read_cmd, char *save_cmd, int with_room_banner) { - char buf[256]; + 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, "bottom"); - - 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"); + wc_printf("

\n"); + wc_printf("", _("Save changes")); + wc_printf(" "); + wc_printf("
\n", _("Cancel")); + wc_printf("
\n"); - wprintf("
\n"); + 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]; + StrBuf *Line; - if (strcmp(bstr("sc"), "Save")) { - printf("HTTP/1.0 200 OK\n"); - output_headers(1, "bottom"); - wprintf("Cancelled. %s was not saved.
\n", description); - wDumpContent(1); + 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); + smart_goto(WC->CurRoom.name); } else { - printf("HTTP/1.0 200 OK\n"); - output_headers(1, "bottom"); - wprintf("%s has been saved.\n", description); - wDumpContent(1); + 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); +}