From 4684e9665d2ddff50f4a8e9a16d73224d2617180 Mon Sep 17 00:00:00 2001 From: Michael Drake Date: Tue, 21 Jan 2014 15:01:18 +0000 Subject: Deselect other options when select option is selected, and it's not a multi-select. --- render/form.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) (limited to 'render') diff --git a/render/form.c b/render/form.c index 49d6f217c..5ce8056de 100644 --- a/render/form.c +++ b/render/form.c @@ -520,7 +520,7 @@ bool form_successful_controls_dom(struct form *_form, goto dom_no_memory; } for(option_index = 0; option_index < options_count; - ++option_index) { + ++option_index) { bool selected; if (option_element != NULL) { dom_node_unref(option_element); @@ -1335,19 +1335,23 @@ static void form__select_process_selection(html_content *html, count++, o = o->next) { if (!control->data.select.multiple) o->selected = false; + dom_html_option_element_set_selected(o->node, false); if (count == item) { if (control->data.select.multiple) { if (o->selected) { o->selected = false; - dom_html_option_element_set_selected(o->node, false); + dom_html_option_element_set_selected( + o->node, false); control->data.select.num_selected--; } else { o->selected = true; - dom_html_option_element_set_selected(o->node, true); + dom_html_option_element_set_selected( + o->node, true); control->data.select.num_selected++; } } else { - dom_html_option_element_set_selected(o->node, true); + dom_html_option_element_set_selected( + o->node, true); o->selected = true; } } -- cgit v1.2.3