Escape markup in contact status and Resource

(Tooltip)
This commit is contained in:
Dimitur Kirov 2005-07-21 14:09:17 +00:00
parent fa69961f57
commit afb15500e0
1 changed files with 14 additions and 8 deletions

View File

@ -516,7 +516,6 @@ class RosterTooltip(gtk.Window):
self.connect('motion-notify-event', self.motion_notify_event) self.connect('motion-notify-event', self.motion_notify_event)
def motion_notify_event(self, widget, event): def motion_notify_event(self, widget, event):
self.hide_tooltip() self.hide_tooltip()
@ -579,10 +578,12 @@ class RosterTooltip(gtk.Window):
if os.path.exists(file): if os.path.exists(file):
image.set_from_file(file) image.set_from_file(file)
break break
image.set_alignment(0.01, 1)
self.table.attach(spacer, 1, 2, self.current_row, self.table.attach(spacer, 1, 2, self.current_row,
self.current_row + 1, 0, 0, 0, 0) self.current_row + 1, 0, 0, 0, 0)
self.table.attach(image,2,3,self.current_row, self.table.attach(image,2,3,self.current_row,
self.current_row + 1, 0, 0, 3, 0) self.current_row + 1, 0, 0, 3, 0)
image.set_alignment(0.01, 1)
str_status = resource + ' ('+str(priority)+')' str_status = resource + ' ('+str(priority)+')'
if status: if status:
status = status.strip() status = status.strip()
@ -592,7 +593,11 @@ class RosterTooltip(gtk.Window):
status_label.set_alignment(00, 0) status_label.set_alignment(00, 0)
self.table.attach(status_label, 3, 4, self.current_row, self.current_row + 1, self.table.attach(status_label, 3, 4, self.current_row, self.current_row + 1,
gtk.EXPAND | gtk.FILL, 0, 0, 0) gtk.EXPAND | gtk.FILL, 0, 0, 0)
def escape_entities(self, text):
# escapes markup entities
return text.replace('&', '&amp;').replace('>','&gt;').replace('<','&lt;')
def populate(self, contacts): def populate(self, contacts):
if not contacts or len(contacts) == 0: if not contacts or len(contacts) == 0:
return return
@ -639,9 +644,9 @@ class RosterTooltip(gtk.Window):
info = '<span size="large" weight="bold">' + prim_contact.jid + '</span>' info = '<span size="large" weight="bold">' + prim_contact.jid + '</span>'
info += '\n<span weight="bold">' + _('Name: ') + '</span>' + \ info += '\n<span weight="bold">' + _('Name: ') + '</span>' + \
prim_contact.name self.escape_entities(prim_contact.name)
info += '\n<span weight="bold">' + _('Subscription: ') + '</span>' + \ info += '\n<span weight="bold">' + _('Subscription: ') + '</span>' + \
prim_contact.sub self.escape_entities(prim_contact.sub)
if prim_contact.keyID: if prim_contact.keyID:
keyID = None keyID = None
@ -651,7 +656,7 @@ class RosterTooltip(gtk.Window):
keyID = prim_contact.keyID[8:] keyID = prim_contact.keyID[8:]
if keyID: if keyID:
info += '\n<span weight="bold">' + _('OpenPGP: ') + \ info += '\n<span weight="bold">' + _('OpenPGP: ') + \
'</span>' + keyID '</span>' + self.escape_entities(keyID )
single_line, resource_str, multiple_resource= '', '', False single_line, resource_str, multiple_resource= '', '', False
num_resources = 0 num_resources = 0
@ -670,15 +675,16 @@ class RosterTooltip(gtk.Window):
else: # only one resource else: # only one resource
if contact.resource: if contact.resource:
info += '\n<span weight="bold">' + _('Resource: ') + \ info += '\n<span weight="bold">' + _('Resource: ') + \
'</span>' + contact.resource + ' (' + str(contact.priority) + ')' '</span>' + self.escape_entities(contact.resource) + ' (' + str(contact.priority) + ')'
if contact.show: if contact.show:
info += '\n<span weight="bold">' + _('Status: ') + \ info += '\n<span weight="bold">' + _('Status: ') + \
'</span>' + helpers.get_uf_show(contact.show) '</span>' + helpers.get_uf_show(contact.show)
if contact.status: if contact.status:
status = contact.status.strip() status = contact.status.strip()
if status != '': if status != '':
info += ' - ' + status # escape markup entities. Is it posible to have markup in status?
info += ' - ' + self.escape_entities(status)
self.account.set_markup(info) self.account.set_markup(info)
class InputDialog: class InputDialog: