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-07-10 11:42:34 (GMT)
committer Marco Pesenti Gritti <marco@localhost.localdomain>2006-07-10 11:42:34 (GMT)
commit9f9f42086333ad7fec3a2f5c0658145cd57dd992 (patch)
tree024d6ebad796d38633ee0e921f367a8475bdd55e /shell
parent1cc14e406a62a015067446976d149a1f60de5197 (diff)
Add tasks to the home window. A bunch of fixes.
Diffstat (limited to 'shell')
-rw-r--r--shell/HomeWindow.py62
-rw-r--r--shell/PresenceWindow.py1
-rwxr-xr-xshell/Shell.py43
3 files changed, 88 insertions, 18 deletions
diff --git a/shell/HomeWindow.py b/shell/HomeWindow.py
index 72e4bfd..f0124b1 100644
--- a/shell/HomeWindow.py
+++ b/shell/HomeWindow.py
@@ -1,14 +1,15 @@
from gettext import gettext as _
import gtk
+import wnck
from sugar.activity import Activity
class NewActivityButton(gtk.MenuToolButton):
- def __init__(self, shell):
+ def __init__(self, home):
gtk.MenuToolButton.__init__(self, None, _('New Activity'))
- self._shell = shell
+ self._home = home
self.set_menu(gtk.Menu())
self.connect("show-menu", self.__show_menu_cb)
@@ -16,7 +17,7 @@ class NewActivityButton(gtk.MenuToolButton):
def __show_menu_cb(self, button):
menu = gtk.Menu()
- for activity_info in self._shell.get_registry().list_activities():
+ for activity_info in self._home.list_activities():
item = gtk.MenuItem(activity_info.get_title(), False)
name = activity_info.get_name()
item.connect('activate', self.__menu_item_activate_cb, name)
@@ -26,7 +27,7 @@ class NewActivityButton(gtk.MenuToolButton):
self.set_menu(menu)
def __menu_item_activate_cb(self, item, name):
- Activity.create(name)
+ self._home.create(name)
class Toolbar(gtk.Toolbar):
def __init__(self, shell):
@@ -36,15 +37,66 @@ class Toolbar(gtk.Toolbar):
self.insert(new_activity_button, -1)
new_activity_button.show()
+class ActivityGrid(gtk.VBox):
+ def __init__(self, home):
+ gtk.VBox.__init__(self)
+
+ self._home = home
+ self.update()
+
+ def _add_all(self):
+ screen = wnck.screen_get_default()
+ for window in screen.get_windows():
+ if not window.is_skip_tasklist():
+ self.add(window)
+
+ def _remove_all(self):
+ for child in self.get_children():
+ self.remove(child)
+
+ def add(self, window):
+ button = gtk.Button(window.get_name())
+ button.connect('clicked', self.__button_clicked_cb, window)
+ self.pack_start(button, False)
+ button.show()
+
+ def update(self):
+ self._remove_all()
+ self._add_all()
+
+ def __button_clicked_cb(self, button, window):
+ self._home.activate(window)
+
class HomeWindow(gtk.Window):
def __init__(self, shell):
gtk.Window.__init__(self)
+ self._shell = shell
+
vbox = gtk.VBox()
- toolbar = Toolbar(shell)
+ toolbar = Toolbar(self)
vbox.pack_start(toolbar, False)
toolbar.show()
+ self._grid = ActivityGrid(self)
+ vbox.pack_start(self._grid)
+ self._grid.show()
+
self.add(vbox)
vbox.show()
+
+ def list_activities(self):
+ return self._shell.get_registry().list_activities()
+
+ def create(self, activity_name):
+ Activity.create(activity_name)
+ self.hide()
+
+ def activate(self, activity_window):
+ activity_window.activate(gtk.get_current_event_time())
+ self.hide()
+
+ def show(self):
+ self._grid.update()
+ gtk.Window.show(self)
diff --git a/shell/PresenceWindow.py b/shell/PresenceWindow.py
index 6b57426..666f86c 100644
--- a/shell/PresenceWindow.py
+++ b/shell/PresenceWindow.py
@@ -51,7 +51,6 @@ class PresenceWindow(gtk.Window):
self._share_button.set_sensitive(False)
else:
self._share_button.set_sensitive(True)
- self._activity.connect('shared', lambda w: self._share_button.set_sensitive(False))
else:
self._share_button.set_sensitive(False)
diff --git a/shell/Shell.py b/shell/Shell.py
index bb79e5d..d8befd5 100755
--- a/shell/Shell.py
+++ b/shell/Shell.py
@@ -11,6 +11,7 @@ from sugar import keybindings
from sugar.activity import Activity
from PresenceWindow import PresenceWindow
from sugar.chat.ActivityChat import ActivityChat
+from Owner import ShellOwner
class ShellDbusService(dbus.service.Object):
def __init__(self, shell, bus_name):
@@ -41,6 +42,8 @@ class Shell(gobject.GObject):
def __init__(self):
gobject.GObject.__init__(self)
+ self._screen = wnck.screen_get_default()
+
def start(self):
self._console = ConsoleLogger()
keybindings.setup_global_keys(self._console.get_window(), self)
@@ -52,6 +55,8 @@ class Shell(gobject.GObject):
bus_name = dbus.service.BusName('com.redhat.Sugar.Shell', bus=session_bus)
ShellDbusService(self, bus_name)
+ self._owner = ShellOwner()
+
self._registry = ActivityRegistry()
self._home_window = HomeWindow(self)
@@ -59,7 +64,9 @@ class Shell(gobject.GObject):
self._home_window.show()
self._presence_window = PresenceWindow(self)
+ self._presence_window.set_type_hint(gtk.gdk.WINDOW_TYPE_HINT_DIALOG)
self._presence_window.set_skip_taskbar_hint(True)
+ self._presence_window.set_decorated(False)
keybindings.setup_global_keys(self._presence_window, self)
self._chat_windows = {}
@@ -73,15 +80,22 @@ class Shell(gobject.GObject):
def toggle_home(self):
self._toggle_window_visibility(self._home_window)
+ def get_activity_from_xid(self, xid):
+ bus = dbus.SessionBus()
+ service = Activity.ACTIVITY_SERVICE_NAME + "%s" % xid
+ path = Activity.ACTIVITY_SERVICE_PATH + "/%s" % xid
+ proxy_obj = bus.get_object(service, path)
+
+ return dbus.Interface(proxy_obj, 'com.redhat.Sugar.Activity')
+
def get_current_activity(self):
- window = wnck.screen_get_default().get_active_window()
+ window = self._screen.get_active_window()
+
+ if window and window.is_skip_tasklist():
+ window = self._screen.get_previously_active_window()
+
if window and not window.is_skip_tasklist():
- bus = dbus.SessionBus()
- xid = window.get_xid()
- service = Activity.ACTIVITY_SERVICE_NAME + "%s" % xid
- path = Activity.ACTIVITY_SERVICE_PATH + "/%s" % xid
- proxy_obj = bus.get_object(service, path)
- return dbus.Interface(proxy_obj, 'com.redhat.Sugar.Activity')
+ return self.get_activity_from_xid(window.get_xid())
else:
return None
@@ -93,20 +107,25 @@ class Shell(gobject.GObject):
if not self._chat_windows.has_key(activity_id):
window = gtk.Window()
+ window.set_type_hint(gtk.gdk.WINDOW_TYPE_HINT_DIALOG)
window.set_skip_taskbar_hint(True)
+ window.set_decorated(False)
keybindings.setup_global_keys(window, self)
chat = ActivityChat(activity)
window.add(chat)
chat.show()
self._chat_windows[activity_id] = window
- self._toggle_window_visibility(self._chat_windows[activity_id])
+ else:
+ window = self._chat_windows[activity_id]
+ window.move(210, 10)
+ window.resize(380, 440)
+ self._toggle_window_visibility(window)
+
+ self._presence_window.move(10, 10)
+ self._presence_window.resize(180, 440)
self._presence_window.set_activity(activity)
self._toggle_window_visibility(self._presence_window)
- else:
- self._presence_window.hide()
- for window in self._chat_windows.values():
- window.hide()
def toggle_console(self):
self._toggle_window_visibility(self._console.get_window())