URL detection just got better and fixes allover
This commit is contained in:
parent
9215059bc2
commit
b8ece6c041
|
@ -1369,7 +1369,7 @@ class Accounts_window:
|
||||||
renderer = gtk.CellRendererToggle()
|
renderer = gtk.CellRendererToggle()
|
||||||
renderer.set_property('activatable', True)
|
renderer.set_property('activatable', True)
|
||||||
renderer.connect('toggled', self.on_toggled, model)
|
renderer.connect('toggled', self.on_toggled, model)
|
||||||
self.accounts_treeview.insert_column_with_attributes(-1, _('Active'), \
|
self.accounts_treeview.insert_column_with_attributes(-1, _('Sync with global status'), \
|
||||||
renderer, active=2)
|
renderer, active=2)
|
||||||
self.xml.signal_autoconnect(self)
|
self.xml.signal_autoconnect(self)
|
||||||
self.init_accounts()
|
self.init_accounts()
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
<property name="spacing">0</property>
|
<property name="spacing">0</property>
|
||||||
|
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkMenuBar" id="menubar1">
|
<widget class="GtkMenuBar" id="menubar">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
|
|
||||||
<child>
|
<child>
|
||||||
|
@ -46,10 +46,9 @@
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="label" translatable="yes">_New Message</property>
|
<property name="label" translatable="yes">_New Message</property>
|
||||||
<property name="use_underline">True</property>
|
<property name="use_underline">True</property>
|
||||||
<accelerator key="N" modifiers="GDK_CONTROL_MASK" signal="activate"/>
|
|
||||||
|
|
||||||
<child internal-child="image">
|
<child internal-child="image">
|
||||||
<widget class="GtkImage" id="image424">
|
<widget class="GtkImage" id="image448">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="stock">gtk-new</property>
|
<property name="stock">gtk-new</property>
|
||||||
<property name="icon_size">1</property>
|
<property name="icon_size">1</property>
|
||||||
|
@ -69,7 +68,7 @@
|
||||||
<property name="use_underline">True</property>
|
<property name="use_underline">True</property>
|
||||||
|
|
||||||
<child internal-child="image">
|
<child internal-child="image">
|
||||||
<widget class="GtkImage" id="image425">
|
<widget class="GtkImage" id="image449">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="stock">gtk-connect</property>
|
<property name="stock">gtk-connect</property>
|
||||||
<property name="icon_size">1</property>
|
<property name="icon_size">1</property>
|
||||||
|
@ -91,11 +90,11 @@
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkImageMenuItem" id="add_contact_menuitem">
|
<widget class="GtkImageMenuItem" id="add_contact_menuitem">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="label" translatable="yes">Add Contact</property>
|
<property name="label" translatable="yes">Add _Contact</property>
|
||||||
<property name="use_underline">True</property>
|
<property name="use_underline">True</property>
|
||||||
|
|
||||||
<child internal-child="image">
|
<child internal-child="image">
|
||||||
<widget class="GtkImage" id="image426">
|
<widget class="GtkImage" id="image450">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="stock">gtk-add</property>
|
<property name="stock">gtk-add</property>
|
||||||
<property name="icon_size">1</property>
|
<property name="icon_size">1</property>
|
||||||
|
@ -111,7 +110,7 @@
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkCheckMenuItem" id="show_offline_contacts_menuitem">
|
<widget class="GtkCheckMenuItem" id="show_offline_contacts_menuitem">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="label" translatable="yes">Show Offline Contacts</property>
|
<property name="label" translatable="yes">Show _Offline Contacts</property>
|
||||||
<property name="use_underline">True</property>
|
<property name="use_underline">True</property>
|
||||||
<property name="active">False</property>
|
<property name="active">False</property>
|
||||||
<signal name="activate" handler="on_show_offline_contacts_menuitem_activate" last_modification_time="Tue, 01 Mar 2005 23:29:52 GMT"/>
|
<signal name="activate" handler="on_show_offline_contacts_menuitem_activate" last_modification_time="Tue, 01 Mar 2005 23:29:52 GMT"/>
|
||||||
|
@ -134,7 +133,7 @@
|
||||||
<accelerator key="Q" modifiers="GDK_CONTROL_MASK" signal="activate"/>
|
<accelerator key="Q" modifiers="GDK_CONTROL_MASK" signal="activate"/>
|
||||||
|
|
||||||
<child internal-child="image">
|
<child internal-child="image">
|
||||||
<widget class="GtkImage" id="image427">
|
<widget class="GtkImage" id="image451">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="stock">gtk-quit</property>
|
<property name="stock">gtk-quit</property>
|
||||||
<property name="icon_size">1</property>
|
<property name="icon_size">1</property>
|
||||||
|
@ -169,7 +168,7 @@
|
||||||
<accelerator key="A" modifiers="GDK_CONTROL_MASK" signal="activate"/>
|
<accelerator key="A" modifiers="GDK_CONTROL_MASK" signal="activate"/>
|
||||||
|
|
||||||
<child internal-child="image">
|
<child internal-child="image">
|
||||||
<widget class="GtkImage" id="image428">
|
<widget class="GtkImage" id="image452">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="stock">gtk-select-color</property>
|
<property name="stock">gtk-select-color</property>
|
||||||
<property name="icon_size">1</property>
|
<property name="icon_size">1</property>
|
||||||
|
@ -189,7 +188,7 @@
|
||||||
<property name="use_underline">True</property>
|
<property name="use_underline">True</property>
|
||||||
|
|
||||||
<child internal-child="image">
|
<child internal-child="image">
|
||||||
<widget class="GtkImage" id="image429">
|
<widget class="GtkImage" id="image453">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="stock">gtk-find</property>
|
<property name="stock">gtk-find</property>
|
||||||
<property name="icon_size">1</property>
|
<property name="icon_size">1</property>
|
||||||
|
@ -217,7 +216,7 @@
|
||||||
<accelerator key="P" modifiers="GDK_CONTROL_MASK" signal="activate"/>
|
<accelerator key="P" modifiers="GDK_CONTROL_MASK" signal="activate"/>
|
||||||
|
|
||||||
<child internal-child="image">
|
<child internal-child="image">
|
||||||
<widget class="GtkImage" id="image430">
|
<widget class="GtkImage" id="image454">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="stock">gtk-preferences</property>
|
<property name="stock">gtk-preferences</property>
|
||||||
<property name="icon_size">1</property>
|
<property name="icon_size">1</property>
|
||||||
|
@ -251,7 +250,7 @@
|
||||||
<signal name="activate" handler="on_about_menuitem_activate" last_modification_time="Tue, 01 Mar 2005 22:56:45 GMT"/>
|
<signal name="activate" handler="on_about_menuitem_activate" last_modification_time="Tue, 01 Mar 2005 22:56:45 GMT"/>
|
||||||
|
|
||||||
<child internal-child="image">
|
<child internal-child="image">
|
||||||
<widget class="GtkImage" id="image431">
|
<widget class="GtkImage" id="image455">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="stock">gtk-about</property>
|
<property name="stock">gtk-about</property>
|
||||||
<property name="icon_size">1</property>
|
<property name="icon_size">1</property>
|
||||||
|
@ -317,13 +316,14 @@
|
||||||
|
|
||||||
<widget class="GtkWindow" id="accounts_window">
|
<widget class="GtkWindow" id="accounts_window">
|
||||||
<property name="border_width">4</property>
|
<property name="border_width">4</property>
|
||||||
|
<property name="width_request">500</property>
|
||||||
<property name="height_request">200</property>
|
<property name="height_request">200</property>
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="title" translatable="yes">Accounts</property>
|
<property name="title" translatable="yes">Accounts</property>
|
||||||
<property name="type">GTK_WINDOW_TOPLEVEL</property>
|
<property name="type">GTK_WINDOW_TOPLEVEL</property>
|
||||||
<property name="window_position">GTK_WIN_POS_NONE</property>
|
<property name="window_position">GTK_WIN_POS_NONE</property>
|
||||||
<property name="modal">False</property>
|
<property name="modal">False</property>
|
||||||
<property name="resizable">False</property>
|
<property name="resizable">True</property>
|
||||||
<property name="destroy_with_parent">False</property>
|
<property name="destroy_with_parent">False</property>
|
||||||
<property name="decorated">True</property>
|
<property name="decorated">True</property>
|
||||||
<property name="skip_taskbar_hint">False</property>
|
<property name="skip_taskbar_hint">False</property>
|
||||||
|
@ -652,7 +652,7 @@ Alex Podaras (bigpod@gmail.com)</property>
|
||||||
<property name="type">GTK_WINDOW_TOPLEVEL</property>
|
<property name="type">GTK_WINDOW_TOPLEVEL</property>
|
||||||
<property name="window_position">GTK_WIN_POS_NONE</property>
|
<property name="window_position">GTK_WIN_POS_NONE</property>
|
||||||
<property name="modal">False</property>
|
<property name="modal">False</property>
|
||||||
<property name="resizable">False</property>
|
<property name="resizable">True</property>
|
||||||
<property name="destroy_with_parent">False</property>
|
<property name="destroy_with_parent">False</property>
|
||||||
<property name="decorated">True</property>
|
<property name="decorated">True</property>
|
||||||
<property name="skip_taskbar_hint">False</property>
|
<property name="skip_taskbar_hint">False</property>
|
||||||
|
@ -2572,7 +2572,7 @@ on the server as a vCard</property>
|
||||||
<property name="type">GTK_WINDOW_TOPLEVEL</property>
|
<property name="type">GTK_WINDOW_TOPLEVEL</property>
|
||||||
<property name="window_position">GTK_WIN_POS_NONE</property>
|
<property name="window_position">GTK_WIN_POS_NONE</property>
|
||||||
<property name="modal">False</property>
|
<property name="modal">False</property>
|
||||||
<property name="resizable">False</property>
|
<property name="resizable">True</property>
|
||||||
<property name="destroy_with_parent">False</property>
|
<property name="destroy_with_parent">False</property>
|
||||||
<property name="decorated">True</property>
|
<property name="decorated">True</property>
|
||||||
<property name="skip_taskbar_hint">False</property>
|
<property name="skip_taskbar_hint">False</property>
|
||||||
|
@ -6869,6 +6869,15 @@ Custom</property>
|
||||||
</packing>
|
</packing>
|
||||||
</child>
|
</child>
|
||||||
|
|
||||||
|
<child>
|
||||||
|
<widget class="GtkScrolledWindow" id="scrolledwindow33">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">True</property>
|
||||||
|
<property name="hscrollbar_policy">GTK_POLICY_AUTOMATIC</property>
|
||||||
|
<property name="vscrollbar_policy">GTK_POLICY_AUTOMATIC</property>
|
||||||
|
<property name="shadow_type">GTK_SHADOW_NONE</property>
|
||||||
|
<property name="window_placement">GTK_CORNER_TOP_LEFT</property>
|
||||||
|
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkTextView" id="DESC_textview">
|
<widget class="GtkTextView" id="DESC_textview">
|
||||||
<property name="border_width">5</property>
|
<property name="border_width">5</property>
|
||||||
|
@ -6888,6 +6897,8 @@ Custom</property>
|
||||||
<property name="indent">0</property>
|
<property name="indent">0</property>
|
||||||
<property name="text" translatable="yes"></property>
|
<property name="text" translatable="yes"></property>
|
||||||
</widget>
|
</widget>
|
||||||
|
</child>
|
||||||
|
</widget>
|
||||||
<packing>
|
<packing>
|
||||||
<property name="tab_expand">False</property>
|
<property name="tab_expand">False</property>
|
||||||
<property name="tab_fill">True</property>
|
<property name="tab_fill">True</property>
|
||||||
|
|
|
@ -49,7 +49,6 @@ def usage():
|
||||||
print " -h, --help\tdisplay this help and exit"
|
print " -h, --help\tdisplay this help and exit"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
GTKGUI_GLADE='plugins/gtkgui/gtkgui.glade'
|
GTKGUI_GLADE='plugins/gtkgui/gtkgui.glade'
|
||||||
|
|
||||||
class ImageCellRenderer(gtk.GenericCellRenderer):
|
class ImageCellRenderer(gtk.GenericCellRenderer):
|
||||||
|
@ -413,38 +412,30 @@ class tabbed_chat_window:
|
||||||
self.tagStatus[user.jid] = conversation_buffer.create_tag('status')
|
self.tagStatus[user.jid] = conversation_buffer.create_tag('status')
|
||||||
color = self.plugin.config['statusmsgcolor']
|
color = self.plugin.config['statusmsgcolor']
|
||||||
self.tagStatus[user.jid].set_property('foreground', color)
|
self.tagStatus[user.jid].set_property('foreground', color)
|
||||||
|
|
||||||
tag = conversation_buffer.create_tag('time_sometimes')
|
tag = conversation_buffer.create_tag('time_sometimes')
|
||||||
tag.set_property('foreground', '#9e9e9e')
|
tag.set_property('foreground', '#9e9e9e')
|
||||||
tag.set_property('scale', pango.SCALE_SMALL)
|
tag.set_property('scale', pango.SCALE_SMALL)
|
||||||
tag.set_property('justification', gtk.JUSTIFY_CENTER)
|
tag.set_property('justification', gtk.JUSTIFY_CENTER)
|
||||||
|
|
||||||
for way in ['status', 'incoming', 'outgoing']:
|
tag = conversation_buffer.create_tag('url')
|
||||||
for special in ['mail', 'italic', 'underline', 'bold', 'url']:
|
|
||||||
tag = conversation_buffer.create_tag(way + '_' + special)
|
|
||||||
if way == 'status':
|
|
||||||
color = self.plugin.config['statusmsgcolor']
|
|
||||||
tag.set_property('foreground', color)
|
|
||||||
elif way == 'incoming':
|
|
||||||
color = self.plugin.config['inmsgcolor']
|
|
||||||
tag.set_property('foreground', color)
|
|
||||||
elif way == 'outgoing':
|
|
||||||
color = self.plugin.config['outmsgcolor']
|
|
||||||
tag.set_property('foreground', color)
|
|
||||||
if special == 'mail':
|
|
||||||
tag.set_property('foreground', '#0000ff')
|
|
||||||
tag.set_property('underline', pango.UNDERLINE_SINGLE)
|
|
||||||
tag.connect('event', self.hyperlink_handler, 'mail')
|
|
||||||
elif special == 'url':
|
|
||||||
tag.set_property('foreground', '#0000ff')
|
tag.set_property('foreground', '#0000ff')
|
||||||
tag.set_property('underline', pango.UNDERLINE_SINGLE)
|
tag.set_property('underline', pango.UNDERLINE_SINGLE)
|
||||||
tag.connect('event', self.hyperlink_handler, 'url')
|
tag.connect('event', self.hyperlink_handler, 'url')
|
||||||
elif special == 'italic':
|
|
||||||
tag.set_property('style', pango.STYLE_ITALIC)
|
tag = conversation_buffer.create_tag('mail')
|
||||||
elif special == 'underline':
|
tag.set_property('foreground', '#0000ff')
|
||||||
tag.set_property('underline', pango.UNDERLINE_SINGLE)
|
tag.set_property('underline', pango.UNDERLINE_SINGLE)
|
||||||
elif special == 'bold':
|
tag.connect('event', self.hyperlink_handler, 'mail')
|
||||||
|
|
||||||
|
tag = conversation_buffer.create_tag('bold')
|
||||||
tag.set_property('weight', pango.WEIGHT_BOLD)
|
tag.set_property('weight', pango.WEIGHT_BOLD)
|
||||||
link_tag = conversation_buffer.create_tag('hyperlink', foreground='blue')
|
|
||||||
|
tag = conversation_buffer.create_tag('italic')
|
||||||
|
tag.set_property('style', pango.STYLE_ITALIC)
|
||||||
|
|
||||||
|
tag = conversation_buffer.create_tag('underline')
|
||||||
|
tag.set_property('underline', pango.UNDERLINE_SINGLE)
|
||||||
|
|
||||||
self.xmls[user.jid].signal_autoconnect(self)
|
self.xmls[user.jid].signal_autoconnect(self)
|
||||||
conversation_scrolledwindow = self.xmls[user.jid].\
|
conversation_scrolledwindow = self.xmls[user.jid].\
|
||||||
|
@ -622,78 +613,39 @@ class tabbed_chat_window:
|
||||||
#we launch the correct application
|
#we launch the correct application
|
||||||
self.plugin.launch_browser_mailer(type, word)
|
self.plugin.launch_browser_mailer(type, word)
|
||||||
|
|
||||||
def print_special_word(self, word, jid, contact = ''):
|
def print_special_text(self, text, jid, contact = ''):
|
||||||
conversation_textview = self.xmls[jid].get_widget('conversation_textview')
|
conversation_textview = self.xmls[jid].get_widget('conversation_textview')
|
||||||
conversation_buffer = conversation_textview.get_buffer()
|
conversation_buffer = conversation_textview.get_buffer()
|
||||||
|
|
||||||
if contact == 'status':
|
if text in self.plugin.emoticons.keys():
|
||||||
tag = 'status'
|
|
||||||
else:
|
|
||||||
if contact:
|
|
||||||
tag = 'outgoing'
|
|
||||||
else:
|
|
||||||
tag = 'incoming'
|
|
||||||
if word in self.plugin.emoticons.keys():
|
|
||||||
#it's a smiley
|
#it's a smiley
|
||||||
end_iter = conversation_buffer.get_end_iter()
|
end_iter = conversation_buffer.get_end_iter()
|
||||||
conversation_buffer.insert_pixbuf(end_iter, self.plugin.emoticons[word])
|
conversation_buffer.insert_pixbuf(end_iter, self.plugin.emoticons[text])
|
||||||
return
|
return
|
||||||
elif word.startswith('mailto:'):
|
elif text.startswith('mailto:'):
|
||||||
#it's a mail
|
#it's a mail
|
||||||
if len(word) > 7:
|
tag = 'mail'
|
||||||
tag += '_mail'
|
elif self.plugin.sth_at_sth_dot_sth_re.match(text): # returns match object or None
|
||||||
text = word[7:]
|
#it's a mail
|
||||||
else:
|
tag = 'mail'
|
||||||
text = word
|
elif text.startswith('*') and text.endswith('*'):
|
||||||
tag = None
|
|
||||||
elif self.plugin.sth_at_sth_dot_sth_re.match(word): # returns match object or None
|
|
||||||
#it's a mail too
|
|
||||||
tag += '_mail'
|
|
||||||
text = word
|
|
||||||
elif word.startswith('/') and word.endswith('/'):
|
|
||||||
#it's an italic text
|
|
||||||
tag += '_italic'
|
|
||||||
text = word[1:-1]
|
|
||||||
elif word.startswith('_') and word.endswith('_'):
|
|
||||||
#it's an underlined text
|
|
||||||
tag += '_underline'
|
|
||||||
text = word[1:-1]
|
|
||||||
elif word.startswith('*') and word.endswith('*'):
|
|
||||||
#it's a bold text
|
#it's a bold text
|
||||||
tag += '_bold'
|
tag = 'bold'
|
||||||
text = word[1:-1]
|
text = text[1:-1] # remove * *
|
||||||
|
elif text.startswith('/') and text.endswith('/'):
|
||||||
|
#it's an italic text
|
||||||
|
tag = 'italic'
|
||||||
|
text = text[1:-1] # remove / /
|
||||||
|
elif text.startswith('_') and text.endswith('_'):
|
||||||
|
#it's an underlined text
|
||||||
|
tag = 'underline'
|
||||||
|
text = text[1:-1] # remove _ _
|
||||||
else:
|
else:
|
||||||
#it's an url
|
#it's a url
|
||||||
if word.startswith('ftp://'):
|
tag = 'url'
|
||||||
if len(word) > 6:
|
|
||||||
text = word[6:]
|
|
||||||
tag += '_url'
|
|
||||||
else:
|
|
||||||
text = word
|
|
||||||
tag = None
|
|
||||||
elif word.startswith('http://') or word.startswith('news://'):
|
|
||||||
if len(word) > 7:
|
|
||||||
text = word[7:]
|
|
||||||
tag += '_url'
|
|
||||||
else:
|
|
||||||
text = word
|
|
||||||
tag = None
|
|
||||||
elif word.startswith('https://'):
|
|
||||||
if len(word) > 8:
|
|
||||||
text = word[8:]
|
|
||||||
tag += '_url'
|
|
||||||
else:
|
|
||||||
text = word
|
|
||||||
tag = None
|
|
||||||
else:
|
|
||||||
tag += '_url'
|
|
||||||
text = word
|
|
||||||
|
|
||||||
end_iter = conversation_buffer.get_end_iter()
|
end_iter = conversation_buffer.get_end_iter()
|
||||||
if tag:
|
|
||||||
conversation_buffer.insert_with_tags_by_name(end_iter, text, tag)
|
conversation_buffer.insert_with_tags_by_name(end_iter, text, tag)
|
||||||
else:
|
|
||||||
conversation_buffer.insert(end_iter, text)
|
|
||||||
|
|
||||||
def print_conversation(self, text, jid, contact = '', tim = None):
|
def print_conversation(self, text, jid, contact = '', tim = None):
|
||||||
"""Print a line in the conversation :
|
"""Print a line in the conversation :
|
||||||
|
@ -739,19 +691,19 @@ class tabbed_chat_window:
|
||||||
index = 0
|
index = 0
|
||||||
|
|
||||||
if self.plugin.config['useemoticons']: # search for emoticons & urls
|
if self.plugin.config['useemoticons']: # search for emoticons & urls
|
||||||
my_re = sre.compile(self.plugin.emot_and_url_pattern, sre.IGNORECASE)
|
my_re = sre.compile(self.plugin.emot_and_formatting_url_pattern, sre.IGNORECASE)
|
||||||
iterator = my_re.finditer(otext)
|
iterator = my_re.finditer(otext)
|
||||||
else: # search for just urls
|
else: # search for just urls
|
||||||
my_re = sre.compile(self.plugin.url_pattern, sre.IGNORECASE)
|
my_re = sre.compile(self.plugin.formatting_url_pattern, sre.IGNORECASE)
|
||||||
iterator = my_re.finditer(otext)
|
iterator = my_re.finditer(otext)
|
||||||
for match in iterator:
|
for match in iterator:
|
||||||
start, end = match.span()
|
start, end = match.span()
|
||||||
special_word = otext[start:end]
|
special_text = otext[start:end]
|
||||||
if start != 0:
|
if start != 0:
|
||||||
text_before_special_word = otext[index:start]
|
text_before_special_text = otext[index:start]
|
||||||
end_iter = conversation_buffer.get_end_iter()
|
end_iter = conversation_buffer.get_end_iter()
|
||||||
conversation_buffer.insert(end_iter, text_before_special_word)
|
conversation_buffer.insert(end_iter, text_before_special_text)
|
||||||
self.print_special_word(special_word, jid, contact)
|
self.print_special_text(special_text, jid, contact)
|
||||||
index = end # update index
|
index = end # update index
|
||||||
|
|
||||||
#add the rest in the index and after
|
#add the rest in the index and after
|
||||||
|
@ -1180,47 +1132,47 @@ class Groupchat_window:
|
||||||
item = gtk.MenuItem(_('Privileges'))
|
item = gtk.MenuItem(_('Privileges'))
|
||||||
menu.append(item)
|
menu.append(item)
|
||||||
|
|
||||||
menu_sub = gtk.Menu()
|
sub_menu = gtk.Menu()
|
||||||
item.set_submenu(menu_sub)
|
item.set_submenu(sub_menu)
|
||||||
item = gtk.MenuItem(_('Kick'))
|
item = gtk.MenuItem(_('Kick'))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect('activate', self.kick, room_jid, nick)
|
item.connect('activate', self.kick, room_jid, nick)
|
||||||
item = gtk.MenuItem(_('Grant voice'))
|
item = gtk.MenuItem(_('Grant voice'))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect('activate', self.grant_voice, room_jid, nick)
|
item.connect('activate', self.grant_voice, room_jid, nick)
|
||||||
item = gtk.MenuItem(_('Revoke voice'))
|
item = gtk.MenuItem(_('Revoke voice'))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect('activate', self.revoke_voice, room_jid, nick)
|
item.connect('activate', self.revoke_voice, room_jid, nick)
|
||||||
item = gtk.MenuItem(_('Grant moderator'))
|
item = gtk.MenuItem(_('Grant moderator'))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect('activate', self.grant_moderator, room_jid, nick)
|
item.connect('activate', self.grant_moderator, room_jid, nick)
|
||||||
item = gtk.MenuItem(_('Revoke moderator'))
|
item = gtk.MenuItem(_('Revoke moderator'))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect('activate', self.revoke_moderator, room_jid, nick)
|
item.connect('activate', self.revoke_moderator, room_jid, nick)
|
||||||
if jid:
|
if jid:
|
||||||
item = gtk.MenuItem()
|
item = gtk.MenuItem()
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
|
|
||||||
item = gtk.MenuItem(_('Ban'))
|
item = gtk.MenuItem(_('Ban'))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect('activate', self.ban, room_jid, jid)
|
item.connect('activate', self.ban, room_jid, jid)
|
||||||
item = gtk.MenuItem(_('Grant membership'))
|
item = gtk.MenuItem(_('Grant membership'))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect('activate', self.grant_membership, room_jid, jid)
|
item.connect('activate', self.grant_membership, room_jid, jid)
|
||||||
item = gtk.MenuItem(_('Revoke membership'))
|
item = gtk.MenuItem(_('Revoke membership'))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect('activate', self.revoke_membership, room_jid, jid)
|
item.connect('activate', self.revoke_membership, room_jid, jid)
|
||||||
item = gtk.MenuItem(_('Grant admin'))
|
item = gtk.MenuItem(_('Grant admin'))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect('activate', self.grant_admin, room_jid, jid)
|
item.connect('activate', self.grant_admin, room_jid, jid)
|
||||||
item = gtk.MenuItem(_('Revoke admin'))
|
item = gtk.MenuItem(_('Revoke admin'))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect('activate', self.revoke_admin, room_jid, jid)
|
item.connect('activate', self.revoke_admin, room_jid, jid)
|
||||||
item = gtk.MenuItem(_('Grant owner'))
|
item = gtk.MenuItem(_('Grant owner'))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect('activate', self.grant_owner, room_jid, jid)
|
item.connect('activate', self.grant_owner, room_jid, jid)
|
||||||
item = gtk.MenuItem(_('Revoke owner'))
|
item = gtk.MenuItem(_('Revoke owner'))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect('activate', self.revoke_owner, room_jid, jid)
|
item.connect('activate', self.revoke_owner, room_jid, jid)
|
||||||
|
|
||||||
item = gtk.MenuItem()
|
item = gtk.MenuItem()
|
||||||
|
@ -1325,6 +1277,7 @@ class Groupchat_window:
|
||||||
end_iter = conversation_buffer.get_end_iter()
|
end_iter = conversation_buffer.get_end_iter()
|
||||||
conversation_buffer.create_mark('end', end_iter, 0)
|
conversation_buffer.create_mark('end', end_iter, 0)
|
||||||
self.tagIn[room_jid] = conversation_buffer.create_tag('incoming')
|
self.tagIn[room_jid] = conversation_buffer.create_tag('incoming')
|
||||||
|
# (nk) what is this?
|
||||||
self.tagInBold[room_jid] = conversation_buffer.create_tag('incoming_bold')
|
self.tagInBold[room_jid] = conversation_buffer.create_tag('incoming_bold')
|
||||||
color = self.plugin.config['inmsgcolor']
|
color = self.plugin.config['inmsgcolor']
|
||||||
self.tagIn[room_jid].set_property('foreground', color)
|
self.tagIn[room_jid].set_property('foreground', color)
|
||||||
|
@ -1734,37 +1687,37 @@ class roster_window:
|
||||||
browse_agents_menuitem.set_sensitive(False)
|
browse_agents_menuitem.set_sensitive(False)
|
||||||
if len(self.plugin.accounts.keys()) > 1: # 2 or more accounts? make submenus
|
if len(self.plugin.accounts.keys()) > 1: # 2 or more accounts? make submenus
|
||||||
#add
|
#add
|
||||||
menu_sub = gtk.Menu()
|
sub_menu = gtk.Menu()
|
||||||
add_contact_menuitem.set_submenu(menu_sub)
|
add_contact_menuitem.set_submenu(sub_menu)
|
||||||
for account in self.plugin.accounts.keys():
|
for account in self.plugin.accounts.keys():
|
||||||
item = gtk.MenuItem('using ' + account + ' account')
|
item = gtk.MenuItem('using ' + account + ' account')
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.on_add_contact, account)
|
item.connect("activate", self.on_add_contact, account)
|
||||||
menu_sub.show_all()
|
sub_menu.show_all()
|
||||||
#agents
|
#agents
|
||||||
menu_sub = gtk.Menu()
|
sub_menu = gtk.Menu()
|
||||||
browse_agents_menuitem.set_submenu(menu_sub)
|
browse_agents_menuitem.set_submenu(sub_menu)
|
||||||
for account in self.plugin.accounts.keys():
|
for account in self.plugin.accounts.keys():
|
||||||
item = gtk.MenuItem('using ' + account + ' account')
|
item = gtk.MenuItem('using ' + account + ' account')
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.on_browse_agents, account)
|
item.connect("activate", self.on_browse_agents, account)
|
||||||
menu_sub.show_all()
|
sub_menu.show_all()
|
||||||
#join gc
|
#join gc
|
||||||
menu_sub = gtk.Menu()
|
sub_menu = gtk.Menu()
|
||||||
join_gc_menuitem.set_submenu(menu_sub)
|
join_gc_menuitem.set_submenu(sub_menu)
|
||||||
for account in self.plugin.accounts.keys():
|
for account in self.plugin.accounts.keys():
|
||||||
item = gtk.MenuItem('using ' + account + ' account')
|
item = gtk.MenuItem('using ' + account + ' account')
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.on_join_gc, account)
|
item.connect("activate", self.on_join_gc, account)
|
||||||
menu_sub.show_all()
|
sub_menu.show_all()
|
||||||
#new message
|
#new message
|
||||||
menu_sub = gtk.Menu()
|
sub_menu = gtk.Menu()
|
||||||
new_message_menuitem.set_submenu(menu_sub)
|
new_message_menuitem.set_submenu(sub_menu)
|
||||||
for account in self.plugin.accounts.keys():
|
for account in self.plugin.accounts.keys():
|
||||||
item = gtk.MenuItem('using ' + account + ' account')
|
item = gtk.MenuItem('using ' + account + ' account')
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.on_new_message_menuitem_activate, account)
|
item.connect("activate", self.on_new_message_menuitem_activate, account)
|
||||||
menu_sub.show_all()
|
sub_menu.show_all()
|
||||||
elif len(self.plugin.accounts.keys()) == 1:
|
elif len(self.plugin.accounts.keys()) == 1:
|
||||||
#add
|
#add
|
||||||
if not self.add_contact_handler_id:
|
if not self.add_contact_handler_id:
|
||||||
|
@ -1922,13 +1875,13 @@ class roster_window:
|
||||||
item = gtk.MenuItem(_("Subscription"))
|
item = gtk.MenuItem(_("Subscription"))
|
||||||
menu.append(item)
|
menu.append(item)
|
||||||
|
|
||||||
menu_sub = gtk.Menu()
|
sub_menu = gtk.Menu()
|
||||||
item.set_submenu(menu_sub)
|
item.set_submenu(sub_menu)
|
||||||
item = gtk.MenuItem(_("Resend authorization to"))
|
item = gtk.MenuItem(_("Resend authorization to"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.authorize, jid, account)
|
item.connect("activate", self.authorize, jid, account)
|
||||||
item = gtk.MenuItem(_("Rerequest authorization from"))
|
item = gtk.MenuItem(_("Rerequest authorization from"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.req_sub, jid, \
|
item.connect("activate", self.req_sub, jid, \
|
||||||
_('I would like to add you to my contact list, please.'), account)
|
_('I would like to add you to my contact list, please.'), account)
|
||||||
|
|
||||||
|
@ -2013,27 +1966,27 @@ class roster_window:
|
||||||
item = gtk.MenuItem(_("Status"))
|
item = gtk.MenuItem(_("Status"))
|
||||||
menu.append(item)
|
menu.append(item)
|
||||||
|
|
||||||
menu_sub = gtk.Menu()
|
sub_menu = gtk.Menu()
|
||||||
item.set_submenu(menu_sub)
|
item.set_submenu(sub_menu)
|
||||||
item = gtk.MenuItem(_("Online"))
|
item = gtk.MenuItem(_("Online"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.change_status, account, 'online')
|
item.connect("activate", self.change_status, account, 'online')
|
||||||
item = gtk.MenuItem(_("Away"))
|
item = gtk.MenuItem(_("Away"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.change_status, account, 'away')
|
item.connect("activate", self.change_status, account, 'away')
|
||||||
item = gtk.MenuItem(_("NA"))
|
item = gtk.MenuItem(_("NA"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.change_status, account, 'xa')
|
item.connect("activate", self.change_status, account, 'xa')
|
||||||
item = gtk.MenuItem(_("DND"))
|
item = gtk.MenuItem(_("DND"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.change_status, account, 'dnd')
|
item.connect("activate", self.change_status, account, 'dnd')
|
||||||
item = gtk.MenuItem(_("Invisible"))
|
item = gtk.MenuItem(_("Invisible"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.change_status, account, 'invisible')
|
item.connect("activate", self.change_status, account, 'invisible')
|
||||||
item = gtk.MenuItem()
|
item = gtk.MenuItem()
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item = gtk.MenuItem(_("Offline"))
|
item = gtk.MenuItem(_("Offline"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.change_status, account, 'offline')
|
item.connect("activate", self.change_status, account, 'offline')
|
||||||
|
|
||||||
item = gtk.MenuItem()
|
item = gtk.MenuItem()
|
||||||
|
@ -2862,27 +2815,27 @@ class systray:
|
||||||
|
|
||||||
item = gtk.MenuItem(_("Status"))
|
item = gtk.MenuItem(_("Status"))
|
||||||
menu.append(item)
|
menu.append(item)
|
||||||
menu_sub = gtk.Menu()
|
sub_menu = gtk.Menu()
|
||||||
item.set_submenu(menu_sub)
|
item.set_submenu(sub_menu)
|
||||||
item = gtk.MenuItem(_("Online"))
|
item = gtk.MenuItem(_("Online"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.set_cb, 'online')
|
item.connect("activate", self.set_cb, 'online')
|
||||||
item = gtk.MenuItem(_("Away"))
|
item = gtk.MenuItem(_("Away"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.set_cb, 'away')
|
item.connect("activate", self.set_cb, 'away')
|
||||||
item = gtk.MenuItem(_("NA"))
|
item = gtk.MenuItem(_("NA"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.set_cb, 'xa')
|
item.connect("activate", self.set_cb, 'xa')
|
||||||
item = gtk.MenuItem(_("DND"))
|
item = gtk.MenuItem(_("DND"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.set_cb, 'dnd')
|
item.connect("activate", self.set_cb, 'dnd')
|
||||||
item = gtk.MenuItem(_("Invisible"))
|
item = gtk.MenuItem(_("Invisible"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.set_cb, 'invisible')
|
item.connect("activate", self.set_cb, 'invisible')
|
||||||
item = gtk.MenuItem()
|
item = gtk.MenuItem()
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item = gtk.MenuItem(_("Offline"))
|
item = gtk.MenuItem(_("Offline"))
|
||||||
menu_sub.append(item)
|
sub_menu.append(item)
|
||||||
item.connect("activate", self.set_cb, 'offline')
|
item.connect("activate", self.set_cb, 'offline')
|
||||||
|
|
||||||
item = gtk.MenuItem()
|
item = gtk.MenuItem()
|
||||||
|
@ -3596,8 +3549,8 @@ class plugin:
|
||||||
# + means 1 or more times
|
# + means 1 or more times
|
||||||
# | means or
|
# | means or
|
||||||
# [^*] anything but * (inside [] you don't have to escape metachars)
|
# [^*] anything but * (inside [] you don't have to escape metachars)
|
||||||
# url_pattern is one string literal. I've put spaces to make the regexp look better
|
# formatting_url_pattern is one string literal. I've put spaces to make the regexp look better
|
||||||
self.url_pattern = r'http://\S*|' 'https://\S*|' 'news://\S*|' 'ftp://\S*|' 'mailto:\S*|' 'ed2k://\S*|' 'www\.\S*|' 'ftp\.\S*|' '\*\w+[^*]*\w+\*|' '/\w+[^/]*\w+/|' '_\w+[^_]*\w+_|' '\w+[^\s]*@\w+\.\w+'
|
self.formatting_url_pattern = r'http://\w+\S*|' 'https://\w+\S*|' 'news://\w+\S*|' 'ftp://\w+\S*|' 'mailto:\w+\S*|' 'ed2k://\w+\S*|' 'www\.\w+\S*|' 'ftp\.\w+\S*|' '\*\w+[^*]*\w+\*|' '/\w+[^/]*\w+/|' '_\w+[^_]*\w+_|' '\w+[^\s]*@\w+\.\w+'
|
||||||
|
|
||||||
# at least one letter in 3 parts (before @, after @, after .)
|
# at least one letter in 3 parts (before @, after @, after .)
|
||||||
self.sth_at_sth_dot_sth_re = sre.compile(r'\w+[^\s]*@\w+\.\w+')
|
self.sth_at_sth_dot_sth_re = sre.compile(r'\w+[^\s]*@\w+\.\w+')
|
||||||
|
@ -3608,7 +3561,7 @@ class plugin:
|
||||||
emoticons_pattern += emoticon_escaped + '|'# or is | in regexp
|
emoticons_pattern += emoticon_escaped + '|'# or is | in regexp
|
||||||
#self.emoticons_pattern = self.emoticons_pattern[0:-1] # remove the last |
|
#self.emoticons_pattern = self.emoticons_pattern[0:-1] # remove the last |
|
||||||
|
|
||||||
self.emot_and_url_pattern = emoticons_pattern + self.url_pattern
|
self.emot_and_formatting_url_pattern = emoticons_pattern + self.formatting_url_pattern
|
||||||
|
|
||||||
gtk.gdk.threads_enter()
|
gtk.gdk.threads_enter()
|
||||||
self.autoconnect()
|
self.autoconnect()
|
||||||
|
|
Loading…
Reference in New Issue