Simplify overdesigned Mesh view impl
This commit is contained in:
parent
aea10ae900
commit
cd0b794879
@ -8,6 +8,3 @@ class HomeModel:
|
|||||||
|
|
||||||
def get_friends(self):
|
def get_friends(self):
|
||||||
return self._friends
|
return self._friends
|
||||||
|
|
||||||
def get_mesh(self):
|
|
||||||
return self._mesh
|
|
||||||
|
@ -38,8 +38,7 @@ class HomeWindow(gtk.Window):
|
|||||||
y2 = y1 + FriendsGroup.HEIGHT
|
y2 = y1 + FriendsGroup.HEIGHT
|
||||||
icon_layout.set_bounds(x1, y1, x2, y2)
|
icon_layout.set_bounds(x1, y1, x2, y2)
|
||||||
|
|
||||||
data_model = model.get_mesh()
|
self._mesh_group = MeshGroup(self._shell, icon_layout)
|
||||||
self._mesh_group = MeshGroup(self._shell, icon_layout, data_model)
|
|
||||||
root.add_child(self._mesh_group)
|
root.add_child(self._mesh_group)
|
||||||
|
|
||||||
icon_layout = IconLayout(FriendsGroup.WIDTH, FriendsGroup.HEIGHT)
|
icon_layout = IconLayout(FriendsGroup.WIDTH, FriendsGroup.HEIGHT)
|
||||||
|
@ -4,35 +4,46 @@ import goocanvas
|
|||||||
|
|
||||||
from sugar.canvas.IconItem import IconItem
|
from sugar.canvas.IconItem import IconItem
|
||||||
from sugar.canvas.IconItem import IconColor
|
from sugar.canvas.IconItem import IconColor
|
||||||
|
from sugar.presence import PresenceService
|
||||||
from sugar import conf
|
from sugar import conf
|
||||||
|
|
||||||
import Theme
|
import Theme
|
||||||
|
|
||||||
class ActivityItem(IconItem):
|
class ActivityItem(IconItem):
|
||||||
def __init__(self, activity):
|
def __init__(self, service):
|
||||||
|
self._service = service
|
||||||
|
|
||||||
|
IconItem.__init__(self, icon_name=self.get_icon_name(),
|
||||||
|
color=self.get_color(), size=144)
|
||||||
|
|
||||||
|
def get_id(self):
|
||||||
|
return self._service.get_activity_id()
|
||||||
|
|
||||||
|
def get_icon_name(self):
|
||||||
registry = conf.get_activity_registry()
|
registry = conf.get_activity_registry()
|
||||||
info = registry.get_activity(activity.get_type())
|
info = registry.get_activity(self._service.get_type())
|
||||||
icon_name = info.get_icon()
|
|
||||||
|
|
||||||
IconItem.__init__(self, icon_name=icon_name,
|
return info.get_icon()
|
||||||
color=activity.get_color(), size=144)
|
|
||||||
|
def get_color(self):
|
||||||
self._activity = activity
|
pservice = PresenceService.get_instance()
|
||||||
|
activity = pservice.get_activity(self.get_id())
|
||||||
|
return IconColor(activity.get_color())
|
||||||
|
|
||||||
def get_service(self):
|
def get_service(self):
|
||||||
return self._activity.get_service()
|
return self._service
|
||||||
|
|
||||||
class MeshGroup(goocanvas.Group):
|
class MeshGroup(goocanvas.Group):
|
||||||
WIDTH = 1200.0 * 3.5
|
WIDTH = 1200.0 * 3.5
|
||||||
HEIGHT = 900.0 * 3.5
|
HEIGHT = 900.0 * 3.5
|
||||||
|
|
||||||
def __init__(self, shell, icon_layout, data_model):
|
def __init__(self, shell, icon_layout):
|
||||||
goocanvas.Group.__init__(self)
|
goocanvas.Group.__init__(self)
|
||||||
self._shell = shell
|
self._shell = shell
|
||||||
self._icon_layout = icon_layout
|
self._icon_layout = icon_layout
|
||||||
|
self._activities = {}
|
||||||
|
|
||||||
self._theme = Theme.get_instance()
|
self._theme = Theme.get_instance()
|
||||||
self._theme.connect("theme-changed", self.__theme_changed_cb)
|
|
||||||
|
|
||||||
color = self._theme.get_home_mesh_color()
|
color = self._theme.get_home_mesh_color()
|
||||||
self._mesh_rect = goocanvas.Rect(width=MeshGroup.WIDTH,
|
self._mesh_rect = goocanvas.Rect(width=MeshGroup.WIDTH,
|
||||||
@ -40,22 +51,32 @@ class MeshGroup(goocanvas.Group):
|
|||||||
fill_color=color)
|
fill_color=color)
|
||||||
self.add_child(self._mesh_rect)
|
self.add_child(self._mesh_rect)
|
||||||
|
|
||||||
for activity in data_model:
|
self._pservice = PresenceService.get_instance()
|
||||||
self.add_activity(activity)
|
self._pservice.connect("service-appeared", self.__service_appeared_cb)
|
||||||
|
|
||||||
data_model.connect('activity-added', self.__activity_added_cb)
|
for service in self._pservice.get_services():
|
||||||
|
self.__check_service(service)
|
||||||
|
|
||||||
def __theme_changed_cb(self, theme):
|
def __service_appeared_cb(self, pservice, service):
|
||||||
pass
|
self.__check_service(service)
|
||||||
|
|
||||||
def add_activity(self, activity):
|
def __check_service(self, service):
|
||||||
item = ActivityItem(activity)
|
registry = conf.get_activity_registry()
|
||||||
|
if registry.get_activity(service.get_type()) != None:
|
||||||
|
if not self.has_activity(service.get_activity_id()):
|
||||||
|
self.add_activity(service)
|
||||||
|
|
||||||
|
def has_activity(self, activity_id):
|
||||||
|
return self._activities.has_key(activity_id)
|
||||||
|
|
||||||
|
def add_activity(self, service):
|
||||||
|
item = ActivityItem(service)
|
||||||
item.connect('clicked', self.__activity_clicked_cb)
|
item.connect('clicked', self.__activity_clicked_cb)
|
||||||
|
|
||||||
self._icon_layout.add_icon(item)
|
self._icon_layout.add_icon(item)
|
||||||
self.add_child(item)
|
self.add_child(item)
|
||||||
|
|
||||||
def __activity_added_cb(self, data_model, activity):
|
self._activities[item.get_id()] = item
|
||||||
self.add_activity(activity)
|
|
||||||
|
|
||||||
def __activity_clicked_cb(self, item):
|
def __activity_clicked_cb(self, item):
|
||||||
self._shell.join_activity(item.get_service())
|
self._shell.join_activity(item.get_service())
|
||||||
|
@ -1,66 +0,0 @@
|
|||||||
import gobject
|
|
||||||
|
|
||||||
from sugar.presence import PresenceService
|
|
||||||
from sugar.canvas.IconColor import IconColor
|
|
||||||
from sugar import conf
|
|
||||||
|
|
||||||
class ActivityInfo:
|
|
||||||
def __init__(self, service):
|
|
||||||
self._service = service
|
|
||||||
|
|
||||||
def get_id(self):
|
|
||||||
return self._service.get_activity_id()
|
|
||||||
|
|
||||||
def get_type(self):
|
|
||||||
return self._service.get_type()
|
|
||||||
|
|
||||||
def get_title(self):
|
|
||||||
return self._service.get_published_value('title')
|
|
||||||
|
|
||||||
def get_color(self):
|
|
||||||
pservice = PresenceService.get_instance()
|
|
||||||
activity = pservice.get_activity(self.get_id())
|
|
||||||
return IconColor(activity.get_color())
|
|
||||||
|
|
||||||
def get_service(self):
|
|
||||||
return self._service
|
|
||||||
|
|
||||||
class MeshModel(gobject.GObject):
|
|
||||||
__gsignals__ = {
|
|
||||||
'activity-added': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
|
|
||||||
([gobject.TYPE_PYOBJECT])),
|
|
||||||
'activity-removed': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
|
|
||||||
([gobject.TYPE_PYOBJECT]))
|
|
||||||
}
|
|
||||||
|
|
||||||
def __init__(self):
|
|
||||||
gobject.GObject.__init__(self)
|
|
||||||
|
|
||||||
self._activities = {}
|
|
||||||
|
|
||||||
self._pservice = PresenceService.get_instance()
|
|
||||||
self._pservice.connect("service-appeared", self.__service_appeared_cb)
|
|
||||||
|
|
||||||
for service in self._pservice.get_services():
|
|
||||||
self.__check_service(service)
|
|
||||||
|
|
||||||
def has_activity(self, activity_id):
|
|
||||||
return self._activities.has_key(activity_id)
|
|
||||||
|
|
||||||
def add_activity(self, service):
|
|
||||||
activity_info = ActivityInfo(service)
|
|
||||||
self._activities[activity_info.get_id()] = (activity_info)
|
|
||||||
self.emit('activity-added', activity_info)
|
|
||||||
|
|
||||||
def __iter__(self):
|
|
||||||
activities = self._activities.values()
|
|
||||||
return activities.__iter__()
|
|
||||||
|
|
||||||
def __service_appeared_cb(self, pservice, service):
|
|
||||||
self.__check_service(service)
|
|
||||||
|
|
||||||
def __check_service(self, service):
|
|
||||||
registry = conf.get_activity_registry()
|
|
||||||
if registry.get_activity(service.get_type()) != None:
|
|
||||||
if not self.has_activity(service.get_activity_id()):
|
|
||||||
self.add_activity(service)
|
|
Loading…
Reference in New Issue
Block a user