Remove invites when accepted

This commit is contained in:
Marco Pesenti Gritti 2006-09-09 14:37:11 +02:00
parent 9d4911d1e3
commit 1cc21aa7cf
3 changed files with 32 additions and 2 deletions

View File

@ -46,5 +46,9 @@ class Invites(gobject.GObject):
self._list.append(invite) self._list.append(invite)
self.emit('invite-added', invite) self.emit('invite-added', invite)
def remove_invite(self, invite):
self._list.remove(invite)
self.emit('invite-removed', invite)
def __iter__(self): def __iter__(self):
return self._list.__iter__() return self._list.__iter__()

View File

@ -30,11 +30,16 @@ class InviteItem(IconItem):
def get_bundle_id(self): def get_bundle_id(self):
return self._invite.get_bundle_id() return self._invite.get_bundle_id()
def get_invite(self):
return self._invite
class BottomPanel(GridBox): class BottomPanel(GridBox):
def __init__(self, shell, invites): def __init__(self, shell, invites):
GridBox.__init__(self, GridBox.HORIZONTAL, 14, 6) GridBox.__init__(self, GridBox.HORIZONTAL, 14, 6)
self._shell = shell self._shell = shell
self._invite_to_item = {}
self._invites = invites
registry = conf.get_activity_registry() registry = conf.get_activity_registry()
for activity in registry.list_activities(): for activity in registry.list_activities():
@ -44,17 +49,22 @@ class BottomPanel(GridBox):
for invite in invites: for invite in invites:
self.add_invite(invite) self.add_invite(invite)
invites.connect('invite-added', self.__invite_added_cb) invites.connect('invite-added', self.__invite_added_cb)
invites.connect('invite-removed', self.__invite_removed_cb)
def __activity_clicked_cb(self, icon): def __activity_clicked_cb(self, icon):
self._shell.start_activity(icon.get_bundle_id()) self._shell.start_activity(icon.get_bundle_id())
def __invite_clicked_cb(self, icon): def __invite_clicked_cb(self, icon):
self._invites.remove_invite(icon.get_invite())
self._shell.join_activity(icon.get_bundle_id(), self._shell.join_activity(icon.get_bundle_id(),
icon.get_activity_id()) icon.get_activity_id())
def __invite_added_cb(self, invites, invite): def __invite_added_cb(self, invites, invite):
self.add_invite(invite) self.add_invite(invite)
def __invite_removed_cb(self, invites, invite):
self.remove_invite(invite)
def add_activity(self, activity): def add_activity(self, activity):
item = ActivityItem(activity) item = ActivityItem(activity)
item.connect('clicked', self.__activity_clicked_cb) item.connect('clicked', self.__activity_clicked_cb)
@ -64,3 +74,9 @@ class BottomPanel(GridBox):
item = InviteItem(invite) item = InviteItem(invite)
item.connect('clicked', self.__invite_clicked_cb) item.connect('clicked', self.__invite_clicked_cb)
self.add_child(item, 0) self.add_child(item, 0)
self._invite_to_item[invite] = item
def remove_invite(self, invite):
self.remove_child(self._invite_to_item[invite])
del self._invite_to_item[invite]

View File

@ -4,6 +4,8 @@ from sugar.canvas.GridLayout import GridGroup
from sugar.canvas.GridLayout import GridConstraints from sugar.canvas.GridLayout import GridConstraints
class GridBox(GridGroup, goocanvas.Item): class GridBox(GridGroup, goocanvas.Item):
__gtype_name__ = 'GridBox'
VERTICAL = 0 VERTICAL = 0
HORIZONTAL = 1 HORIZONTAL = 1
@ -27,7 +29,7 @@ class GridBox(GridGroup, goocanvas.Item):
constraints = GridConstraints(col, row, 1, 1, self._padding) constraints = GridConstraints(col, row, 1, 1, self._padding)
self._layout.set_constraints(item, constraints) self._layout.set_constraints(item, constraints)
def add_child(self, item, position=-1): def do_add_child(self, item, position=-1):
if position == -1: if position == -1:
position = self.get_n_children() position = self.get_n_children()
@ -38,4 +40,12 @@ class GridBox(GridGroup, goocanvas.Item):
self._update_constraints(self.get_child(i), i + 1) self._update_constraints(self.get_child(i), i + 1)
i += 1 i += 1
GridGroup.add_child(self, item, position) GridGroup.do_add_child(self, item, position)
def do_remove_child(self, position):
GridGroup.do_remove_child(self, position)
i = position
while i < self.get_n_children():
self._update_constraints(self.get_child(i), i)
i += 1