[tryton-debian-vcs] tryton-client branch upstream updated. upstream/4.2.0-1-g0e1cc73

Mathias Behrle tryton-debian-vcs at alioth.debian.org
Thu Jan 5 10:47:05 UTC 2017


The following commit has been merged in the upstream branch:
https://alioth.debian.org/plugins/scmgit/cgi-bin/gitweb.cgi/?p=tryton/tryton-client.git;a=commitdiff;h=upstream/4.2.0-1-g0e1cc73

commit 0e1cc7374f56396534f76f200c662beab2abf351
Author: Mathias Behrle <mathiasb at m9s.biz>
Date:   Wed Jan 4 12:47:40 2017 +0100

    Adding upstream version 4.2.1.
    
    Signed-off-by: Mathias Behrle <mathiasb at m9s.biz>

diff --git a/CHANGELOG b/CHANGELOG
index 11335a1..dba7a77 100644
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -1,3 +1,6 @@
+Version 4.2.1 - 2017-01-03
+* Bug fixes (see mercurial logs for details)
+
 Version 4.2.0 - 2016-11-28
 * Bug fixes (see mercurial logs for details)
 * Add support for GTK+ 3.0
diff --git a/PKG-INFO b/PKG-INFO
index e60659f..265f251 100644
--- a/PKG-INFO
+++ b/PKG-INFO
@@ -1,6 +1,6 @@
 Metadata-Version: 1.1
 Name: tryton
-Version: 4.2.0
+Version: 4.2.1
 Summary: Tryton client
 Home-page: http://www.tryton.org/
 Author: Tryton
diff --git a/tryton.egg-info/PKG-INFO b/tryton.egg-info/PKG-INFO
index e60659f..265f251 100644
--- a/tryton.egg-info/PKG-INFO
+++ b/tryton.egg-info/PKG-INFO
@@ -1,6 +1,6 @@
 Metadata-Version: 1.1
 Name: tryton
-Version: 4.2.0
+Version: 4.2.1
 Summary: Tryton client
 Home-page: http://www.tryton.org/
 Author: Tryton
diff --git a/tryton/__init__.py b/tryton/__init__.py
index 9d9331b..75fc627 100644
--- a/tryton/__init__.py
+++ b/tryton/__init__.py
@@ -1,3 +1,3 @@
 # This file is part of Tryton.  The COPYRIGHT file at the top level of
 # this repository contains the full copyright notices and license terms.
-__version__ = "4.2.0"
+__version__ = "4.2.1"
diff --git a/tryton/client.py b/tryton/client.py
index f57d4d1..d979f52 100644
--- a/tryton/client.py
+++ b/tryton/client.py
@@ -104,24 +104,6 @@ if os.environ.get('GTK_VERSION', '2').startswith('3'):
     Pango.SCALE_LARGE = 1.2
     Pango.SCALE_X_LARGE = 1.2 * 1.2
     Pango.SCALE_XX_LARGE = 1.2 * 1.2 * 1.2
-
-    style_provider = Gtk.CssProvider()
-    css = """
-    #editable {
-        background-color: @theme_base_color;
-        color: @theme_text_color;
-    }
-    #readonly {
-        background-color: @insensitive_bg_color;
-        color: @insensitive_fg_color;
-    }
-    """
-    style_provider.load_from_data(css)
-    Gtk.StyleContext.add_provider_for_screen(
-        Gdk.Screen.get_default(),
-        style_provider,
-        Gtk.STYLE_PROVIDER_PRIORITY_APPLICATION)
-
 else:
     import pygtk
     pygtk.require('2.0')
diff --git a/tryton/common/common.py b/tryton/common/common.py
index a5dc066..cb7e54e 100644
--- a/tryton/common/common.py
+++ b/tryton/common/common.py
@@ -1187,9 +1187,9 @@ class RPCProgress(object):
             # Parent is only useful if it is asynchronous
             # otherwise the cursor is not updated.
             self.parent = get_toplevel_window()
-            if self.parent.window:
+            if self.parent.get_window():
                 watch = gtk.gdk.Cursor(gtk.gdk.WATCH)
-                self.parent.window.set_cursor(watch)
+                self.parent.get_window().set_cursor(watch)
             thread.start_new_thread(self.start, ())
             return
         else:
