More work on the mesh view
This commit is contained in:
parent
2ee61e4475
commit
59add6e901
@ -12,18 +12,42 @@ class ActivityView(goocanvas.Group):
|
|||||||
def __init__(self, shell, menu_shell, model):
|
def __init__(self, shell, menu_shell, model):
|
||||||
goocanvas.Group.__init__(self)
|
goocanvas.Group.__init__(self)
|
||||||
|
|
||||||
|
self._shell = shell
|
||||||
self._model = model
|
self._model = model
|
||||||
self._layout = SnowflakeLayout()
|
self._layout = SnowflakeLayout()
|
||||||
|
self._icons = {}
|
||||||
|
|
||||||
icon = IconItem(icon_name=model.get_icon_name(),
|
icon = IconItem(icon_name=model.get_icon_name(),
|
||||||
color=model.get_color(), size=80)
|
color=model.get_color(), size=80)
|
||||||
|
icon.connect('clicked', self._clicked_cb)
|
||||||
self.add_child(icon)
|
self.add_child(icon)
|
||||||
self._layout.set_root(icon)
|
self._layout.set_root(icon)
|
||||||
|
|
||||||
|
def has_buddy_icon(self, name):
|
||||||
|
return self._icons.has_key(name)
|
||||||
|
|
||||||
|
def add_buddy_icon(self, name, icon):
|
||||||
|
self._icons[name] = icon
|
||||||
|
self.add_child(icon)
|
||||||
|
self._layout.add_child(icon)
|
||||||
|
|
||||||
|
def remove_buddy_icon(self, name):
|
||||||
|
icon = self._icons[name]
|
||||||
|
self._layout.remove_child(icon)
|
||||||
|
self.remove_child(icon)
|
||||||
|
del self._icons[name]
|
||||||
|
|
||||||
def get_size_request(self):
|
def get_size_request(self):
|
||||||
size = self._layout.get_size()
|
size = self._layout.get_size()
|
||||||
return [size, size]
|
return [size, size]
|
||||||
|
|
||||||
|
def _clicked_cb(self, item):
|
||||||
|
registry = conf.get_activity_registry()
|
||||||
|
default_type = self._model.get_service().get_type()
|
||||||
|
bundle = registry.get_activity_from_type(default_type)
|
||||||
|
self._shell.join_activity(bundle.get_id(), self._model.get_id())
|
||||||
|
|
||||||
|
|
||||||
class MeshGroup(goocanvas.Group):
|
class MeshGroup(goocanvas.Group):
|
||||||
def __init__(self, shell, menu_shell):
|
def __init__(self, shell, menu_shell):
|
||||||
goocanvas.Group.__init__(self)
|
goocanvas.Group.__init__(self)
|
||||||
@ -34,12 +58,14 @@ class MeshGroup(goocanvas.Group):
|
|||||||
self._layout = IconLayout(shell.get_grid())
|
self._layout = IconLayout(shell.get_grid())
|
||||||
self._buddies = {}
|
self._buddies = {}
|
||||||
self._activities = {}
|
self._activities = {}
|
||||||
|
self._buddy_to_activity = {}
|
||||||
|
|
||||||
for buddy_model in self._model.get_buddies():
|
for buddy_model in self._model.get_buddies():
|
||||||
self._add_buddy(buddy_model)
|
self._add_buddy(buddy_model)
|
||||||
|
|
||||||
self._model.connect('buddy-added', self._buddy_added_cb)
|
self._model.connect('buddy-added', self._buddy_added_cb)
|
||||||
self._model.connect('buddy-removed', self._buddy_removed_cb)
|
self._model.connect('buddy-removed', self._buddy_removed_cb)
|
||||||
|
self._model.connect('buddy-moved', self._buddy_moved_cb)
|
||||||
|
|
||||||
for activity_model in self._model.get_activities():
|
for activity_model in self._model.get_activities():
|
||||||
self._add_activity(activity_model)
|
self._add_activity(activity_model)
|
||||||
@ -53,6 +79,9 @@ class MeshGroup(goocanvas.Group):
|
|||||||
def _buddy_removed_cb(self, model, buddy_model):
|
def _buddy_removed_cb(self, model, buddy_model):
|
||||||
self._remove_buddy(buddy_model)
|
self._remove_buddy(buddy_model)
|
||||||
|
|
||||||
|
def _buddy_moved_cb(self, model, buddy_model, activity_model):
|
||||||
|
self._move_buddy(buddy_model, activity_model)
|
||||||
|
|
||||||
def _activity_added_cb(self, model, activity_model):
|
def _activity_added_cb(self, model, activity_model):
|
||||||
self._add_activity(activity_model)
|
self._add_activity(activity_model)
|
||||||
|
|
||||||
@ -70,8 +99,28 @@ class MeshGroup(goocanvas.Group):
|
|||||||
def _remove_buddy(self, buddy_model):
|
def _remove_buddy(self, buddy_model):
|
||||||
icon = self._buddies[buddy_model.get_name()]
|
icon = self._buddies[buddy_model.get_name()]
|
||||||
self.remove_child(icon)
|
self.remove_child(icon)
|
||||||
|
self._layout.remove_icon(icon)
|
||||||
del self._buddies[buddy_model.get_name()]
|
del self._buddies[buddy_model.get_name()]
|
||||||
|
|
||||||
|
def _move_buddy(self, buddy_model, activity_model):
|
||||||
|
name = buddy_model.get_name()
|
||||||
|
|
||||||
|
if self._buddies.has_key(name):
|
||||||
|
self._remove_buddy(buddy_model)
|
||||||
|
|
||||||
|
for activity in self._activities.values():
|
||||||
|
if activity.has_buddy_icon(name):
|
||||||
|
activity.remove_buddy_icon(name)
|
||||||
|
|
||||||
|
if activity_model == None:
|
||||||
|
self.add_buddy(buddy_model)
|
||||||
|
else:
|
||||||
|
activity = self._activities[activity_model.get_id()]
|
||||||
|
|
||||||
|
icon = BuddyIcon(self._shell, self._menu_shell, buddy_model)
|
||||||
|
icon.props.size = 60
|
||||||
|
activity.add_buddy_icon(buddy_model.get_name(), icon)
|
||||||
|
|
||||||
def _add_activity(self, activity_model):
|
def _add_activity(self, activity_model):
|
||||||
icon = ActivityView(self._shell, self._menu_shell, activity_model)
|
icon = ActivityView(self._shell, self._menu_shell, activity_model)
|
||||||
self.add_child(icon)
|
self.add_child(icon)
|
||||||
@ -82,4 +131,5 @@ class MeshGroup(goocanvas.Group):
|
|||||||
def _remove_activity(self, activity_model):
|
def _remove_activity(self, activity_model):
|
||||||
icon = self._activities[activity_model.get_id()]
|
icon = self._activities[activity_model.get_id()]
|
||||||
self.remove_child(icon)
|
self.remove_child(icon)
|
||||||
|
self._layout.remove_icon(icon)
|
||||||
del self._activities[activity_model.get_id()]
|
del self._activities[activity_model.get_id()]
|
||||||
|
Loading…
Reference in New Issue
Block a user