changeset ca48c92eaf73 in tryton:5.6 details: https://hg.tryton.org/tryton?cmd=changeset;node=ca48c92eaf73 description: Store record and field instead of path when editing is started
The path can not more be valid or pointing to the proper record if the treeview model is modified during the edition. issue9765 review294841002 (grafted from 445bee75c18715f87b35f9e7f20f08d053e2514b) diffstat: tryton/gui/window/view_form/view/list_gtk/widget.py | 13 +++++++------ 1 files changed, 7 insertions(+), 6 deletions(-) diffs (45 lines): diff -r 3aed04dfbd0c -r ca48c92eaf73 tryton/gui/window/view_form/view/list_gtk/widget.py --- a/tryton/gui/window/view_form/view/list_gtk/widget.py Wed Oct 21 23:21:26 2020 +0200 +++ b/tryton/gui/window/view_form/view/list_gtk/widget.py Wed Oct 28 23:59:06 2020 +0100 @@ -210,6 +210,7 @@ class GenericText(Cell): align = 0 editable = None + editing = None def __init__(self, view, attrs, renderer=None): super(GenericText, self).__init__() @@ -295,17 +296,17 @@ callback() def set_editable(self): - if not self.editable: + if not self.editable or not self.editing: return - record, field = self._get_record_field_from_path(self.editable_path) + record, field = self.editing self.editable.set_text(self.get_textual_value(record)) def editing_started(self, cell, editable, path): def remove(editable): self.editable = None - self.editable_path = None + self.editing = None self.editable = editable - self.editable_path = path + self.editing = self._get_record_field_from_path(path) editable.connect('remove-widget', remove) return False @@ -981,9 +982,9 @@ callback() def set_editable(self): - if not self.editable: + if not self.editable and not self.editing: return - record, field = self._get_record_field_from_path(self.editable_path) + record, field = self.editing value = self.get_value(record, field) self.update_selection(record, field) self.set_popdown_value(self.editable, value)