Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/shell
diff options
context:
space:
mode:
authorMarco Pesenti Gritti <marco@localhost.localdomain>2006-09-25 14:01:11 (GMT)
committer Marco Pesenti Gritti <marco@localhost.localdomain>2006-09-25 14:01:11 (GMT)
commit56229aad368973c66eae89d4282ace59f7778024 (patch)
tree5ca3dae1ed2d560299acf993ed8a9d3ca349eb75 /shell
parent73be416c672829b5f6aa1f4750d24283665b6794 (diff)
Write a mesh model and start using it in the mesh view
Diffstat (limited to 'shell')
-rw-r--r--shell/model/Makefile.am1
-rw-r--r--shell/model/MeshModel.py108
-rw-r--r--shell/model/ShellModel.py5
-rw-r--r--shell/view/home/HomeWindow.py2
-rw-r--r--shell/view/home/MeshGroup.py85
5 files changed, 129 insertions, 72 deletions
diff --git a/shell/model/Makefile.am b/shell/model/Makefile.am
index 322e732..50fe145 100644
--- a/shell/model/Makefile.am
+++ b/shell/model/Makefile.am
@@ -5,4 +5,5 @@ sugar_PYTHON = \
Friends.py \
Invites.py \
Owner.py \
+ MeshModel.py \
ShellModel.py
diff --git a/shell/model/MeshModel.py b/shell/model/MeshModel.py
new file mode 100644
index 0000000..2b47baf
--- /dev/null
+++ b/shell/model/MeshModel.py
@@ -0,0 +1,108 @@
+import gobject
+
+import conf
+from sugar.canvas.IconItem import IconColor
+from sugar.presence import PresenceService
+from model.BuddyModel import BuddyModel
+
+class ActivityModel:
+ def __init__(self, activity, service):
+ self._service = service
+ self._activity = activity
+
+ def get_id(self):
+ return self._activity.get_id()
+
+ def get_icon_name(self):
+ registry = conf.get_activity_registry()
+ info = registry.get_activity_from_type(self._service.get_type())
+
+ return info.get_icon()
+
+ def get_color(self):
+ return IconColor(self._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])),
+ 'buddy-added': (gobject.SIGNAL_RUN_FIRST,
+ gobject.TYPE_NONE, ([gobject.TYPE_PYOBJECT])),
+ 'buddy-moved': (gobject.SIGNAL_RUN_FIRST,
+ gobject.TYPE_NONE, ([gobject.TYPE_PYOBJECT,
+ gobject.TYPE_PYOBJECT])),
+ 'buddy-removed': (gobject.SIGNAL_RUN_FIRST,
+ gobject.TYPE_NONE, ([gobject.TYPE_PYOBJECT]))
+ }
+
+ def __init__(self):
+ gobject.GObject.__init__(self)
+
+ self._activities = {}
+ self._buddies = {}
+
+ self._pservice = PresenceService.get_instance()
+ self._pservice.connect("service-appeared",
+ self._service_appeared_cb)
+ self._pservice.connect('activity-disappeared',
+ self._activity_disappeared_cb)
+ self._pservice.connect("buddy-appeared",
+ self._buddy_appeared_cb)
+ self._pservice.connect("buddy-disappeared",
+ self._buddy_disappeared_cb)
+
+ for service in self._pservice.get_services():
+ self._check_service(service)
+
+ def get_activities(self):
+ return self._activities
+
+ def get_buddies(self):
+ return self._buddies
+
+ def _buddy_activity_changed_cb(self, buddy, cur_activity):
+ buddy_model = self._buddies[buddy.get_name()]
+ activity_model = self._activities[cur_activity.get_id()]
+ self.emit('buddy-moved', buddy_model, activity_model)
+
+ def _buddy_appeared_cb(self, pservice, buddy):
+ model = BuddyModel(buddy=buddy)
+ model.connect('current-activity-changed',
+ self._buddy_activity_changed_cb)
+ self._buddies[model.get_name()] = model
+ self.emit('buddy-added', model)
+
+ def _buddy_disappeared_cb(self, pservice, buddy):
+ self.emit('buddy-removed', buddy)
+ del self._buddies[buddy.get_name()]
+
+ 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_from_type(service.get_type()) != None:
+ activity_id = service.get_activity_id()
+ if not self.has_activity(activity_id):
+ activity = self._pservice.get_activity(activity_id)
+ if activity != None:
+ self.add_activity(activity, service)
+
+ def has_activity(self, activity_id):
+ return self._activities.has_key(activity_id)
+
+ def add_activity(self, activity, service):
+ model = ActivityModel(activity, service)
+ self._activities[model.get_id()] = model
+ self.emit('activity-added', model)
+
+ def _activity_disappeared_cb(self, pservice, activity):
+ if self._activities.has_key(activity.get_id()):
+ activity_model = self._activities[activity.get_id()]
+ self.emit('activity-removed', activity_model)
+ del self._activities[activity.get_id()]
diff --git a/shell/model/ShellModel.py b/shell/model/ShellModel.py
index 5872b02..9b6d598 100644
--- a/shell/model/ShellModel.py
+++ b/shell/model/ShellModel.py
@@ -1,5 +1,6 @@
from sugar.presence import PresenceService
from model.Friends import Friends
+from model.MeshModel import MeshModel
from model.Owner import ShellOwner
class ShellModel:
@@ -12,6 +13,10 @@ class ShellModel:
self._owner = ShellOwner()
self._owner.announce()
self._friends = Friends()
+ self._mesh = MeshModel()
+
+ def get_mesh(self):
+ return self._mesh
def get_friends(self):
return self._friends
diff --git a/shell/view/home/HomeWindow.py b/shell/view/home/HomeWindow.py
index 9e2fb2a..66ce883 100644
--- a/shell/view/home/HomeWindow.py
+++ b/shell/view/home/HomeWindow.py
@@ -28,7 +28,7 @@ class HomeWindow(gtk.Window):
self._add_page(HomeGroup(shell))
self._add_page(FriendsGroup(shell, menu_shell))
- self._add_page(MeshGroup(shell))
+ self._add_page(MeshGroup(shell, menu_shell))
def _add_page(self, group):
view = CanvasView()
diff --git a/shell/view/home/MeshGroup.py b/shell/view/home/MeshGroup.py
index 4f523de..89f8f4e 100644
--- a/shell/view/home/MeshGroup.py
+++ b/shell/view/home/MeshGroup.py
@@ -4,84 +4,27 @@ import goocanvas
import conf
from sugar.canvas.IconItem import IconItem
-from sugar.canvas.IconItem import IconColor
-from sugar.presence import PresenceService
from view.home.IconLayout import IconLayout
-
-class ActivityItem(IconItem):
- def __init__(self, activity, service):
- self._service = service
- self._activity = activity
-
- IconItem.__init__(self, icon_name=self.get_icon_name(),
- color=self.get_color(), size=112)
-
- def get_id(self):
- return self._activity.get_id()
-
- def get_icon_name(self):
- registry = conf.get_activity_registry()
- info = registry.get_activity_from_type(self._service.get_type())
-
- return info.get_icon()
-
- def get_color(self):
- return IconColor(self._activity.get_color())
-
- def get_service(self):
- return self._service
+from view.BuddyIcon import BuddyIcon
class MeshGroup(goocanvas.Group):
- def __init__(self, shell):
+ def __init__(self, shell, menu_shell):
goocanvas.Group.__init__(self)
self._shell = shell
+ self._menu_shell = menu_shell
+ self._model = shell.get_model().get_mesh()
+ self._layout = IconLayout(shell.get_grid())
- self._icon_layout = IconLayout(shell.get_grid())
- self._activities = {}
-
- self._pservice = PresenceService.get_instance()
- self._pservice.connect("service-appeared",
- self._service_appeared_cb)
- self._pservice.connect('activity-disappeared',
- self._activity_disappeared_cb)
-
- for service in self._pservice.get_services():
- self._check_service(service)
-
- 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_from_type(service.get_type()) != None:
- activity_id = service.get_activity_id()
- if not self.has_activity(activity_id):
- activity = self._pservice.get_activity(activity_id)
- if activity != None:
- self.add_activity(activity, service)
-
- def has_activity(self, activity_id):
- return self._activities.has_key(activity_id)
-
- def add_activity(self, activity, service):
- item = ActivityItem(activity, service)
- item.connect('clicked', self._activity_clicked_cb)
- self._icon_layout.add_icon(item)
- self.add_child(item)
-
- self._activities[item.get_id()] = item
-
- def _activity_disappeared_cb(self, pservice, activity):
- if self._activities.has_key(activity.get_id()):
- self.remove_child(self._activities[activity.get_id()])
- del self._activities[activity.get_id()]
+ for buddy_model in self._model.get_buddies():
+ self._add_buddy(buddy_model)
- def _activity_clicked_cb(self, item):
- default_type = item.get_service().get_type()
- registry = conf.get_activity_registry()
+ self._model.connect('buddy-added', self._buddy_added_cb)
- bundle_id = registry.get_activity_from_type(default_type).get_id()
- activity_id = item.get_id()
+ def _buddy_added_cb(self, model, buddy_model):
+ self._add_buddy(buddy_model)
- self._shell.join_activity(bundle_id, activity_id)
+ def _add_buddy(self, buddy_model):
+ icon = BuddyIcon(self._shell, self._menu_shell, buddy_model)
+ self.add_child(icon)
+ self._layout.add_icon(icon)