1
0
mirror of https://github.com/profanity-im/profanity.git synced 2024-12-04 14:46:46 -05:00

Create new window for room configuration

This commit is contained in:
James Booth 2014-09-07 00:49:42 +01:00
parent 47d1b1ea21
commit 85ccedd01c
3 changed files with 38 additions and 17 deletions

View File

@ -1873,51 +1873,58 @@ _ui_draw_term_title(void)
static void static void
_ui_handle_room_configuration(const char * const room, DataForm *form) _ui_handle_room_configuration(const char * const room, DataForm *form)
{ {
cons_show("Recieved configuration form for %s", room); GString *title = g_string_new(room);
g_string_append(title, " config");
ProfWin *window = wins_new(title->str, WIN_MUC_CONFIG);
g_string_free(title, TRUE);
int num = wins_get_num(window);
ui_switch_win(num);
win_save_vprint(window, '-', NULL, 0, 0, "", "Receieved configuration for room %s.", room);
if (form->type != NULL) { if (form->type != NULL) {
cons_show(" Type: %s", form->type); win_save_vprint(window, '-', NULL, 0, 0, "", " Type: %s", form->type);
} }
if (form->title != NULL) { if (form->title != NULL) {
cons_show(" Title: %s", form->title); win_save_vprint(window, '-', NULL, 0, 0, "", " Title: %s", form->title);
} }
if (form->instructions != NULL) { if (form->instructions != NULL) {
cons_show(" Instructions: %s", form->instructions); win_save_vprint(window, '-', NULL, 0, 0, "", " Instructions: %s", form->instructions);
} }
GSList *fields = form->fields; GSList *fields = form->fields;
GSList *curr_field = fields; GSList *curr_field = fields;
while (curr_field != NULL) { while (curr_field != NULL) {
FormField *field = curr_field->data; FormField *field = curr_field->data;
cons_show(" Field:"); win_save_vprint(window, '-', NULL, 0, 0, "", " Field:");
if (field->label != NULL) { if (field->label != NULL) {
cons_show(" Label: %s", field->label); win_save_vprint(window, '-', NULL, 0, 0, "", " Label: %s", field->label);
} }
if (field->type != NULL) { if (field->type != NULL) {
cons_show(" Type: %s", field->type); win_save_vprint(window, '-', NULL, 0, 0, "", " Type: %s", field->type);
} }
if (field->var != NULL) { if (field->var != NULL) {
cons_show(" Var: %s", field->var); win_save_vprint(window, '-', NULL, 0, 0, "", " Var: %s", field->var);
} }
if (field->description != NULL) { if (field->description != NULL) {
cons_show(" Description: %s", field->description); win_save_vprint(window, '-', NULL, 0, 0, "", " Description: %s", field->description);
} }
if (field->required) { if (field->required) {
cons_show(" Required: TRUE"); win_save_vprint(window, '-', NULL, 0, 0, "", " Required: TRUE");
} else { } else {
cons_show(" Required: FALSE"); win_save_vprint(window, '-', NULL, 0, 0, "", " Required: FALSE");
} }
GSList *values = field->values; GSList *values = field->values;
GSList *curr_value = values; GSList *curr_value = values;
if (curr_value != NULL) { if (curr_value != NULL) {
cons_show(" Values:"); win_save_vprint(window, '-', NULL, 0, 0, "", " Values:");
} }
while (curr_value != NULL) { while (curr_value != NULL) {
char *value = curr_value->data; char *value = curr_value->data;
cons_show(" %s", value); win_save_vprint(window, '-', NULL, 0, 0, "", " %s", value);
curr_value = g_slist_next(curr_value); curr_value = g_slist_next(curr_value);
} }
@ -1925,15 +1932,15 @@ _ui_handle_room_configuration(const char * const room, DataForm *form)
GSList *options = field->options; GSList *options = field->options;
GSList *curr_option = options; GSList *curr_option = options;
if (curr_option != NULL) { if (curr_option != NULL) {
cons_show(" Options:"); win_save_vprint(window, '-', NULL, 0, 0, "", " Options:");
} }
while (curr_option != NULL) { while (curr_option != NULL) {
FormOption *option = curr_option->data; FormOption *option = curr_option->data;
if (option->label != NULL) { if (option->label != NULL) {
cons_show(" Label: %s", option->label); win_save_vprint(window, '-', NULL, 0, 0, "", " Label: %s", option->label);
} }
if (option->value != NULL) { if (option->value != NULL) {
cons_show(" Value: %s", option->value); win_save_vprint(window, '-', NULL, 0, 0, "", " Value: %s", option->value);
} }
curr_option = g_slist_next(curr_option); curr_option = g_slist_next(curr_option);

View File

@ -58,6 +58,7 @@ typedef enum {
WIN_CONSOLE, WIN_CONSOLE,
WIN_CHAT, WIN_CHAT,
WIN_MUC, WIN_MUC,
WIN_MUC_CONFIG,
WIN_PRIVATE, WIN_PRIVATE,
WIN_DUCK, WIN_DUCK,
WIN_XML WIN_XML

View File

@ -385,7 +385,11 @@ wins_get_prune_recipients(void)
while (curr != NULL) { while (curr != NULL) {
ProfWin *window = curr->data; ProfWin *window = curr->data;
if (window->unread == 0 && window->type != WIN_MUC && window->type != WIN_CONSOLE) { if (window->unread == 0 &&
window->type != WIN_MUC &&
window->type != WIN_MUC_CONFIG &&
window->type != WIN_XML &&
window->type != WIN_CONSOLE) {
result = g_slist_append(result, window->from); result = g_slist_append(result, window->from);
} }
curr = g_list_next(curr); curr = g_list_next(curr);
@ -539,6 +543,7 @@ wins_create_summary(void)
GString *chat_string; GString *chat_string;
GString *priv_string; GString *priv_string;
GString *muc_string; GString *muc_string;
GString *muc_config_string;
GString *duck_string; GString *duck_string;
GString *xml_string; GString *xml_string;
@ -606,6 +611,14 @@ wins_create_summary(void)
break; break;
case WIN_MUC_CONFIG:
muc_config_string = g_string_new("");
g_string_printf(muc_config_string, "%d: %s", ui_index, window->from);
result = g_slist_append(result, strdup(muc_config_string->str));
g_string_free(muc_config_string, TRUE);
break;
case WIN_DUCK: case WIN_DUCK:
duck_string = g_string_new(""); duck_string = g_string_new("");
g_string_printf(duck_string, "%d: DuckDuckGo search", ui_index); g_string_printf(duck_string, "%d: DuckDuckGo search", ui_index);