diff options
Diffstat (limited to 'src/ui/core.c')
-rw-r--r-- | src/ui/core.c | 86 |
1 files changed, 85 insertions, 1 deletions
diff --git a/src/ui/core.c b/src/ui/core.c index 4a7bb365..83bcb6ba 100644 --- a/src/ui/core.c +++ b/src/ui/core.c @@ -1601,7 +1601,8 @@ _ui_room_requires_config(const char * const room_jid) ui_index = 0; } - win_save_vprint(window, '!', NULL, 0, COLOUR_ROOMINFO, "", "Room requires configuration, use '/room config accept' or '/room config cancel'"); + win_save_vprint(window, '!', NULL, 0, COLOUR_ROOMINFO, "", + "Room requires configuration, use '/room config accept' or '/room config destroy'"); // currently in groupchat window if (wins_is_current(window)) { @@ -1870,6 +1871,88 @@ _ui_draw_term_title(void) } static void +_ui_handle_room_configuration(const char * const room, DataForm *form) +{ + 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) { + win_save_vprint(window, '-', NULL, 0, 0, "", " Type: %s", form->type); + } + if (form->title != NULL) { + win_save_vprint(window, '-', NULL, 0, 0, "", " Title: %s", form->title); + } + if (form->instructions != NULL) { + win_save_vprint(window, '-', NULL, 0, 0, "", " Instructions: %s", form->instructions); + } + + GSList *fields = form->fields; + GSList *curr_field = fields; + while (curr_field != NULL) { + FormField *field = curr_field->data; + win_save_vprint(window, '-', NULL, 0, 0, "", " Field:"); + + if (field->label != NULL) { + win_save_vprint(window, '-', NULL, 0, 0, "", " Label: %s", field->label); + } + if (field->type != NULL) { + win_save_vprint(window, '-', NULL, 0, 0, "", " Type: %s", field->type); + } + if (field->var != NULL) { + win_save_vprint(window, '-', NULL, 0, 0, "", " Var: %s", field->var); + } + if (field->description != NULL) { + win_save_vprint(window, '-', NULL, 0, 0, "", " Description: %s", field->description); + } + + if (field->required) { + win_save_vprint(window, '-', NULL, 0, 0, "", " Required: TRUE"); + } else { + win_save_vprint(window, '-', NULL, 0, 0, "", " Required: FALSE"); + } + + GSList *values = field->values; + GSList *curr_value = values; + if (curr_value != NULL) { + win_save_vprint(window, '-', NULL, 0, 0, "", " Values:"); + } + while (curr_value != NULL) { + char *value = curr_value->data; + win_save_vprint(window, '-', NULL, 0, 0, "", " %s", value); + + curr_value = g_slist_next(curr_value); + } + + GSList *options = field->options; + GSList *curr_option = options; + if (curr_option != NULL) { + win_save_vprint(window, '-', NULL, 0, 0, "", " Options:"); + } + while (curr_option != NULL) { + FormOption *option = curr_option->data; + if (option->label != NULL) { + win_save_vprint(window, '-', NULL, 0, 0, "", " Label: %s", option->label); + } + if (option->value != NULL) { + win_save_vprint(window, '-', NULL, 0, 0, "", " Value: %s", option->value); + } + + curr_option = g_slist_next(curr_option); + } + + curr_field = g_slist_next(curr_field); + } + + form_destroy(form); +} + +static void _win_handle_switch(const wint_t * const ch) { if (*ch == KEY_F(1)) { @@ -2106,4 +2189,5 @@ ui_init_module(void) ui_update = _ui_update; ui_room_requires_config = _ui_room_requires_config; ui_room_destroyed = _ui_room_destroyed; + ui_handle_room_configuration = _ui_handle_room_configuration; } |