Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSimon Schampijer <simon@schampijer.de>2007-09-17 21:42:17 (GMT)
committer Simon Schampijer <simon@schampijer.de>2007-09-17 21:42:17 (GMT)
commit8ae1f9aad8e96c683c55988b317562c37634737e (patch)
treef005bbd4da779b14530b5e985d3c3f0339397b98
parent44ffef5f67d7ecae2ebdf7f6ce4c0934f645e8ad (diff)
Fix that several palettes are not hooked up to the same button #3293
-rw-r--r--NEWS1
-rw-r--r--sugar/graphics/icon.py2
-rw-r--r--sugar/graphics/palette.py11
-rw-r--r--sugar/graphics/radiotoolbutton.py2
-rw-r--r--sugar/graphics/toggletoolbutton.py2
-rw-r--r--sugar/graphics/toolbutton.py4
-rw-r--r--sugar/graphics/tray.py2
7 files changed, 21 insertions, 3 deletions
diff --git a/NEWS b/NEWS
index 3d99f7a..2f52186 100644
--- a/NEWS
+++ b/NEWS
@@ -1,3 +1,4 @@
+* #3293 Fix that several palettes are not hooked up to the same button (erikos)
* #3514 Remove invite when the activiy disappear from the mesh. (cassidy)
* #3003 Make image drags on the clipboard work consistently. (marco)
diff --git a/sugar/graphics/icon.py b/sugar/graphics/icon.py
index 1598e4b..cbff3f9 100644
--- a/sugar/graphics/icon.py
+++ b/sugar/graphics/icon.py
@@ -480,6 +480,8 @@ class CanvasIcon(hippo.CanvasBox, hippo.CanvasItem):
return self._palette
def set_palette(self, palette):
+ if self._palette is not None:
+ self._palette.props.invoker = None
self._palette = palette
if not self._palette.props.invoker:
self._palette.props.invoker = CanvasInvoker(self)
diff --git a/sugar/graphics/palette.py b/sugar/graphics/palette.py
index 8f2a404..acc14f7 100644
--- a/sugar/graphics/palette.py
+++ b/sugar/graphics/palette.py
@@ -192,9 +192,16 @@ class Palette(gtk.Window):
def do_set_property(self, pspec, value):
if pspec.name == 'invoker':
+ if self._invoker is not None:
+ self._invoker.disconnect(self._enter_invoker_hid)
+ self._invoker.disconnect(self._leave_invoker_hid)
+
self._invoker = value
- self._invoker.connect('mouse-enter', self._invoker_mouse_enter_cb)
- self._invoker.connect('mouse-leave', self._invoker_mouse_leave_cb)
+ if value is not None:
+ self._enter_invoker_hid = self._invoker.connect(
+ 'mouse-enter', self._invoker_mouse_enter_cb)
+ self._leave_invoker_hid = self._invoker.connect(
+ 'mouse-leave', self._invoker_mouse_leave_cb)
else:
raise AssertionError
diff --git a/sugar/graphics/radiotoolbutton.py b/sugar/graphics/radiotoolbutton.py
index 80afb49..8a1399a 100644
--- a/sugar/graphics/radiotoolbutton.py
+++ b/sugar/graphics/radiotoolbutton.py
@@ -41,6 +41,8 @@ class RadioToolButton(gtk.RadioToolButton):
return self._palette
def set_palette(self, palette):
+ if self._palette is not None:
+ self._palette.props.invoker = None
self._palette = palette
self._palette.props.invoker = ToolInvoker(self.child)
diff --git a/sugar/graphics/toggletoolbutton.py b/sugar/graphics/toggletoolbutton.py
index 5f44601..2c97fa3 100644
--- a/sugar/graphics/toggletoolbutton.py
+++ b/sugar/graphics/toggletoolbutton.py
@@ -37,6 +37,8 @@ class ToggleToolButton(gtk.ToggleToolButton):
return self._palette
def set_palette(self, palette):
+ if self._palette is not None:
+ self._palette.props.invoker = None
self._palette = palette
self._palette.props.invoker = ToolInvoker(self.child)
diff --git a/sugar/graphics/toolbutton.py b/sugar/graphics/toolbutton.py
index e06afe9..8a0005e 100644
--- a/sugar/graphics/toolbutton.py
+++ b/sugar/graphics/toolbutton.py
@@ -41,12 +41,14 @@ class ToolButton(gtk.ToolButton):
return self._palette
def set_palette(self, palette):
+ if self._palette is not None:
+ self._palette.props.invoker = None
self._palette = palette
self._palette.props.invoker = ToolInvoker(self.child)
def set_tooltip(self, text):
self.set_palette(Palette(text))
-
+
def do_expose_event(self, event):
if self._palette and self._palette.is_up():
invoker = self._palette.props.invoker
diff --git a/sugar/graphics/tray.py b/sugar/graphics/tray.py
index af2e7eb..b779ac9 100644
--- a/sugar/graphics/tray.py
+++ b/sugar/graphics/tray.py
@@ -216,6 +216,8 @@ class _IconWidget(gtk.EventBox):
gtk.EventBox.do_expose_event(self, event)
def set_palette(self, palette):
+ if self._palette is not None:
+ self._palette.props.invoker = None
self._palette = palette
self._palette.props.invoker = ToolInvoker(self)