Groupchat: Use icons from IconTheme
This commit is contained in:
parent
acc89ad622
commit
619793a085
|
@ -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):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -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):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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 ..
|
||||||
|
|
Loading…
Reference in New Issue