Groupchat: Use icons from IconTheme

This commit is contained in:
Philipp Hörist 2018-11-18 15:59:59 +01:00
parent acc89ad622
commit 619793a085
4 changed files with 104 additions and 103 deletions

View File

@ -1015,24 +1015,22 @@ class ChatControl(ChatControlBase):
['printed_' + self.type_id, self.type_id])) ['printed_' + self.type_id, self.type_id]))
else: else:
num_unread = 0 num_unread = 0
# Set tab image (always 16x16); unread messages show the 'event' image
tab_img = None transport = None
if app.jid_is_transport(jid):
transport = app.get_transport_name_from_jid(jid)
if num_unread and app.config.get('show_unread_tab_icon'): if num_unread and app.config.get('show_unread_tab_icon'):
img_16 = app.interface.roster.get_appropriate_state_images( icon_name = get_icon_name('event', transport=transport)
self.contact.jid, icon_name='event')
tab_img = img_16['event']
else: else:
contact = app.contacts.get_contact_with_highest_priority( contact = app.contacts.get_contact_with_highest_priority(
self.account, self.contact.jid) self.account, self.contact.jid)
if not contact or self.resource: if not contact or self.resource:
# For transient contacts # For transient contacts
contact = self.contact contact = self.contact
img_16 = app.interface.roster.get_appropriate_state_images( icon_name = get_icon_name(contact.show, transport=transport)
self.contact.jid, icon_name=contact.show)
tab_img = img_16[contact.show]
return tab_img return icon_name
def prepare_context_menu(self, hide_buttonbar_items=False): def prepare_context_menu(self, hide_buttonbar_items=False):
""" """

View File

