1803 lines
66 KiB
Python
1803 lines
66 KiB
Python
## plugins/config.py
|
|
##
|
|
## Gajim Team:
|
|
## - Yann Le Boulanger <asterix@lagaule.org>
|
|
## - Vincent Hanquez <tab@snarc.org>
|
|
## - Nikos Kouremenos <kourem@gmail.com>
|
|
##
|
|
## Copyright (C) 2003-2005 Gajim Team
|
|
##
|
|
## This program 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 2 only.
|
|
##
|
|
## This program 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.
|
|
##
|
|
|
|
import gtk
|
|
import gtk.glade
|
|
import gobject
|
|
import os
|
|
import common.sleepy
|
|
from common import i18n
|
|
_ = i18n._
|
|
APP = i18n.APP
|
|
gtk.glade.bindtextdomain (APP, i18n.DIR)
|
|
gtk.glade.textdomain (APP)
|
|
|
|
from dialogs import *
|
|
import gtkgui
|
|
|
|
GTKGUI_GLADE='plugins/gtkgui/gtkgui.glade'
|
|
|
|
|
|
class Preferences_window:
|
|
"""Class for Preferences window"""
|
|
|
|
def on_preferences_window_delete_event(self, widget, event):
|
|
self.window.hide()
|
|
return True # do NOT destroy the window
|
|
|
|
def on_close_button_clicked(self, widget):
|
|
self.window.hide()
|
|
|
|
def on_preferences_window_show(self, widget):
|
|
self.notebook.set_current_page(0)
|
|
|
|
def on_checkbutton_toggled(self, widget, config_name, \
|
|
extra_function = None, change_sensitivity_widgets = None):
|
|
if widget.get_active():
|
|
self.plugin.config[config_name] = 1
|
|
if extra_function != None:
|
|
apply(extra_function)
|
|
else:
|
|
self.plugin.config[config_name] = 0
|
|
if change_sensitivity_widgets != None:
|
|
for w in change_sensitivity_widgets:
|
|
w.set_sensitive(widget.get_active())
|
|
|
|
def on_tray_icon_checkbutton_toggled(self, widget):
|
|
if widget.get_active():
|
|
self.plugin.config['trayicon'] = 1
|
|
self.plugin.show_systray()
|
|
self.plugin.roster.update_status_comboxbox()
|
|
else:
|
|
self.plugin.config['trayicon'] = 0
|
|
self.plugin.hide_systray()
|
|
self.plugin.send('CONFIG', None, ('GtkGui', self.plugin.config, 'GtkGui'))
|
|
self.plugin.roster.draw_roster()
|
|
|
|
def on_save_position_checkbutton_toggled(self, widget):
|
|
if widget.get_active():
|
|
self.plugin.config['saveposition'] = 1
|
|
else:
|
|
self.plugin.config['saveposition'] = 0
|
|
|
|
def on_merge_checkbutton_toggled(self, widget):
|
|
if widget.get_active():
|
|
self.plugin.config['mergeaccounts'] = 1
|
|
else:
|
|
self.plugin.config['mergeaccounts'] = 0
|
|
self.plugin.roster.regroup = self.plugin.config['mergeaccounts']
|
|
self.plugin.roster.draw_roster()
|
|
|
|
def on_iconset_combobox_changed(self, widget):
|
|
model = widget.get_model()
|
|
active = widget.get_active()
|
|
icon_string = model[active][0]
|
|
self.plugin.config['iconset'] = icon_string
|
|
self.plugin.roster.reload_pixbufs()
|
|
|
|
def on_account_text_colorbutton_color_set(self, widget):
|
|
"""Take The Color For The Account Text"""
|
|
color = widget.get_color()
|
|
color_string = '#' + (hex(color.red) + '0')[2:4] + \
|
|
(hex(color.green) + '0')[2:4] + (hex(color.blue) + '0')[2:4]
|
|
self.plugin.config['accounttextcolor'] = color_string
|
|
self.plugin.roster.draw_roster()
|
|
|
|
def on_group_text_colorbutton_color_set(self, widget):
|
|
"""Take The Color For The Group Text"""
|
|
color = widget.get_color()
|
|
color_string = '#' + (hex(color.red) + '0')[2:4] + \
|
|
(hex(color.green) + '0')[2:4] + (hex(color.blue) + '0')[2:4]
|
|
self.plugin.config['grouptextcolor'] = color_string
|
|
self.plugin.roster.draw_roster()
|
|
|
|
def on_user_text_colorbutton_color_set(self, widget):
|
|
"""Take The Color For The User Text"""
|
|
color = widget.get_color()
|
|
color_string = '#' + (hex(color.red) + '0')[2:4] + \
|
|
(hex(color.green) + '0')[2:4] + (hex(color.blue) + '0')[2:4]
|
|
self.plugin.config['usertextcolor'] = color_string
|
|
self.plugin.roster.draw_roster()
|
|
|
|
def on_account_text_bg_colorbutton_color_set(self, widget):
|
|
"""Take The Color For The Background Of Account Text"""
|
|
color = widget.get_color()
|
|
color_string = '#' + (hex(color.red) + '0')[2:4] + \
|
|
(hex(color.green) + '0')[2:4] + (hex(color.blue) + '0')[2:4]
|
|
self.plugin.config['accountbgcolor'] = color_string
|
|
self.plugin.roster.draw_roster()
|
|
|
|
def on_group_text_bg_colorbutton_color_set(self, widget):
|
|
"""Take The Color For The Background Of Group Text"""
|
|
color = widget.get_color()
|
|
color_string = '#' + (hex(color.red) + '0')[2:4] + \
|
|
(hex(color.green) + '0')[2:4] + (hex(color.blue) + '0')[2:4]
|
|
self.plugin.config['groupbgcolor'] = color_string
|
|
self.plugin.roster.draw_roster()
|
|
|
|
def on_user_text_bg_colorbutton_color_set(self, widget):
|
|
"""Take The Color For The Background Of User Text"""
|
|
color = widget.get_color()
|
|
color_string = '#' + (hex(color.red) + '0')[2:4] + \
|
|
(hex(color.green) + '0')[2:4] + (hex(color.blue) + '0')[2:4]
|
|
self.plugin.config['userbgcolor'] = color_string
|
|
self.plugin.roster.draw_roster()
|
|
|
|
def on_account_text_fontbutton_font_set(self, widget):
|
|
"""Take The Font For The User Text"""
|
|
font_string = widget.get_font_name()
|
|
self.plugin.config['accountfont'] = font_string
|
|
self.plugin.roster.draw_roster()
|
|
|
|
def on_group_text_fontbutton_font_set(self, widget):
|
|
"""Take The Font For The Group Text"""
|
|
font_string = widget.get_font_name()
|
|
self.plugin.config['groupfont'] = font_string
|
|
self.plugin.roster.draw_roster()
|
|
|
|
def on_user_text_fontbutton_font_set(self, widget):
|
|
"""Take The Font For The User Text"""
|
|
font_string = widget.get_font_name()
|
|
self.plugin.config['userfont'] = font_string
|
|
self.plugin.roster.draw_roster()
|
|
|
|
def on_reset_colors_and_fonts_button_clicked(self, widget):
|
|
defaults = self.plugin.default_config
|
|
self.plugin.config['accounttextcolor'] = defaults['accounttextcolor']
|
|
self.plugin.config['grouptextcolor'] = defaults['grouptextcolor']
|
|
self.plugin.config['usertextcolor'] = defaults['usertextcolor']
|
|
self.plugin.config['accountbgcolor'] = defaults['accountbgcolor']
|
|
self.plugin.config['groupbgcolor'] = defaults['groupbgcolor']
|
|
self.plugin.config['userbgcolor'] = defaults['userbgcolor']
|
|
self.plugin.config['accountfont'] = defaults['accountfont']
|
|
self.plugin.config['groupfont'] = defaults['groupfont']
|
|
self.plugin.config['userfont'] = defaults['userfont']
|
|
self.xml.get_widget('account_text_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(defaults['accounttextcolor']))
|
|
self.xml.get_widget('group_text_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(defaults['grouptextcolor']))
|
|
self.xml.get_widget('user_text_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(defaults['usertextcolor']))
|
|
self.xml.get_widget('account_text_bg_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(defaults['accountbgcolor']))
|
|
self.xml.get_widget('group_text_bg_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(defaults['groupbgcolor']))
|
|
self.xml.get_widget('user_text_bg_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(defaults['userbgcolor']))
|
|
self.xml.get_widget('account_text_fontbutton').set_font_name(\
|
|
defaults['accountfont'])
|
|
self.xml.get_widget('group_text_fontbutton').set_font_name(\
|
|
defaults['groupfont'])
|
|
self.xml.get_widget('user_text_fontbutton').set_font_name(\
|
|
defaults['userfont'])
|
|
self.plugin.roster.draw_roster()
|
|
|
|
def on_use_tabbed_chat_window_checkbutton_toggled(self, widget):
|
|
buf1 = {}
|
|
buf2 = {}
|
|
jids = {}
|
|
if widget.get_active():
|
|
#FIXME Does not work
|
|
#save buffers and close windows
|
|
# for acct in self.plugin.accounts:
|
|
# buf1[acct] = {}
|
|
# buf2[acct] = {}
|
|
# jids[acct] = self.plugin.windows[acct]['chats'].keys()
|
|
# for jid in jids[acct]:
|
|
# buf1[acct][jid] = self.plugin.windows[acct]['chats'][jid].\
|
|
# xmls[jid].get_widget('conversation_textview').get_buffer()
|
|
# buf2[acct][jid] = self.plugin.windows[acct]['chats'][jid].\
|
|
# xmls[jid].get_widget('message_textview').get_buffer()
|
|
# self.plugin.windows[acct]['chats'][jid].window.destroy()
|
|
self.plugin.config['usetabbedchat'] = 1
|
|
#open new tabbed chat windows
|
|
# for acct in self.plugin.accounts:
|
|
# for jid in jids[acct]:
|
|
# user = self.plugin.roster.contacts[acct][jid][0]
|
|
# self.plugin.roster.new_chat(user, acct)
|
|
# self.plugin.windows[acct]['chats'][jid].xmls[jid].\
|
|
# get_widget('conversation_textview').set_buffer(\
|
|
# buf1[acct][jid])
|
|
# self.plugin.windows[acct]['chats'][jid].xmls[jid].\
|
|
# get_widget('message_textview').set_buffer(buf2[acct][jid])
|
|
else:
|
|
#save buffers and close tabbed chat windows
|
|
# for acct in self.plugin.accounts:
|
|
# buf1[acct] = {}
|
|
# buf2[acct] = {}
|
|
# jids[acct] = self.plugin.windows[acct]['chats'].keys()
|
|
# if 'tabbed' in jids[acct]:
|
|
# jids[acct].remove('tabbed')
|
|
# for jid in jids[acct]:
|
|
# buf1[acct][jid] = self.plugin.windows[acct]['chats'][jid].\
|
|
# xmls[jid].get_widget('conversation_textview').get_buffer()
|
|
# buf2[acct][jid] = self.plugin.windows[acct]['chats'][jid].\
|
|
# xmls[jid].get_widget('message_textview').get_buffer()
|
|
# self.plugin.windows[acct]['chats']['tabbed'].window.destroy()
|
|
self.plugin.config['usetabbedchat'] = 0
|
|
#open new tabbed chat windows
|
|
# for acct in self.plugin.accounts:
|
|
# for jid in jids[acct]:
|
|
# user = self.plugin.roster.contacts[acct][jid][0]
|
|
# self.plugin.roster.new_chat(user, acct)
|
|
# self.plugin.windows[acct]['chats'][jid].xmls[jid].\
|
|
# get_widget('conversation_textview').set_buffer(\
|
|
# buf1[acct][jid])
|
|
# self.plugin.windows[acct]['chats'][jid].xmls[jid].\
|
|
# get_widget('message_textview').set_buffer(buf2[acct][jid])
|
|
|
|
def update_print_time(self):
|
|
"""Update time in Opened Chat Windows"""
|
|
for a in self.plugin.accounts.keys():
|
|
if self.plugin.windows[a]['chats'].has_key('tabbed'):
|
|
self.plugin.windows[a]['chats']['tabbed'].update_print_time()
|
|
else:
|
|
for jid in self.plugin.windows[a]['chats'].keys():
|
|
self.plugin.windows[a]['chats'][jid].update_print_time()
|
|
|
|
def on_time_never_radiobutton_toggled(self, widget):
|
|
if widget.get_active():
|
|
self.plugin.config['print_time'] = 'never'
|
|
self.update_print_time()
|
|
|
|
def on_time_sometimes_radiobutton_toggled(self, widget):
|
|
if widget.get_active():
|
|
self.plugin.config['print_time'] = 'sometimes'
|
|
self.update_print_time()
|
|
|
|
def on_time_always_radiobutton_toggled(self, widget):
|
|
if widget.get_active():
|
|
self.plugin.config['print_time'] = 'always'
|
|
self.update_print_time()
|
|
|
|
def on_before_time_entry_focus_out_event(self, widget, event):
|
|
self.plugin.config['before_time'] = widget.get_text()
|
|
|
|
def on_after_time_entry_focus_out_event(self, widget, event):
|
|
self.plugin.config['after_time'] = widget.get_text()
|
|
|
|
def on_before_nickname_entry_focus_out_event(self, widget, event):
|
|
self.plugin.config['before_nickname'] = widget.get_text()
|
|
|
|
def on_after_nickname_entry_focus_out_event(self, widget, event):
|
|
self.plugin.config['after_nickname'] = widget.get_text()
|
|
|
|
def update_text_tags(self):
|
|
"""Update color tags in Opened Chat Windows"""
|
|
for a in self.plugin.accounts.keys():
|
|
if self.plugin.windows[a]['chats'].has_key('tabbed'):
|
|
self.plugin.windows[a]['chats']['tabbed'].update_tags()
|
|
else:
|
|
for jid in self.plugin.windows[a]['chats'].keys():
|
|
self.plugin.windows[a]['chats'][jid].update_tags()
|
|
|
|
def on_incoming_msg_colorbutton_color_set(self, widget):
|
|
"""Take The Color For The Incoming Messages"""
|
|
color = widget.get_color()
|
|
color_string = '#' + (hex(color.red) + '0')[2:4] + \
|
|
(hex(color.green) + '0')[2:4] + (hex(color.blue) + '0')[2:4]
|
|
self.plugin.config['inmsgcolor'] = color_string
|
|
self.update_text_tags()
|
|
|
|
def on_outgoing_msg_colorbutton_color_set(self, widget):
|
|
"""Take The Color For The Outgoing Messages"""
|
|
color = widget.get_color()
|
|
color_string = '#' + (hex(color.red) + '0')[2:4] + \
|
|
(hex(color.green) + '0')[2:4] + (hex(color.blue) + '0')[2:4]
|
|
self.plugin.config['outmsgcolor'] = color_string
|
|
self.update_text_tags()
|
|
|
|
def on_status_msg_colorbutton_color_set(self, widget):
|
|
"""Take The Color For The Status Messages"""
|
|
color = widget.get_color()
|
|
color_string = '#' + (hex(color.red) + '0')[2:4] + \
|
|
(hex(color.green) + '0')[2:4] + (hex(color.blue) + '0')[2:4]
|
|
self.plugin.config['statusmsgcolor'] = color_string
|
|
self.update_text_tags()
|
|
|
|
def on_reset_colors_button_clicked(self, widget):
|
|
defaults = self.plugin.default_config
|
|
self.plugin.config['inmsgcolor'] = defaults['inmsgcolor']
|
|
self.plugin.config['outmsgcolor'] = defaults['outmsgcolor']
|
|
self.plugin.config['statusmsgcolor'] = defaults['statusmsgcolor']
|
|
self.xml.get_widget('incoming_msg_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(defaults['inmsgcolor']))
|
|
self.xml.get_widget('outgoing_msg_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(defaults['outmsgcolor']))
|
|
self.xml.get_widget('status_msg_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(defaults['statusmsgcolor']))
|
|
self.update_text_tags()
|
|
|
|
def on_use_emoticons_checkbutton_toggled(self, widget):
|
|
self.on_checkbutton_toggled(widget, 'useemoticons', None, \
|
|
self.xml.get_widget('add_remove_emoticons_button'))
|
|
|
|
def on_add_remove_emoticons_button_clicked(self, widget):
|
|
Add_remove_emoticons_window(self.plugin)
|
|
|
|
def on_auto_popup_checkbutton_toggled(self, widget):
|
|
self.on_checkbutton_toggled(widget, 'autopopup', None,\
|
|
[self.auto_popup_away_checkbutton])
|
|
|
|
def on_auto_popup_away_checkbutton_toggled(self, widget):
|
|
self.on_checkbutton_toggled(widget, 'autopopupaway')
|
|
|
|
def on_ignore_events_from_unknown_contacts_checkbutton_toggled(self, widget):
|
|
self.on_checkbutton_toggled(widget, 'ignore_unknown_contacts')
|
|
|
|
def on_soundplayer_entry_changed(self, widget):
|
|
self.plugin.config['soundplayer'] = widget.get_text()
|
|
|
|
def on_prompt_online_status_message_checkbutton_toggled(self, widget):
|
|
self.on_checkbutton_toggled(widget, 'ask_online_status')
|
|
|
|
def on_prompt_offline_status_message_checkbutton_toggled(self, widget):
|
|
self.on_checkbutton_toggled(widget, 'ask_offline_status')
|
|
|
|
def on_sounds_treemodel_row_changed(self, model, path, iter):
|
|
iter = model.get_iter_first()
|
|
while iter:
|
|
path = model.get_path(iter)
|
|
sound_event = model.get_value(iter, 0)
|
|
if model[path][1]:
|
|
self.plugin.config['sound_' + sound_event] = 1
|
|
else:
|
|
self.plugin.config['sound_' + sound_event] = 0
|
|
self.plugin.config['sound_' + sound_event + '_file'] = \
|
|
model.get_value(iter, 2)
|
|
iter = model.iter_next(iter)
|
|
|
|
def on_auto_away_checkbutton_toggled(self, widget):
|
|
self.on_checkbutton_toggled(widget, 'autoaway', None,\
|
|
[self.auto_away_time_spinbutton])
|
|
|
|
def on_auto_away_time_spinbutton_value_changed(self, widget):
|
|
aat = widget.get_value_as_int()
|
|
self.plugin.config['autoawaytime'] = aat
|
|
self.plugin.sleeper = common.sleepy.Sleepy(\
|
|
self.plugin.config['autoawaytime']*60, \
|
|
self.plugin.config['autoxatime']*60)
|
|
|
|
def on_auto_xa_checkbutton_toggled(self, widget):
|
|
self.on_checkbutton_toggled(widget, 'autoxa', None,\
|
|
[self.auto_xa_time_spinbutton])
|
|
|
|
def on_auto_xa_time_spinbutton_value_changed(self, widget):
|
|
axt = widget.get_value_as_int()
|
|
self.plugin.config['autoxatime'] = axt
|
|
self.plugin.sleeper = common.sleepy.Sleepy(\
|
|
self.plugin.config['autoawaytime']*60, \
|
|
self.plugin.config['autoxatime']*60)
|
|
|
|
def on_msg_treemodel_row_changed(self, model, path, iter):
|
|
iter = model.get_iter_first()
|
|
i = 0
|
|
while iter:
|
|
self.plugin.config['msg%i_name' % i] = model.get_value(iter, 0)
|
|
self.plugin.config['msg%i' % i] = model.get_value(iter, 1)
|
|
iter = model.iter_next(iter)
|
|
i += 1
|
|
while self.plugin.config.has_key('msg%s_name' % i):
|
|
del self.plugin.config['msg%i_name' % i]
|
|
del self.plugin.config['msg%i' % i]
|
|
i += 1
|
|
|
|
def on_msg_treemodel_row_deleted(self, model, path, iter):
|
|
iter = model.get_iter_first()
|
|
i = 0
|
|
while iter:
|
|
self.plugin.config['msg%i_name' % i] = model.get_value(iter, 0)
|
|
self.plugin.config['msg%i' % i] = model.get_value(iter, 1)
|
|
iter = model.iter_next(iter)
|
|
i += 1
|
|
while self.plugin.config.has_key('msg%s_name' % i):
|
|
del self.plugin.config['msg%i_name' % i]
|
|
del self.plugin.config['msg%i' % i]
|
|
i += 1
|
|
|
|
def on_links_open_with_combobox_changed(self, widget):
|
|
if widget.get_active() == 2:
|
|
self.xml.get_widget('custom_apps_frame').set_sensitive(True)
|
|
self.plugin.config['openwith'] = 'custom'
|
|
else:
|
|
if widget.get_active() == 0:
|
|
self.plugin.config['openwith'] = 'gnome-open'
|
|
if widget.get_active() == 1:
|
|
self.plugin.config['openwith'] = 'kfmclient exec'
|
|
self.xml.get_widget('custom_apps_frame').set_sensitive(False)
|
|
|
|
def on_custom_browser_entry_changed(self, widget):
|
|
self.plugin.config['custombrowser'] = widget.get_text()
|
|
|
|
def on_custom_mail_client_entry_changed(self, widget):
|
|
self.plugin.config['custommailapp'] = widget.get_text()
|
|
|
|
def on_log_in_contact_checkbutton_toggled(self, widget):
|
|
if widget.get_active():
|
|
self.config_logger['lognotusr'] = 1
|
|
else:
|
|
self.config_logger['lognotusr'] = 0
|
|
self.plugin.send('CONFIG', None, ('Logger', self.config_logger, 'GtkGui'))
|
|
|
|
def on_log_in_extern_checkbutton_toggled(self, widget):
|
|
if widget.get_active():
|
|
self.config_logger['lognotsep'] = 1
|
|
else:
|
|
self.config_logger['lognotsep'] = 0
|
|
self.plugin.send('CONFIG', None, ('Logger', self.config_logger, 'GtkGui'))
|
|
|
|
def on_do_not_send_os_info_checkbutton_toggled(self, widget):
|
|
if widget.get_active():
|
|
#FIXME: when threads are removed, make sure this work
|
|
self.plugin.config['do_not_send_os_info'] = 1
|
|
else:
|
|
self.plugin.config['do_not_send_os_info'] = 0
|
|
|
|
|
|
def fill_msg_treeview(self):
|
|
i = 0
|
|
self.xml.get_widget('delete_msg_button').set_sensitive(False)
|
|
model = self.msg_tree.get_model()
|
|
model.clear()
|
|
while self.plugin.config.has_key('msg%s_name' % i):
|
|
iter = model.append()
|
|
model.set(iter, 0, self.plugin.config['msg%s_name' % i], 1, self.plugin.config['msg%s' % i])
|
|
i += 1
|
|
|
|
def on_msg_cell_edited(self, cell, row, new_text):
|
|
model = self.msg_tree.get_model()
|
|
iter = model.get_iter_from_string(row)
|
|
model.set_value(iter, 0, new_text)
|
|
|
|
def on_msg_treeview_cursor_changed(self, widget, data=None):
|
|
self.xml.get_widget('delete_msg_button').set_sensitive(True)
|
|
buf = self.xml.get_widget('msg_textview').get_buffer()
|
|
(model, iter) = self.msg_tree.get_selection().get_selected()
|
|
name = model.get_value(iter, 0)
|
|
msg = model.get_value(iter, 1)
|
|
buf.set_text(msg)
|
|
|
|
def on_new_msg_button_clicked(self, widget, data=None):
|
|
model = self.msg_tree.get_model()
|
|
iter = model.append()
|
|
model.set(iter, 0, 'msg', 1, 'message')
|
|
|
|
def on_delete_msg_button_clicked(self, widget, data=None):
|
|
(model, iter) = self.msg_tree.get_selection().get_selected()
|
|
buf = self.xml.get_widget('msg_textview').get_buffer()
|
|
model.remove(iter)
|
|
buf.set_text('')
|
|
self.xml.get_widget('delete_msg_button').set_sensitive(False)
|
|
|
|
def on_msg_textview_changed(self, widget, data=None):
|
|
(model, iter) = self.msg_tree.get_selection().get_selected()
|
|
if not iter:
|
|
return
|
|
buf = self.xml.get_widget('msg_textview').get_buffer()
|
|
first_iter, end_iter = buf.get_bounds()
|
|
name = model.get_value(iter, 0)
|
|
model.set_value(iter, 1, buf.get_text(first_iter, end_iter))
|
|
|
|
def on_msg_treeview_key_press_event(self, widget, event):
|
|
if event.keyval == gtk.keysyms.Delete:
|
|
self.on_delete_msg_button_clicked(widget)
|
|
|
|
def sound_toggled_cb(self, cell, path):
|
|
model = self.sound_tree.get_model()
|
|
model[path][1] = not model[path][1]
|
|
return
|
|
|
|
def fill_sound_treeview(self):
|
|
events = {}
|
|
#events = {name : [use_it, file], name2 : [., .], ...}
|
|
for key in self.plugin.config.keys():
|
|
if key.find('sound_') == 0:
|
|
if not self.plugin.config.has_key(key + '_file'):
|
|
continue
|
|
ev = key.replace('sound_', '')
|
|
events[ev] = [self.plugin.config[key], self.plugin.config[key + \
|
|
'_file']]
|
|
model = self.sound_tree.get_model()
|
|
model.clear()
|
|
for ev in events:
|
|
iter = model.append((ev, events[ev][0], events[ev][1]))
|
|
|
|
def on_treeview_sounds_cursor_changed(self, widget, data=None):
|
|
(model, iter) = self.sound_tree.get_selection().get_selected()
|
|
if not iter:
|
|
self.xml.get_widget('sounds_entry').set_text('')
|
|
return
|
|
str = model.get_value(iter, 2)
|
|
self.xml.get_widget('sounds_entry').set_text(str)
|
|
|
|
def on_button_sounds_clicked(self, widget, data=None):
|
|
(model, iter) = self.sound_tree.get_selection().get_selected()
|
|
if not iter:
|
|
return
|
|
file = model.get_value(iter, 2)
|
|
dialog = gtk.FileChooserDialog(_('Choose sound'),
|
|
None,
|
|
gtk.FILE_CHOOSER_ACTION_OPEN,
|
|
(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL,
|
|
gtk.STOCK_OPEN, gtk.RESPONSE_OK))
|
|
dialog.set_default_response(gtk.RESPONSE_OK)
|
|
filter = gtk.FileFilter()
|
|
filter.set_name(_('All files'))
|
|
filter.add_pattern("*")
|
|
dialog.add_filter(filter)
|
|
|
|
filter = gtk.FileFilter()
|
|
filter.set_name(_('Wav Sounds'))
|
|
filter.add_pattern("*.wav")
|
|
dialog.add_filter(filter)
|
|
dialog.set_filter(filter)
|
|
|
|
file = os.path.join(os.getcwd(), file)
|
|
dialog.set_filename(file)
|
|
file = ''
|
|
ok = 0
|
|
while(ok == 0):
|
|
response = dialog.run()
|
|
if response == gtk.RESPONSE_OK:
|
|
file = dialog.get_filename()
|
|
if os.path.exists(file):
|
|
ok = 1
|
|
else:
|
|
ok = 1
|
|
dialog.destroy()
|
|
if file:
|
|
self.xml.get_widget('sounds_entry').set_text(file)
|
|
model.set_value(iter, 2, file)
|
|
model.set_value(iter, 1, 1)
|
|
|
|
def __init__(self, plugin):
|
|
"""Initialize Preferences window"""
|
|
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'preferences_window', APP)
|
|
self.window = self.xml.get_widget('preferences_window')
|
|
self.plugin = plugin
|
|
self.iconset_combobox = self.xml.get_widget('iconset_combobox')
|
|
self.auto_popup_checkbutton = self.xml.get_widget('auto_popup_checkbutton')
|
|
self.auto_popup_away_checkbutton = self.xml.get_widget \
|
|
('auto_popup_away_checkbutton')
|
|
self.auto_away_checkbutton = self.xml.get_widget('auto_away_checkbutton')
|
|
self.auto_away_time_spinbutton = self.xml.get_widget \
|
|
('auto_away_time_spinbutton')
|
|
self.auto_xa_checkbutton = self.xml.get_widget('auto_xa_checkbutton')
|
|
self.auto_xa_time_spinbutton = self.xml.get_widget \
|
|
('auto_xa_time_spinbutton')
|
|
self.tray_icon_checkbutton = self.xml.get_widget('tray_icon_checkbutton')
|
|
self.notebook = self.xml.get_widget('preferences_notebook')
|
|
|
|
#trayicon
|
|
if self.plugin.systray_capabilities:
|
|
st = self.plugin.config['trayicon']
|
|
self.tray_icon_checkbutton.set_active(st)
|
|
else:
|
|
self.tray_icon_checkbutton.set_sensitive(False)
|
|
|
|
#Save position
|
|
st = self.plugin.config['saveposition']
|
|
self.xml.get_widget('save_position_checkbutton').set_active(st)
|
|
|
|
#Merge accounts
|
|
st = self.plugin.config['mergeaccounts']
|
|
self.xml.get_widget('merge_checkbutton').set_active(st)
|
|
|
|
#iconset
|
|
list_style = os.listdir('plugins/gtkgui/iconsets/')
|
|
model = gtk.ListStore(gobject.TYPE_STRING)
|
|
self.iconset_combobox.set_model(model)
|
|
l = []
|
|
for i in list_style:
|
|
if i != 'CVS' and i[0] != '.':
|
|
l.append(i)
|
|
if l.count == 0:
|
|
l.append(' ')
|
|
for i in range(len(l)):
|
|
model.append([l[i]])
|
|
if self.plugin.config['iconset'] == l[i]:
|
|
self.iconset_combobox.set_active(i)
|
|
|
|
#Color for account text
|
|
colSt = self.plugin.config['accounttextcolor']
|
|
self.xml.get_widget('account_text_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(colSt))
|
|
|
|
#Color for group text
|
|
colSt = self.plugin.config['grouptextcolor']
|
|
self.xml.get_widget('group_text_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(colSt))
|
|
|
|
#Color for user text
|
|
colSt = self.plugin.config['usertextcolor']
|
|
self.xml.get_widget('user_text_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(colSt))
|
|
|
|
#Color for background account
|
|
colSt = self.plugin.config['accountbgcolor']
|
|
self.xml.get_widget('account_text_bg_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(colSt))
|
|
|
|
#Color for background group
|
|
colSt = self.plugin.config['groupbgcolor']
|
|
self.xml.get_widget('group_text_bg_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(colSt))
|
|
|
|
#Color for background user
|
|
colSt = self.plugin.config['userbgcolor']
|
|
self.xml.get_widget('user_text_bg_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(colSt))
|
|
|
|
#font for account
|
|
fontStr = self.plugin.config['accountfont']
|
|
self.xml.get_widget('account_text_fontbutton').set_font_name(fontStr)
|
|
|
|
#font for group
|
|
fontStr = self.plugin.config['groupfont']
|
|
self.xml.get_widget('group_text_fontbutton').set_font_name(fontStr)
|
|
|
|
#font for account
|
|
fontStr = self.plugin.config['userfont']
|
|
self.xml.get_widget('user_text_fontbutton').set_font_name(fontStr)
|
|
|
|
#use tabbed chat window
|
|
st = self.plugin.config['usetabbedchat']
|
|
self.xml.get_widget('use_tabbed_chat_window_checkbutton').set_active(st)
|
|
|
|
#Print time
|
|
if self.plugin.config['print_time'] == 'never':
|
|
self.xml.get_widget('time_never_radiobutton').set_active(1)
|
|
elif self.plugin.config['print_time'] == 'sometimes':
|
|
self.xml.get_widget('time_sometimes_radiobutton').set_active(1)
|
|
else:
|
|
self.xml.get_widget('time_always_radiobutton').set_active(1)
|
|
|
|
#before time
|
|
st = self.plugin.config['before_time']
|
|
self.xml.get_widget('before_time_entry').set_text(st)
|
|
|
|
#after time
|
|
st = self.plugin.config['after_time']
|
|
self.xml.get_widget('after_time_entry').set_text(st)
|
|
|
|
#before nickname
|
|
st = self.plugin.config['before_nickname']
|
|
self.xml.get_widget('before_nickname_entry').set_text(st)
|
|
|
|
#after nickanme
|
|
st = self.plugin.config['after_nickname']
|
|
self.xml.get_widget('after_nickname_entry').set_text(st)
|
|
|
|
#Color for incomming messages
|
|
colSt = self.plugin.config['inmsgcolor']
|
|
self.xml.get_widget('incoming_msg_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(colSt))
|
|
|
|
#Color for outgoing messages
|
|
colSt = self.plugin.config['outmsgcolor']
|
|
self.xml.get_widget('outgoing_msg_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(colSt))
|
|
|
|
#Color for status messages
|
|
colSt = self.plugin.config['statusmsgcolor']
|
|
self.xml.get_widget('status_msg_colorbutton').set_color(\
|
|
gtk.gdk.color_parse(colSt))
|
|
|
|
#Use emoticons
|
|
st = self.plugin.config['useemoticons']
|
|
self.xml.get_widget('use_emoticons_checkbutton').set_active(st)
|
|
self.xml.get_widget('add_remove_emoticons_button').set_sensitive(st)
|
|
|
|
#autopopup
|
|
st = self.plugin.config['autopopup']
|
|
self.auto_popup_checkbutton.set_active(st)
|
|
|
|
#autopopupaway
|
|
st = self.plugin.config['autopopupaway']
|
|
self.auto_popup_away_checkbutton.set_active(st)
|
|
self.auto_popup_away_checkbutton.set_sensitive(self.plugin.config['autopopup'])
|
|
|
|
#Ignore messages from unknown contacts
|
|
self.xml.get_widget('ignore_events_from_unknown_contacts_checkbutton').\
|
|
set_active(self.plugin.config['ignore_unknown_contacts'])
|
|
|
|
#sound player
|
|
self.xml.get_widget('soundplayer_entry').set_text(\
|
|
self.plugin.config['soundplayer'])
|
|
|
|
#sounds
|
|
self.sound_tree = self.xml.get_widget('sounds_treeview')
|
|
model = gtk.ListStore(gobject.TYPE_STRING, gobject.TYPE_BOOLEAN, \
|
|
gobject.TYPE_STRING)
|
|
self.sound_tree.set_model(model)
|
|
|
|
col = gtk.TreeViewColumn(_('Active'))
|
|
self.sound_tree.append_column(col)
|
|
renderer = gtk.CellRendererToggle()
|
|
renderer.set_property('activatable', True)
|
|
renderer.connect('toggled', self.sound_toggled_cb)
|
|
col.pack_start(renderer)
|
|
col.set_attributes(renderer, active=1)
|
|
|
|
col = gtk.TreeViewColumn(_('Event'))
|
|
self.sound_tree.append_column(col)
|
|
renderer = gtk.CellRendererText()
|
|
col.pack_start(renderer)
|
|
col.set_attributes(renderer, text=0)
|
|
|
|
col = gtk.TreeViewColumn(_('Sound'))
|
|
self.sound_tree.append_column(col)
|
|
renderer = gtk.CellRendererText()
|
|
col.pack_start(renderer)
|
|
col.set_attributes(renderer, text=2)
|
|
self.fill_sound_treeview()
|
|
|
|
if not os.name == 'posix':
|
|
self.xml.get_widget('soundplayer_entry').set_sensitive(False)
|
|
self.sound_tree.set_sensitive(False)
|
|
self.xml.get_widget('sounds_entry').set_sensitive(False)
|
|
self.xml.get_widget('sounds_button').set_sensitive(False)
|
|
|
|
#Autoaway
|
|
st = self.plugin.config['autoaway']
|
|
self.auto_away_checkbutton.set_active(st)
|
|
|
|
#Autoawaytime
|
|
st = self.plugin.config['autoawaytime']
|
|
self.auto_away_time_spinbutton.set_value(st)
|
|
self.auto_away_time_spinbutton.set_sensitive(self.plugin.config['autoaway'])
|
|
|
|
#Autoxa
|
|
st = self.plugin.config['autoxa']
|
|
self.auto_xa_checkbutton.set_active(st)
|
|
|
|
#Autoxatime
|
|
st = self.plugin.config['autoxatime']
|
|
self.auto_xa_time_spinbutton.set_value(st)
|
|
self.auto_xa_time_spinbutton.set_sensitive(self.plugin.config['autoxa'])
|
|
|
|
#ask_status when online / offline
|
|
st = self.plugin.config['ask_online_status']
|
|
self.xml.get_widget('prompt_online_status_message_checkbutton').\
|
|
set_active(st)
|
|
st = self.plugin.config['ask_offline_status']
|
|
self.xml.get_widget('prompt_offline_status_message_checkbutton').\
|
|
set_active(st)
|
|
|
|
#Status messages
|
|
self.msg_tree = self.xml.get_widget('msg_treeview')
|
|
model = gtk.ListStore(gobject.TYPE_STRING, gobject.TYPE_STRING)
|
|
self.msg_tree.set_model(model)
|
|
col = gtk.TreeViewColumn('name')
|
|
self.msg_tree.append_column(col)
|
|
renderer = gtk.CellRendererText()
|
|
col.pack_start(renderer, True)
|
|
col.set_attributes(renderer, text=0)
|
|
renderer.connect('edited', self.on_msg_cell_edited)
|
|
renderer.set_property('editable', True)
|
|
self.fill_msg_treeview()
|
|
buf = self.xml.get_widget('msg_textview').get_buffer()
|
|
buf.connect('changed', self.on_msg_textview_changed)
|
|
|
|
self.plugin.send('ASK_CONFIG', None, ('GtkGui', 'Logger', {'lognotsep':1,\
|
|
'lognotusr':1}))
|
|
self.config_logger = self.plugin.wait('CONFIG')
|
|
|
|
#open links with
|
|
self.links_open_with_combobox = self.xml.get_widget('links_open_with_combobox')
|
|
if self.plugin.config['openwith'] == 'gnome-open':
|
|
self.links_open_with_combobox.set_active(0)
|
|
elif self.plugin.config['openwith'] == 'kfmclient exec':
|
|
self.links_open_with_combobox.set_active(1)
|
|
elif self.plugin.config['openwith'] == 'custom':
|
|
self.links_open_with_combobox.set_active(2)
|
|
self.xml.get_widget('custom_apps_frame').set_sensitive(True)
|
|
self.xml.get_widget('custom_browser_entry').set_text(\
|
|
self.plugin.config['custombrowser'])
|
|
self.xml.get_widget('custom_mail_client_entry').set_text(\
|
|
self.plugin.config['custommailapp'])
|
|
|
|
#log presences in user file
|
|
st = self.config_logger['lognotusr']
|
|
self.xml.get_widget('log_in_contact_checkbutton').set_active(st)
|
|
|
|
#log presences in external file
|
|
st = self.config_logger['lognotsep']
|
|
self.xml.get_widget('log_in_extern_checkbutton').set_active(st)
|
|
|
|
# don't send os info
|
|
st = self.plugin.config['do_not_send_os_info']
|
|
self.xml.get_widget('do_not_send_os_info_checkbutton').set_active(st)
|
|
self.xml.signal_autoconnect(self)
|
|
|
|
self.sound_tree.get_model().connect('row-changed', \
|
|
self.on_sounds_treemodel_row_changed)
|
|
self.msg_tree.get_model().connect('row-changed', \
|
|
self.on_msg_treemodel_row_changed)
|
|
self.msg_tree.get_model().connect('row-deleted', \
|
|
self.on_msg_treemodel_row_deleted)
|
|
|
|
|
|
class Account_modification_window:
|
|
"""Class for account informations"""
|
|
def on_account_modification_window_destroy(self, widget):
|
|
"""close window"""
|
|
del self.plugin.windows['account_modification']
|
|
|
|
def on_close_button_clicked(self, widget):
|
|
"""When Close button is clicked"""
|
|
widget.get_toplevel().destroy()
|
|
|
|
def on_checkbutton_toggled(self, widget, widgets):
|
|
"""set or unset sensitivity of widgets when widget is toggled"""
|
|
for w in widgets:
|
|
w.set_sensitive(widget.get_active())
|
|
|
|
def init_account(self, infos):
|
|
"""Initialize window with defaults values"""
|
|
if infos.has_key('accname'):
|
|
self.xml.get_widget('name_entry').set_text(infos['accname'])
|
|
if infos.has_key('jid'):
|
|
self.xml.get_widget('jid_entry').set_text(infos['jid'])
|
|
if infos.has_key('savepass'):
|
|
self.xml.get_widget('save_password_checkbutton').set_active(\
|
|
infos['savepass'])
|
|
if infos['savepass']:
|
|
password_entry = self.xml.get_widget('password_entry')
|
|
password_entry.set_sensitive(True)
|
|
if infos.has_key('password'):
|
|
password_entry.set_text(infos['password'])
|
|
if infos.has_key('resource'):
|
|
self.xml.get_widget('resource_entry').set_text(infos['resource'])
|
|
if infos.has_key('priority'):
|
|
self.xml.get_widget('priority_spinbutton').set_value(infos['priority'])
|
|
if infos.has_key('use_proxy'):
|
|
self.xml.get_widget('use_proxy_checkbutton').\
|
|
set_active(infos['use_proxy'])
|
|
if infos.has_key('proxyhost'):
|
|
self.xml.get_widget('proxyhost_entry').set_text(infos['proxyhost'])
|
|
if infos.has_key('proxyport'):
|
|
self.xml.get_widget('proxyport_entry').set_text(str(\
|
|
infos['proxyport']))
|
|
gpg_key_label = self.xml.get_widget('gpg_key_label')
|
|
if not self.plugin.config.has_key('usegpg'):
|
|
gpg_key_label.set_text('GPG is not usable on this computer')
|
|
self.xml.get_widget('gpg_choose_button').set_sensitive(False)
|
|
if infos.has_key('keyid') and self.plugin.config.has_key('usegpg'):
|
|
if infos['keyid'] and self.plugin.config['usegpg']:
|
|
gpg_key_label.set_text(infos['keyid'])
|
|
if infos.has_key('keyname'):
|
|
self.xml.get_widget('gpg_name_label').set_text(infos['keyname'])
|
|
gpg_save_password_checkbutton = \
|
|
self.xml.get_widget('gpg_save_password_checkbutton')
|
|
gpg_save_password_checkbutton.set_sensitive(True)
|
|
if infos.has_key('savegpgpass'):
|
|
gpg_save_password_checkbutton.set_active(infos['savegpgpass'])
|
|
if infos['savegpgpass']:
|
|
gpg_password_entry = self.xml.get_widget('gpg_password_entry')
|
|
gpg_password_entry.set_sensitive(True)
|
|
if infos.has_key('gpgpassword'):
|
|
gpg_password_entry.set_text(infos['gpgpassword'])
|
|
if infos.has_key('autoconnect'):
|
|
self.xml.get_widget('autoconnect_checkbutton').set_active(\
|
|
infos['autoconnect'])
|
|
if infos.has_key('sync_with_global_status'):
|
|
self.xml.get_widget('sync_with_global_status_checkbutton').set_active(\
|
|
infos['sync_with_global_status'])
|
|
if infos.has_key('no_log_for'):
|
|
list_no_log_for = infos['no_log_for'].split()
|
|
if infos['accname'] in list_no_log_for:
|
|
self.xml.get_widget('log_history_checkbutton').set_active(0)
|
|
|
|
def on_save_button_clicked(self, widget):
|
|
"""When save button is clicked : Save informations in config file"""
|
|
save_password = 0
|
|
if self.xml.get_widget('save_password_checkbutton').get_active():
|
|
save_password = 1
|
|
password = self.xml.get_widget('password_entry').get_text()
|
|
resource = self.xml.get_widget('resource_entry').get_text()
|
|
priority = self.xml.get_widget('priority_spinbutton').get_value_as_int()
|
|
new_account_checkbutton = self.xml.get_widget('new_account_checkbutton')
|
|
name = self.xml.get_widget('name_entry').get_text()
|
|
if self.plugin.connected.has_key(self.account):
|
|
if name != self.account and self.plugin.connected[self.account] != 0:
|
|
Error_dialog(_('You must be offline to change the account\'s name'))
|
|
return
|
|
jid = self.xml.get_widget('jid_entry').get_text()
|
|
autoconnect = 0
|
|
if self.xml.get_widget('autoconnect_checkbutton').get_active():
|
|
autoconnect = 1
|
|
|
|
if not self.infos.has_key('no_log_for'):
|
|
self.infos['no_log_for'] = ''
|
|
list_no_log_for = self.infos['no_log_for'].split()
|
|
if self.account in list_no_log_for:
|
|
list_no_log_for.remove(self.account)
|
|
if not self.xml.get_widget('log_history_checkbutton').get_active():
|
|
list_no_log_for.append(name)
|
|
self.infos['no_log_for'] = ' '.join(list_no_log_for)
|
|
|
|
sync_with_global_status = 0
|
|
if self.xml.get_widget('sync_with_global_status_checkbutton').\
|
|
get_active():
|
|
sync_with_global_status = 1
|
|
|
|
use_proxy = 0
|
|
if self.xml.get_widget('use_proxy_checkbutton').get_active():
|
|
use_proxy = 1
|
|
proxyhost = self.xml.get_widget('proxyhost_entry').get_text()
|
|
proxyport = self.xml.get_widget('proxyport_entry').get_text()
|
|
if (name == ''):
|
|
Error_dialog(_('You must enter a name for this account'))
|
|
return
|
|
if name.find(' ') != -1:
|
|
Error_dialog(_('Spaces are not permited in account name'))
|
|
return
|
|
if (jid == '') or (jid.count('@') != 1):
|
|
Error_dialog(_('You must enter a Jabber ID for this account\nFor example: someone@someserver.org'))
|
|
return
|
|
if new_account_checkbutton.get_active() and password == '':
|
|
Error_dialog(_('You must enter a password to register a new account'))
|
|
return
|
|
if use_proxy:
|
|
if proxyport != '':
|
|
try:
|
|
proxyport = int(proxyport)
|
|
except ValueError:
|
|
Error_dialog(_('Proxy Port must be a port number'))
|
|
return
|
|
if proxyhost == '':
|
|
Error_dialog(_('You must enter a proxy host to use proxy'))
|
|
|
|
(login, hostname) = jid.split('@')
|
|
key_name = self.xml.get_widget('gpg_name_label').get_text()
|
|
if key_name == '': #no key selected
|
|
keyID = ''
|
|
save_gpg_password = 0
|
|
gpg_password = ''
|
|
else:
|
|
keyID = self.xml.get_widget('gpg_key_label').get_text()
|
|
save_gpg_password = 0
|
|
if self.xml.get_widget('gpg_save_password_checkbutton').get_active():
|
|
save_gpg_password = 1
|
|
gpg_password = self.xml.get_widget('gpg_password_entry').get_text()
|
|
#if we are modifying an account
|
|
if self.modify:
|
|
#if we modify the name of the account
|
|
if name != self.account:
|
|
#update variables
|
|
self.plugin.windows[name] = self.plugin.windows[self.account]
|
|
self.plugin.queues[name] = self.plugin.queues[self.account]
|
|
self.plugin.connected[name] = self.plugin.connected[self.account]
|
|
self.plugin.nicks[name] = self.plugin.nicks[self.account]
|
|
self.plugin.roster.groups[name] = \
|
|
self.plugin.roster.groups[self.account]
|
|
self.plugin.roster.contacts[name] = \
|
|
self.plugin.roster.contacts[self.account]
|
|
self.plugin.roster.newly_added[name] = \
|
|
self.plugin.roster.newly_added[self.account]
|
|
self.plugin.roster.to_be_removed[name] = \
|
|
self.plugin.roster.to_be_removed[self.account]
|
|
self.plugin.sleeper_state[name] = \
|
|
self.plugin.sleeper_state[self.account]
|
|
#upgrade account variable in opened windows
|
|
for kind in ['infos', 'chats', 'gc']:
|
|
for j in self.plugin.windows[name][kind]:
|
|
self.plugin.windows[name][kind][j].account = name
|
|
#upgrade account in systray
|
|
for list in self.plugin.systray.jids:
|
|
if list[0] == self.account:
|
|
list[0] = name
|
|
del self.plugin.windows[self.account]
|
|
del self.plugin.queues[self.account]
|
|
del self.plugin.connected[self.account]
|
|
del self.plugin.nicks[self.account]
|
|
del self.plugin.roster.groups[self.account]
|
|
del self.plugin.roster.contacts[self.account]
|
|
del self.plugin.accounts[self.account]
|
|
del self.plugin.sleeper_state[self.account]
|
|
self.plugin.send('ACC_CHG', self.account, name)
|
|
self.plugin.accounts[name] = {'name': login, 'hostname': hostname,\
|
|
'savepass': save_password, 'password': password, \
|
|
'resource': resource, 'priority' : priority, \
|
|
'autoconnect': autoconnect, 'use_proxy': use_proxy, 'proxyhost': \
|
|
proxyhost, 'proxyport': proxyport, 'keyid': keyID, \
|
|
'keyname': key_name, 'savegpgpass': save_gpg_password, \
|
|
'gpgpassword': gpg_password, 'sync_with_global_status': \
|
|
sync_with_global_status, 'no_log_for': self.infos['no_log_for']}
|
|
self.plugin.send('CONFIG', None, ('accounts', self.plugin.accounts, \
|
|
'GtkGui'))
|
|
if save_password:
|
|
self.plugin.send('PASSPHRASE', name, password)
|
|
#refresh accounts window
|
|
if self.plugin.windows.has_key('accounts'):
|
|
self.plugin.windows['accounts'].init_accounts()
|
|
#refresh roster
|
|
self.plugin.roster.draw_roster()
|
|
widget.get_toplevel().destroy()
|
|
return
|
|
#if it's a new account
|
|
if name in self.plugin.accounts.keys():
|
|
Error_dialog(_('An account already has this name'))
|
|
return
|
|
#if we neeed to register a new account
|
|
if new_account_checkbutton.get_active():
|
|
self.plugin.send('NEW_ACC', None, (hostname, login, password, name, \
|
|
resource, priority, use_proxy, proxyhost, proxyport))
|
|
return
|
|
self.plugin.accounts[name] = {'name': login, 'hostname': hostname,\
|
|
'savepass': save_password, 'password': password, 'resource': \
|
|
resource, 'priority' : priority, 'autoconnect': autoconnect, \
|
|
'use_proxy': use_proxy, 'proxyhost': proxyhost, \
|
|
'proxyport': proxyport, 'keyid': keyID, 'keyname': key_name, \
|
|
'savegpgpass': save_gpg_password, 'gpgpassword': gpg_password,\
|
|
'sync_with_global_status': 1, 'no_log_for': self.infos['no_log_for']}
|
|
self.plugin.send('CONFIG', None, ('accounts', self.plugin.accounts, \
|
|
'GtkGui'))
|
|
if save_password:
|
|
self.plugin.send('PASSPHRASE', name, password)
|
|
#update variables
|
|
self.plugin.windows[name] = {'infos': {}, 'chats': {}, 'gc': {}}
|
|
self.plugin.queues[name] = {}
|
|
self.plugin.connected[name] = 0
|
|
self.plugin.roster.groups[name] = {}
|
|
self.plugin.roster.contacts[name] = {}
|
|
self.plugin.roster.newly_added[name] = []
|
|
self.plugin.roster.to_be_removed[name] = []
|
|
self.plugin.nicks[name] = login
|
|
self.plugin.sleeper_state[name] = 0
|
|
#refresh accounts window
|
|
if self.plugin.windows.has_key('accounts'):
|
|
self.plugin.windows['accounts'].init_accounts()
|
|
#refresh roster
|
|
self.plugin.roster.draw_roster()
|
|
widget.get_toplevel().destroy()
|
|
|
|
def on_change_password_button_clicked(self, widget):
|
|
dialog = Change_password_dialog(self.plugin, self.account)
|
|
new_password = dialog.run()
|
|
if new_password != -1:
|
|
self.plugin.send('CHANGE_PASSWORD', self.account,\
|
|
(new_password, self.plugin.nicks[self.account]))
|
|
if self.xml.get_widget('save_password_checkbutton').get_active():
|
|
self.xml.get_widget('password_entry').set_text(new_password)
|
|
|
|
def account_is_ok(self, acct):
|
|
"""When the account has been created with sucess"""
|
|
self.xml.get_widget('new_account_checkbutton').set_active(False)
|
|
self.modify = True
|
|
self.account = acct
|
|
jid = self.xml.get_widget('jid_entry').get_text()
|
|
(login, hostname) = jid.split('@')
|
|
save_password = 0
|
|
password = self.xml.get_widget('password_entry').get_text()
|
|
resource = self.xml.get_widget('resource_entry').get_text()
|
|
priority = self.xml.get_widget('priority_spinbutton').get_value_as_int()
|
|
autoconnect = 0
|
|
if self.xml.get_widget('autoconnect_checkbutton').get_active():
|
|
autoconnect = 1
|
|
use_proxy = 0
|
|
if self.xml.get_widget('use_proxy_checkbutton').get_active():
|
|
use_proxy = 1
|
|
proxyhost = self.xml.get_widget('proxyhost_entry').get_text()
|
|
proxyport = self.xml.get_widget('proxyport_entry').get_text()
|
|
key_name = self.xml.get_widget('gpg_name_label').get_text()
|
|
if self.xml.get_widget('save_password_checkbutton').get_active():
|
|
save_password = 1
|
|
if key_name == '': #no key selected
|
|
keyID = ''
|
|
save_gpg_password = 0
|
|
gpg_password = ''
|
|
else:
|
|
keyID = self.xml.get_widget('gpg_key_label').get_text()
|
|
save_gpg_password = 0
|
|
if self.xml.get_widget('gpg_save_password_checkbutton').get_active():
|
|
save_gpg_password = 1
|
|
gpg_password = self.xml.get_widget('gpg_password_entry').get_text()
|
|
no_log_for = ''
|
|
if self.xml.get_widget('log_history_checkbutton').get_active():
|
|
no_log_for = acct
|
|
self.plugin.accounts[acct] = {'name': login, 'hostname': hostname,\
|
|
'savepass': save_password, 'password': password, 'resource': \
|
|
resource, 'priority' : priority, 'autoconnect': autoconnect, \
|
|
'use_proxy': use_proxy, 'proxyhost': proxyhost, \
|
|
'proxyport': proxyport, 'keyid': keyID, 'keyname': key_name, \
|
|
'savegpgpass': save_gpg_password, 'gpgpassword': gpg_password,\
|
|
'sync_with_global_status': 1, 'no_log_for': no_log_for}
|
|
self.plugin.send('CONFIG', None, ('accounts', self.plugin.accounts, \
|
|
'GtkGui'))
|
|
|
|
def on_edit_details_button_clicked(self, widget):
|
|
if not self.plugin.windows.has_key(self.account):
|
|
Error_dialog(_('You must first create your account before editing your information'))
|
|
return
|
|
jid = self.xml.get_widget('jid_entry').get_text()
|
|
if self.plugin.connected[self.account] < 2:
|
|
Error_dialog(_('You must be connected to edit your information'))
|
|
return
|
|
if not self.plugin.windows[self.account]['infos'].has_key('vcard'):
|
|
self.plugin.windows[self.account]['infos'][jid] = \
|
|
vcard_information_window(jid, self.plugin, self.account, True)
|
|
self.plugin.send('ASK_VCARD', self.account, jid)
|
|
|
|
def on_gpg_choose_button_clicked(self, widget, data=None):
|
|
w = choose_gpg_key_dialog()
|
|
self.plugin.windows['gpg_keys'] = w
|
|
self.plugin.send('GPG_SECRETE_KEYS', None, ())
|
|
keyID = w.run()
|
|
if keyID == -1:
|
|
return
|
|
gpg_save_password_checkbutton = \
|
|
self.xml.get_widget('gpg_save_password_checkbutton')
|
|
gpg_key_label = self.xml.get_widget('gpg_key_label')
|
|
gpg_name_label = self.xml.get_widget('gpg_name_label')
|
|
if keyID[0] == 'None':
|
|
gpg_key_label.set_text(_('No key selected'))
|
|
gpg_name_label.set_text('')
|
|
gpg_save_password_checkbutton.set_sensitive(False)
|
|
self.xml.get_widget('gpg_password_entry').set_sensitive(False)
|
|
else:
|
|
gpg_key_label.set_text(keyID[0])
|
|
gpg_name_label.set_text(keyID[1])
|
|
gpg_save_password_checkbutton.set_sensitive(True)
|
|
gpg_save_password_checkbutton.set_active(False)
|
|
self.xml.get_widget('gpg_password_entry').set_text('')
|
|
|
|
def on_checkbutton_toggled_and_clear(self, widget, widgets):
|
|
self.on_checkbutton_toggled(widget, widgets)
|
|
for w in widgets:
|
|
if not widget.get_active():
|
|
w.set_text('')
|
|
|
|
def on_gpg_save_password_checkbutton_toggled(self, widget):
|
|
self.on_checkbutton_toggled_and_clear(widget, [\
|
|
self.xml.get_widget('gpg_password_entry')])
|
|
|
|
def on_save_password_checkbutton_toggled(self, widget):
|
|
if self.xml.get_widget('new_account_checkbutton').get_active():
|
|
return
|
|
self.on_checkbutton_toggled_and_clear(widget, \
|
|
[self.xml.get_widget('password_entry')])
|
|
self.xml.get_widget('password_entry').grab_focus()
|
|
|
|
def on_new_account_checkbutton_toggled(self, widget):
|
|
password_entry = self.xml.get_widget('password_entry')
|
|
if widget.get_active():
|
|
password_entry.set_sensitive(True)
|
|
elif not self.xml.get_widget('save_password_checkbutton').get_active():
|
|
password_entry.set_sensitive(False)
|
|
password_entry.set_text('')
|
|
|
|
#infos must be a dictionnary
|
|
def __init__(self, plugin, infos):
|
|
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'account_modification_window', APP)
|
|
self.window = self.xml.get_widget('account_modification_window')
|
|
self.plugin = plugin
|
|
self.account = ''
|
|
self.modify = False
|
|
self.infos = infos
|
|
self.xml.get_widget('gpg_key_label').set_text('No key selected')
|
|
self.xml.get_widget('gpg_name_label').set_text('')
|
|
self.xml.get_widget('gpg_save_password_checkbutton').set_sensitive(False)
|
|
self.xml.get_widget('gpg_password_entry').set_sensitive(False)
|
|
self.xml.get_widget('password_entry').set_sensitive(False)
|
|
self.xml.get_widget('log_history_checkbutton').set_active(1)
|
|
#default is checked
|
|
self.xml.get_widget('sync_with_global_status_checkbutton').set_active(1)
|
|
self.xml.signal_autoconnect(self)
|
|
if infos:
|
|
self.modify = True
|
|
self.account = infos['accname']
|
|
self.init_account(infos)
|
|
self.xml.get_widget('new_account_checkbutton').set_sensitive(False)
|
|
self.xml.get_widget('save_button').grab_focus()
|
|
self.window.show_all()
|
|
|
|
class Accounts_window:
|
|
"""Class for accounts window: lists of accounts"""
|
|
def on_accounts_window_destroy(self, widget):
|
|
del self.plugin.windows['accounts']
|
|
|
|
def on_close_button_clicked(self, widget):
|
|
widget.get_toplevel().destroy()
|
|
|
|
def init_accounts(self):
|
|
"""initialize listStore with existing accounts"""
|
|
self.modify_button.set_sensitive(False)
|
|
self.delete_button.set_sensitive(False)
|
|
model = self.accounts_treeview.get_model()
|
|
model.clear()
|
|
for account in self.plugin.accounts:
|
|
iter = model.append()
|
|
model.set(iter, 0, account, 1,\
|
|
self.plugin.accounts[account]['hostname'])
|
|
|
|
def on_accounts_treeview_cursor_changed(self, widget):
|
|
"""Activate delete and modify buttons when a row is selected"""
|
|
self.modify_button.set_sensitive(True)
|
|
self.delete_button.set_sensitive(True)
|
|
|
|
def on_new_button_clicked(self, widget):
|
|
"""When new button is clicked : open an account information window"""
|
|
if not self.plugin.windows.has_key('account_modification_window'):
|
|
self.plugin.windows['account_modification'] = \
|
|
Account_modification_window(self.plugin, {}) #find out what's wrong
|
|
else:
|
|
self.plugin.windows['account_modification'].window.present()
|
|
|
|
def on_delete_button_clicked(self, widget):
|
|
"""When delete button is clicked :
|
|
Remove an account from the listStore and from the config file"""
|
|
sel = self.accounts_treeview.get_selection()
|
|
(model, iter) = sel.get_selected()
|
|
account = model.get_value(iter, 0)
|
|
dialog = Confirmation_dialog(_('Are you sure you want to remove account (%s) ?') % account)
|
|
if dialog.get_response() == gtk.RESPONSE_YES:
|
|
if self.plugin.connected[account]:
|
|
self.plugin.send('STATUS', account, ('offline', 'offline'))
|
|
del self.plugin.accounts[account]
|
|
self.plugin.send('CONFIG', None, ('accounts', self.plugin.accounts, \
|
|
'GtkGui'))
|
|
del self.plugin.windows[account]
|
|
del self.plugin.queues[account]
|
|
del self.plugin.connected[account]
|
|
del self.plugin.roster.groups[account]
|
|
del self.plugin.roster.contacts[account]
|
|
self.plugin.roster.draw_roster()
|
|
self.init_accounts()
|
|
|
|
def on_modify_button_clicked(self, widget):
|
|
"""When modify button is clicked :
|
|
open the account information window for this account"""
|
|
if not self.plugin.windows.has_key('account_modification_window'):
|
|
sel = self.accounts_treeview.get_selection()
|
|
(model, iter) = sel.get_selected()
|
|
account = model.get_value(iter, 0)
|
|
infos = self.plugin.accounts[account]
|
|
infos['accname'] = account
|
|
infos['jid'] = self.plugin.accounts[account]['name'] + \
|
|
'@' + self.plugin.accounts[account]['hostname']
|
|
self.plugin.windows['account_modification'] = \
|
|
Account_modification_window(self.plugin, infos) # may it messes with this one
|
|
else:
|
|
self.plugin.windows['account_modification'].window.present()
|
|
|
|
def on_sync_with_global_status_checkbutton_toggled(self, widget):
|
|
if widget.get_active():
|
|
self.plugin.accounts[account]['sync_with_global_status'] = 0
|
|
else:
|
|
self.plugin.accounts[account]['sync_with_global_status'] = 1
|
|
|
|
def __init__(self, plugin):
|
|
self.plugin = plugin
|
|
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'accounts_window', APP)
|
|
self.window = self.xml.get_widget('accounts_window')
|
|
self.accounts_treeview = self.xml.get_widget('accounts_treeview')
|
|
self.modify_button = self.xml.get_widget('modify_button')
|
|
self.delete_button = self.xml.get_widget('delete_button')
|
|
model = gtk.ListStore(gobject.TYPE_STRING, gobject.TYPE_STRING, \
|
|
gobject.TYPE_BOOLEAN)
|
|
self.accounts_treeview.set_model(model)
|
|
#columns
|
|
renderer = gtk.CellRendererText()
|
|
self.accounts_treeview.insert_column_with_attributes(-1, _('Name'), renderer, \
|
|
text=0)
|
|
renderer = gtk.CellRendererText()
|
|
self.accounts_treeview.insert_column_with_attributes(-1, _('Server'), \
|
|
renderer, text=1)
|
|
self.xml.signal_autoconnect(self)
|
|
self.init_accounts()
|
|
self.window.show_all()
|
|
|
|
class Service_registration_window:
|
|
"""Class for Service registration window:
|
|
Window that appears when we want to subscribe to a service"""
|
|
def on_cancel_button_clicked(self, widget):
|
|
"""When Cancel button is clicked"""
|
|
widget.get_toplevel().destroy()
|
|
|
|
def draw_table(self):
|
|
"""Draw the table in the window"""
|
|
nbrow = 0
|
|
table = self.xml.get_widget('table')
|
|
for name in self.infos.keys():
|
|
if name != 'key' and name != 'instructions' and name != 'x':
|
|
nbrow = nbrow + 1
|
|
table.resize(rows=nbrow, columns=2)
|
|
label = gtk.Label(name.capitalize() + ':')
|
|
table.attach(label, 0, 1, nbrow-1, nbrow, 0, 0, 0, 0)
|
|
entry = gtk.Entry()
|
|
entry.set_text(self.infos[name])
|
|
table.attach(entry, 1, 2, nbrow-1, nbrow, 0, 0, 0, 0)
|
|
self.entries[name] = entry
|
|
if nbrow == 1:
|
|
entry.grab_focus()
|
|
table.show_all()
|
|
|
|
def on_ok_button_clicked(self, widget):
|
|
"""When Ok button is clicked :
|
|
send registration info to the core"""
|
|
for name in self.entries.keys():
|
|
self.infos[name] = self.entries[name].get_text()
|
|
user1 = gtkgui.User(self.service, self.service, ['Agents'], 'offline', \
|
|
'offline', 'from', '', '', 0, '')
|
|
self.plugin.roster.contacts[self.account][self.service] = [user1]
|
|
self.plugin.roster.add_user_to_roster(self.service, self.account)
|
|
self.plugin.send('REG_AGENT', self.account, self.service)
|
|
widget.get_toplevel().destroy()
|
|
|
|
def __init__(self, service, infos, plugin, account):
|
|
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'service_registration_window', APP)
|
|
self.service = service
|
|
self.infos = infos
|
|
self.plugin = plugin
|
|
self.account = account
|
|
window = self.xml.get_widget('service_registration_window')
|
|
window.set_title(_('Register to %s') % service)
|
|
self.xml.get_widget('label').set_text(infos['instructions'])
|
|
self.entries = {}
|
|
self.draw_table()
|
|
self.xml.signal_autoconnect(self)
|
|
self.window.show_all()
|
|
|
|
|
|
class Add_remove_emoticons_window:
|
|
def __init__(self, plugin):
|
|
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'add_remove_emoticons_window', APP)
|
|
self.window = self.xml.get_widget('add_remove_emoticons_window')
|
|
self.plugin = plugin
|
|
|
|
#emoticons
|
|
self.emot_tree = self.xml.get_widget('emoticons_treeview')
|
|
model = gtk.ListStore(gobject.TYPE_STRING, gobject.TYPE_STRING, gtk.Image)
|
|
self.emot_tree.set_model(model)
|
|
col = gtk.TreeViewColumn(_('Name'))
|
|
self.emot_tree.append_column(col)
|
|
renderer = gtk.CellRendererText()
|
|
renderer.connect('edited', self.on_emot_cell_edited)
|
|
renderer.set_property('editable', True)
|
|
col.pack_start(renderer, True)
|
|
col.set_attributes(renderer, text=0)
|
|
|
|
col = gtk.TreeViewColumn(_('Image'))
|
|
self.emot_tree.append_column(col)
|
|
renderer = gtkgui.CellRendererImage()
|
|
col.pack_start(renderer, expand = False)
|
|
col.add_attribute(renderer, 'image', 2)
|
|
|
|
self.fill_emot_treeview()
|
|
self.emot_tree.get_model().connect('row-changed', \
|
|
self.on_emoticons_treemodel_row_changed)
|
|
self.emot_tree.get_model().connect('row-deleted', \
|
|
self.on_emoticons_treemodel_row_deleted)
|
|
|
|
self.plugin = plugin
|
|
self.xml.signal_autoconnect(self)
|
|
self.window.show_all()
|
|
|
|
def on_add_remove_emoticons_window_delete_event(self, widget, event):
|
|
self.window.hide()
|
|
return True # do NOT destroy the window
|
|
|
|
def on_close_button_clicked(self, widget):
|
|
self.window.hide()
|
|
|
|
def on_emoticons_treemodel_row_deleted(self, model, path):
|
|
iter = model.get_iter_first()
|
|
emots = []
|
|
while iter:
|
|
emots.append(model.get_value(iter, 0))
|
|
emots.append(model.get_value(iter, 1))
|
|
iter = model.iter_next(iter)
|
|
self.plugin.config['emoticons'] = '\t'.join(emots)
|
|
self.plugin.init_regexp()
|
|
|
|
def on_emoticons_treemodel_row_changed(self, model, path, iter):
|
|
if model[path][1] != None and len(model[path][1]) != 0:
|
|
iter = model.get_iter_first()
|
|
emots = []
|
|
while iter:
|
|
emots.append(model.get_value(iter, 0))
|
|
emots.append(model.get_value(iter, 1))
|
|
iter = model.iter_next(iter)
|
|
self.plugin.config['emoticons'] = '\t'.join(emots)
|
|
self.plugin.init_regexp()
|
|
|
|
def image_is_ok(self, image):
|
|
if not os.path.exists(image):
|
|
return 0
|
|
img = gtk.Image()
|
|
try:
|
|
img.set_from_file(image)
|
|
except:
|
|
return 0
|
|
if img.get_storage_type() == gtk.IMAGE_PIXBUF:
|
|
pix = img.get_pixbuf()
|
|
else:
|
|
return 0
|
|
if pix.get_width() > 24 or pix.get_height() > 24:
|
|
return 0
|
|
return 1
|
|
|
|
def load_emots(self):
|
|
emots = {}
|
|
split_line = self.plugin.config['emoticons'].split('\t')
|
|
for i in range(0, len(split_line)/2):
|
|
if not self.image_is_ok(split_line[2*i+1]):
|
|
continue
|
|
emots[split_line[2*i]] = split_line[2*i+1]
|
|
return emots
|
|
|
|
def fill_emot_treeview(self):
|
|
model = self.emot_tree.get_model()
|
|
model.clear()
|
|
emots = self.load_emots()
|
|
for i in emots:
|
|
file = emots[i]
|
|
iter = model.append((i, file, None))
|
|
if not os.path.exists(file):
|
|
continue
|
|
img = gtk.Image()
|
|
img.show()
|
|
if file.find('.gif') != -1:
|
|
pix = gtk.gdk.PixbufAnimation(file)
|
|
img.set_from_animation(pix)
|
|
else:
|
|
pix = gtk.gdk.pixbuf_new_from_file(file)
|
|
img.set_from_pixbuf(pix)
|
|
model.set(iter, 2, img)
|
|
|
|
def on_emot_cell_edited(self, cell, row, new_text):
|
|
model = self.emot_tree.get_model()
|
|
iter = model.get_iter_from_string(row)
|
|
model.set_value(iter, 0, new_text)
|
|
|
|
def on_set_image_button_clicked(self, widget, data=None):
|
|
(model, iter) = self.emot_tree.get_selection().get_selected()
|
|
if not iter:
|
|
return
|
|
file = model.get_value(iter, 1)
|
|
dialog = gtk.FileChooserDialog("Choose image",
|
|
None,
|
|
gtk.FILE_CHOOSER_ACTION_OPEN,
|
|
(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL,
|
|
gtk.STOCK_OPEN, gtk.RESPONSE_OK))
|
|
dialog.set_default_response(gtk.RESPONSE_OK)
|
|
filter = gtk.FileFilter()
|
|
filter.set_name("All files")
|
|
filter.add_pattern("*")
|
|
dialog.add_filter(filter)
|
|
|
|
filter = gtk.FileFilter()
|
|
filter.set_name("Images")
|
|
filter.add_mime_type("image/png")
|
|
filter.add_mime_type("image/jpeg")
|
|
filter.add_mime_type("image/gif")
|
|
filter.add_pattern("*.png")
|
|
filter.add_pattern("*.jpg")
|
|
filter.add_pattern("*.gif")
|
|
filter.add_pattern("*.tif")
|
|
filter.add_pattern("*.xpm")
|
|
dialog.add_filter(filter)
|
|
dialog.set_filter(filter)
|
|
|
|
file = os.path.join(os.getcwd(), file)
|
|
dialog.set_filename(file)
|
|
file = ''
|
|
ok = 0
|
|
while(ok == 0):
|
|
response = dialog.run()
|
|
if response == gtk.RESPONSE_OK:
|
|
file = dialog.get_filename()
|
|
if self.image_is_ok(file):
|
|
ok = 1
|
|
else:
|
|
ok = 1
|
|
dialog.destroy()
|
|
if file:
|
|
model.set_value(iter, 1, file)
|
|
img = gtk.Image()
|
|
img.show()
|
|
if file.find('.gif') != -1:
|
|
pix = gtk.gdk.PixbufAnimation(file)
|
|
img.set_from_animation(pix)
|
|
else:
|
|
pix = gtk.gdk.pixbuf_new_from_file(file)
|
|
img.set_from_pixbuf(pix)
|
|
model.set(iter, 2, img)
|
|
|
|
def on_button_new_emoticon_clicked(self, widget, data=None):
|
|
model = self.emot_tree.get_model()
|
|
iter = model.append()
|
|
model.set(iter, 0, 'emoticon', 1, '')
|
|
col = self.emot_tree.get_column(0)
|
|
self.emot_tree.set_cursor(model.get_path(iter), col, True)
|
|
|
|
def on_button_remove_emoticon_clicked(self, widget, data=None):
|
|
(model, iter) = self.emot_tree.get_selection().get_selected()
|
|
if not iter:
|
|
return
|
|
model.remove(iter)
|
|
|
|
def on_emoticons_treeview_key_press_event(self, widget, event):
|
|
if event.keyval == gtk.keysyms.Delete:
|
|
self.on_button_remove_emoticon_clicked(widget)
|
|
|
|
|
|
class Service_discovery_window:
|
|
"""Class for Service Discovery Window:
|
|
to know the services on the selected server"""
|
|
def on_service_discovery_window_destroy(self, widget):
|
|
"""close window"""
|
|
del self.plugin.windows[self.account]['disco']
|
|
|
|
def on_close_button_clicked(self, widget):
|
|
"""When Close button is clicked"""
|
|
widget.get_toplevel().destroy()
|
|
|
|
def browse(self, jid):
|
|
"""Send a request to the core to know the available services"""
|
|
model = self.services_treeview.get_model()
|
|
if not model.get_iter_first():
|
|
# we begin to fill the treevier with the first line
|
|
iter = model.append(None, (jid, jid))
|
|
self.agent_infos[jid] = {'features' : []}
|
|
self.plugin.send('REQ_AGENTS', self.account, jid)
|
|
|
|
def agents(self, agents):
|
|
"""When list of available agent arrive :
|
|
Fill the treeview with it"""
|
|
model = self.services_treeview.get_model()
|
|
for agent in agents:
|
|
iter = model.append(None, (agent['name'], agent['jid']))
|
|
self.agent_infos[agent['jid']] = {'features' : []}
|
|
|
|
def iter_is_visible(self, iter):
|
|
if not iter:
|
|
return False
|
|
model = self.services_treeview.get_model()
|
|
iter = model.iter_parent(iter)
|
|
while iter:
|
|
if not self.services_treeview.row_expanded(model.get_path(iter)):
|
|
return False
|
|
iter = model.iter_parent(iter)
|
|
return True
|
|
|
|
def on_services_treeview_row_expanded(self, widget, iter, path):
|
|
model = self.services_treeview.get_model()
|
|
jid = model.get_value(iter, 1)
|
|
child = model.iter_children(iter)
|
|
while child:
|
|
child_jid = model.get_value(child, 1)
|
|
# We never requested its infos
|
|
if not self.agent_infos[child_jid].has_key('features'):
|
|
self.browse(child_jid)
|
|
child = model.iter_next(child)
|
|
|
|
def agent_info_info(self, agent, identities, features):
|
|
"""When we recieve informations about an agent, but not its items"""
|
|
self.agent_info(agent, identities, features, [])
|
|
|
|
def agent_info_items(self, agent, items):
|
|
"""When we recieve items about an agent"""
|
|
model = self.services_treeview.get_model()
|
|
iter = model.get_iter_root()
|
|
# We look if this agent is in the treeview
|
|
while (iter):
|
|
if agent == model.get_value(iter, 1):
|
|
break
|
|
if model.iter_has_child(iter):
|
|
iter = model.iter_children(iter)
|
|
else:
|
|
if not model.iter_next(iter):
|
|
iter = model.iter_parent(iter)
|
|
if iter:
|
|
iter = model.iter_next(iter)
|
|
if not iter: #If it is not, we stop
|
|
return
|
|
expand = False
|
|
if len(model.get_path(iter)) == 1:
|
|
expand = True
|
|
for item in items:
|
|
name = ''
|
|
if item.has_key('name'):
|
|
name = item['name']
|
|
# We look if this item is already in the treeview
|
|
iter_child = model.iter_children(iter)
|
|
while iter_child:
|
|
if item['jid'] == model.get_value(iter_child, 1):
|
|
break
|
|
iter_child = model.iter_next(iter_child)
|
|
if not iter_child: # If it is not we add it
|
|
iter_child = model.append(iter, (name, item['jid']))
|
|
self.agent_infos[item['jid']] = {'identities': [item]}
|
|
if self.iter_is_visible(iter_child) or expand:
|
|
self.browse(item['jid'])
|
|
if expand:
|
|
self.services_treeview.expand_row((model.get_path(iter)), False)
|
|
|
|
def agent_info(self, agent, identities, features, items):
|
|
"""When we recieve informations about an agent"""
|
|
model = self.services_treeview.get_model()
|
|
iter = model.get_iter_root()
|
|
# We look if this agent is in the treeview
|
|
while (iter):
|
|
if agent == model.get_value(iter, 1):
|
|
break
|
|
if model.iter_has_child(iter):
|
|
iter = model.iter_children(iter)
|
|
else:
|
|
if not model.iter_next(iter):
|
|
iter = model.iter_parent(iter)
|
|
if iter:
|
|
iter = model.iter_next(iter)
|
|
if not iter: #If it is not we stop
|
|
return
|
|
self.agent_infos[agent]['features'] = features
|
|
if len(identities):
|
|
self.agent_infos[agent]['identities'] = identities
|
|
if identities[0].has_key('name'):
|
|
model.set_value(iter, 0, identities[0]['name'])
|
|
for item in items:
|
|
if not item.has_key('name'):
|
|
continue
|
|
# We look if this item is already in the treeview
|
|
iter_child = model.iter_children(iter)
|
|
while iter_child:
|
|
if item['jid'] == model.get_value(iter_child, 1):
|
|
break
|
|
iter_child = model.iter_next(iter_child)
|
|
if not iter_child: # If it is not we add it
|
|
iter_child = model.append(iter, (item['name'], item['jid']))
|
|
self.agent_infos[item['jid']] = {'identities': [item]}
|
|
if self.iter_is_visible(iter_child):
|
|
self.browse(item['jid'])
|
|
|
|
def on_refresh_button_clicked(self, widget):
|
|
"""When refresh button is clicked: refresh list: clear and rerequest it"""
|
|
self.services_treeview.get_model().clear()
|
|
jid = self.address_comboboxentry.child.get_text()
|
|
self.browse(jid)
|
|
|
|
def on_address_comboboxentry_changed(self, widget):
|
|
return # not ready
|
|
'is executed on each keypress'
|
|
text = self.comboboxentry_entry.get_text()
|
|
|
|
self.on_go_button_clicked(widget)
|
|
|
|
def on_address_comboboxentry_button_press_event(self, widget, event):
|
|
return # not ready
|
|
if event.click == 1: #Left click (user possibly selected sth)
|
|
pass
|
|
def on_services_treeview_row_activated(self, widget, path, col=0):
|
|
"""When a row is activated: Register or join the selected agent"""
|
|
#if both buttons are sensitive, it will register [default]
|
|
if self.register_button.get_property('sensitive'):
|
|
self.on_register_button_clicked(widget)
|
|
elif self.join_button.get_property('sensitive'):
|
|
self.on_join_button_clicked(widget)
|
|
|
|
def on_join_button_clicked(self, widget):
|
|
"""When we want to join a conference:
|
|
Ask specific informations about the selected agent and close the window"""
|
|
model, iter = self.services_treeview.get_selection().get_selected()
|
|
if not iter:
|
|
return
|
|
service = model.get_value(iter, 1)
|
|
room = ''
|
|
if service.find('@') > -1:
|
|
services = service.split('@')
|
|
room = services[0]
|
|
service = services[1]
|
|
if not self.plugin.windows.has_key('join_gc'):
|
|
self.plugin.windows['join_gc'] = Join_groupchat_window(self.plugin, self.account, service, room)
|
|
|
|
def on_register_button_clicked(self, widget):
|
|
"""When we want to register an agent :
|
|
Ask specific informations about the selected agent and close the window"""
|
|
model, iter = self.services_treeview.get_selection().get_selected()
|
|
if not iter :
|
|
return
|
|
service = model.get_value(iter, 1)
|
|
self.plugin.send('REG_AGENT_INFO', self.account, service)
|
|
widget.get_toplevel().destroy()
|
|
|
|
def on_services_treeview_cursor_changed(self, widget):
|
|
"""When we select a row :
|
|
activate buttons if needed"""
|
|
model, iter = self.services_treeview.get_selection().get_selected()
|
|
jid = model.get_value(iter, 1)
|
|
self.register_button.set_sensitive(False)
|
|
if self.agent_infos[jid].has_key('features'):
|
|
if common.jabber.NS_REGISTER in self.agent_infos[jid]['features']:
|
|
self.register_button.set_sensitive(True)
|
|
self.join_button.set_sensitive(False)
|
|
if self.agent_infos[jid].has_key('identities'):
|
|
if len(self.agent_infos[jid]['identities']):
|
|
if self.agent_infos[jid]['identities'][0].has_key('category'):
|
|
if self.agent_infos[jid]['identities'][0]['category'] == 'conference':
|
|
self.join_button.set_sensitive(True)
|
|
|
|
def on_go_button_clicked(self, widget):
|
|
server_address = self.address_comboboxentry.child.get_text()
|
|
if server_address in self.latest_addresses:
|
|
self.latest_addresses.remove(server_address)
|
|
self.latest_addresses.insert(0, server_address)
|
|
if len(self.latest_addresses) > 10:
|
|
self.latest_addresses = self.latest_addresses[0:10]
|
|
self.address_comboboxentry.get_model().clear()
|
|
for j in self.latest_addresses:
|
|
self.address_comboboxentry.append_text(j)
|
|
self.plugin.config['latest_disco_addresses'] = \
|
|
' '.join(self.latest_addresses)
|
|
self.services_treeview.get_model().clear()
|
|
self.browse(server_address)
|
|
|
|
def __init__(self, plugin, account):
|
|
if plugin.connected[account] < 2:
|
|
Error_dialog(_("You must be connected to browse services"))
|
|
return
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'service_discovery_window', APP)
|
|
self.window = xml.get_widget('service_discovery_window')
|
|
self.services_treeview = xml.get_widget('services_treeview')
|
|
self.join_button = xml.get_widget('join_button')
|
|
self.register_button = xml.get_widget('register_button')
|
|
self.address_comboboxentry = xml.get_widget('address_comboboxentry')
|
|
self.address_comboboxentry_entry = self.address_comboboxentry.child
|
|
self.address_comboboxentry_entry.set_activates_default(True)
|
|
self.plugin = plugin
|
|
self.account = account
|
|
self.agent_infos = {}
|
|
model = gtk.TreeStore(gobject.TYPE_STRING, gobject.TYPE_STRING)
|
|
self.services_treeview.set_model(model)
|
|
#columns
|
|
renderer = gtk.CellRendererText()
|
|
renderer.set_data('column', 0)
|
|
self.services_treeview.insert_column_with_attributes(-1, 'Name', \
|
|
renderer, text=0)
|
|
renderer = gtk.CellRendererText()
|
|
renderer.set_data('column', 1)
|
|
self.services_treeview.insert_column_with_attributes(-1, 'Service', \
|
|
renderer, text=1)
|
|
|
|
self.address_comboboxentry = xml.get_widget('address_comboboxentry')
|
|
liststore = gtk.ListStore(str)
|
|
self.address_comboboxentry.set_model(liststore)
|
|
self.address_comboboxentry.set_text_column(0)
|
|
self.latest_addresses = \
|
|
self.plugin.config['latest_disco_addresses'].split()
|
|
server_address = self.plugin.accounts[self.account]['hostname']
|
|
if server_address in self.latest_addresses:
|
|
self.latest_addresses.remove(server_address)
|
|
self.latest_addresses.insert(0, server_address)
|
|
if len(self.latest_addresses) > 10:
|
|
self.latest_addresses = self.latest_addresses[0:10]
|
|
for j in self.latest_addresses:
|
|
self.address_comboboxentry.append_text(j)
|
|
self.address_comboboxentry.child.set_text(server_address)
|
|
|
|
self.register_button = xml.get_widget('register_button')
|
|
self.register_button.set_sensitive(False)
|
|
self.join_button = xml.get_widget('join_button')
|
|
self.join_button.set_sensitive(False)
|
|
xml.signal_autoconnect(self)
|
|
self.browse(server_address)
|
|
self.window.show_all()
|