@@ -1197,8 +1197,8 @@ class RPCProgress(object):
             return self.process()
 
     def process(self):
-        if self.parent and self.parent.window:
-            self.parent.window.set_cursor(None)
+        if self.parent and self.parent.get_window():
+            self.parent.get_window().set_cursor(None)
         if self.exception:
             if self.process_exception_p:
                 def rpc_execute(*args):
diff --git a/tryton/common/placeholder_entry.py b/tryton/common/placeholder_entry.py
index a9e5c35..17ff13e 100644
--- a/tryton/common/placeholder_entry.py
+++ b/tryton/common/placeholder_entry.py
@@ -38,6 +38,8 @@ else:
         def set_placeholder_text(self, text):
             self._placeholder = text
             if not self.has_focus():
+                if self._default:
+                    super(PlaceholderEntry, self).set_text('')
                 self._focus_out()
 
         def get_text(self):
@@ -65,6 +67,8 @@ if __name__ == '__main__':
 
     placeholder_entry = PlaceholderEntry()
     placeholder_entry.set_placeholder_text('Placeholder')
+    # Set twice to check placeholder does not become text
+    placeholder_entry.set_placeholder_text('Placeholder')
     vbox.pack_start(placeholder_entry)
 
     win.show_all()
diff --git a/tryton/common/treeviewcontrol.py b/tryton/common/treeviewcontrol.py
index 79c4192..b886772 100644
--- a/tryton/common/treeviewcontrol.py
+++ b/tryton/common/treeviewcontrol.py
@@ -13,10 +13,6 @@ __all__ = ['TreeViewControl']
 
 
 class TreeViewControl(gtk.TreeView):
-    __gsignals__ = {
-        'button-press-event': 'override',
-        'key-press-event': 'override',
-        }
 
     def do_button_press_event(self, event):
         self.grab_focus()  # grab focus because it doesn't whith CONTROL MASK
diff --git a/tryton/common/widget_style.py b/tryton/common/widget_style.py
index 09ccceb..ab93099 100644
--- a/tryton/common/widget_style.py
+++ b/tryton/common/widget_style.py
@@ -18,4 +18,5 @@ if gtk_version == 2:
             widget.modify_bg(gtk.STATE_NORMAL, style.bg[gtk.STATE_INSENSITIVE])
 else:
     def set_widget_style(widget, editable):
