Generic menu
This commit is contained in:
parent
8dbdda5384
commit
a1d2b993c0
@ -2,90 +2,41 @@ import gtk
|
|||||||
import goocanvas
|
import goocanvas
|
||||||
import gobject
|
import gobject
|
||||||
|
|
||||||
from sugar.canvas.CanvasView import CanvasView
|
from sugar.canvas.Menu import Menu
|
||||||
from sugar.canvas.CanvasBox import CanvasBox
|
|
||||||
from sugar.canvas.IconItem import IconItem
|
from sugar.canvas.IconItem import IconItem
|
||||||
from sugar.presence import PresenceService
|
from sugar.presence import PresenceService
|
||||||
|
|
||||||
class BuddyPopup(gtk.Window):
|
class BuddyPopup(Menu):
|
||||||
ACTION_MAKE_FRIEND = 0
|
ACTION_MAKE_FRIEND = 0
|
||||||
ACTION_INVITE = 1
|
ACTION_INVITE = 1
|
||||||
ACTION_REMOVE_FRIEND = 2
|
ACTION_REMOVE_FRIEND = 2
|
||||||
|
|
||||||
__gsignals__ = {
|
|
||||||
'action': (gobject.SIGNAL_RUN_FIRST,
|
|
||||||
gobject.TYPE_NONE, ([int])),
|
|
||||||
}
|
|
||||||
|
|
||||||
def __init__(self, shell, buddy):
|
def __init__(self, shell, buddy):
|
||||||
gtk.Window.__init__(self, gtk.WINDOW_POPUP)
|
color = buddy.get_color()
|
||||||
|
Menu.__init__(self, shell.get_grid(), buddy.get_name(),
|
||||||
|
color.get_fill_color(), color.get_stroke_color())
|
||||||
|
|
||||||
self._buddy = buddy
|
self._buddy = buddy
|
||||||
self._hover = False
|
|
||||||
self._popdown_on_leave = False
|
|
||||||
self._width = 13
|
|
||||||
self._shell = shell
|
self._shell = shell
|
||||||
self._buddy = buddy
|
|
||||||
|
|
||||||
grid = shell.get_grid()
|
|
||||||
|
|
||||||
canvas = CanvasView()
|
|
||||||
self.add(canvas)
|
|
||||||
canvas.show()
|
|
||||||
|
|
||||||
model = goocanvas.CanvasModelSimple()
|
|
||||||
root = model.get_root_item()
|
|
||||||
|
|
||||||
color = self._buddy.get_color()
|
|
||||||
rect = goocanvas.Rect(fill_color=color.get_fill_color(),
|
|
||||||
stroke_color=color.get_stroke_color(),
|
|
||||||
line_width=3)
|
|
||||||
root.add_child(rect)
|
|
||||||
|
|
||||||
text = goocanvas.Text(text=self._buddy.get_name(), font="Sans bold 18",
|
|
||||||
fill_color='black', anchor=gtk.ANCHOR_SW)
|
|
||||||
grid.set_constraints(text, 1, 3, self._width, 2)
|
|
||||||
root.add_child(text)
|
|
||||||
|
|
||||||
self._height = 4
|
|
||||||
|
|
||||||
owner = shell.get_model().get_owner()
|
owner = shell.get_model().get_owner()
|
||||||
if buddy.get_name() != owner.get_name():
|
if buddy.get_name() != owner.get_name():
|
||||||
self._add_actions(grid, root)
|
self._add_actions()
|
||||||
|
|
||||||
grid.set_constraints(canvas, 0, 0, self._width, self._height)
|
def _add_actions(self):
|
||||||
grid.set_constraints(rect, 0, 0, self._width, self._height)
|
|
||||||
|
|
||||||
canvas.set_model(model)
|
|
||||||
|
|
||||||
def _add_actions(self, grid, root):
|
|
||||||
shell_model = self._shell.get_model()
|
shell_model = self._shell.get_model()
|
||||||
pservice = PresenceService.get_instance()
|
pservice = PresenceService.get_instance()
|
||||||
|
|
||||||
separator = goocanvas.Path(data='M 15 0 L 185 0', line_width=3,
|
|
||||||
fill_color='black')
|
|
||||||
grid.set_constraints(separator, 0, 4)
|
|
||||||
root.add_child(separator)
|
|
||||||
|
|
||||||
box = CanvasBox(grid, CanvasBox.HORIZONTAL, 1)
|
|
||||||
grid.set_constraints(box, 0, 5)
|
|
||||||
|
|
||||||
friends = shell_model.get_friends()
|
friends = shell_model.get_friends()
|
||||||
if friends.has_buddy(self._buddy):
|
if friends.has_buddy(self._buddy):
|
||||||
icon = IconItem(icon_name='stock-remove-friend')
|
icon = IconItem(icon_name='stock-remove-friend')
|
||||||
icon.connect('clicked', self._action_clicked_cb,
|
self.add_action(icon, BuddyPopup.ACTION_REMOVE_FRIEND)
|
||||||
BuddyPopup.ACTION_REMOVE_FRIEND)
|
|
||||||
else:
|
else:
|
||||||
icon = IconItem(icon_name='stock-make-friend')
|
icon = IconItem(icon_name='stock-make-friend')
|
||||||
icon.connect('clicked', self._action_clicked_cb,
|
self.add_action(icon, BuddyPopup.ACTION_MAKE_FRIEND)
|
||||||
BuddyPopup.ACTION_MAKE_FRIEND)
|
|
||||||
|
|
||||||
box.set_constraints(icon, 3, 3)
|
|
||||||
box.add_child(icon)
|
|
||||||
|
|
||||||
icon = IconItem(icon_name='stock-chat')
|
icon = IconItem(icon_name='stock-chat')
|
||||||
box.set_constraints(icon, 3, 3)
|
self.add_action(icon, -1)
|
||||||
box.add_child(icon)
|
|
||||||
|
|
||||||
activity = shell_model.get_current_activity()
|
activity = shell_model.get_current_activity()
|
||||||
if activity != None:
|
if activity != None:
|
||||||
@ -94,20 +45,4 @@ class BuddyPopup(gtk.Window):
|
|||||||
# FIXME check that the buddy is not in the activity already
|
# FIXME check that the buddy is not in the activity already
|
||||||
|
|
||||||
icon = IconItem(icon_name='stock-invite')
|
icon = IconItem(icon_name='stock-invite')
|
||||||
icon.connect('clicked', self._action_clicked_cb,
|
self.add_action(icon, BuddyPopup.ACTION_INVITE)
|
||||||
BuddyPopup.ACTION_INVITE)
|
|
||||||
box.set_constraints(icon, 3, 3)
|
|
||||||
box.add_child(icon)
|
|
||||||
|
|
||||||
root.add_child(box)
|
|
||||||
|
|
||||||
self._height = 10
|
|
||||||
|
|
||||||
def _action_clicked_cb(self, icon, action):
|
|
||||||
self.emit('action', action)
|
|
||||||
|
|
||||||
def get_width(self):
|
|
||||||
return self._width
|
|
||||||
|
|
||||||
def get_height(self):
|
|
||||||
return self._height
|
|
||||||
|
79
sugar/canvas/Menu.py
Normal file
79
sugar/canvas/Menu.py
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
import gtk
|
||||||
|
import goocanvas
|
||||||
|
import gobject
|
||||||
|
|
||||||
|
from sugar.canvas.CanvasView import CanvasView
|
||||||
|
from sugar.canvas.CanvasBox import CanvasBox
|
||||||
|
from sugar.canvas.IconItem import IconItem
|
||||||
|
|
||||||
|
class Menu(gtk.Window):
|
||||||
|
__gsignals__ = {
|
||||||
|
'action': (gobject.SIGNAL_RUN_FIRST,
|
||||||
|
gobject.TYPE_NONE, ([int])),
|
||||||
|
}
|
||||||
|
|
||||||
|
def __init__(self, grid, title, fill, stroke):
|
||||||
|
gtk.Window.__init__(self, gtk.WINDOW_POPUP)
|
||||||
|
|
||||||
|
self._width = 13
|
||||||
|
self._grid = grid
|
||||||
|
self._action_box = None
|
||||||
|
|
||||||
|
self._canvas = CanvasView()
|
||||||
|
self.add(self._canvas)
|
||||||
|
self._canvas.show()
|
||||||
|
|
||||||
|
model = goocanvas.CanvasModelSimple()
|
||||||
|
self._root = model.get_root_item()
|
||||||
|
|
||||||
|
self._rect = goocanvas.Rect(fill_color=fill,stroke_color=stroke,
|
||||||
|
line_width=3)
|
||||||
|
self._root.add_child(self._rect)
|
||||||
|
|
||||||
|
text = goocanvas.Text(text=title, font="Sans bold 18",
|
||||||
|
fill_color='black', anchor=gtk.ANCHOR_SW)
|
||||||
|
self._grid.set_constraints(text, 1, 3, self._width, 2)
|
||||||
|
self._root.add_child(text)
|
||||||
|
|
||||||
|
self._height = 4
|
||||||
|
self._update_constraints()
|
||||||
|
|
||||||
|
self._canvas.set_model(model)
|
||||||
|
|
||||||
|
def _create_action_box(self):
|
||||||
|
separator = goocanvas.Path(data='M 15 0 L 185 0', line_width=3,
|
||||||
|
fill_color='black')
|
||||||
|
self._grid.set_constraints(separator, 0, 4)
|
||||||
|
self._root.add_child(separator)
|
||||||
|
|
||||||
|
box = CanvasBox(self._grid, CanvasBox.HORIZONTAL, 1)
|
||||||
|
self._grid.set_constraints(box, 0, 5)
|
||||||
|
|
||||||
|
return box
|
||||||
|
|
||||||
|
def add_action(self, icon, action_id):
|
||||||
|
if self._action_box == None:
|
||||||
|
self._action_box = self._create_action_box()
|
||||||
|
self._root.add_child(self._action_box)
|
||||||
|
|
||||||
|
self._height = 10
|
||||||
|
self._update_constraints()
|
||||||
|
|
||||||
|
icon.connect('clicked', self._action_clicked_cb, action_id)
|
||||||
|
self._action_box.set_constraints(icon, 3, 3)
|
||||||
|
self._action_box.add_child(icon)
|
||||||
|
|
||||||
|
def _action_clicked_cb(self, icon, action):
|
||||||
|
self.emit('action', action)
|
||||||
|
|
||||||
|
def _update_constraints(self):
|
||||||
|
self._grid.set_constraints(self._canvas, 0, 0,
|
||||||
|
self._width, self._height)
|
||||||
|
self._grid.set_constraints(self._rect, 0, 0,
|
||||||
|
self._width, self._height)
|
||||||
|
|
||||||
|
def get_width(self):
|
||||||
|
return self._width
|
||||||
|
|
||||||
|
def get_height(self):
|
||||||
|
return self._height
|
Loading…
Reference in New Issue
Block a user