@ -76,7 +76,7 @@ from gajim.gtk.tooltips import GCTooltip
from gajim.gtk.groupchat_config import GroupchatConfig from gajim.gtk.groupchat_config import GroupchatConfig
from gajim.gtk.adhoc_commands import CommandWindow from gajim.gtk.adhoc_commands import CommandWindow
from gajim.gtk.util import get_icon_name from gajim.gtk.util import get_icon_name
from gajim.gtk.util import get_image_from_icon_name from gajim.gtk.util import get_affiliation_surface
log = logging.getLogger('gajim.groupchat_control') log = logging.getLogger('gajim.groupchat_control')
@ -90,60 +90,6 @@ class Column(IntEnum):
AVATAR_IMG = 4 # avatar of the contact AVATAR_IMG = 4 # avatar of the contact
def cell_data_func(column, renderer, model, iter_, user_data):
# Background color has to be rendered for all cells
theme = app.config.get('roster_theme')
has_parent = bool(model.iter_parent(iter_))
if has_parent:
bgcolor = app.css_config.get_value('.gajim-contact-row', StyleAttr.BACKGROUND)
renderer.set_property('cell-background', bgcolor)
else:
bgcolor = app.css_config.get_value('.gajim-group-row', StyleAttr.BACKGROUND)
renderer.set_property('cell-background', bgcolor)
if user_data == 'status':
status_cell_data_func(column, renderer, model, iter_, has_parent)
elif user_data == 'name':
text_cell_data_func(column, renderer, model, iter_, has_parent, theme)
elif user_data == 'avatar':
avatar_cell_data_func(column, renderer, model, iter_, has_parent)
def status_cell_data_func(column, renderer, model, iter_, has_parent):
renderer.set_property('width', 26)
image = model[iter_][Column.IMG]
surface = image.get_property('surface')
renderer.set_property('surface', surface)
def avatar_cell_data_func(column, renderer, model, iter_, has_parent):
image = model[iter_][Column.AVATAR_IMG]
if image is None:
renderer.set_property('surface', None)
else:
surface = image.get_property('surface')
renderer.set_property('surface', surface)
renderer.set_property('xalign', 0.5)
if has_parent:
renderer.set_property('visible', True)
renderer.set_property('width', AvatarSize.ROSTER)
else:
renderer.set_property('visible', False)
def text_cell_data_func(column, renderer, model, iter_, has_parent, theme):
# cell data func is global, because we don't want it to keep
# reference to GroupchatControl instance (self)
if has_parent:
color = app.css_config.get_value('.gajim-contact-row', StyleAttr.COLOR)
renderer.set_property('foreground', color)
desc = app.css_config.get_font('.gajim-contact-row')
renderer.set_property('font-desc', desc)
else:
color = app.css_config.get_value('.gajim-group-row', StyleAttr.COLOR)
renderer.set_property('foreground', color)
desc = app.css_config.get_font('.gajim-group-row')
renderer.set_property('font-desc', desc)
class PrivateChatControl(ChatControl): class PrivateChatControl(ChatControl):
TYPE_ID = message_control.TYPE_PM TYPE_ID = message_control.TYPE_PM
@ -408,7 +354,7 @@ class GroupchatControl(ChatControlBase):
self._role_refs = {} self._role_refs = {}
#status_image, shown_nick, type, nickname, avatar #status_image, shown_nick, type, nickname, avatar
self.columns = [Gtk.Image, str, str, str, Gtk.Image] self.columns = [str, str, str, str, Gtk.Image]
self.model = Gtk.TreeStore(*self.columns) self.model = Gtk.TreeStore(*self.columns)
self.model.set_sort_func(Column.NICK, self.tree_compare_iters) self.model.set_sort_func(Column.NICK, self.tree_compare_iters)
@ -428,15 +374,15 @@ class GroupchatControl(ChatControlBase):
self.renderers_list += ( self.renderers_list += (
# status img # status img
('icon', Gtk.CellRendererPixbuf(), False, ('icon', Gtk.CellRendererPixbuf(), False,
None, Column.IMG, cell_data_func, 'status'), 'icon_name', Column.IMG, self._cell_data_func, 'status'),
# contact name # contact name
('name', renderer_text, True, ('name', renderer_text, True,
'markup', Column.TEXT, cell_data_func, 'name')) 'markup', Column.TEXT, self._cell_data_func, 'name'))
# avatar img # avatar img
avatar_renderer = ('avatar', Gtk.CellRendererPixbuf(), avatar_renderer = ('avatar', Gtk.CellRendererPixbuf(),
False, None, Column.AVATAR_IMG, False, None, Column.AVATAR_IMG,
cell_data_func, 'avatar') self._cell_data_func, 'avatar')
if app.config.get('avatar_position_in_roster') == 'right': if app.config.get('avatar_position_in_roster') == 'right':
self.renderers_list.append(avatar_renderer) self.renderers_list.append(avatar_renderer)
@ -654,6 +600,67 @@ class GroupchatControl(ChatControlBase):
has_mam = muc_caps_cache.has_mam(self.room_jid) has_mam = muc_caps_cache.has_mam(self.room_jid)
win.lookup_action('choose-sync-' + self.control_id).set_enabled(has_mam) win.lookup_action('choose-sync-' + self.control_id).set_enabled(has_mam)
def _cell_data_func(self, column, renderer, model, iter_, user_data):
# Background color has to be rendered for all cells
theme = app.config.get('roster_theme')
has_parent = bool(model.iter_parent(iter_))
if has_parent:
bgcolor = app.css_config.get_value('.gajim-contact-row', StyleAttr.BACKGROUND)
renderer.set_property('cell-background', bgcolor)
else:
bgcolor = app.css_config.get_value('.gajim-group-row', StyleAttr.BACKGROUND)
renderer.set_property('cell-background', bgcolor)
if user_data == 'status':
self._status_cell_data_func(column, renderer, model, iter_, has_parent)
elif user_data == 'name':
self._text_cell_data_func(column, renderer, model, iter_, has_parent, theme)
elif user_data == 'avatar':
self._avatar_cell_data_func(column, renderer, model, iter_, has_parent)
def _status_cell_data_func(self, column, renderer, model, iter_, has_parent):
renderer.set_property('width', 26)
icon_name = model[iter_][Column.IMG]
if ':' in icon_name:
icon_name, affiliation = icon_name.split(':')
surface = get_affiliation_surface(
icon_name, affiliation, self.scale_factor)
renderer.set_property('icon_name', None)
renderer.set_property('surface', surface)
else:
renderer.set_property('surface', None)
renderer.set_property('icon_name', icon_name)
def _avatar_cell_data_func(self, column, renderer, model, iter_, has_parent):
image = model[iter_][Column.AVATAR_IMG]
if image is None:
renderer.set_property('surface', None)
else:
surface = image.get_property('surface')
renderer.set_property('surface', surface)
renderer.set_property('xalign', 0.5)
if has_parent:
renderer.set_property('visible', True)
renderer.set_property('width', AvatarSize.ROSTER)
else:
renderer.set_property('visible', False)
def _text_cell_data_func(self, column, renderer, model, iter_, has_parent, theme):
# cell data func is global, because we don't want it to keep
# reference to GroupchatControl instance (self)
if has_parent:
color = app.css_config.get_value('.gajim-contact-row', StyleAttr.COLOR)
renderer.set_property('foreground', color)
desc = app.css_config.get_font('.gajim-contact-row')
renderer.set_property('font-desc', desc)
else:
color = app.css_config.get_value('.gajim-group-row', StyleAttr.COLOR)
renderer.set_property('foreground', color)
desc = app.css_config.get_font('.gajim-group-row')
renderer.set_property('font-desc', desc)
def _on_room_created(self): def _on_room_created(self):
if self.parent_win is None: if self.parent_win is None:
return return
@ -1318,11 +1325,11 @@ class GroupchatControl(ChatControlBase):
if not autopopup or (not autopopupaway and \ if not autopopup or (not autopopupaway and \
app.connections[self.account].connected > 2): app.connections[self.account].connected > 2):
if no_queue: # We didn't have a queue: we change icons if no_queue: # We didn't have a queue: we change icons
state_images = \ transport = None
app.interface.roster.get_appropriate_state_images( if app.jid_is_transport(self.room_jid):
self.room_jid, icon_name='event') transport = app.get_transport_name_from_jid(self.room_jid)
image = state_images['event'] self.model[iter_][Column.IMG] = get_icon_name(
self.model[iter_][Column.IMG] = image 'event', transport=transport)
if self.parent_win: if self.parent_win:
self.parent_win.show_title() self.parent_win.show_title()
self.parent_win.redraw_tab(self) self.parent_win.redraw_tab(self)
@ -1759,15 +1766,13 @@ class GroupchatControl(ChatControlBase):
iter_ = self.get_contact_iter(nick) iter_ = self.get_contact_iter(nick)
if not iter_: if not iter_:
return return
gc_contact = app.contacts.get_gc_contact(self.account, self.room_jid, gc_contact = app.contacts.get_gc_contact(
nick) self.account, self.room_jid, nick)
theme = Gtk.IconTheme.get_default()
if app.events.get_events(self.account, self.room_jid + '/' + nick): if app.events.get_events(self.account, self.room_jid + '/' + nick):
icon_name = get_icon_name('event') icon_name = get_icon_name('event')
surface = theme.load_surface(icon_name, 16, self.scale_factor, None, 0)
else: else:
icon_name = get_icon_name(gc_contact.show) icon_name = get_icon_name(gc_contact.show)
surface = theme.load_surface(icon_name, 16, self.scale_factor, None, 0)
name = GLib.markup_escape_text(gc_contact.name) name = GLib.markup_escape_text(gc_contact.name)
@ -1788,10 +1793,9 @@ class GroupchatControl(ChatControlBase):
if (gc_contact.affiliation != 'none' and if (gc_contact.affiliation != 'none' and
app.config.get('show_affiliation_in_groupchat')): app.config.get('show_affiliation_in_groupchat')):
gtkgui_helpers.draw_affiliation(surface, gc_contact.affiliation) icon_name += ':%s' % gc_contact.affiliation
image = Gtk.Image.new_from_surface(surface) self.model[iter_][Column.IMG] = icon_name
self.model[iter_][Column.IMG] = image
self.model[iter_][Column.TEXT] = name self.model[iter_][Column.TEXT] = name
def draw_avatar(self, gc_contact): def draw_avatar(self, gc_contact):
@ -2125,9 +2129,9 @@ class GroupchatControl(ChatControlBase):
# Create Role # Create Role
role_iter = self.get_role_iter(role) role_iter = self.get_role_iter(role)
if not role_iter: if not role_iter:
image = get_image_from_icon_name('closed', self.scale_factor) icon_name = get_icon_name('closed')
ext_columns = [None] * self.nb_ext_renderers ext_columns = [None] * self.nb_ext_renderers
row = [image, role, 'role', role_name, None] + ext_columns row = [icon_name, role, 'role', role_name, None] + ext_columns
role_iter = self.model.append(None, row) role_iter = self.model.append(None, row)
self._role_refs[role] = Gtk.TreeRowReference( self._role_refs[role] = Gtk.TreeRowReference(
self.model, self.model.get_path(role_iter)) self.model, self.model.get_path(role_iter))
@ -2142,7 +2146,7 @@ class GroupchatControl(ChatControlBase):
# Add to model # Add to model
ext_columns = [None] * self.nb_ext_renderers ext_columns = [None] * self.nb_ext_renderers
row = [image, nick, 'contact', name, None] + ext_columns row = [None, nick, 'contact', name, image] + ext_columns
iter_ = self.model.append(role_iter, row) iter_ = self.model.append(role_iter, row)
self._contact_refs[nick] = Gtk.TreeRowReference( self._contact_refs[nick] = Gtk.TreeRowReference(
self.model, self.model.get_path(iter_)) self.model, self.model.get_path(iter_))
@ -2591,16 +2595,14 @@ class GroupchatControl(ChatControlBase):
When a row is expanded: change the icon of the arrow When a row is expanded: change the icon of the arrow
""" """
model = widget.get_model() model = widget.get_model()
image = get_image_from_icon_name('opened', self.scale_factor) model[iter_][Column.IMG] = get_icon_name('opened')
model[iter_][Column.IMG] = image
def on_list_treeview_row_collapsed(self, widget, iter_, path): def on_list_treeview_row_collapsed(self, widget, iter_, path):
""" """
When a row is collapsed: change the icon of the arrow When a row is collapsed: change the icon of the arrow
""" """
model = widget.get_model() model = widget.get_model()
image = get_image_from_icon_name('closed', self.scale_factor) model[iter_][Column.IMG] = get_icon_name('closed')
model[iter_][Column.IMG] = image
def kick(self, widget, nick): def kick(self, widget, nick):
""" """

