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-08-16 21:20:22 (GMT)
committer Marco Pesenti Gritti <marco@localhost.localdomain>2006-08-16 21:20:22 (GMT)
commitdae3d2be2b99cbbb59a3aff1ab00fb0b8705a3ff (patch)
treee4d7c9797a46abe43bcbc513287ba5ba4bed0152 /shell
parent47f25f234ee9775b0c6723312b05ca69d3709449 (diff)
Some work to implement the activity bar
Diffstat (limited to 'shell')
-rw-r--r--shell/ActivityRegistry.py12
-rw-r--r--shell/HomeWindow.py20
2 files changed, 30 insertions, 2 deletions
diff --git a/shell/ActivityRegistry.py b/shell/ActivityRegistry.py
index acf379c..5ff0059 100644
--- a/shell/ActivityRegistry.py
+++ b/shell/ActivityRegistry.py
@@ -8,6 +8,7 @@ class ActivityModule:
def __init__(self, name, activity_id, directory):
self._name = name
+ self._icon = None
self._id = activity_id
self._directory = directory
self._show_launcher = False
@@ -20,6 +21,14 @@ class ActivityModule:
"""Get the activity identifier"""
return self._id
+ def get_icon(self):
+ """Get the activity icon name"""
+ return self._icon
+
+ def set_icon(self, icon):
+ """Set the activity icon name"""
+ self._icon = icon
+
def get_directory(self):
"""Get the path to activity directory."""
return self._directory
@@ -97,6 +106,9 @@ class ActivityRegistry:
if cp.has_option('Activity', 'show_launcher'):
module.set_show_launcher(True)
+ if cp.has_option('Activity', 'icon'):
+ module.set_icon(cp.get('Activity', 'icon'))
+
module.set_default_type(default_type)
return True
diff --git a/shell/HomeWindow.py b/shell/HomeWindow.py
index 47cd7f7..d44add6 100644
--- a/shell/HomeWindow.py
+++ b/shell/HomeWindow.py
@@ -3,6 +3,19 @@ import goocanvas
from sugar.canvas.IconItem import IconItem
+class ActivityBar(goocanvas.Group):
+ def __init__(self, registry):
+ goocanvas.Group.__init__(self)
+
+ for activity in registry.list_activities():
+ if activity.get_show_launcher():
+ self.add_activity(activity)
+
+ def add_activity(self, activity):
+ item = IconItem(icon_name=activity.get_icon(),
+ color='white', width=42, height=42)
+ self.add_child(item)
+
class Background(goocanvas.Group):
def __init__(self):
goocanvas.Group.__init__(self)
@@ -22,7 +35,7 @@ class Background(goocanvas.Group):
self.add_child(item)
class Model(goocanvas.CanvasModelSimple):
- def __init__(self):
+ def __init__(self, shell):
goocanvas.CanvasModelSimple.__init__(self)
root = self.get_root_item()
@@ -30,6 +43,9 @@ class Model(goocanvas.CanvasModelSimple):
background = Background()
root.add_child(background)
+ activity_bar = ActivityBar(shell.get_registry())
+ root.add_child(activity_bar)
+
class HomeWindow(gtk.Window):
def __init__(self, shell):
gtk.Window.__init__(self)
@@ -39,7 +55,7 @@ class HomeWindow(gtk.Window):
self.connect('realize', self.__realize_cb)
canvas = goocanvas.CanvasView()
- canvas_model = Model()
+ canvas_model = Model(shell)
canvas.set_bounds(0, 0, 1200, 900)
canvas.set_scale(float(800) / float(1200))
canvas.set_size_request(800, 600)