X-Git-Url: https://code.citadel.org/?a=blobdiff_plain;f=webcit%2Fsysmsgs.c;h=6c0ce1d04ae2d7241b135c0859cb2eb234063084;hb=fd034bea666febed8eff22cf10f2b72b8b009665;hp=b2ba73f898b51cad5b537e0a871a16976ed5f235;hpb=89fc82a8ab4fb0dd1b57888a877fa8078223fa89;p=citadel.git diff --git a/webcit/sysmsgs.c b/webcit/sysmsgs.c index b2ba73f89..6c0ce1d04 100644 --- a/webcit/sysmsgs.c +++ b/webcit/sysmsgs.c @@ -1,14 +1,31 @@ /* - * $Id$ + * Copyright (c) 1996-2011 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 as + * published by the Free Software Foundation; either version 3 of the + * License, or (at your option) any later version. + * + * 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. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #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) @@ -24,48 +41,52 @@ void display_edit(char *description, char *check_cmd, 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("beginbox_1"); + StrBufAppendPrintf (WC->WBuf, _("Edit %s"), description); + do_template("beginbox_2"); - 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("
"); + 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", save_cmd); - wprintf("

\n"); - wprintf(""); - wprintf(" "); - wprintf("
\n"); + wc_printf("
\n"); + wc_printf("", _("Save changes")); + wc_printf(" "); + wc_printf("
\n", _("Cancel")); + wc_printf("
\n"); - wprintf("
\n"); do_template("endbox"); wDumpContent(1); } -/* - * 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]; - if (strlen(bstr("save_button")) == 0) { + if (!havebstr("save_button")) { sprintf(WC->ImportantMessage, - "Cancelled. %s was not saved.\n", description); + _("Cancelled. %s was not saved."), + description); display_main_menu(); return; } @@ -76,15 +97,37 @@ void save_edit(char *description, char *enter_cmd, int regoto) display_main_menu(); return; } - text_to_server(bstr("msgtext"), 0); + 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.\n", description); + _("%s has been saved."), + description); 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); +}