Make the popup logic more solid
This commit is contained in:
parent
fe69dec4ad
commit
d053a7f219
@ -21,6 +21,7 @@ class FriendsGroup(goocanvas.Group):
|
|||||||
def __init__(self, shell, friends):
|
def __init__(self, shell, friends):
|
||||||
goocanvas.Group.__init__(self)
|
goocanvas.Group.__init__(self)
|
||||||
|
|
||||||
|
self._popup = None
|
||||||
self._shell = shell
|
self._shell = shell
|
||||||
self._icon_layout = IconLayout(1200, 900)
|
self._icon_layout = IconLayout(1200, 900)
|
||||||
self._friends = friends
|
self._friends = friends
|
||||||
@ -50,7 +51,8 @@ class FriendsGroup(goocanvas.Group):
|
|||||||
def _friend_popup_cb(self, icon, x1, y1, x2, y2):
|
def _friend_popup_cb(self, icon, x1, y1, x2, y2):
|
||||||
grid = Grid()
|
grid = Grid()
|
||||||
|
|
||||||
self._popup = BuddyPopup(self._shell, grid, icon.get_friend())
|
if not self._popup:
|
||||||
|
self._popup = BuddyPopup(self._shell, grid, icon.get_friend())
|
||||||
|
|
||||||
[grid_x1, grid_y1] = grid.convert_from_screen(x1, y1)
|
[grid_x1, grid_y1] = grid.convert_from_screen(x1, y1)
|
||||||
[grid_x2, grid_y2] = grid.convert_from_screen(x2, y2)
|
[grid_x2, grid_y2] = grid.convert_from_screen(x2, y2)
|
||||||
@ -72,6 +74,10 @@ class FriendsGroup(goocanvas.Group):
|
|||||||
|
|
||||||
self._popup.show()
|
self._popup.show()
|
||||||
|
|
||||||
def _friend_popdown_cb(self, friend):
|
def _popup_destroy_cb(self, popup):
|
||||||
self._popup.popdown()
|
|
||||||
self._popup = None
|
self._popup = None
|
||||||
|
|
||||||
|
def _friend_popdown_cb(self, friend):
|
||||||
|
if self._popup:
|
||||||
|
self._popup.connect('destroy', self._popup_destroy_cb)
|
||||||
|
self._popup.popdown()
|
||||||
|
@ -195,6 +195,7 @@ class IconItem(goocanvas.ItemSimple, goocanvas.Item):
|
|||||||
self.size = 24
|
self.size = 24
|
||||||
self.color = None
|
self.color = None
|
||||||
self.icon_name = None
|
self.icon_name = None
|
||||||
|
self._popdown_timeout = 0
|
||||||
|
|
||||||
goocanvas.ItemSimple.__init__(self, **kwargs)
|
goocanvas.ItemSimple.__init__(self, **kwargs)
|
||||||
|
|
||||||
@ -239,15 +240,29 @@ class IconItem(goocanvas.ItemSimple, goocanvas.Item):
|
|||||||
def _button_press_cb(self, view, target, event):
|
def _button_press_cb(self, view, target, event):
|
||||||
self.emit('clicked')
|
self.emit('clicked')
|
||||||
|
|
||||||
|
def _start_popup_timeout(self):
|
||||||
|
self._stop_popup_timeout()
|
||||||
|
self._popdown_timeout = gobject.timeout_add(1000, self._popdown)
|
||||||
|
|
||||||
|
def _stop_popup_timeout(self):
|
||||||
|
if self._popdown_timeout > 0:
|
||||||
|
gobject.source_remove(self._popdown_timeout)
|
||||||
|
self._popdown_timeout = 0
|
||||||
|
|
||||||
def _enter_notify_event_cb(self, view, target, event, canvas):
|
def _enter_notify_event_cb(self, view, target, event, canvas):
|
||||||
|
self._stop_popup_timeout()
|
||||||
|
|
||||||
[x1, y1] = canvas.convert_to_pixels(view.get_bounds().x1,
|
[x1, y1] = canvas.convert_to_pixels(view.get_bounds().x1,
|
||||||
view.get_bounds().y1)
|
view.get_bounds().y1)
|
||||||
[x2, y2] = canvas.convert_to_pixels(view.get_bounds().x2,
|
[x2, y2] = canvas.convert_to_pixels(view.get_bounds().x2,
|
||||||
view.get_bounds().y2)
|
view.get_bounds().y2)
|
||||||
|
|
||||||
self.emit('popup', int(x1), int(y1), int(x2), int(y2))
|
self.emit('popup', int(x1), int(y1), int(x2), int(y2))
|
||||||
|
|
||||||
def _popdown(self):
|
def _popdown(self):
|
||||||
|
self._popdown_timeout = 0
|
||||||
self.emit('popdown')
|
self.emit('popdown')
|
||||||
|
return False
|
||||||
|
|
||||||
def _leave_notify_event_cb(self, view, target, event):
|
def _leave_notify_event_cb(self, view, target, event):
|
||||||
gobject.timeout_add(1000, self._popdown)
|
self._start_popup_timeout()
|
||||||
|
Loading…
Reference in New Issue
Block a user