Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAleksey Lim <alsroot@member.fsf.org>2009-07-31 22:04:28 (GMT)
committer Aleksey Lim <alsroot@member.fsf.org>2009-08-01 11:23:20 (GMT)
commit68fa6bf0931039e4d3db893c0614ca9fda1be3fd (patch)
treed7e9fe00ffdb449c3e9a21a56c94cc9c5064bcff
parent35bbfe1d5015bb4f2792d10739ad90ba94fec410 (diff)
Fix mess with gtk.Widget.set_state and Palette.set_state
-rw-r--r--src/sugar/graphics/palette.py38
-rw-r--r--src/sugar/graphics/toolbarbox.py4
2 files changed, 26 insertions, 16 deletions
diff --git a/src/sugar/graphics/palette.py b/src/sugar/graphics/palette.py
index c681af9..2a3b6c6 100644
--- a/src/sugar/graphics/palette.py
+++ b/src/sugar/graphics/palette.py
@@ -128,6 +128,9 @@ class MouseSpeedDetector(gobject.GObject):
return True
class PaletteWindow(gtk.Window):
+ PRIMARY = 0
+ SECONDARY = 1
+
__gtype_name__ = 'SugarPaletteWindow'
__gsignals__ = {
@@ -148,6 +151,7 @@ class PaletteWindow(gtk.Window):
self._alignment = None
self._up = False
self._old_alloc = None
+ self._palette_state = self.PRIMARY
self._popup_anim = animator.Animator(.5, 10)
self._popup_anim.add(_PopupAnimation(self))
@@ -314,7 +318,7 @@ class PaletteWindow(gtk.Window):
def get_full_size_request(self):
return self.size_request()
- def popup(self, immediate=False):
+ def popup(self, immediate=False, state=None):
if self._invoker is not None:
full_size_request = self.get_full_size_request()
self._alignment = self._invoker.get_alignment(full_size_request)
@@ -361,7 +365,7 @@ class PaletteWindow(gtk.Window):
self.on_invoker_leave()
def _invoker_right_click_cb(self, invoker):
- self.popup(immediate=True)
+ self.popup(immediate=True, state=self.SECONDARY)
def __enter_notify_event_cb(self, widget, event):
if event.detail != gtk.gdk.NOTIFY_INFERIOR and \
@@ -400,10 +404,18 @@ class PaletteWindow(gtk.Window):
return gtk.gdk.Rectangle(x, y, width, height)
-class Palette(PaletteWindow):
- PRIMARY = 0
- SECONDARY = 1
+ def get_palette_state(self):
+ return self._palette_state
+
+ def _set_palette_state(self, state):
+ self._palette_state = state
+
+ def set_palette_state(self, state):
+ self._set_palette_state(state)
+ palette_state = property(get_palette_state)
+
+class Palette(PaletteWindow):
__gtype_name__ = 'SugarPalette'
# DEPRECATED: label is passed with the primary-text property, accel_path
@@ -411,8 +423,6 @@ class Palette(PaletteWindow):
def __init__(self, label=None, accel_path=None, menu_after_content=False,
text_maxlen=60, **kwargs):
- self.palette_state = self.PRIMARY
-
self._primary_text = None
self._secondary_text = None
self._icon = None
@@ -549,7 +559,7 @@ class Palette(PaletteWindow):
if state is None:
state = self.PRIMARY
- self.set_state(state)
+ self.set_palette_state(state)
self._secondary_anim.start()
@@ -696,18 +706,18 @@ class Palette(PaletteWindow):
self._update_accept_focus()
def _update_full_request(self):
- if self.palette_state == self.PRIMARY:
+ if self._palette_state == self.PRIMARY:
self.menu.embed(self._menu_box)
self._secondary_box.show()
self._full_request = self.size_request()
- if self.palette_state == self.PRIMARY:
+ if self._palette_state == self.PRIMARY:
self.menu.unembed()
self._secondary_box.hide()
- def set_state(self, state):
- if self.palette_state == state:
+ def _set_palette_state(self, state):
+ if self._palette_state == state:
return
if state == self.PRIMARY:
@@ -718,7 +728,7 @@ class Palette(PaletteWindow):
self._secondary_box.show()
self.update_position()
- self.palette_state = state
+ self._palette_state = state
class PaletteActionBar(gtk.HButtonBox):
def add_action(self, label, icon_name=None):
@@ -784,7 +794,7 @@ class _SecondaryAnimation(animator.Animation):
def next_frame(self, current):
if current == 1.0:
- self._palette.set_state(Palette.SECONDARY)
+ self._palette.set_palette_state(Palette.SECONDARY)
class _PopdownAnimation(animator.Animation):
def __init__(self, palette):
diff --git a/src/sugar/graphics/toolbarbox.py b/src/sugar/graphics/toolbarbox.py
index 91c5c2d..fac92b9 100644
--- a/src/sugar/graphics/toolbarbox.py
+++ b/src/sugar/graphics/toolbarbox.py
@@ -214,14 +214,14 @@ class _ToolbarPalette(PaletteWindow):
requisition.width = max(requisition.width,
gtk.gdk.screen_width())
- def popup(self, immediate=False):
+ def popup(self, immediate=False, state=None):
button = self.toolbar_button
if button.is_expanded():
return
box = button.toolbar_box
_setup_page(button.page_widget, style.COLOR_BLACK.get_gdk_color(),
box.props.padding)
- PaletteWindow.popup(self, immediate)
+ PaletteWindow.popup(self, immediate, state)
def __group_popdown_cb(self, group):
if self._focus == 0: