Fix some bugs, make it more solid, update on share.
This commit is contained in:
parent
c630a8b11e
commit
95be6c3e42
@ -48,6 +48,10 @@ class Shell(gobject.GObject):
|
|||||||
def __init__(self):
|
def __init__(self):
|
||||||
gobject.GObject.__init__(self)
|
gobject.GObject.__init__(self)
|
||||||
|
|
||||||
|
self._screen = wnck.screen_get_default()
|
||||||
|
self._hosts = {}
|
||||||
|
self._current_window = None
|
||||||
|
|
||||||
self._key_grabber = KeyGrabber()
|
self._key_grabber = KeyGrabber()
|
||||||
self._key_grabber.connect('key-pressed', self.__global_key_pressed_cb)
|
self._key_grabber.connect('key-pressed', self.__global_key_pressed_cb)
|
||||||
self._key_grabber.grab('F1')
|
self._key_grabber.grab('F1')
|
||||||
@ -56,9 +60,6 @@ class Shell(gobject.GObject):
|
|||||||
self._key_grabber.grab('F4')
|
self._key_grabber.grab('F4')
|
||||||
self._key_grabber.grab('F5')
|
self._key_grabber.grab('F5')
|
||||||
|
|
||||||
self._screen = wnck.screen_get_default()
|
|
||||||
self._hosts = {}
|
|
||||||
|
|
||||||
self._home_window = HomeWindow(self)
|
self._home_window = HomeWindow(self)
|
||||||
self._home_window.show()
|
self._home_window.show()
|
||||||
|
|
||||||
@ -133,6 +134,8 @@ class Shell(gobject.GObject):
|
|||||||
def __active_window_changed_cb(self, screen):
|
def __active_window_changed_cb(self, screen):
|
||||||
window = screen.get_active_window()
|
window = screen.get_active_window()
|
||||||
if window and window.get_window_type() == wnck.WINDOW_NORMAL:
|
if window and window.get_window_type() == wnck.WINDOW_NORMAL:
|
||||||
|
if self._current_window != window:
|
||||||
|
self._current_window = window
|
||||||
self.emit('activity-changed', self.get_current_activity())
|
self.emit('activity-changed', self.get_current_activity())
|
||||||
|
|
||||||
def __window_closed_cb(self, screen, window):
|
def __window_closed_cb(self, screen, window):
|
||||||
@ -151,20 +154,10 @@ class Shell(gobject.GObject):
|
|||||||
return None
|
return None
|
||||||
|
|
||||||
def get_current_activity(self):
|
def get_current_activity(self):
|
||||||
window = self._screen.get_active_window()
|
if self._current_window != None:
|
||||||
if window:
|
xid = self._current_window.get_xid()
|
||||||
xid = None
|
|
||||||
|
|
||||||
if window.get_window_type() == wnck.WINDOW_NORMAL:
|
|
||||||
xid = window.get_xid()
|
|
||||||
elif window.get_window_type() == wnck.WINDOW_DIALOG:
|
|
||||||
parent = window.get_transient()
|
|
||||||
if not parent is None:
|
|
||||||
xid = parent.get_xid()
|
|
||||||
|
|
||||||
if xid != None:
|
|
||||||
return self._hosts[xid]
|
return self._hosts[xid]
|
||||||
|
else:
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def show_console(self):
|
def show_console(self):
|
||||||
|
@ -10,8 +10,15 @@ class FriendsGroup(goocanvas.Group):
|
|||||||
|
|
||||||
def __init__(self, shell, width):
|
def __init__(self, shell, width):
|
||||||
goocanvas.Group.__init__(self)
|
goocanvas.Group.__init__(self)
|
||||||
self._pservice = PresenceService.get_instance()
|
self._shell = shell
|
||||||
self._width = width
|
self._width = width
|
||||||
|
self._activity_ps = None
|
||||||
|
self._joined_hid = -1
|
||||||
|
self._left_hid = -1
|
||||||
|
|
||||||
|
self._pservice = PresenceService.get_instance()
|
||||||
|
self._pservice.connect('activity-appeared',
|
||||||
|
self.__activity_appeared_cb)
|
||||||
|
|
||||||
self._buddies = []
|
self._buddies = []
|
||||||
i = 0
|
i = 0
|
||||||
@ -26,7 +33,7 @@ class FriendsGroup(goocanvas.Group):
|
|||||||
i = 0
|
i = 0
|
||||||
while i < FriendsGroup.N_BUDDIES:
|
while i < FriendsGroup.N_BUDDIES:
|
||||||
if self._buddies[i] == None:
|
if self._buddies[i] == None:
|
||||||
self._add_buddy(i)
|
self._add_buddy(buddy, i)
|
||||||
break
|
break
|
||||||
i += 1
|
i += 1
|
||||||
|
|
||||||
@ -34,13 +41,14 @@ class FriendsGroup(goocanvas.Group):
|
|||||||
i = 0
|
i = 0
|
||||||
while i < FriendsGroup.N_BUDDIES:
|
while i < FriendsGroup.N_BUDDIES:
|
||||||
if self._buddies[i] == buddy.get_name():
|
if self._buddies[i] == buddy.get_name():
|
||||||
self._remove_buddy(i)
|
self._remove_buddy(buddy, i)
|
||||||
break
|
break
|
||||||
i += 1
|
i += 1
|
||||||
|
|
||||||
def clear(self):
|
def clear(self):
|
||||||
i = 0
|
i = 0
|
||||||
while i < FriendsGroup.N_BUDDIES:
|
while i < FriendsGroup.N_BUDDIES:
|
||||||
|
if self._buddies[i] != None:
|
||||||
self._remove_buddy(i)
|
self._remove_buddy(i)
|
||||||
i += 1
|
i += 1
|
||||||
|
|
||||||
@ -49,12 +57,12 @@ class FriendsGroup(goocanvas.Group):
|
|||||||
|
|
||||||
def _add_buddy(self, buddy, i):
|
def _add_buddy(self, buddy, i):
|
||||||
self.remove_child(i)
|
self.remove_child(i)
|
||||||
icon = IconItem(icon_name='stock-buddy', y=self._get_y(i),
|
icon = IconItem(icon_name='stock-buddy',
|
||||||
color=buddy.get_color(), size=self._width)
|
color=IconColor(buddy.get_color()),
|
||||||
|
size=self._width, y=self._get_y(i))
|
||||||
self.add_child(icon, i)
|
self.add_child(icon, i)
|
||||||
self._buddies[i] = buddy.get_name()
|
self._buddies[i] = buddy.get_name()
|
||||||
|
|
||||||
|
|
||||||
def _create_placeholder(self, i):
|
def _create_placeholder(self, i):
|
||||||
icon = IconItem(icon_name='stock-buddy', color=IconColor('white'),
|
icon = IconItem(icon_name='stock-buddy', color=IconColor('white'),
|
||||||
y=self._get_y(i), size=self._width)
|
y=self._get_y(i), size=self._width)
|
||||||
@ -65,14 +73,38 @@ class FriendsGroup(goocanvas.Group):
|
|||||||
self.add_child(self._create_placeholder(i), i)
|
self.add_child(self._create_placeholder(i), i)
|
||||||
self._buddies[i] = None
|
self._buddies[i] = None
|
||||||
|
|
||||||
def __activity_changed_cb(self, group, activity):
|
def __activity_appeared_cb(self, pservice, activity_ps):
|
||||||
|
activity = self._shell.get_current_activity()
|
||||||
|
if activity_ps.get_id() == activity.get_id():
|
||||||
|
self._set_activity_ps(activity_ps)
|
||||||
|
|
||||||
|
def _set_activity_ps(self, activity_ps):
|
||||||
|
if self._activity_ps == activity_ps:
|
||||||
|
return
|
||||||
|
|
||||||
|
self._activity_ps = activity_ps
|
||||||
|
|
||||||
self.clear()
|
self.clear()
|
||||||
activity_ps = self._pservice.get_activity(activity.get_id())
|
|
||||||
if activity_ps:
|
if self._joined_hid > 0:
|
||||||
|
self.disconnect(self._joined_hid)
|
||||||
|
self._joined_hid = -1
|
||||||
|
if self._left_hid > 0:
|
||||||
|
self.disconnect(self._left_hid)
|
||||||
|
self._left_hid = -1
|
||||||
|
|
||||||
|
if activity_ps != None:
|
||||||
for buddy in activity_ps.get_joined_buddies():
|
for buddy in activity_ps.get_joined_buddies():
|
||||||
self.add(buddy)
|
self.add(buddy)
|
||||||
activity_ps.connect('buddy-joined', self.__buddy_joined_cb)
|
|
||||||
activity_ps.connect('buddy-left', self.__buddy_left_cb)
|
self._joined_hid = activity_ps.connect(
|
||||||
|
'buddy-joined', self.__buddy_joined_cb)
|
||||||
|
self._left_hid = activity_ps.connect(
|
||||||
|
'buddy-left', self.__buddy_left_cb)
|
||||||
|
|
||||||
|
def __activity_changed_cb(self, group, activity):
|
||||||
|
activity_ps = self._pservice.get_activity(activity.get_id())
|
||||||
|
self._set_activity_ps(activity_ps)
|
||||||
|
|
||||||
def __buddy_joined_cb(self, activity, buddy):
|
def __buddy_joined_cb(self, activity, buddy):
|
||||||
self.add(buddy)
|
self.add(buddy)
|
||||||
|
Loading…
Reference in New Issue
Block a user