Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/sugar
diff options
context:
space:
mode:
authorEduardo Silva <edsiper@monotop.(none)>2007-06-02 04:33:41 (GMT)
committer Eduardo Silva <edsiper@monotop.(none)>2007-06-02 04:33:41 (GMT)
commitaab18a866d3e2aec907c0b99212d54aca05d1664 (patch)
tree41853794bc4eff44f016efadc3b406123100ec14 /sugar
parente707f1b1cc3d6d41d9ee52308e52528d315671fa (diff)
Palette: Tooltip support
Diffstat (limited to 'sugar')
-rw-r--r--sugar/graphics/palette.py59
-rw-r--r--sugar/graphics/toolbutton.py11
2 files changed, 41 insertions, 29 deletions
diff --git a/sugar/graphics/palette.py b/sugar/graphics/palette.py
index ea14d86..f474783 100644
--- a/sugar/graphics/palette.py
+++ b/sugar/graphics/palette.py
@@ -38,43 +38,50 @@ class Palette(gtk.Window):
'parent': (object, None, None, gobject.PARAM_READWRITE),
'alignment': (gobject.TYPE_INT, None, None, 0, 8, ALIGNMENT_AUTOMATIC,
- gobject.PARAM_READWRITE)
+ gobject.PARAM_READWRITE),
+
+ 'is-tooltip': (bool, None, None, False, gobject.PARAM_READWRITE | gobject.PARAM_CONSTRUCT_ONLY)
}
_PADDING = 1
_WIN_BORDER = 5
- def __init__(self):
- gobject.GObject.__init__(self, type=gtk.WINDOW_POPUP)
+ def __init__(self, **kwargs):
+ gobject.GObject.__init__(self, type=gtk.WINDOW_POPUP, **kwargs)
gtk.Window.__init__(self)
self._alignment = ALIGNMENT_AUTOMATIC
self._palette_label = gtk.Label()
- self._palette_label.set_ellipsize(pango.ELLIPSIZE_START)
+ #self._palette_label.set_justify(gtk.JUSTIFY_LEFT)
self._palette_label.show()
- self._separator = gtk.HSeparator()
- self._separator.hide()
-
- self._menu_bar = gtk.MenuBar()
- self._menu_bar.set_pack_direction(gtk.PACK_DIRECTION_TTB)
- self._menu_bar.show()
-
- self._content = gtk.HBox()
- self._content.show()
-
- self._button_bar = gtk.HButtonBox()
- self._button_bar.show()
-
- # Set main container
vbox = gtk.VBox(False, 0)
- vbox.pack_start(self._palette_label, False, False, self._PADDING)
- vbox.pack_start(self._separator, True, True, self._PADDING)
- vbox.pack_start(self._menu_bar, True, True, self._PADDING)
- vbox.pack_start(self._content, True, True, self._PADDING)
- vbox.pack_start(self._button_bar, True, True, self._PADDING)
+ vbox.pack_start(self._palette_label, True, True, self._PADDING)
+
+ # If it's a tooltip palette..
+ if not self._is_tooltip:
+ self._separator = gtk.HSeparator()
+ self._separator.hide()
+
+ self._menu_bar = gtk.MenuBar()
+ self._menu_bar.set_pack_direction(gtk.PACK_DIRECTION_TTB)
+ self._menu_bar.show()
+
+ self._content = gtk.HBox()
+ self._content.show()
+
+ self._button_bar = gtk.HButtonBox()
+ self._button_bar.show()
+
+ # Set main container
+ vbox.pack_start(self._separator, True, True, self._PADDING)
+ vbox.pack_start(self._menu_bar, True, True, self._PADDING)
+ vbox.pack_start(self._content, True, True, self._PADDING)
+ vbox.pack_start(self._button_bar, True, True, self._PADDING)
+
vbox.show()
+ self.add(vbox)
# Widget events
self.connect('motion-notify-event', self._mouse_over_widget_cb)
@@ -83,13 +90,14 @@ class Palette(gtk.Window):
self.connect('key-press-event', self._on_key_press_event_cb)
self.set_border_width(self._WIN_BORDER)
- self.add(vbox)
def do_set_property(self, pspec, value):
if pspec.name == 'parent':
self._parent_widget = value
elif pspec.name == 'alignment':
self._alignment = value
+ elif pspec.name == 'is-tooltip':
+ self._is_tooltip = value
else:
raise AssertionError
@@ -184,7 +192,8 @@ class Palette(gtk.Window):
self._separator.hide()
else:
self._palette_label.set_text(label)
- self._separator.show()
+ if not self._is_tooltip:
+ self._separator.show()
def append_menu_item(self, item):
self._menu_bar.append(item)
diff --git a/sugar/graphics/toolbutton.py b/sugar/graphics/toolbutton.py
index 7d286d9..8a06c2f 100644
--- a/sugar/graphics/toolbutton.py
+++ b/sugar/graphics/toolbutton.py
@@ -36,11 +36,14 @@ class ToolButton(gtk.ToolButton):
def set_palette(self, palette):
self._palette = palette
self._palette.props.parent = self
- self.child.connect('enter-notify-event', self._show_palette_timeout_cb)
+ self.child.connect('enter-notify-event', self._show_palette_timeout_cb, self._palette)
def set_tooltip(self, text):
- pass
+ self._palette_tt = Palette(is_tooltip=True)
+ self._palette_tt.set_primary_state(text)
+ self._palette_tt.props.parent = self
+ self.child.connect('enter-notify-event', self._show_palette_timeout_cb, self._palette_tt)
- def _show_palette_timeout_cb(self, widget, event):
+ def _show_palette_timeout_cb(self, widget, event, palette):
time.sleep(self._POPUP_PALETTE_DELAY)
- self._palette.popup()
+ palette.popup()