Skip to content
Snippets Groups Projects
Commit fe177d62 authored by Philipp Hörist's avatar Philipp Hörist
Browse files

StatusIcon: Refactor code

- Make methods private
- Rename some methods (shorter names)
- Fix pylint errors
parent f8da1e7b
No related branches found
No related tags found
No related merge requests found
......@@ -19,7 +19,7 @@
<property name="can_focus">False</property>
<property name="label" translatable="yes">_Start Chat...</property>
<property name="use_underline">True</property>
<signal name="activate" handler="on_new_chat" swapped="no"/>
<signal name="activate" handler="_on_new_chat" swapped="no"/>
</object>
</child>
<child>
......@@ -42,7 +42,7 @@
<property name="can_focus">False</property>
<property name="label" translatable="yes">Show All Pending _Events</property>
<property name="use_underline">True</property>
<signal name="activate" handler="on_show_all_events_menuitem_activate" swapped="no"/>
<signal name="activate" handler="_on_show_all_events" swapped="no"/>
</object>
</child>
<child>
......@@ -51,7 +51,7 @@
<property name="can_focus">False</property>
<property name="label" translatable="yes">Mute Sounds</property>
<property name="use_underline">True</property>
<signal name="activate" handler="on_sounds_mute_menuitem_activate" swapped="no"/>
<signal name="activate" handler="_on_sounds_mute" swapped="no"/>
</object>
</child>
<child>
......@@ -67,7 +67,7 @@
<property name="can_focus">False</property>
<property name="label" translatable="yes">_Preferences</property>
<property name="use_underline">True</property>
<signal name="activate" handler="on_preferences_menuitem_activate" swapped="no"/>
<signal name="activate" handler="_on_preferences" swapped="no"/>
</object>
</child>
<child>
......@@ -82,7 +82,7 @@
<property name="can_focus">False</property>
<property name="label" translatable="yes">_Quit</property>
<property name="use_underline">True</property>
<signal name="activate" handler="on_quit_menuitem_activate" swapped="no"/>
<signal name="activate" handler="_on_quit" swapped="no"/>
</object>
</child>
</object>
......
......@@ -45,8 +45,8 @@ class StatusIcon:
"""
def __init__(self):
self.single_message_handler_id = None
self.show_roster_handler_id = None
self._single_message_handler_id = None
self._show_roster_handler_id = None
# click somewhere else does not popdown menu. workaround this.
self.added_hide_menuitem = False
self.status = 'offline'
......@@ -56,75 +56,85 @@ def __init__(self):
self.popup_menus = []
self.status_icon = None
self.tooltip = NotificationAreaTooltip()
self._icon_size = '16'
def subscribe_events(self):
def show_icon(self):
if not self.status_icon:
self.status_icon = Gtk.StatusIcon()
self.status_icon.set_property('has-tooltip', True)
self.status_icon.connect('activate', self._on_activate)
self.status_icon.connect('popup-menu', self._on_popup_menu)
self.status_icon.connect('query-tooltip', self._on_query_tooltip)
self.status_icon.connect('size-changed', self.set_img)
self.set_img()
self._subscribe_events()
def hide_icon(self):
self.status_icon.set_visible(False)
self._unsubscribe_events()
def change_status(self, global_status):
"""
Set tray image to 'global_status'
"""
# change image and status, only if it is different
if global_status is not None and self.status != global_status:
self.status = global_status
self.set_img()
def _subscribe_events(self):
"""
Register listeners to the events class
"""
app.events.event_added_subscribe(self.on_event_added)
app.events.event_removed_subscribe(self.on_event_removed)
app.events.event_added_subscribe(self._on_event_added)
app.events.event_removed_subscribe(self._on_event_removed)
def unsubscribe_events(self):
def _unsubscribe_events(self):
"""
Unregister listeners to the events class
"""
app.events.event_added_unsubscribe(self.on_event_added)
app.events.event_removed_unsubscribe(self.on_event_removed)
app.events.event_added_unsubscribe(self._on_event_added)
app.events.event_removed_unsubscribe(self._on_event_removed)
def on_event_added(self, event):
def _on_event_added(self, event):
"""
Called when an event is added to the event list
"""
if event.show_in_systray:
self.set_img()
def on_event_removed(self, event_list):
def _on_event_removed(self, _event_list):
"""
Called when one or more events are removed from the event list
"""
self.set_img()
def show_icon(self):
if not self.status_icon:
self.status_icon = Gtk.StatusIcon()
self.status_icon.set_property('has-tooltip', True)
self.status_icon.connect('activate', self._on_activate)
self.status_icon.connect('popup-menu', self._on_popup_menu)
self.status_icon.connect('query-tooltip', self._on_query_tooltip)
self.status_icon.connect('size-changed', self.set_img)
self.set_img()
self.subscribe_events()
def _on_query_tooltip(self, _status_icon, _x, _y, _keyboard_mode, tooltip):
tooltip.set_custom(self.tooltip.get_tooltip())
return True
def hide_icon(self):
self.status_icon.set_visible(False)
self.unsubscribe_events()
def _on_popup_menu(self, _status_icon, button, activate_time):
if button == 1: # Left click
self.on_left_click()
self._on_left_click()
elif button == 2: # middle click
self.on_middle_click()
self._on_middle_click()
elif button == 3: # right click
self.make_menu(button, activate_time)
self._make_menu(button, activate_time)
def _on_activate(self, _status_icon):
self.on_left_click()
self._on_left_click()
def on_status_icon_size_changed(self, statusicon, size):
def on_status_icon_size_changed(self, _statusicon, size):
if size > 31:
self.statusicon_size = '32'
self._icon_size = '32'
elif size > 23:
self.statusicon_size = '24'
self._icon_size = '24'
else:
self.statusicon_size = '16'
self._icon_size = '16'
if os.environ.get('KDE_FULL_SESSION') == 'true':
# detect KDE session. see #5476
self.statusicon_size = '32'
self._icon_size = '32'
self.set_img()
def set_img(self, *args):
......@@ -148,37 +158,20 @@ def set_img(self, *args):
icon_name = get_icon_name(self.status)
self.status_icon.set_from_icon_name(icon_name)
def change_status(self, global_status):
"""
Set tray image to 'global_status'
"""
# change image and status, only if it is different
if global_status is not None and self.status != global_status:
self.status = global_status
self.set_img()
def start_chat(self, widget, account, jid):
contact = app.contacts.get_first_contact_from_jid(account, jid)
if app.interface.msg_win_mgr.has_window(jid, account):
app.interface.msg_win_mgr.get_window(jid, account).set_active_tab(
jid, account)
elif contact:
app.interface.new_chat(contact, account)
app.interface.msg_win_mgr.get_window(jid, account).set_active_tab(
jid, account)
def on_single_message_menuitem_activate(self, widget, account):
@staticmethod
def _on_single_message(_widget, account):
SingleMessageWindow(account, action='send')
def on_new_chat(self, _widget):
@staticmethod
def _on_new_chat(_widget):
app.app.activate_action('start-chat', GLib.Variant('s', ''))
def make_menu(self, event_button, event_time):
def _make_menu(self, _event_button, event_time):
"""
Create chat with and new message (sub) menus/menuitems
"""
for m in self.popup_menus:
m.destroy()
for menu in self.popup_menus:
menu.destroy()
start_chat_menuitem = self._ui.start_chat_menuitem
single_message_menuitem = self._ui.single_message_menuitem
......@@ -186,10 +179,10 @@ def make_menu(self, event_button, event_time):
sounds_mute_menuitem = self._ui.sounds_mute_menuitem
show_roster_menuitem = self._ui.show_roster_menuitem
if self.single_message_handler_id:
if self._single_message_handler_id:
single_message_menuitem.handler_disconnect(
self.single_message_handler_id)
self.single_message_handler_id = None
self._single_message_handler_id)
self._single_message_handler_id = None
sub_menu = Gtk.Menu()
self.popup_menus.append(sub_menu)
......@@ -199,14 +192,14 @@ def make_menu(self, event_button, event_time):
uf_show = helpers.get_uf_show(show, use_mnemonic=True)
item = Gtk.MenuItem.new_with_mnemonic(uf_show)
sub_menu.append(item)
item.connect('activate', self.on_show_menuitem_activate, show)
item.connect('activate', self._on_show, show)
item = Gtk.SeparatorMenuItem.new()
sub_menu.append(item)
item = Gtk.MenuItem.new_with_mnemonic(_('_Change Status Message…'))
sub_menu.append(item)
item.connect('activate', self.on_change_status_message_activate)
item.connect('activate', self._on_change_status)
connected_accounts = app.get_number_of_connected_accounts()
if connected_accounts < 1:
......@@ -218,10 +211,10 @@ def make_menu(self, event_button, event_time):
uf_show = helpers.get_uf_show('offline', use_mnemonic=True)
item = Gtk.MenuItem.new_with_mnemonic(uf_show)
sub_menu.append(item)
item.connect('activate', self.on_show_menuitem_activate, 'offline')
item.connect('activate', self._on_show, 'offline')
iskey = connected_accounts > 0 and not (connected_accounts == 1 and
app.zeroconf_is_connected())
is_zeroconf = connected_accounts == 1 and app.zeroconf_is_connected()
iskey = connected_accounts > 0 and not is_zeroconf
start_chat_menuitem.set_sensitive(iskey)
single_message_menuitem.set_sensitive(iskey)
......@@ -238,15 +231,15 @@ def make_menu(self, event_button, event_time):
# for single message
single_message_menuitem.set_submenu(None)
self.single_message_handler_id = single_message_menuitem.\
self._single_message_handler_id = single_message_menuitem.\
connect('activate',
self.on_single_message_menuitem_activate, account)
self._on_single_message, account)
break # No other account connected
else:
# 2 or more 'real' accounts are connected, make submenus
account_menu_for_single_message = Gtk.Menu()
single_message_menuitem.set_submenu(
account_menu_for_single_message)
account_menu_for_single_message)
self.popup_menus.append(account_menu_for_single_message)
for account in accounts_list:
......@@ -258,22 +251,25 @@ def make_menu(self, event_button, event_time):
item = Gtk.MenuItem.new_with_label(
_('using account %s') % account_label)
item.connect('activate',
self.on_single_message_menuitem_activate, account)
self._on_single_message, account)
account_menu_for_single_message.append(item)
sounds_mute_menuitem.set_active(not app.config.get('sounds_on'))
win = app.interface.roster.window
if self.show_roster_handler_id:
show_roster_menuitem.handler_disconnect(self.show_roster_handler_id)
if self._show_roster_handler_id:
show_roster_menuitem.handler_disconnect(
self._show_roster_handler_id)
if win.get_property('has-toplevel-focus'):
show_roster_menuitem.get_children()[0].set_label(_('Hide _Contact List'))
self.show_roster_handler_id = show_roster_menuitem.connect(
'activate', self.on_hide_roster_menuitem_activate)
show_roster_menuitem.get_children()[0].set_label(
_('Hide _Contact List'))
self._show_roster_handler_id = show_roster_menuitem.connect(
'activate', self._on_hide_roster)
else:
show_roster_menuitem.get_children()[0].set_label(_('Show _Contact List'))
self.show_roster_handler_id = show_roster_menuitem.connect(
'activate', self.on_show_roster_menuitem_activate)
show_roster_menuitem.get_children()[0].set_label(
_('Show _Contact List'))
self._show_roster_handler_id = show_roster_menuitem.connect(
'activate', self._on_show_roster)
if os.name == 'nt':
if self.added_hide_menuitem is False:
......@@ -286,31 +282,37 @@ def make_menu(self, event_button, event_time):
self.systray_context_menu.show_all()
self.systray_context_menu.popup(None, None, None, None, 0, event_time)
def on_show_all_events_menuitem_activate(self, widget):
@staticmethod
def _on_show_all_events(_widget):
events = app.events.get_systray_events()
for account in events:
for jid in events[account]:
for event in events[account][jid]:
app.interface.handle_event(account, jid, event.type_)
def on_sounds_mute_menuitem_activate(self, widget):
@staticmethod
def _on_sounds_mute(widget):
app.config.set('sounds_on', not widget.get_active())
def on_show_roster_menuitem_activate(self, widget):
@staticmethod
def _on_show_roster(_widget):
win = app.interface.roster.window
win.present()
def on_hide_roster_menuitem_activate(self, widget):
@staticmethod
def _on_hide_roster(_widget):
win = app.interface.roster.window
win.hide()
def on_preferences_menuitem_activate(self, widget):
@staticmethod
def _on_preferences(_widget):
open_window('Preferences')
def on_quit_menuitem_activate(self, widget):
@staticmethod
def _on_quit(_widget):
app.interface.roster.on_quit_request()
def on_left_click(self):
def _on_left_click(self):
win = app.interface.roster.window
if not app.events.get_systray_events():
# No pending events, so toggle visible/hidden for roster window
......@@ -325,9 +327,10 @@ def on_left_click(self):
win.set_property('skip-taskbar-hint', False)
win.present_with_time(Gtk.get_current_event_time())
else:
self.handle_first_event()
self._handle_first_event()
def handle_first_event(self):
@staticmethod
def _handle_first_event():
account, jid, event = app.events.get_first_systray_event()
if not event:
return
......@@ -337,23 +340,26 @@ def handle_first_event(self):
restore_roster_position(win)
app.interface.handle_event(account, jid, event.type_)
def on_middle_click(self):
@staticmethod
def _on_middle_click():
"""
Middle click raises window to have complete focus (fe. get kbd events)
but if already raised, it hides it
"""
win = app.interface.roster.window
if win.is_active(): # is it fully raised? (eg does it receive kbd events?)
if win.is_active():
win.hide()
else:
win.present()
def on_show_menuitem_activate(self, widget, show):
@staticmethod
def _on_show(_widget, show):
# we all add some fake (we cannot select those nor have them as show)
# but this helps to align with roster's status_combobox index positions
l = ['online', 'chat', 'away', 'xa', 'dnd', 'invisible', 'SEPARATOR',
'CHANGE_STATUS_MSG_MENUITEM', 'SEPARATOR', 'offline']
index = l.index(show)
status = ['online', 'chat', 'away', 'xa', 'dnd', 'invisible',
'SEPARATOR', 'CHANGE_STATUS_MSG_MENUITEM', 'SEPARATOR',
'offline']
index = status.index(show)
if not helpers.statuses_unified():
app.interface.roster.status_combobox.set_active(index + 2)
return
......@@ -361,7 +367,8 @@ def on_show_menuitem_activate(self, widget, show):
if index != current:
app.interface.roster.status_combobox.set_active(index)
def on_change_status_message_activate(self, widget):
@staticmethod
def _on_change_status(_widget):
model = app.interface.roster.status_combobox.get_model()
active = app.interface.roster.status_combobox.get_active()
status = model[active][2]
......@@ -370,8 +377,9 @@ def on_response(message, pep_dict):
return
accounts = app.connections.keys()
for acct in accounts:
if not app.config.get_per('accounts', acct,
'sync_with_global_status'):
if not app.config.get_per('accounts',
acct,
'sync_with_global_status'):
continue
show = app.SHOW_LIST[app.connections[acct].connected]
app.interface.roster.send_status(acct, show, message)
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment