scrolling over the tray icon switches among devices; fixes #101

It now works for the standard systray as well, not just the
appindicator.
This commit is contained in:
Daniel Pavel 2013-08-08 19:22:47 +02:00
parent c0874220d2
commit 6a66370ffe
1 changed files with 79 additions and 74 deletions

View File

@ -67,15 +67,14 @@ def _create_menu(quit_handler):
return menu return menu
try: _last_scroll = 0
# raise ImportError def _scroll(tray_icon, event, direction=None):
from gi.repository import AppIndicator3 if direction is None:
direction = event.direction
now = event.time / 1000.0
else:
now = None
if _log.isEnabledFor(_DEBUG):
_log.debug("using AppIndicator3")
_last_scroll = 0
def _scroll(ind, _ignore, direction):
if direction != ScrollDirection.UP and direction != ScrollDirection.DOWN: if direction != ScrollDirection.UP and direction != ScrollDirection.DOWN:
# ignore all other directions # ignore all other directions
return return
@ -88,7 +87,7 @@ try:
# scroll events come way too fast (at least 5-6 at once) # scroll events come way too fast (at least 5-6 at once)
# so take a little break between them # so take a little break between them
global _last_scroll global _last_scroll
now = _timestamp() now = now or _timestamp()
if now - _last_scroll < 0.33: # seconds if now - _last_scroll < 0.33: # seconds
return return
_last_scroll = now _last_scroll = now
@ -144,6 +143,13 @@ try:
_update_tray_icon() _update_tray_icon()
try:
# raise ImportError
from gi.repository import AppIndicator3
if _log.isEnabledFor(_DEBUG):
_log.debug("using AppIndicator3")
def _create(menu): def _create(menu):
theme_paths = Gtk.IconTheme.get_default().get_search_path() theme_paths = Gtk.IconTheme.get_default().get_search_path()
@ -210,10 +216,9 @@ except ImportError:
icon.set_title(NAME) icon.set_title(NAME)
icon.set_tooltip_text(NAME) icon.set_tooltip_text(NAME)
icon.connect('activate', _window_toggle) icon.connect('activate', _window_toggle)
icon.connect('scroll-event', _scroll)
icon.connect('popup_menu', icon.connect('popup-menu',
lambda icon, button, time: lambda icon, button, time: menu.popup(None, None, icon.position_menu, icon, button, time))
menu.popup(None, None, icon.position_menu, icon, button, time))
return icon return icon