Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/shell
diff options
context:
space:
mode:
authorDan Williams <dcbw@localhost.localdomain>2006-09-22 21:24:56 (GMT)
committer Dan Williams <dcbw@localhost.localdomain>2006-09-22 21:24:56 (GMT)
commit188394f09f788b19303909738adfff8ec8c788c0 (patch)
tree16219a47f57cab8c33782d739d5e594cbeb3e8db /shell
parent2031eb650a7734029383bf49f01ad79870ccc16d (diff)
- Track BuddyModel appeared/disappeared signals, and update our icon colors accordingly
- s/friend/buddy since BuddyModel isn't just for friends
Diffstat (limited to 'shell')
-rw-r--r--shell/view/BuddyIcon.py24
1 files changed, 15 insertions, 9 deletions
diff --git a/shell/view/BuddyIcon.py b/shell/view/BuddyIcon.py
index 9ae709a..2109226 100644
--- a/shell/view/BuddyIcon.py
+++ b/shell/view/BuddyIcon.py
@@ -2,18 +2,24 @@ from sugar.canvas.MenuIcon import MenuIcon
from view.BuddyMenu import BuddyMenu
class BuddyIcon(MenuIcon):
- def __init__(self, shell, menu_shell, friend):
+ def __init__(self, shell, menu_shell, buddy):
MenuIcon.__init__(self, menu_shell, icon_name='stock-buddy',
- color=friend.get_color(), size=112)
+ color=buddy.get_color(), size=112)
self._shell = shell
- self._friend = friend
+ self._buddy = buddy
+ self._buddy.connect('appeared', self.__buddy_presence_change_cb)
+ self._buddy.connect('disappeared', self.__buddy_presence_change_cb)
+
+ def __buddy_presence_change_cb(self, buddy):
+ # Update the icon's color when the buddy comes and goes
+ self.set_property('color', buddy.get_color())
def set_popup_distance(self, distance):
self._popup_distance = distance
def create_menu(self):
- menu = BuddyMenu(self._shell, self._friend)
+ menu = BuddyMenu(self._shell, self._buddy)
menu.connect('action', self._popup_action_cb)
return menu
@@ -22,14 +28,14 @@ class BuddyIcon(MenuIcon):
friends = self._shell.get_model().get_friends()
if action == BuddyMenu.ACTION_REMOVE_FRIEND:
- friends.remove(self._friend)
+ friends.remove(self._buddy)
- buddy = self._friend.get_buddy()
- if buddy == None:
+ ps_buddy = self._buddy.get_buddy()
+ if ps_buddy == None:
return
if action == BuddyMenu.ACTION_INVITE:
activity = self._shell.get_current_activity()
- activity.invite(buddy)
+ activity.invite(ps_buddy)
elif action == BuddyMenu.ACTION_MAKE_FRIEND:
- friends.make_friend(buddy)
+ friends.make_friend(ps_buddy)