Mercurial > libervia-backend
changeset 762:aed7d99276b8
core (xml_tools), frontends: added a prefix to XMLUI form names in result data, to avoid name conflicts (e.g.: if a form has name "submit", and this name is also used internally by SàT)
author | Goffi <goffi@goffi.org> |
---|---|
date | Tue, 24 Dec 2013 15:43:22 +0100 |
parents | 2f8d72226bc0 |
children | ab851b46009c |
files | frontends/src/primitivus/xmlui.py frontends/src/wix/xmlui.py src/tools/xml_tools.py |
diffstat | 3 files changed, 30 insertions(+), 6 deletions(-) [+] |
line wrap: on
line diff
--- a/frontends/src/primitivus/xmlui.py Tue Dec 24 15:43:22 2013 +0100 +++ b/frontends/src/primitivus/xmlui.py Tue Dec 24 15:43:22 2013 +0100 @@ -22,6 +22,9 @@ from logging import debug, info, warning, error from xml.dom import minidom + +SAT_FORM_PREFIX = "SAT_FORM_" + def getText(node): """Get child text nodes @param node: dom Node @@ -254,13 +257,14 @@ def onFormSubmitted(self, button): selected_values = [] for ctrl_name in self.ctrl_list: + escaped = u"%s%s" % (SAT_FORM_PREFIX, ctrl_name) ctrl = self.ctrl_list[ctrl_name] if isinstance(ctrl['control'], sat_widgets.List): - selected_values.append((ctrl_name, u'\t'.join([option.value for option in ctrl['control'].getSelectedValues()]))) + selected_values.append((escaped, u'\t'.join([option.value for option in ctrl['control'].getSelectedValues()]))) elif isinstance(ctrl['control'], urwid.CheckBox): - selected_values.append((ctrl_name, "true" if ctrl['control'].get_state() else "false")) + selected_values.append((escaped, "true" if ctrl['control'].get_state() else "false")) else: - selected_values.append((ctrl_name, ctrl['control'].get_edit_text())) + selected_values.append((escaped, ctrl['control'].get_edit_text())) if self.misc.has_key('action_back'): #FIXME FIXME FIXME: WTF ! Must be cleaned raise NotImplementedError elif 'callback' in self.misc: # FIXME: this part is not needed anymore
--- a/frontends/src/wix/xmlui.py Tue Dec 24 15:43:22 2013 +0100 +++ b/frontends/src/wix/xmlui.py Tue Dec 24 15:43:22 2013 +0100 @@ -25,6 +25,8 @@ from logging import debug, info, warning, error from sat.tools.jid import JID +SAT_FORM_PREFIX = "SAT_FORM_" + class XMLUI(wx.Frame): """Create an user interface from a SàT xml""" @@ -216,15 +218,16 @@ debug(_("Submitting form")) selected_values = [] for ctrl_name in self.ctrl_list: + escaped = u"%s%s" % (SAT_FORM_PREFIX, ctrl_name) ctrl = self.ctrl_list[ctrl_name] if isinstance(ctrl['control'], wx.ListBox): label = ctrl['control'].GetStringSelection() value = ctrl['attr_map'][label] - selected_values.append((ctrl_name, value)) + selected_values.append((escaped, value)) elif isinstance(ctrl['control'], wx.CheckBox): - selected_values.append((ctrl_name, "true" if ctrl['control'].GetValue() else "false")) + selected_values.append((escaped, "true" if ctrl['control'].GetValue() else "false")) else: - selected_values.append((ctrl_name, ctrl['control'].GetValue())) + selected_values.append((escaped, ctrl['control'].GetValue())) if self.misc.has_key('action_back'): #FIXME FIXME FIXME: WTF ! Must be cleaned id = self.misc['action_back']("SUBMIT",self.misc['target'], selected_values) self.host.current_action_ids.add(id)
--- a/src/tools/xml_tools.py Tue Dec 24 15:43:22 2013 +0100 +++ b/src/tools/xml_tools.py Tue Dec 24 15:43:22 2013 +0100 @@ -25,6 +25,8 @@ """This library help manage XML used in SàT (parameters, registration, etc) """ +SAT_FORM_PREFIX ="SAT_FORM_" + def dataForm2XMLUI(form, submit_id, session_id=None): """Take a data form (xep-0004, Wokkel's implementation) and convert it to a SàT xml""" @@ -116,6 +118,21 @@ dataFormResult2AdvancedList(form_ui, form_xml) return form_ui +def XMLUIResult2DataFormResult(xmlui_data): + """ Extract form data from a XMLUI return + @xmlui_data: data returned by frontends for XMLUI form + @return: dict of data usable by Wokkel's dataform + """ + return {key[len(SAT_FORM_PREFIX):]: value for key, value in xmlui_data.iteritems() if key.startswith(SAT_FORM_PREFIX)} + +def XMLUIResultToElt(xmlui_data): + """ Construct result domish.Element from XMLUI result + @xmlui_data: data returned by frontends for XMLUI form + """ + form = data_form.Form('result') + form.makeFields(XMLUIResult2DataFormResult(xmlui_data)) + return form.toElement() + def tupleList2dataForm(values): """convert a list of tuples (name,value) to a wokkel submit data form""" form = data_form.Form('submit')