View File

@ -307,3 +307,19 @@ def get_metacontact_surface(icon_name, expanded, scale):
ctx.set_source_surface(expanded_surface) ctx.set_source_surface(expanded_surface)
ctx.fill() ctx.fill()
return state_surface return state_surface
def get_affiliation_surface(icon_name, affiliation, scale):
surface = _icon_theme.load_surface(
icon_name, 16, scale, None, 0)
ctx = cairo.Context(surface)
ctx.rectangle(16 - 4, 16 - 4, 4, 4)
if affiliation == 'owner':
ctx.set_source_rgb(204/255, 0, 0)
elif affiliation == 'admin':
ctx.set_source_rgb(255/255, 140/255, 0)
elif affiliation == 'member':
ctx.set_source_rgb(0, 255/255, 0)
ctx.fill()
return surface

View File

@ -554,21 +554,6 @@ def remove_css_class(widget, class_name):
style = widget.get_style_context() style = widget.get_style_context()
style.remove_class(class_name) style.remove_class(class_name)
def draw_affiliation(surface, affiliation):
icon_size = 16
size = 4 * 1
if affiliation not in ('owner', 'admin', 'member'):
return
ctx = cairo.Context(surface)
ctx.rectangle(icon_size-size, icon_size-size, size, size)
if affiliation == 'owner':
ctx.set_source_rgb(204/255, 0, 0)
elif affiliation == 'admin':
ctx.set_source_rgb(255/255, 140/255, 0)
elif affiliation == 'member':
ctx.set_source_rgb(0, 255/255, 0)
ctx.fill()
def pango_to_css_weight(number): def pango_to_css_weight(number):
# Pango allows for weight values between 100 and 1000 # Pango allows for weight values between 100 and 1000
# CSS allows only full hundred numbers like 100, 200 .. # CSS allows only full hundred numbers like 100, 200 ..