GroupchatConfig: Valid form before sending

This commit is contained in:
Philipp Hörist 2018-11-04 17:45:27 +01:00
parent 4753e6015e
commit 3e387f5215
2 changed files with 9 additions and 3 deletions

View File

@ -101,7 +101,7 @@
<property name="vexpand">False</property> <property name="vexpand">False</property>
<property name="spacing">6</property> <property name="spacing">6</property>
<child> <child>
<object class="GtkMenuButton"> <object class="GtkMenuButton" id="info_button">
<property name="visible">True</property> <property name="visible">True</property>
<property name="can_focus">True</property> <property name="can_focus">True</property>
<property name="receives_default">True</property> <property name="receives_default">True</property>
@ -195,7 +195,7 @@
</packing> </packing>
</child> </child>
<child> <child>
<object class="GtkButton"> <object class="GtkButton" id="ok_button">
<property name="label">gtk-ok</property> <property name="label">gtk-ok</property>
<property name="visible">True</property> <property name="visible">True</property>
<property name="can_focus">True</property> <property name="can_focus">True</property>

View File

@ -51,6 +51,7 @@ class GroupchatConfig(Gtk.ApplicationWindow):
visible = muc_caps_cache.supports(jid, nbxmpp.NS_REGISTER) visible = muc_caps_cache.supports(jid, nbxmpp.NS_REGISTER)
self._ui.reserved_name_column.set_visible(visible) self._ui.reserved_name_column.set_visible(visible)
self._ui.info_button.set_sensitive(False)
self._form = form self._form = form
self._affiliations = {} self._affiliations = {}
@ -67,8 +68,9 @@ class GroupchatConfig(Gtk.ApplicationWindow):
if form is not None: if form is not None:
self._ui.stack.set_visible_child_name('config') self._ui.stack.set_visible_child_name('config')
self._data_form_widget = DataFormWidget(form) self._data_form_widget = DataFormWidget(form)
self._data_form_widget.connect('is-valid', self._on_is_valid)
self._data_form_widget.validate()
self._ui.config_grid.add(self._data_form_widget) self._ui.config_grid.add(self._data_form_widget)
# self._ui.stack.set_visible_child_name('affiliation')
else: else:
self._ui.stack.get_child_by_name('config').hide() self._ui.stack.get_child_by_name('config').hide()
self._ui.stack.get_child_by_name('config').set_no_show_all(True) self._ui.stack.get_child_by_name('config').set_no_show_all(True)
@ -79,6 +81,9 @@ class GroupchatConfig(Gtk.ApplicationWindow):
self.show_all() self.show_all()
self._ui.stack.notify('visible-child-name') self._ui.stack.notify('visible-child-name')
def _on_is_valid(self, _widget, is_valid):
self._ui.ok_button.set_sensitive(is_valid)
def _get_current_treeview(self): def _get_current_treeview(self):
page_name = self._ui.stack.get_visible_child_name() page_name = self._ui.stack.get_visible_child_name()
return getattr(self._ui, '%s_treeview' % page_name) return getattr(self._ui, '%s_treeview' % page_name)
@ -208,6 +213,7 @@ class GroupchatConfig(Gtk.ApplicationWindow):
affiliation = self._own_affiliation in ('admin', 'owner') affiliation = self._own_affiliation in ('admin', 'owner')
page = page_name != 'config' page = page_name != 'config'
self._ui.treeview_buttonbox.set_visible(affiliation and page) self._ui.treeview_buttonbox.set_visible(affiliation and page)
self._ui.info_button.set_sensitive(page_name == 'outcast')
def _set_remove_button_state(self, sensitive, selected_affiliations): def _set_remove_button_state(self, sensitive, selected_affiliations):
if self._own_affiliation not in ('admin', 'owner'): if self._own_affiliation not in ('admin', 'owner'):