gajim-plural/gajim/gtk/tooltips.py

669 lines
24 KiB
Python
Raw Normal View History

# Copyright (C) 2005 Alex Mauer <hawke AT hawkesnest.net>
# Stéphan Kochen <stephan AT kochen.nl>
# Copyright (C) 2005-2006 Dimitur Kirov <dkirov AT gmail.com>
# Copyright (C) 2005-2007 Nikos Kouremenos <kourem AT gmail.com>
# Copyright (C) 2005-2014 Yann Leboulanger <asterix AT lagaule.org>
# Copyright (C) 2006 Travis Shirk <travis AT pobox.com>
# Stefan Bethge <stefan AT lanpartei.de>
# Copyright (C) 2006-2007 Jean-Marie Traissard <jim AT lapin.org>
# Copyright (C) 2007 Julien Pivotto <roidelapluie AT gmail.com>
# Copyright (C) 2007-2008 Stephan Erb <steve-e AT h3c.de>
# Copyright (C) 2008 Jonathan Schleifer <js-gajim AT webkeks.org>
#
# This file is part of Gajim.
#
# Gajim is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published
# by the Free Software Foundation; version 3 only.
#
# Gajim is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Gajim. If not, see <http://www.gnu.org/licenses/>.
2017-12-23 21:13:34 +01:00
import os
import time
2018-03-06 23:16:30 +01:00
import logging
2017-12-23 21:13:34 +01:00
from datetime import datetime
from gi.repository import Gtk
2013-07-28 20:50:30 +02:00
from gi.repository import GLib
from gi.repository import Pango
from gajim.common import app
2017-06-13 23:58:06 +02:00
from gajim.common import helpers
from gajim.common.const import AvatarSize
from gajim.common.const import PEPEventType
2017-06-13 23:58:06 +02:00
from gajim.common.i18n import Q_
from gajim.common.i18n import _
from gajim.gtk.util import get_builder
from gajim.gtk.util import get_icon_name
from gajim.gtk.util import format_mood
from gajim.gtk.util import format_activity
from gajim.gtk.util import format_tune
from gajim.gtk.util import format_location
2018-10-28 09:33:40 +01:00
log = logging.getLogger('gajim.gtk.tooltips')
2018-03-06 23:16:30 +01:00
class StatusTable:
"""
Contains methods for creating status table. This is used in Roster and
NotificationArea tooltips
"""
def __init__(self):
2016-11-17 03:29:18 +01:00
self.current_row = 0
self.table = None
self.text_label = None
self.spacer_label = ' '
def create_table(self):
self.table = Gtk.Grid()
self.table.insert_column(0)
self.table.set_property('column-spacing', 3)
2016-11-17 03:29:18 +01:00
def add_text_row(self, text, col_inc=0):
self.table.insert_row(self.current_row)
self.text_label = Gtk.Label()
self.text_label.set_line_wrap(True)
self.text_label.set_line_wrap_mode(Pango.WrapMode.WORD_CHAR)
self.text_label.set_max_width_chars(25)
self.text_label.set_halign(Gtk.Align.START)
self.text_label.set_valign(Gtk.Align.START)
self.text_label.set_selectable(False)
self.text_label.set_markup(text)
self.table.attach(self.text_label, 1 + col_inc,
self.current_row,
3 - col_inc,
1)
2016-11-17 03:29:18 +01:00
self.current_row += 1
@staticmethod
def get_status_info(resource, priority, _show, status):
2013-01-01 21:06:16 +01:00
str_status = resource + ' (' + str(priority) + ')'
if status:
status = status.strip()
if status != '':
# reduce to 100 chars, 1 line
status = helpers.reduce_chars_newlines(status, 100, 1)
2013-07-28 20:50:30 +02:00
str_status = GLib.markup_escape_text(str_status)
status = GLib.markup_escape_text(status)
str_status += ' - <i>' + status + '</i>'
return str_status
2018-10-28 10:44:05 +01:00
def add_status_row(self, show, str_status, show_lock=False,
indent=True, transport=None):
"""
Append a new row with status icon to the table
"""
2016-11-17 03:29:18 +01:00
self.table.insert_row(self.current_row)
image = Gtk.Image()
icon_name = get_icon_name(show, transport=transport)
2018-10-28 10:44:05 +01:00
image.set_from_icon_name(icon_name, Gtk.IconSize.MENU)
spacer = Gtk.Label(label=self.spacer_label)
image.set_halign(Gtk.Align.START)
image.set_valign(Gtk.Align.CENTER)
if indent:
self.table.attach(spacer, 1, self.current_row, 1, 1)
self.table.attach(image, 2, self.current_row, 1, 1)
status_label = Gtk.Label()
status_label.set_markup(str_status)
status_label.set_halign(Gtk.Align.START)
status_label.set_valign(Gtk.Align.START)
status_label.set_line_wrap(True)
self.table.attach(status_label, 3, self.current_row, 1, 1)
if show_lock:
lock_image = Gtk.Image()
lock_image.set_from_icon_name('dialog-password', Gtk.IconSize.MENU)
self.table.attach(lock_image, 4, self.current_row, 1, 1)
2016-11-17 03:29:18 +01:00
self.current_row += 1
2008-12-03 22:56:12 +01:00
def fill_table_with_accounts(self, accounts):
for acct in accounts:
message = acct['message']
message = helpers.reduce_chars_newlines(message, 100, 1)
2013-07-28 20:50:30 +02:00
message = GLib.markup_escape_text(message)
con_type = app.con_types.get(acct['name'])
show_lock = con_type in ('tls', 'ssl')
account_label = GLib.markup_escape_text(acct['account_label'])
if message:
status = '%s - %s' % (account_label, message)
else:
status = account_label
2018-10-28 10:44:05 +01:00
self.add_status_row(acct['show'],
status,
show_lock=show_lock,
indent=False)
for line in acct['event_lines']:
self.add_text_row(' ' + line, 1)
class NotificationAreaTooltip(StatusTable):
"""
Tooltip that is shown in the notification area
"""
def __init__(self):
StatusTable.__init__(self)
def get_tooltip(self):
self.create_table()
accounts = helpers.get_notification_icon_tooltip_dict()
self.fill_table_with_accounts(accounts)
self.table.set_property('column-spacing', 1)
hbox = Gtk.HBox()
hbox.add(self.table)
hbox.show_all()
return hbox
2005-08-24 19:29:35 +02:00
class GCTooltip():
def __init__(self):
self.contact = None
2016-11-13 21:06:37 +01:00
self._ui = get_builder('tooltip_gc_contact.ui')
2016-11-13 21:06:37 +01:00
def clear_tooltip(self):
self.contact = None
def get_tooltip(self, contact):
if self.contact == contact:
return True, self._ui.tooltip_grid
self._populate_grid(contact)
self.contact = contact
return False, self._ui.tooltip_grid
def _hide_grid_childs(self):
2016-11-13 21:06:37 +01:00
"""
Hide all Elements of the Tooltip Grid
"""
for child in self._ui.tooltip_grid.get_children():
2016-11-13 21:06:37 +01:00
child.hide()
def _populate_grid(self, contact):
2016-11-13 21:06:37 +01:00
"""
Populate the Tooltip Grid with data of from the contact
"""
self._hide_grid_childs()
self._ui.nick.set_text(contact.get_shown_name())
self._ui.nick.show()
2016-11-13 21:06:37 +01:00
# Status Message
if contact.status:
status = contact.status.strip()
if status != '':
self._ui.status.set_text(status)
self._ui.status.show()
2016-11-13 21:06:37 +01:00
# Status
show = helpers.get_uf_show(contact.show.value)
self._ui.user_show.set_markup(colorize_status(show))
self._ui.user_show.show()
2016-11-13 21:06:37 +01:00
# JID
if contact.jid is not None:
self._ui.jid.set_text(str(contact.jid))
self._ui.jid.show()
2016-11-13 21:06:37 +01:00
# Affiliation
if not contact.affiliation.is_none:
uf_affiliation = helpers.get_uf_affiliation(contact.affiliation)
uf_affiliation = \
2016-11-13 21:06:37 +01:00
_('%(owner_or_admin_or_member)s of this group chat') \
% {'owner_or_admin_or_member': uf_affiliation}
uf_affiliation = self.colorize_affiliation(uf_affiliation)
self._ui.affiliation.set_markup(uf_affiliation)
self._ui.affiliation.show()
2016-11-13 21:06:37 +01:00
# Avatar
if contact.avatar_sha is not None:
app.log('avatar').debug(
'Load GCTooltip: %s %s', contact.name, contact.avatar_sha)
scale = self._ui.tooltip_grid.get_scale_factor()
2017-10-19 21:12:27 +02:00
surface = app.interface.get_avatar(
contact.avatar_sha, AvatarSize.TOOLTIP, scale)
if surface is not None:
self._ui.avatar.set_from_surface(surface)
self._ui.avatar.show()
self._ui.fillelement.show()
2018-02-20 22:51:28 +01:00
app.plugin_manager.gui_extension_point(
'gc_tooltip_populate', self, contact, self._ui.tooltip_grid)
2018-02-20 22:51:28 +01:00
2016-11-13 21:06:37 +01:00
@staticmethod
def colorize_affiliation(affiliation):
"""
Color the affiliation of a MUC participant inside the tooltip by
it's semantics. Color palette is the Tango.
"""
formatted = "<span foreground='%s'>%s</span>"
color = None
if affiliation.startswith(Q_("?Group Chat Contact Affiliation:None")):
color = app.config.get('tooltip_affiliation_none_color')
2016-11-13 21:06:37 +01:00
elif affiliation.startswith(_("Member")):
color = app.config.get('tooltip_affiliation_member_color')
2016-11-13 21:06:37 +01:00
elif affiliation.startswith(_("Administrator")):
color = app.config.get('tooltip_affiliation_administrator_color')
2016-11-13 21:06:37 +01:00
elif affiliation.startswith(_("Owner")):
color = app.config.get('tooltip_affiliation_owner_color')
2016-11-13 21:06:37 +01:00
if color:
affiliation = formatted % (color, affiliation)
return affiliation
2005-08-24 14:58:03 +02:00
class RosterTooltip(StatusTable):
def __init__(self):
2016-11-17 03:29:18 +01:00
StatusTable.__init__(self)
self.create_table()
self.account = None
2016-11-17 03:29:18 +01:00
self.row = None
self.contact_jid = None
self.prim_contact = None
2016-11-17 03:29:18 +01:00
self.last_widget = None
self.num_resources = 0
self._ui = get_builder('tooltip_roster_contact.ui')
2016-11-17 03:29:18 +01:00
def clear_tooltip(self):
"""
Hide all Elements of the Tooltip Grid
"""
for child in self._ui.tooltip_grid.get_children():
2016-11-17 03:29:18 +01:00
child.hide()
status_table = self._ui.tooltip_grid.get_child_at(1, 3)
2016-11-17 03:29:18 +01:00
if status_table:
status_table.destroy()
self.create_table()
self.row = None
def get_tooltip(self, row, connected_contacts, account, typ):
if self.row == row:
return True, self._ui.tooltip_grid
self._populate_grid(connected_contacts, account, typ)
self.row = row
return False, self._ui.tooltip_grid
2016-11-17 03:29:18 +01:00
def _populate_grid(self, contacts, account, typ):
2016-11-17 03:29:18 +01:00
"""
Populate the Tooltip Grid with data of from the contact
"""
self.current_row = 0
self.account = account
if self.last_widget:
self.last_widget.set_vexpand(False)
self.clear_tooltip()
if account == 'all':
# Tooltip for merged accounts row
accounts = helpers.get_notification_icon_tooltip_dict()
self.spacer_label = ''
self.fill_table_with_accounts(accounts)
self._ui.tooltip_grid.attach(self.table, 1, 3, 2, 1)
2016-11-17 03:29:18 +01:00
self.table.show_all()
return
2016-11-17 03:29:18 +01:00
if typ == 'account':
jid = app.get_jid_from_account(account)
2016-11-17 03:29:18 +01:00
contacts = []
connection = app.connections[account]
2016-11-17 03:29:18 +01:00
# get our current contact info
nbr_on, nbr_total = app.\
contacts.get_nb_online_total_contacts(accounts=[account])
2018-08-30 19:27:40 +02:00
account_name = app.get_account_label(account)
if app.account_is_connected(account):
account_name += ' (%s/%s)' % (repr(nbr_on), repr(nbr_total))
contact = app.contacts.create_self_contact(
jid=jid,
account=account,
name=account_name,
show=connection.get_status(),
status=connection.status,
2016-11-17 03:29:18 +01:00
resource=connection.server_resource,
priority=connection.priority)
if app.connections[account].gpg:
contact.keyID = app.config.get_per(
'accounts', connection.name, 'keyid')
2016-11-17 03:29:18 +01:00
contacts.append(contact)
# Username/Account/Groupchat
self.prim_contact = app.contacts.get_highest_prio_contact_from_contacts(
contacts)
if self.prim_contact is None:
log.error('No contact for Roster tooltip found')
log.error('contacts: %s, typ: %s, account: %s', contacts, typ, account)
return
2016-11-17 03:29:18 +01:00
self.contact_jid = self.prim_contact.jid
name = GLib.markup_escape_text(self.prim_contact.get_shown_name())
name_markup = '<b>{}</b>'.format(name)
if app.config.get('mergeaccounts'):
color = app.config.get('tooltip_account_name_color')
2016-11-17 03:29:18 +01:00
account_name = GLib.markup_escape_text(self.prim_contact.account.name)
name_markup += " <span foreground='{}'>({})</span>".format(
color, account_name)
2016-11-17 03:29:18 +01:00
if account and helpers.jid_is_blocked(account, self.prim_contact.jid):
name_markup += _(' [blocked]')
2016-11-17 03:29:18 +01:00
try:
if self.prim_contact.jid in app.interface.minimized_controls[account]:
2016-11-17 03:29:18 +01:00
name_markup += _(' [minimized]')
except KeyError:
pass
self._ui.name.set_markup(name_markup)
self._ui.name.show()
2016-11-17 03:29:18 +01:00
self.num_resources = 0
# put contacts in dict, where key is priority
contacts_dict = {}
for contact in contacts:
if contact.resource:
2016-11-17 03:29:18 +01:00
self.num_resources += 1
priority = int(contact.priority)
if priority in contacts_dict:
contacts_dict[priority].append(contact)
else:
2016-11-17 03:29:18 +01:00
contacts_dict[priority] = [contact]
if self.num_resources > 1:
transport = app.get_transport_name_from_jid(self.prim_contact.jid)
2018-11-06 21:31:43 +01:00
if transport == 'jabber':
transport = None
contact_keys = sorted(contacts_dict.keys())
contact_keys.reverse()
for priority in contact_keys:
for acontact in contacts_dict[priority]:
2018-10-28 10:44:05 +01:00
show = self._get_icon_name_for_tooltip(acontact)
2016-11-17 03:29:18 +01:00
if acontact.status and len(acontact.status) > 25:
status = ''
add_text = True
else:
status = acontact.status
add_text = False
status_line = self.get_status_info(
acontact.resource,
acontact.priority,
acontact.show,
status)
2018-10-28 10:44:05 +01:00
self.add_status_row(show, status_line, transport=transport)
2016-11-17 03:29:18 +01:00
if add_text:
self.add_text_row(acontact.status, 2)
self._ui.tooltip_grid.attach(self.table, 1, 3, 2, 1)
2016-11-17 03:29:18 +01:00
self.table.show_all()
2016-11-17 03:29:18 +01:00
else: # only one resource
if contact.show and contact.status:
status = contact.status.strip()
if status:
self._ui.status.set_text(status)
self._ui.status.show()
2016-11-17 03:29:18 +01:00
# PEP Info
self._append_pep_info(contact)
2016-11-17 03:29:18 +01:00
# JID
self._ui.jid.set_text(self.prim_contact.jid)
self._ui.jid.show()
2018-06-22 00:47:29 +02:00
# contact has only one resource
2016-11-17 03:29:18 +01:00
if self.num_resources == 1 and contact.resource:
res = GLib.markup_escape_text(contact.resource)
prio = str(contact.priority)
self._ui.resource.set_text("{} ({})".format(res, prio))
self._ui.resource.show()
self._ui.resource_label.show()
if self.prim_contact.jid not in app.gc_connected[account]:
2016-11-17 03:29:18 +01:00
if (account and
self.prim_contact.sub and
2016-11-17 03:29:18 +01:00
self.prim_contact.sub != 'both'):
# ('both' is the normal sub so we don't show it)
self._ui.sub.set_text(helpers.get_uf_sub(self.prim_contact.sub))
self._ui.sub.show()
self._ui.sub_label.show()
2016-11-17 03:29:18 +01:00
if self.prim_contact.keyID:
key_id = None
2016-11-17 03:29:18 +01:00
if len(self.prim_contact.keyID) == 8:
key_id = self.prim_contact.keyID
2016-11-17 03:29:18 +01:00
elif len(self.prim_contact.keyID) == 16:
key_id = self.prim_contact.keyID[8:]
if key_id:
self._ui.pgp.set_text(key_id)
self._ui.pgp.show()
self._ui.pgp_label.show()
2016-11-17 03:29:18 +01:00
self._set_idle_time(contact)
# Avatar
scale = self._ui.tooltip_grid.get_scale_factor()
2017-10-19 21:12:27 +02:00
surface = app.contacts.get_avatar(
account, self.prim_contact.jid, AvatarSize.TOOLTIP, scale)
if surface is not None:
self._ui.avatar.set_from_surface(surface)
self._ui.avatar.show()
2018-03-07 22:37:02 +01:00
app.plugin_manager.gui_extension_point(
'roster_tooltip_populate', self, contacts, self._ui.tooltip_grid)
2018-03-07 22:37:02 +01:00
# Sets the Widget that is at the bottom to expand.
# This is needed in case the Picture takes more Space than the Labels
i = 1
while i < 15:
if self._ui.tooltip_grid.get_child_at(1, i):
if self._ui.tooltip_grid.get_child_at(1, i).get_visible():
self.last_widget = self._ui.tooltip_grid.get_child_at(1, i)
i += 1
self.last_widget.set_vexpand(True)
2016-11-17 03:29:18 +01:00
def _append_pep_info(self, contact):
"""
Append Tune, Mood, Activity, Location information of the specified contact
to the given property list.
"""
if PEPEventType.MOOD in contact.pep:
mood = format_mood(*contact.pep[PEPEventType.MOOD])
self._ui.mood.set_markup(mood)
self._ui.mood.show()
self._ui.mood_label.show()
2016-11-17 03:29:18 +01:00
if PEPEventType.ACTIVITY in contact.pep:
activity = format_activity(*contact.pep[PEPEventType.ACTIVITY])
self._ui.activity.set_markup(activity)
self._ui.activity.show()
self._ui.activity_label.show()
2016-11-17 03:29:18 +01:00
if PEPEventType.TUNE in contact.pep:
tune = format_tune(*contact.pep[PEPEventType.TUNE])
self._ui.tune.set_markup(tune)
self._ui.tune.show()
self._ui.tune_label.show()
if PEPEventType.LOCATION in contact.pep:
location = format_location(contact.pep[PEPEventType.LOCATION])
self._ui.location.set_markup(location)
self._ui.location.show()
self._ui.location_label.show()
2016-11-17 03:29:18 +01:00
def _set_idle_time(self, contact):
if contact.idle_time:
idle_color = app.config.get('tooltip_idle_color')
idle_time = contact.idle_time
idle_time = time.localtime(contact.idle_time)
idle_time = datetime(*(idle_time[:6]))
current = datetime.now()
if idle_time.date() == current.date():
formatted = idle_time.strftime('%X')
else:
formatted = idle_time.strftime('%c')
idle_markup = '<span foreground="{}">{}</span>'.format(
idle_color, formatted)
self._ui.idle_since.set_markup(idle_markup)
self._ui.idle_since.show()
self._ui.idle_since_label.show()
2016-11-17 03:29:18 +01:00
if contact.show and self.num_resources < 2:
show = helpers.get_uf_show(contact.show)
# Contact is Groupchat
if (self.account and
self.prim_contact.jid in app.gc_connected[self.account]):
if app.gc_connected[self.account][self.prim_contact.jid]:
2016-11-17 03:29:18 +01:00
show = _('Connected')
else:
show = _('Disconnected')
self._ui.user_show.set_markup(colorize_status(show))
self._ui.user_show.show()
2016-11-17 03:29:18 +01:00
@staticmethod
def _get_icon_name_for_tooltip(contact):
2016-11-17 03:29:18 +01:00
"""
2018-06-22 00:47:29 +02:00
Helper function used for tooltip contacts/accounts
2016-11-17 03:29:18 +01:00
Tooltip on account has fake contact with sub == '', in this case we show
real status of the account
"""
if contact.ask == 'subscribe':
return 'requested'
2018-09-18 10:14:04 +02:00
if contact.sub in ('both', 'to', ''):
2016-11-17 03:29:18 +01:00
return contact.show
return 'not in roster'
2017-12-22 20:55:00 +01:00
class FileTransfersTooltip():
def __init__(self):
2017-12-22 20:55:00 +01:00
self.sid = None
self.widget = None
2017-12-22 20:55:00 +01:00
def clear_tooltip(self):
self.sid = None
self.widget = None
def get_tooltip(self, file_props, sid):
if self.sid == sid:
return True, self.widget
self.widget = self._create_tooltip(file_props, sid)
self.sid = sid
return False, self.widget
@staticmethod
def _create_tooltip(file_props, _sid):
ft_table = Gtk.Table(2, 1)
ft_table.set_property('column-spacing', 2)
current_row = 1
properties = []
2012-06-14 18:27:23 +02:00
name = file_props.name
if file_props.type_ == 'r':
file_name = os.path.split(file_props.file_name)[1]
else:
2012-06-14 18:27:23 +02:00
file_name = file_props.name
2013-07-28 20:50:30 +02:00
properties.append((_('Name: '), GLib.markup_escape_text(file_name)))
2012-06-14 18:27:23 +02:00
if file_props.type_ == 'r':
2017-08-18 22:05:16 +02:00
type_ = Q_('?Noun:Download')
actor = _('Sender: ')
2013-01-01 21:06:16 +01:00
sender = file_props.sender.split('/')[0]
name = app.contacts.get_first_contact_from_jid(
file_props.tt_account, sender).get_shown_name()
else:
2017-08-18 22:05:16 +02:00
type_ = Q_('?Noun:Upload')
actor = _('Recipient: ')
2012-06-14 18:27:23 +02:00
receiver = file_props.receiver
if hasattr(receiver, 'name'):
name = receiver.get_shown_name()
else:
name = receiver.split('/')[0]
properties.append((_('Type: '), type_))
2013-07-28 20:50:30 +02:00
properties.append((actor, GLib.markup_escape_text(name)))
2012-06-14 18:27:23 +02:00
transfered_len = file_props.received_len
if not transfered_len:
transfered_len = 0
properties.append((_('Transferred: '), helpers.convert_bytes(transfered_len)))
status = ''
2012-06-14 18:27:23 +02:00
if file_props.started:
status = _('Not started')
2017-12-22 20:55:00 +01:00
if file_props.stopped:
2012-06-14 18:27:23 +02:00
status = _('Stopped')
elif file_props.completed:
status = _('Completed')
2017-12-22 20:55:00 +01:00
elif not file_props.connected:
2012-06-14 18:27:23 +02:00
if file_props.completed:
status = _('Completed')
else:
2017-12-22 20:55:00 +01:00
if file_props.paused:
2017-08-18 22:05:16 +02:00
status = Q_('?transfer status:Paused')
2017-12-22 20:55:00 +01:00
elif file_props.stalled:
# stalled is not paused. it is like 'frozen' it stopped alone
status = _('Stalled')
else:
status = _('Transferring')
else:
status = _('Not started')
properties.append((_('Status: '), status))
2014-02-15 21:28:39 +01:00
file_desc = file_props.desc or ''
2013-07-28 20:50:30 +02:00
properties.append((_('Description: '), GLib.markup_escape_text(
file_desc)))
while properties:
property_ = properties.pop(0)
current_row += 1
label = Gtk.Label()
label.set_halign(Gtk.Align.START)
label.set_valign(Gtk.Align.START)
label.set_markup(property_[0])
ft_table.attach(
label, 1, 2, current_row, current_row + 1,
Gtk.AttachOptions.FILL, Gtk.AttachOptions.FILL, 0, 0)
label = Gtk.Label()
label.set_halign(Gtk.Align.START)
label.set_valign(Gtk.Align.START)
label.set_line_wrap(True)
label.set_markup(property_[1])
ft_table.attach(
label, 2, 3, current_row, current_row + 1,
Gtk.AttachOptions.EXPAND | Gtk.AttachOptions.FILL,
Gtk.AttachOptions.FILL, 0, 0)
2017-12-22 20:55:00 +01:00
ft_table.show_all()
return ft_table
2016-11-13 21:06:37 +01:00
def colorize_status(status):
"""
Colorize the status message inside the tooltip by it's
semantics. Color palette is the Tango.
"""
formatted = "<span foreground='%s'>%s</span>"
color = None
if status.startswith(Q_("?user status:Available")):
color = app.config.get('tooltip_status_online_color')
2016-11-13 21:06:37 +01:00
elif status.startswith(_("Free for Chat")):
color = app.config.get('tooltip_status_free_for_chat_color')
2016-11-13 21:06:37 +01:00
elif status.startswith(_("Away")):
color = app.config.get('tooltip_status_away_color')
2016-11-13 21:06:37 +01:00
elif status.startswith(_("Busy")):
color = app.config.get('tooltip_status_busy_color')
2016-11-13 21:06:37 +01:00
elif status.startswith(_("Not Available")):
color = app.config.get('tooltip_status_na_color')
2016-11-13 21:06:37 +01:00
elif status.startswith(_("Offline")):
color = app.config.get('tooltip_status_offline_color')
2016-11-13 21:06:37 +01:00
if color:
status = formatted % (color, status)
2017-02-07 20:56:26 +01:00
return status