-        widget.set_name('editable' if editable else 'readonly')
+        # TODO
+        pass
diff --git a/tryton/data/locale/bg/LC_MESSAGES/tryton.mo b/tryton/data/locale/bg/LC_MESSAGES/tryton.mo
index 67f3faf..9dc29ea 100644
Binary files a/tryton/data/locale/bg/LC_MESSAGES/tryton.mo and b/tryton/data/locale/bg/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/ca/LC_MESSAGES/tryton.mo b/tryton/data/locale/ca/LC_MESSAGES/tryton.mo
index 0499b42..10fbd9c 100644
Binary files a/tryton/data/locale/ca/LC_MESSAGES/tryton.mo and b/tryton/data/locale/ca/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/cs/LC_MESSAGES/tryton.mo b/tryton/data/locale/cs/LC_MESSAGES/tryton.mo
index ca1f5cb..7072fc1 100644
Binary files a/tryton/data/locale/cs/LC_MESSAGES/tryton.mo and b/tryton/data/locale/cs/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/de/LC_MESSAGES/tryton.mo b/tryton/data/locale/de/LC_MESSAGES/tryton.mo
index 54174ec..45eafd4 100644
Binary files a/tryton/data/locale/de/LC_MESSAGES/tryton.mo and b/tryton/data/locale/de/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/es/LC_MESSAGES/tryton.mo b/tryton/data/locale/es/LC_MESSAGES/tryton.mo
index 069520f..5e40ab7 100644
Binary files a/tryton/data/locale/es/LC_MESSAGES/tryton.mo and b/tryton/data/locale/es/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/es_419/LC_MESSAGES/tryton.mo b/tryton/data/locale/es_419/LC_MESSAGES/tryton.mo
index 565f539..789a924 100644
Binary files a/tryton/data/locale/es_419/LC_MESSAGES/tryton.mo and b/tryton/data/locale/es_419/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/fr/LC_MESSAGES/tryton.mo b/tryton/data/locale/fr/LC_MESSAGES/tryton.mo
index 17ba5b4..6fade0f 100644
Binary files a/tryton/data/locale/fr/LC_MESSAGES/tryton.mo and b/tryton/data/locale/fr/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/hu_HU/LC_MESSAGES/tryton.mo b/tryton/data/locale/hu_HU/LC_MESSAGES/tryton.mo
index 47ed466..f8d849f 100644
Binary files a/tryton/data/locale/hu_HU/LC_MESSAGES/tryton.mo and b/tryton/data/locale/hu_HU/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/it_IT/LC_MESSAGES/tryton.mo b/tryton/data/locale/it_IT/LC_MESSAGES/tryton.mo
index ce33fa7..a4fcc7f 100644
Binary files a/tryton/data/locale/it_IT/LC_MESSAGES/tryton.mo and b/tryton/data/locale/it_IT/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/ja_JP/LC_MESSAGES/tryton.mo b/tryton/data/locale/ja_JP/LC_MESSAGES/tryton.mo
index 06be136..642970b 100644
Binary files a/tryton/data/locale/ja_JP/LC_MESSAGES/tryton.mo and b/tryton/data/locale/ja_JP/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/lo/LC_MESSAGES/tryton.mo b/tryton/data/locale/lo/LC_MESSAGES/tryton.mo
index 9f09e3d..4fb0557 100644
Binary files a/tryton/data/locale/lo/LC_MESSAGES/tryton.mo and b/tryton/data/locale/lo/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/lt/LC_MESSAGES/tryton.mo b/tryton/data/locale/lt/LC_MESSAGES/tryton.mo
index d8439be..22deb8a 100644
Binary files a/tryton/data/locale/lt/LC_MESSAGES/tryton.mo and b/tryton/data/locale/lt/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/nl/LC_MESSAGES/tryton.mo b/tryton/data/locale/nl/LC_MESSAGES/tryton.mo
index e6ce9e4..b5c8782 100644
Binary files a/tryton/data/locale/nl/LC_MESSAGES/tryton.mo and b/tryton/data/locale/nl/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/pl/LC_MESSAGES/tryton.mo b/tryton/data/locale/pl/LC_MESSAGES/tryton.mo
index 7403fcf..989ccb4 100644
Binary files a/tryton/data/locale/pl/LC_MESSAGES/tryton.mo and b/tryton/data/locale/pl/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/pt_BR/LC_MESSAGES/tryton.mo b/tryton/data/locale/pt_BR/LC_MESSAGES/tryton.mo
index d319832..7879e86 100644
Binary files a/tryton/data/locale/pt_BR/LC_MESSAGES/tryton.mo and b/tryton/data/locale/pt_BR/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/ru/LC_MESSAGES/tryton.mo b/tryton/data/locale/ru/LC_MESSAGES/tryton.mo
index 7b58960..48a5536 100644
Binary files a/tryton/data/locale/ru/LC_MESSAGES/tryton.mo and b/tryton/data/locale/ru/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/sl/LC_MESSAGES/tryton.mo b/tryton/data/locale/sl/LC_MESSAGES/tryton.mo
index 8eac9a0..3a4276d 100644
Binary files a/tryton/data/locale/sl/LC_MESSAGES/tryton.mo and b/tryton/data/locale/sl/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/data/locale/zh_CN/LC_MESSAGES/tryton.mo b/tryton/data/locale/zh_CN/LC_MESSAGES/tryton.mo
index 1ffe416..528d156 100644
Binary files a/tryton/data/locale/zh_CN/LC_MESSAGES/tryton.mo and b/tryton/data/locale/zh_CN/LC_MESSAGES/tryton.mo differ
diff --git a/tryton/gui/main.py b/tryton/gui/main.py
index c0f49d0..7ed1d7a 100644
--- a/tryton/gui/main.py
+++ b/tryton/gui/main.py
@@ -1272,7 +1272,7 @@ class Main(object):
             try:
                 view_ids = json.loads(params.get('views', 'false'))
                 limit = json.loads(params.get('limit', 'null'))
-                name = json.loads(params.get('name', ''))
+                name = json.loads(params.get('name', '""'))
                 search_value = json.loads(params.get('search_value', '{}'),
                     object_hook=object_hook)
                 domain = json.loads(params.get('domain', '[]'),
@@ -1304,7 +1304,7 @@ class Main(object):
                 direct_print = json.loads(params.get('direct_print', 'false'))
                 email_print = json.loads(params.get('email_print', 'false'))
                 email = json.loads(params.get('email', 'null'))
-                name = json.loads(params.get('name', 'false'))
+                name = json.loads(params.get('name', '""'))
                 window = json.loads(params.get('window', 'false'))
                 context = json.loads(params.get('context', '{}'),
                     object_hook=object_hook)
diff --git a/tryton/gui/window/revision.py b/tryton/gui/window/revision.py
index c2aaaac..1c37d08 100644
--- a/tryton/gui/window/revision.py
+++ b/tryton/gui/window/revision.py
@@ -30,8 +30,9 @@ class Revision(object):
         label = gtk.Label(_('Revision:'))
         hbox.pack_start(label, expand=True, fill=True)
         list_store = gtk.ListStore(str, str)
-        combobox = gtk.ComboBoxEntry(list_store)
-        self.entry = combobox.child
+        combobox = gtk.ComboBoxEntry()
+        combobox.set_model(list_store)
+        self.entry = combobox.get_child()
         self.entry.connect('focus-out-event', self.focus_out)
         self.entry.connect('activate', self.activate)
         label.set_mnemonic_widget(self.entry)
diff --git a/tryton/gui/window/view_board/view_board.py b/tryton/gui/window/view_board/view_board.py
index d800455..360883a 100644
--- a/tryton/gui/window/view_board/view_board.py
+++ b/tryton/gui/window/view_board/view_board.py
@@ -115,7 +115,8 @@ class ViewBoard(object):
     def _parse_group(self, node, container, attributes):
         group = self.parse(node)
         group.table.set_homogeneous(attributes.get('homogeneous', False))
-        frame = gtk.Frame(attributes.get('string'))
+        frame = gtk.Frame()
+        frame.set_label(attributes.get('string'))
         if not attributes.get('string'):
             frame.set_shadow_type(gtk.SHADOW_NONE)
         frame.set_border_width(0)
diff --git a/tryton/gui/window/view_form/model/group.py b/tryton/gui/window/view_form/model/group.py
index 72584ae..7855eb3 100644
--- a/tryton/gui/window/view_form/model/group.py
+++ b/tryton/gui/window/view_form/model/group.py
@@ -299,7 +299,7 @@ class Group(SignalEvent, list):
         for record in self:
             # Assume not loaded records are correctly ordered
             # as far as we do not change any previous records.
-            if (record.get_loaded([field]) and not changed) or record.id < 0:
+            if record.get_loaded([field]) or changed or record.id < 0:
                 if prev:
                     index = prev[field].get(prev)
                 else:
@@ -314,7 +314,7 @@ class Group(SignalEvent, list):
                 if value == index:
                     if prev and record.id >= 0:
                         update = record.id < prev.id
-                elif value < index:
+                elif value <= (index or 0):
                     update = True
                 if update:
                     if index is None:
diff --git a/tryton/gui/window/view_form/view/form_gtk/dictionary.py b/tryton/gui/window/view_form/view/form_gtk/dictionary.py
index 32b5826..f712ff4 100644
--- a/tryton/gui/window/view_form/view/form_gtk/dictionary.py
+++ b/tryton/gui/window/view_form/view/form_gtk/dictionary.py
@@ -84,11 +84,12 @@ class DictSelectionEntry(DictEntry):
         widget = gtk.ComboBoxEntry()
 
         # customizing entry
-        widget.child.props.activates_default = True
-        widget.child.connect('changed', self.parent_widget.send_modified)
-        widget.child.connect('focus-out-event',
+        child = widget.get_child()
+        child.props.activates_default = True
+        child.connect('changed', self.parent_widget.send_modified)
+        child.connect('focus-out-event',
             lambda w, e: self.parent_widget._focus_out())
-        widget.child.connect('activate',
+        child.connect('activate',
             lambda w: self.parent_widget._focus_out())
         widget.connect('notify::active',
             lambda w, e: self.parent_widget._focus_out())
@@ -109,18 +110,19 @@ class DictSelectionEntry(DictEntry):
             width = max(width, len(name))
         widget.set_model(model)
         widget.set_text_column(0)
-        widget.child.set_width_chars(width)
+        child.set_width_chars(width)
         completion = gtk.EntryCompletion()
         completion.set_inline_selection(True)
         completion.set_model(model)
-        widget.child.set_completion(completion)
+        child.set_completion(completion)
         completion.set_text_column(0)
         return widget
 
     def get_value(self):
-        if not self.widget.child:  # widget is destroyed
+        child = self.widget.get_child()
+        if not child:  # widget is destroyed
             return
-        text = self.widget.child.get_text()
+        text = child.get_text()
         value = None
         if text:
             for txt, val in self._selection.items():
@@ -134,8 +136,9 @@ class DictSelectionEntry(DictEntry):
 
     def set_value(self, value):
         values = dict(self.definition['selection'])
-        self.widget.child.set_text(values.get(value, ''))
-        reset_position(self.widget.child)
+        child = self.widget.get_child()
+        child.set_text(values.get(value, ''))
+        reset_position(child)
 
     def set_readonly(self, readonly):
         self.widget.set_sensitive(not readonly)
@@ -319,7 +322,8 @@ class DictWidget(Widget):
         self.buttons = {}
         self.rows = {}
 
-        self.widget = gtk.Frame(attrs.get('string', ''))
+        self.widget = gtk.Frame()
+        self.widget.set_label(attrs.get('string', ''))
         self.widget.set_shadow_type(gtk.SHADOW_OUT)
 
         vbox = gtk.VBox()
diff --git a/tryton/gui/window/view_form/view/form_gtk/multiselection.py b/tryton/gui/window/view_form/view/form_gtk/multiselection.py
index 6543290..26a737c 100644
--- a/tryton/gui/window/view_form/view/form_gtk/multiselection.py
+++ b/tryton/gui/window/view_form/view/form_gtk/multiselection.py
@@ -47,7 +47,7 @@ class MultiSelection(Widget, SelectionMixin):
         super(MultiSelection, self)._readonly_set(readonly)
         set_widget_style(self.tree, not readonly)
         selection = self.tree.get_selection()
-        selection.set_select_function(lambda info: not readonly)
+        selection.set_select_function(lambda *a: not readonly)
 
     @property
     def modified(self):
@@ -77,7 +77,7 @@ class MultiSelection(Widget, SelectionMixin):
         try:
             # Remove select_function to allow update,
             # it will be set back in the super call
-            selection.set_select_function(lambda info: True)
+            selection.set_select_function(lambda *a: True)
             self.update_selection(record, field)
             self.model.clear()
             if field is None:
diff --git a/tryton/gui/window/view_form/view/form_gtk/selection.py b/tryton/gui/window/view_form/view/form_gtk/selection.py
index a3663ee..b9d1062 100644
--- a/tryton/gui/window/view_form/view/form_gtk/selection.py
+++ b/tryton/gui/window/view_form/view/form_gtk/selection.py
@@ -44,11 +44,11 @@ class Selection(Widget, SelectionMixin, PopdownMixin):
         gobject.idle_add(focus_out)
 
     def _move_active(self, combobox, scroll_type):
-        if not combobox.child.get_editable():
+        if not combobox.get_child().get_editable():
             combobox.emit_stop_by_name('move-active')
 
     def _scroll_event(self, combobox, event):
-        if not combobox.child.get_editable():
+        if not combobox.get_child().get_editable():
             combobox.emit_stop_by_name('scroll-event')
 
     def _readonly_set(self, value):
diff --git a/tryton/gui/window/view_form/view/list_gtk/widget.py b/tryton/gui/window/view_form/view/list_gtk/widget.py
index 4a2957b..e950dfe 100644
--- a/tryton/gui/window/view_form/view/list_gtk/widget.py
+++ b/tryton/gui/window/view_form/view/list_gtk/widget.py
@@ -1,6 +1,6 @@
 # This file is part of Tryton.  The COPYRIGHT file at the top level of
 # this repository contains the full copyright notices and license terms.
-
+import datetime
 import os
 import tempfile
 import gtk
@@ -387,7 +387,9 @@ class Time(Date):
             return ''
         value = record[self.attrs['name']].get_client(record)
         if value is not None:
-            return datetime_strftime(value, self.renderer.props.format)
+            if isinstance(value, datetime.datetime):
+                value = value.time()
+            return value.strftime(self.renderer.props.format)
         else:
             return ''
 
-- 
tryton-client



More information about the tryton-debian-vcs mailing list