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)

Reply via email to