2003-11-30 23:40:24 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
## plugins/gtkgui.py
|
|
|
|
##
|
|
|
|
## Gajim Team:
|
|
|
|
## - Yann Le Boulanger <asterix@crans.org>
|
|
|
|
## - Vincent Hanquez <tab@tuxfamily.org>
|
|
|
|
##
|
|
|
|
## Copyright (C) 2003 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 pygtk
|
|
|
|
pygtk.require('2.0')
|
|
|
|
import gtk
|
|
|
|
from gtk import TRUE, FALSE
|
2004-01-02 16:21:02 +01:00
|
|
|
import gtk.glade,gobject
|
|
|
|
import os,string,time,Queue
|
|
|
|
import common.optparser,common.sleepy
|
2004-02-17 03:23:38 +01:00
|
|
|
browserWindow = 0
|
|
|
|
accountsWindow = 0
|
|
|
|
|
|
|
|
GTKGUI_GLADE='plugins/gtkgui/gtkgui.glade'
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
class user:
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Informations concerning each users"""
|
2003-11-30 23:40:24 +01:00
|
|
|
def __init__(self, *args):
|
|
|
|
if len(args) == 0:
|
|
|
|
self.jid = ''
|
|
|
|
self.name = ''
|
|
|
|
self.groups = []
|
|
|
|
self.show = ''
|
|
|
|
self.status = ''
|
|
|
|
self.sub == ''
|
2004-01-14 02:06:27 +01:00
|
|
|
self.resource == ''
|
|
|
|
elif len(args) == 7:
|
2003-11-30 23:40:24 +01:00
|
|
|
self.jid = args[0]
|
|
|
|
self.name = args[1]
|
|
|
|
self.groups = args[2]
|
|
|
|
self.show = args[3]
|
|
|
|
self.status = args[4]
|
|
|
|
self.sub = args[5]
|
2004-01-14 02:06:27 +01:00
|
|
|
self.resource = args[6]
|
2003-11-30 23:40:24 +01:00
|
|
|
else: raise TypeError, 'bad arguments'
|
|
|
|
|
2004-02-19 05:20:40 +01:00
|
|
|
class vCard_Window:
|
|
|
|
"""Class for window that show vCard information"""
|
|
|
|
def delete_event(self, widget):
|
|
|
|
"""close window"""
|
2004-02-21 19:57:29 +01:00
|
|
|
del self.r.tab_vcard[self.jid]
|
2004-03-11 18:07:36 +01:00
|
|
|
self.xml.get_widget("vcard").destroy()
|
2004-02-19 05:20:40 +01:00
|
|
|
|
|
|
|
def set_values(self, vcard):
|
|
|
|
for i in vcard.keys():
|
2004-02-21 19:57:29 +01:00
|
|
|
if type(vcard[i]) == type({}):
|
|
|
|
for j in vcard[i].keys():
|
|
|
|
try:
|
|
|
|
self.xml.get_widget('entry_'+i+'_'+j).set_text(vcard[i][j])
|
|
|
|
except AttributeError, e:
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
if i == 'DESC':
|
|
|
|
self.xml.get_widget('textview_DESC').get_buffer().\
|
|
|
|
set_text(vcard[i], 0)
|
|
|
|
else:
|
|
|
|
try:
|
|
|
|
self.xml.get_widget('entry_'+i).set_text(vcard[i])
|
|
|
|
except AttributeError, e:
|
|
|
|
pass
|
2004-02-19 05:20:40 +01:00
|
|
|
|
2004-02-21 19:57:29 +01:00
|
|
|
def add_to_vcard(self, vcard, entry, txt):
|
2004-03-11 18:07:36 +01:00
|
|
|
"""Add an information to the vCard dictionary"""
|
2004-02-21 19:57:29 +01:00
|
|
|
entries = string.split(entry, '_')
|
|
|
|
loc = vcard
|
|
|
|
while len(entries) > 1:
|
|
|
|
if not loc.has_key(entries[0]):
|
|
|
|
loc[entries[0]] = {}
|
|
|
|
loc = loc[entries[0]]
|
|
|
|
del entries[0]
|
|
|
|
loc[entries[0]] = txt
|
|
|
|
return vcard
|
|
|
|
|
2004-03-11 18:07:36 +01:00
|
|
|
def make_vcard(self):
|
|
|
|
"""make the vCard dictionary"""
|
2004-02-21 19:57:29 +01:00
|
|
|
entries = ['FN', 'NICKNAME', 'BDAY', 'EMAIL_USERID', 'URL', 'TEL_NUMBER',\
|
|
|
|
'ADR_STREET', 'ADR_EXTADR', 'ADR_LOCALITY', 'ADR_REGION', 'ADR_PCODE',\
|
|
|
|
'ADR_CTRY', 'ORG_ORGNAME', 'ORG_ORGUNIT', 'TITLE', 'ROLE']
|
|
|
|
vcard = {}
|
|
|
|
for e in entries:
|
|
|
|
txt = self.xml.get_widget('entry_'+e).get_text()
|
|
|
|
if txt != '':
|
|
|
|
vcard = self.add_to_vcard(vcard, e, txt)
|
|
|
|
buf = self.xml.get_widget('textview_DESC').get_buffer()
|
|
|
|
start_iter = buf.get_start_iter()
|
|
|
|
end_iter = buf.get_end_iter()
|
|
|
|
txt = buf.get_text(start_iter, end_iter, 0)
|
|
|
|
if txt != '':
|
|
|
|
vcard['DESC']= txt
|
2004-03-11 18:07:36 +01:00
|
|
|
return vcard
|
|
|
|
|
|
|
|
|
|
|
|
def on_retrieve(self, widget):
|
|
|
|
acct = self.plugin.accts.which_account(self.user)
|
|
|
|
if self.plugin.connected[acct]:
|
2004-03-11 22:14:09 +01:00
|
|
|
self.plugin.send('ASK_VCARD', acct, self.jid)
|
2004-03-11 18:07:36 +01:00
|
|
|
else:
|
|
|
|
warning_Window("You must be connected to get your informations")
|
|
|
|
|
|
|
|
def on_publish(self, widget):
|
|
|
|
acct = self.plugin.accts.which_account(self.user)
|
|
|
|
if not self.plugin.connected[acct]:
|
|
|
|
warning_Window("You must be connected to publish your informations")
|
|
|
|
return
|
|
|
|
vcard = self.make_vcard()
|
|
|
|
self.plugin.send('VCARD', acct, vcard)
|
2004-02-19 05:20:40 +01:00
|
|
|
|
2004-03-11 18:07:36 +01:00
|
|
|
def __init__(self, plugin, user):
|
2004-02-19 05:20:40 +01:00
|
|
|
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'vcard')
|
2004-03-11 18:07:36 +01:00
|
|
|
self.user = user
|
|
|
|
self.plugin = plugin
|
2004-02-19 05:20:40 +01:00
|
|
|
|
|
|
|
self.xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
|
|
|
self.xml.signal_connect('on_close_clicked', self.delete_event)
|
|
|
|
self.xml.signal_connect('on_retrieve_clicked', self.on_retrieve)
|
2004-02-21 19:57:29 +01:00
|
|
|
self.xml.signal_connect('on_publish_clicked', self.on_publish)
|
2004-02-19 05:20:40 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class infoUser_Window:
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Class for user's information window"""
|
2004-01-14 02:06:27 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
2004-02-21 19:57:29 +01:00
|
|
|
del self.r.tab_vcard[self.user.jid]
|
2004-01-14 02:06:27 +01:00
|
|
|
self.window.destroy()
|
|
|
|
|
|
|
|
def add_grp_to_user(self, model, path, iter):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Insert user to the group in inter"""
|
2004-01-14 02:06:27 +01:00
|
|
|
self.user.groups.append(model.get_value(iter, 0))
|
|
|
|
|
|
|
|
def on_close(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Save user's informations and update the roster on the Jabber server"""
|
2004-02-17 03:23:38 +01:00
|
|
|
#update: to know if things have changed to send things
|
|
|
|
# to server only if changes are done
|
|
|
|
update = 0
|
2004-01-22 00:09:03 +01:00
|
|
|
#update user.name if it's not ""
|
|
|
|
newName = self.entry_name.get_text()
|
2004-02-17 03:23:38 +01:00
|
|
|
if newName != self.user.name:
|
|
|
|
update = 1
|
|
|
|
if newName != '':
|
|
|
|
self.user.name = newName
|
2004-01-22 00:09:03 +01:00
|
|
|
#update user.groups and redraw the user in the roster
|
2004-02-17 03:23:38 +01:00
|
|
|
old_groups = self.user.groups
|
2004-01-22 00:09:03 +01:00
|
|
|
self.r.remove_user(self.user)
|
2004-01-14 02:06:27 +01:00
|
|
|
self.user.groups = []
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.list2.get_model()
|
|
|
|
model.foreach(self.add_grp_to_user)
|
2004-01-14 02:06:27 +01:00
|
|
|
self.r.add_user(self.user)
|
2004-02-17 03:23:38 +01:00
|
|
|
for g in old_groups:
|
|
|
|
if not g in self.user.groups:
|
|
|
|
update = 1
|
|
|
|
break
|
|
|
|
if not update:
|
|
|
|
for g in self.user.groups:
|
|
|
|
if not g in old_groups:
|
|
|
|
update = 1
|
|
|
|
break
|
|
|
|
if update:
|
|
|
|
self.r.queueOUT.put(('UPDUSER', (self.user.jid, self.user.name, \
|
|
|
|
self.user.groups)))
|
2004-01-14 02:06:27 +01:00
|
|
|
self.delete_event(self)
|
|
|
|
|
|
|
|
def add_grp(self, model, path, iter, stors):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Transfert the iter from stors[0] to stors[1]"""
|
2004-01-14 02:06:27 +01:00
|
|
|
i = stors[1].append()
|
|
|
|
stors[1].set(i, 0, stors[0].get_value(iter, 0))
|
|
|
|
stors[0].remove(iter)
|
|
|
|
|
|
|
|
def on_add(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""When Add button is clicked"""
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.list1.get_model()
|
2004-01-14 02:06:27 +01:00
|
|
|
select = self.list1.get_selection()
|
2004-01-18 23:56:28 +01:00
|
|
|
select.selected_foreach(self.add_grp, (model, self.list2.get_model()))
|
2004-01-14 02:06:27 +01:00
|
|
|
|
|
|
|
def on_remove(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""When Remove button is clicked"""
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.list2.get_model()
|
2004-01-14 02:06:27 +01:00
|
|
|
select = self.list2.get_selection()
|
2004-01-18 23:56:28 +01:00
|
|
|
select.selected_foreach(self.add_grp, (model, self.list1.get_model()))
|
2004-01-14 02:06:27 +01:00
|
|
|
|
|
|
|
def on_new_key_pressed(self, widget, event):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""If enter is pressed in new group entry, add the group"""
|
2004-01-14 02:06:27 +01:00
|
|
|
if event.keyval == gtk.keysyms.Return:
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.list1.get_model()
|
2004-01-14 02:06:27 +01:00
|
|
|
txt = self.entry_new.get_text()
|
2004-01-18 23:56:28 +01:00
|
|
|
iter = model.append()
|
|
|
|
model.set(iter, 0, txt)
|
2004-01-14 02:06:27 +01:00
|
|
|
self.entry_new.set_text('')
|
2004-01-17 16:38:29 +01:00
|
|
|
return 1
|
|
|
|
else:
|
|
|
|
return 0
|
2004-01-14 02:06:27 +01:00
|
|
|
|
2004-02-21 19:57:29 +01:00
|
|
|
def set_values(self, vcard):
|
|
|
|
self.vc = vcard
|
|
|
|
for i in vcard.keys():
|
|
|
|
if type(vcard[i]) == type({}):
|
|
|
|
for j in vcard[i].keys():
|
|
|
|
try:
|
|
|
|
self.xml.get_widget('entry_'+i+'_'+j).set_text(vcard[i][j])
|
|
|
|
except AttributeError, e:
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
if i == 'DESC':
|
|
|
|
self.xml.get_widget('textview_DESC').get_buffer().\
|
|
|
|
set_text(vcard[i], 0)
|
|
|
|
else:
|
|
|
|
try:
|
|
|
|
self.xml.get_widget('entry_'+i).set_text(vcard[i])
|
|
|
|
except AttributeError, e:
|
|
|
|
pass
|
|
|
|
|
2004-01-14 02:06:27 +01:00
|
|
|
def init_lists(self):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Initialize both available and current listStores"""
|
2004-01-14 02:06:27 +01:00
|
|
|
#list available
|
2004-01-18 23:56:28 +01:00
|
|
|
store = gtk.ListStore(gobject.TYPE_STRING)
|
2004-02-17 03:23:38 +01:00
|
|
|
for g in self.r.l_group.keys():
|
|
|
|
if g != 'Agents' and g not in self.user.groups:
|
2004-01-18 23:56:28 +01:00
|
|
|
iter = store.append()
|
2004-02-17 03:23:38 +01:00
|
|
|
store.set(iter, 0, g)
|
2004-01-18 23:56:28 +01:00
|
|
|
self.list1.set_model(store)
|
2004-01-14 02:06:27 +01:00
|
|
|
column = gtk.TreeViewColumn('Available', gtk.CellRendererText(), text=0)
|
|
|
|
self.list1.append_column(column)
|
|
|
|
|
|
|
|
#list_current
|
2004-01-18 23:56:28 +01:00
|
|
|
store = gtk.ListStore(gobject.TYPE_STRING)
|
2004-02-17 03:23:38 +01:00
|
|
|
for g in self.user.groups:
|
2004-01-18 23:56:28 +01:00
|
|
|
iter = store.append()
|
2004-02-17 03:23:38 +01:00
|
|
|
store.set(iter, 0, g)
|
2004-01-18 23:56:28 +01:00
|
|
|
self.list2.set_model(store)
|
2004-01-14 02:06:27 +01:00
|
|
|
column = gtk.TreeViewColumn('Available', gtk.CellRendererText(), text=0)
|
|
|
|
self.list2.append_column(column)
|
|
|
|
|
|
|
|
def __init__(self, user, roster):
|
2004-02-21 19:57:29 +01:00
|
|
|
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'Info_user')
|
|
|
|
self.window = self.xml.get_widget("Info_user")
|
2004-01-14 02:06:27 +01:00
|
|
|
self.r = roster
|
|
|
|
self.user = user
|
2004-02-21 19:57:29 +01:00
|
|
|
self.list1 = self.xml.get_widget("treeview_available")
|
|
|
|
self.list2 = self.xml.get_widget("treeview_current")
|
|
|
|
self.entry_new = self.xml.get_widget("entry_new")
|
|
|
|
|
|
|
|
self.xml.get_widget('label_name').set_text(user.name)
|
|
|
|
self.xml.get_widget('label_id').set_text(user.jid)
|
|
|
|
self.xml.get_widget('label_resource').set_text(user.resource)
|
|
|
|
self.xml.get_widget('label_sub').set_text(user.sub)
|
|
|
|
self.entry_name = self.xml.get_widget('entry_name')
|
2004-01-22 00:09:03 +01:00
|
|
|
self.entry_name.set_text(user.name)
|
2004-01-17 16:38:29 +01:00
|
|
|
if not user.status:
|
|
|
|
user.status = ''
|
2004-02-21 19:57:29 +01:00
|
|
|
self.xml.get_widget('label_status').set_text(user.show + ' : ' + \
|
2004-01-17 16:38:29 +01:00
|
|
|
user.status)
|
2004-01-14 02:06:27 +01:00
|
|
|
self.init_lists()
|
2004-02-21 19:57:29 +01:00
|
|
|
self.r.queueOUT.put(('ASK_VCARD', self.user.jid))
|
2004-01-14 02:06:27 +01:00
|
|
|
|
2004-02-21 19:57:29 +01:00
|
|
|
self.xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
|
|
|
self.xml.signal_connect('on_close_clicked', self.on_close)
|
|
|
|
self.xml.signal_connect('on_add_clicked', self.on_add)
|
|
|
|
self.xml.signal_connect('on_remove_clicked', self.on_remove)
|
|
|
|
self.xml.signal_connect('on_entry_new_key_press_event', \
|
2004-01-17 16:38:29 +01:00
|
|
|
self.on_new_key_pressed)
|
2004-01-14 02:06:27 +01:00
|
|
|
|
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class preference_Window:
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Class for Preferences window"""
|
2003-12-29 19:37:31 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
2003-12-29 19:37:31 +01:00
|
|
|
self.window.destroy()
|
|
|
|
|
|
|
|
def on_color_button_clicked(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Open a ColorSelectionDialog and change button's color"""
|
2003-12-29 19:37:31 +01:00
|
|
|
if widget.name == 'colorIn':
|
|
|
|
color = self.colorIn
|
|
|
|
da = self.da_in
|
|
|
|
elif widget.name == 'colorOut':
|
|
|
|
color = self.colorOut
|
|
|
|
da = self.da_out
|
|
|
|
elif widget.name == 'colorStatus':
|
|
|
|
color = self.colorStatus
|
|
|
|
da = self.da_status
|
|
|
|
colorseldlg = gtk.ColorSelectionDialog('Select Color')
|
|
|
|
colorsel = colorseldlg.colorsel
|
|
|
|
colorsel.set_previous_color(color)
|
|
|
|
colorsel.set_current_color(color)
|
|
|
|
colorsel.set_has_palette(gtk.TRUE)
|
|
|
|
response = colorseldlg.run()
|
|
|
|
if response == gtk.RESPONSE_OK:
|
|
|
|
color = colorsel.get_current_color()
|
|
|
|
da.modify_bg(gtk.STATE_NORMAL, color)
|
|
|
|
if widget.name == 'colorIn':
|
|
|
|
self.colorIn = color
|
|
|
|
elif widget.name == 'colorOut':
|
|
|
|
self.colorOut = color
|
|
|
|
elif widget.name == 'colorStatus':
|
|
|
|
self.colorStatus = color
|
|
|
|
colorseldlg.destroy()
|
|
|
|
|
|
|
|
def write_cfg(self):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Save preferences in config File and apply them"""
|
2003-12-29 19:37:31 +01:00
|
|
|
#Color for incomming messages
|
|
|
|
colSt = '#'+(hex(self.colorIn.red)+'0')[2:4]\
|
|
|
|
+(hex(self.colorIn.green)+'0')[2:4]\
|
|
|
|
+(hex(self.colorIn.blue)+'0')[2:4]
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.plugin.config['inmsgcolor'] = colSt
|
2003-12-29 19:37:31 +01:00
|
|
|
for j in self.r.tab_messages.keys():
|
|
|
|
self.r.tab_messages[j].tagIn.set_property("foreground", colSt)
|
|
|
|
#Color for outgoing messages
|
|
|
|
colSt = '#'+(hex(self.colorOut.red)+'0')[2:4]\
|
|
|
|
+(hex(self.colorOut.green)+'0')[2:4]\
|
|
|
|
+(hex(self.colorOut.blue)+'0')[2:4]
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.plugin.config['outmsgcolor'] = colSt
|
2003-12-29 19:37:31 +01:00
|
|
|
for j in self.r.tab_messages.keys():
|
|
|
|
self.r.tab_messages[j].tagOut.set_property("foreground", colSt)
|
|
|
|
#Color for status messages
|
|
|
|
colSt = '#'+(hex(self.colorStatus.red)+'0')[2:4]\
|
|
|
|
+(hex(self.colorStatus.green)+'0')[2:4]\
|
|
|
|
+(hex(self.colorStatus.blue)+'0')[2:4]
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.plugin.config['statusmsgcolor'] = colSt
|
2003-12-29 19:37:31 +01:00
|
|
|
for j in self.r.tab_messages.keys():
|
|
|
|
self.r.tab_messages[j].tagStatus.set_property("foreground", colSt)
|
2004-01-02 16:21:02 +01:00
|
|
|
#IconStyle
|
|
|
|
ist = self.combo_iconstyle.entry.get_text()
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.plugin.config['iconstyle'] = ist
|
2004-01-02 16:21:02 +01:00
|
|
|
self.r.iconstyle = ist
|
|
|
|
self.r.mkpixbufs()
|
2003-12-29 19:37:31 +01:00
|
|
|
#autopopup
|
|
|
|
pp = self.chk_autopp.get_active()
|
|
|
|
if pp == True:
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.plugin.config['autopopup'] = 1
|
2003-12-29 19:37:31 +01:00
|
|
|
else:
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.plugin.config['autopopup'] = 0
|
2004-01-02 16:21:02 +01:00
|
|
|
#autoaway
|
|
|
|
aw = self.chk_autoaway.get_active()
|
|
|
|
if aw == True:
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.plugin.config['autoaway'] = 1
|
2004-01-02 16:21:02 +01:00
|
|
|
else:
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.plugin.config['autoaway'] = 0
|
2004-01-02 16:21:02 +01:00
|
|
|
aat = self.spin_autoawaytime.get_value_as_int()
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.plugin.config['autoawaytime'] = aat
|
2004-01-03 00:27:28 +01:00
|
|
|
#autoxa
|
|
|
|
xa = self.chk_autoxa.get_active()
|
|
|
|
if xa == True:
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.plugin.config['autoxa'] = 1
|
2004-01-03 00:27:28 +01:00
|
|
|
else:
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.plugin.config['autoxa'] = 0
|
2004-01-03 00:27:28 +01:00
|
|
|
axt = self.spin_autoxatime.get_value_as_int()
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.plugin.config['autoxatime'] = axt
|
2004-01-03 00:27:28 +01:00
|
|
|
if self.r.plugin.sleeper:
|
|
|
|
self.r.plugin.sleeper = common.sleepy.Sleepy(\
|
|
|
|
self.r.plugin.autoawaytime*60, self.r.plugin.autoxatime*60)
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.queueOUT.put(('CONFIG', ('GtkGui', self.r.plugin.config)))
|
2003-12-31 11:55:13 +01:00
|
|
|
|
|
|
|
self.r.redraw_roster()
|
2003-12-29 19:37:31 +01:00
|
|
|
|
|
|
|
def on_ok(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""When Ok button is clicked"""
|
2003-12-29 19:37:31 +01:00
|
|
|
self.write_cfg()
|
|
|
|
self.window.destroy()
|
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
def change_notebook_page(self, number):
|
|
|
|
self.notebook.set_current_page(number)
|
|
|
|
|
|
|
|
def on_lookfeel_button_clicked(self, widget, data=None):
|
|
|
|
self.change_notebook_page(0)
|
|
|
|
|
|
|
|
def on_events_button_clicked(self, widget, data=None):
|
|
|
|
self.change_notebook_page(1)
|
|
|
|
|
|
|
|
def on_presence_button_clicked(self, widget, data=None):
|
|
|
|
self.change_notebook_page(2)
|
|
|
|
|
2003-12-29 19:37:31 +01:00
|
|
|
def __init__(self, roster):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Initialize Preference window"""
|
2004-02-17 03:23:38 +01:00
|
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'preferences_window')
|
|
|
|
self.window = xml.get_widget('preferences_window')
|
2003-12-29 19:37:31 +01:00
|
|
|
self.r = roster
|
2004-02-17 03:23:38 +01:00
|
|
|
self.da_in = xml.get_widget('drawing_in')
|
|
|
|
self.da_out = xml.get_widget('drawing_out')
|
|
|
|
self.da_status = xml.get_widget('drawing_status')
|
|
|
|
self.combo_iconstyle = xml.get_widget('combo_iconstyle')
|
|
|
|
self.chk_autopp = xml.get_widget('chk_autopopup')
|
|
|
|
self.chk_autoaway = xml.get_widget('chk_autoaway')
|
|
|
|
self.spin_autoawaytime = xml.get_widget('spin_autoawaytime')
|
|
|
|
self.chk_autoxa = xml.get_widget('chk_autoxa')
|
|
|
|
self.spin_autoxatime = xml.get_widget('spin_autoxatime')
|
|
|
|
self.notebook = xml.get_widget('preferences_notebook')
|
|
|
|
|
|
|
|
button = xml.get_widget('lookfeel_button')
|
|
|
|
button.connect('clicked', self.on_lookfeel_button_clicked)
|
|
|
|
button = xml.get_widget('events_button')
|
|
|
|
button.connect('clicked', self.on_events_button_clicked)
|
|
|
|
button = xml.get_widget('presence_button')
|
|
|
|
button.connect('clicked', self.on_presence_button_clicked)
|
2003-12-29 19:37:31 +01:00
|
|
|
|
|
|
|
#Color for incomming messages
|
2004-01-24 21:32:51 +01:00
|
|
|
colSt = self.r.plugin.config['inmsgcolor']
|
2003-12-29 19:37:31 +01:00
|
|
|
if not colSt:
|
|
|
|
colSt = '#ff0000'
|
|
|
|
cmapIn = self.da_in.get_colormap()
|
|
|
|
self.colorIn = cmapIn.alloc_color(colSt)
|
|
|
|
self.da_in.window.set_background(self.colorIn)
|
|
|
|
|
|
|
|
#Color for outgoing messages
|
2004-01-24 21:32:51 +01:00
|
|
|
colSt = self.r.plugin.config['outmsgcolor']
|
2003-12-29 19:37:31 +01:00
|
|
|
if not colSt:
|
|
|
|
colSt = '#0000ff'
|
|
|
|
cmapOut = self.da_out.get_colormap()
|
|
|
|
self.colorOut = cmapOut.alloc_color(colSt)
|
|
|
|
self.da_out.window.set_background(self.colorOut)
|
|
|
|
|
|
|
|
#Color for status messages
|
2004-01-24 21:32:51 +01:00
|
|
|
colSt = self.r.plugin.config['statusmsgcolor']
|
2003-12-29 19:37:31 +01:00
|
|
|
if not colSt:
|
|
|
|
colSt = '#00ff00'
|
|
|
|
cmapStatus = self.da_status.get_colormap()
|
|
|
|
self.colorStatus = cmapStatus.alloc_color(colSt)
|
|
|
|
self.da_status.window.set_background(self.colorStatus)
|
|
|
|
|
2003-12-30 02:07:38 +01:00
|
|
|
#iconStyle
|
|
|
|
list_style = os.listdir('plugins/gtkgui/icons/')
|
|
|
|
l = []
|
|
|
|
for i in list_style:
|
|
|
|
if i != 'CVS':
|
|
|
|
l.append(i)
|
|
|
|
if l.count == 0:
|
|
|
|
l.append(" ")
|
|
|
|
self.combo_iconstyle.set_popdown_strings(l)
|
|
|
|
if self.r.iconstyle in l:
|
|
|
|
self.combo_iconstyle.entry.set_text(self.r.iconstyle)
|
2003-12-29 19:37:31 +01:00
|
|
|
|
2004-01-02 16:21:02 +01:00
|
|
|
#Autopopup
|
2004-02-17 03:23:38 +01:00
|
|
|
st = 0
|
2004-01-24 21:32:51 +01:00
|
|
|
if self.r.plugin.config.has_key('autopopup'):
|
|
|
|
st = self.r.plugin.config['autopopup']
|
|
|
|
self.chk_autopp.set_active(st)
|
2004-01-02 16:21:02 +01:00
|
|
|
|
|
|
|
#Autoaway
|
2004-02-17 03:23:38 +01:00
|
|
|
st = 1
|
2004-01-24 21:32:51 +01:00
|
|
|
if self.r.plugin.config.has_key('autoaway'):
|
|
|
|
st = self.r.plugin.config['autoaway']
|
|
|
|
self.chk_autoaway.set_active(st)
|
2004-02-17 03:23:38 +01:00
|
|
|
|
|
|
|
#Autoawaytime
|
|
|
|
st = 10
|
2004-01-24 21:32:51 +01:00
|
|
|
if self.r.plugin.config.has_key('autoawaytime'):
|
|
|
|
st = self.r.plugin.config['autoawaytime']
|
|
|
|
self.spin_autoawaytime.set_value(st)
|
2004-01-02 16:21:02 +01:00
|
|
|
|
2004-01-03 00:27:28 +01:00
|
|
|
#Autoxa
|
2004-02-17 03:23:38 +01:00
|
|
|
st = 1
|
2004-01-24 21:32:51 +01:00
|
|
|
if self.r.plugin.config.has_key('autoxa'):
|
|
|
|
st = self.r.plugin.config['autoxa']
|
|
|
|
self.chk_autoxa.set_active(st)
|
2004-02-17 03:23:38 +01:00
|
|
|
|
|
|
|
#Autoxatime
|
|
|
|
st = 20
|
2004-01-24 21:32:51 +01:00
|
|
|
if self.r.plugin.config.has_key('autoxatime'):
|
|
|
|
st = self.r.plugin.config['autoxatime']
|
|
|
|
self.spin_autoxatime.set_value(st)
|
2004-01-03 00:27:28 +01:00
|
|
|
|
2004-01-18 23:56:28 +01:00
|
|
|
xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
|
|
|
xml.signal_connect('on_but_col_clicked', \
|
2004-01-17 16:38:29 +01:00
|
|
|
self.on_color_button_clicked)
|
2004-01-18 23:56:28 +01:00
|
|
|
xml.signal_connect('on_ok_clicked', self.on_ok)
|
2003-12-29 19:37:31 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class awayMsg_Window:
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Class for Away Message Window"""
|
2004-01-14 02:06:27 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
|
|
|
self.window.destroy()
|
2004-01-14 02:06:27 +01:00
|
|
|
|
|
|
|
def on_ok(self):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""When Ok button is clicked"""
|
2004-01-14 02:06:27 +01:00
|
|
|
beg, end = self.txtBuffer.get_bounds()
|
|
|
|
self.msg = self.txtBuffer.get_text(beg, end, 0)
|
|
|
|
self.window.destroy()
|
|
|
|
|
|
|
|
def run(self):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Wait for Ok button to be pressed and return away messsage"""
|
2004-01-14 02:06:27 +01:00
|
|
|
rep = self.window.run()
|
2004-02-17 03:23:38 +01:00
|
|
|
msg = ''
|
2004-01-14 02:06:27 +01:00
|
|
|
if rep == gtk.RESPONSE_OK:
|
2004-01-18 23:56:28 +01:00
|
|
|
beg, end = self.txtBuffer.get_bounds()
|
|
|
|
msg = self.txtBuffer.get_text(beg, end, 0)
|
|
|
|
self.window.destroy()
|
|
|
|
return msg
|
2004-01-14 02:06:27 +01:00
|
|
|
|
|
|
|
def __init__(self):
|
2004-02-17 03:23:38 +01:00
|
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'Away_msg')
|
2004-01-18 23:56:28 +01:00
|
|
|
self.window = xml.get_widget("Away_msg")
|
|
|
|
txt = xml.get_widget("textview")
|
|
|
|
self.txtBuffer = txt.get_buffer()
|
|
|
|
xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
2004-01-14 02:06:27 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class addContact_Window:
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Class for Add user window"""
|
2003-11-30 23:40:24 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
2003-11-30 23:40:24 +01:00
|
|
|
self.Wadd.destroy()
|
|
|
|
|
|
|
|
def on_subscribe(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""When Subscribe button is clicked"""
|
2004-01-20 13:46:27 +01:00
|
|
|
who = self.entry_who.get_text()
|
|
|
|
buf = self.textview_sub.get_buffer()
|
2003-11-30 23:40:24 +01:00
|
|
|
start_iter = buf.get_start_iter()
|
|
|
|
end_iter = buf.get_end_iter()
|
|
|
|
txt = buf.get_text(start_iter, end_iter, 0)
|
|
|
|
self.r.req_sub(self, who, txt)
|
|
|
|
self.delete_event(self)
|
|
|
|
|
|
|
|
def __init__(self, roster, jid=None):
|
|
|
|
self.r = roster
|
2004-02-17 03:23:38 +01:00
|
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'Add')
|
2004-01-20 13:46:27 +01:00
|
|
|
self.entry_who = xml.get_widget('entry_who')
|
|
|
|
self.textview_sub = xml.get_widget("textview_sub")
|
2003-11-30 23:40:24 +01:00
|
|
|
if jid:
|
2004-01-20 13:46:27 +01:00
|
|
|
self.entry_who.set_text(jid)
|
2004-01-18 23:56:28 +01:00
|
|
|
self.Wadd = xml.get_widget("Add")
|
|
|
|
xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
|
|
|
xml.signal_connect('on_button_sub_clicked', self.on_subscribe)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class warning_Window:
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Class for warning window : print a warning message"""
|
2003-12-14 01:47:00 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
2003-12-14 01:47:00 +01:00
|
|
|
self.window.destroy()
|
|
|
|
|
|
|
|
def __init__(self, txt):
|
2004-02-17 03:23:38 +01:00
|
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'Warning')
|
2004-01-18 23:56:28 +01:00
|
|
|
self.window = xml.get_widget("Warning")
|
|
|
|
xml.get_widget('label').set_text(txt)
|
|
|
|
xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
2003-12-14 01:47:00 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class about_Window:
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Class for about window"""
|
2003-11-30 23:40:24 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
2003-11-30 23:40:24 +01:00
|
|
|
self.Wabout.destroy()
|
|
|
|
|
|
|
|
def __init__(self):
|
2004-02-17 03:23:38 +01:00
|
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'About')
|
2004-01-18 23:56:28 +01:00
|
|
|
self.Wabout = xml.get_widget("About")
|
|
|
|
xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class accountPreference_Window:
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Class for account informations"""
|
2003-12-11 23:26:29 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
2003-12-11 23:26:29 +01:00
|
|
|
self.window.destroy()
|
|
|
|
|
|
|
|
def init_account(self, infos):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Initialize window with defaults values"""
|
2003-12-11 23:26:29 +01:00
|
|
|
if infos.has_key('name'):
|
2004-01-18 23:56:28 +01:00
|
|
|
self.entryName.set_text(infos['name'])
|
2003-12-11 23:26:29 +01:00
|
|
|
if infos.has_key('jid'):
|
2004-01-18 23:56:28 +01:00
|
|
|
self.entryJid.set_text(infos['jid'])
|
2003-12-11 23:26:29 +01:00
|
|
|
if infos.has_key('password'):
|
2004-01-18 23:56:28 +01:00
|
|
|
self.entryPass.set_text(infos['password'])
|
2003-12-11 23:26:29 +01:00
|
|
|
if infos.has_key('ressource'):
|
2004-01-18 23:56:28 +01:00
|
|
|
self.entryRessource.set_text(infos['ressource'])
|
2003-12-11 23:26:29 +01:00
|
|
|
|
|
|
|
def on_save_clicked(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""When save button is clicked : Save informations in config file"""
|
2004-01-18 23:56:28 +01:00
|
|
|
name = self.entryName.get_text()
|
|
|
|
jid = self.entryJid.get_text()
|
2003-12-11 23:26:29 +01:00
|
|
|
if (name == ''):
|
2004-02-17 03:23:38 +01:00
|
|
|
warning_Window('You must enter a name for this account')
|
2003-12-11 23:26:29 +01:00
|
|
|
return 0
|
2003-12-14 01:47:00 +01:00
|
|
|
if (jid == '') or (string.count(jid, '@') != 1):
|
2004-02-17 03:23:38 +01:00
|
|
|
warning_Window('You must enter a Jabber ID for this account\n\
|
2004-01-24 21:32:51 +01:00
|
|
|
For example : login@hostname')
|
2003-12-14 01:47:00 +01:00
|
|
|
return 0
|
|
|
|
else:
|
|
|
|
(login, hostname) = string.split(jid, '@')
|
|
|
|
#if we are modifying an account
|
2003-12-11 23:26:29 +01:00
|
|
|
if self.mod:
|
2003-12-14 01:47:00 +01:00
|
|
|
#if we modify the name of the account
|
2003-12-11 23:26:29 +01:00
|
|
|
if name != self.acc:
|
2004-01-24 21:32:51 +01:00
|
|
|
del self.accs.r.plugin.accounts[self.acc]
|
2003-12-14 01:47:00 +01:00
|
|
|
#if it's a new account
|
2003-12-11 23:26:29 +01:00
|
|
|
else:
|
2004-02-25 01:33:06 +01:00
|
|
|
if name in self.accs.r.plugin.accounts:
|
2004-02-17 03:23:38 +01:00
|
|
|
warning_Window('An account already has this name')
|
2003-12-11 23:26:29 +01:00
|
|
|
return 0
|
2003-12-14 01:47:00 +01:00
|
|
|
#if we neeed to register a new account
|
2004-01-18 23:56:28 +01:00
|
|
|
if self.check.get_active():
|
2003-12-14 01:47:00 +01:00
|
|
|
self.accs.r.queueOUT.put(('NEW_ACC', (hostname, login, \
|
2004-01-18 23:56:28 +01:00
|
|
|
self.entryPass.get_text(), name, \
|
|
|
|
self.entryRessource.get_text())))
|
|
|
|
self.check.set_active(FALSE)
|
2003-12-14 01:47:00 +01:00
|
|
|
return 1
|
2004-01-24 21:32:51 +01:00
|
|
|
self.accs.r.plugin.accounts[name] = {'name': login, 'hostname': hostname,\
|
|
|
|
'password': self.entryPass.get_text(), 'ressource': \
|
|
|
|
self.entryRessource.get_text()}
|
|
|
|
self.accs.r.queueOUT.put(('CONFIG', ('accounts', \
|
|
|
|
self.accs.r.plugin.accounts)))
|
2003-12-11 23:26:29 +01:00
|
|
|
self.accs.init_accounts()
|
2004-01-14 02:06:27 +01:00
|
|
|
self.delete_event(self)
|
2004-02-19 05:20:40 +01:00
|
|
|
|
|
|
|
def on_edit_details_clicked(self, widget):
|
2004-02-21 19:57:29 +01:00
|
|
|
if not self.accs.r.tab_vcard.has_key(self.entryJid.get_text()):
|
|
|
|
self.accs.r.tab_vcard[self.entryJid.get_text()] = vCard_Window(self, self.entryJid.get_text())
|
2004-03-01 02:39:12 +01:00
|
|
|
if self.accs.r.connected:
|
|
|
|
self.accs.r.queueOUT.put(('ASK_VCARD', self.entryJid.get_text()))
|
|
|
|
else:
|
|
|
|
warning_Window("You must be connected to get your informations")
|
2003-12-11 23:26:29 +01:00
|
|
|
|
|
|
|
#info must be a dictionnary
|
|
|
|
def __init__(self, accs, infos = {}):
|
2004-02-17 03:23:38 +01:00
|
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'Account')
|
2004-01-18 23:56:28 +01:00
|
|
|
self.window = xml.get_widget("Account")
|
|
|
|
self.entryPass = xml.get_widget("entry_password")
|
|
|
|
self.entryRessource = xml.get_widget("entry_ressource")
|
|
|
|
self.check = xml.get_widget("checkbutton")
|
|
|
|
self.entryName = xml.get_widget("entry_name")
|
|
|
|
self.entryJid = xml.get_widget("entry_jid")
|
2003-12-11 23:26:29 +01:00
|
|
|
self.accs = accs
|
2004-02-17 03:23:38 +01:00
|
|
|
self.mod = FALSE
|
2003-12-11 23:26:29 +01:00
|
|
|
if infos:
|
|
|
|
self.mod = TRUE
|
|
|
|
self.acc = infos['name']
|
|
|
|
self.init_account(infos)
|
2004-01-24 21:32:51 +01:00
|
|
|
self.check.set_sensitive(FALSE)
|
2004-01-18 23:56:28 +01:00
|
|
|
xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
|
|
|
xml.signal_connect('on_save_clicked', self.on_save_clicked)
|
2004-02-19 05:20:40 +01:00
|
|
|
xml.signal_connect('on_edit_details_clicked', self.on_edit_details_clicked)
|
2003-12-11 23:26:29 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class accounts_Window:
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Class for accounts window : lists of accounts"""
|
2003-11-30 23:40:24 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
2004-02-17 03:23:38 +01:00
|
|
|
global accountsWindow
|
|
|
|
accountsWindow = 0
|
2003-11-30 23:40:24 +01:00
|
|
|
self.window.destroy()
|
|
|
|
|
2003-12-11 23:26:29 +01:00
|
|
|
def init_accounts(self):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""initialize listStore with existing accounts"""
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.treeview.get_model()
|
|
|
|
model.clear()
|
2004-02-17 19:40:14 +01:00
|
|
|
for account in self.r.plugin.accounts.keys():
|
2004-01-18 23:56:28 +01:00
|
|
|
iter = model.append()
|
2004-01-24 21:32:51 +01:00
|
|
|
model.set(iter, 0, account, 1, \
|
|
|
|
self.r.plugin.accounts[account]["hostname"])
|
2003-12-11 23:26:29 +01:00
|
|
|
|
|
|
|
def on_row_activated(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""Activate delete and modify buttons when a row is selected"""
|
2003-12-11 23:26:29 +01:00
|
|
|
self.modButt.set_sensitive(TRUE)
|
|
|
|
self.delButt.set_sensitive(TRUE)
|
|
|
|
|
|
|
|
def on_new_clicked(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""When new button is clicked : open an account information window"""
|
2004-02-17 03:23:38 +01:00
|
|
|
accountPreference_Window(self)
|
2003-12-11 23:26:29 +01:00
|
|
|
|
|
|
|
def on_delete_clicked(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""When delete button is clicked :
|
|
|
|
Remove an account from the listStore and from the config file"""
|
2003-12-11 23:26:29 +01:00
|
|
|
sel = self.treeview.get_selection()
|
|
|
|
(mod, iter) = sel.get_selected()
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.treeview.get_model()
|
|
|
|
account = model.get_value(iter, 0)
|
2004-02-25 01:33:06 +01:00
|
|
|
del self.r.plugin.accounts[account]
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.queueOUT.put(('CONFIG', ('accounts', self.r.plugin.accounts)))
|
2003-12-11 23:26:29 +01:00
|
|
|
self.init_accounts()
|
|
|
|
|
|
|
|
def on_modify_clicked(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""When modify button is clicked :
|
|
|
|
open the account information window for this account"""
|
2003-12-11 23:26:29 +01:00
|
|
|
infos = {}
|
|
|
|
sel = self.treeview.get_selection()
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.treeview.get_model()
|
2003-12-11 23:26:29 +01:00
|
|
|
(mod, iter) = sel.get_selected()
|
2004-01-18 23:56:28 +01:00
|
|
|
account = model.get_value(iter, 0)
|
2003-12-11 23:26:29 +01:00
|
|
|
infos['name'] = account
|
2004-01-24 21:32:51 +01:00
|
|
|
infos['jid'] = self.r.plugin.accounts[account]["name"] + \
|
|
|
|
'@' + self.r.plugin.accounts[account]["hostname"]
|
|
|
|
infos['password'] = self.r.plugin.accounts[account]["password"]
|
|
|
|
infos['ressource'] = self.r.plugin.accounts[account]["ressource"]
|
2004-02-17 03:23:38 +01:00
|
|
|
accountPreference_Window(self, infos)
|
2003-12-11 23:26:29 +01:00
|
|
|
|
2003-12-14 01:47:00 +01:00
|
|
|
def __init__(self, roster):
|
|
|
|
self.r = roster
|
2004-02-17 03:23:38 +01:00
|
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'Accounts')
|
2004-01-18 23:56:28 +01:00
|
|
|
self.window = xml.get_widget("Accounts")
|
|
|
|
self.treeview = xml.get_widget("treeview")
|
|
|
|
self.modButt = xml.get_widget("modify_button")
|
|
|
|
self.delButt = xml.get_widget("delete_button")
|
|
|
|
model = gtk.ListStore(gobject.TYPE_STRING, gobject.TYPE_STRING)
|
|
|
|
self.treeview.set_model(model)
|
2003-12-11 23:26:29 +01:00
|
|
|
#columns
|
|
|
|
renderer = gtk.CellRendererText()
|
|
|
|
renderer.set_data('column', 0)
|
|
|
|
self.treeview.insert_column_with_attributes(-1, 'Name', renderer, text=0)
|
|
|
|
renderer = gtk.CellRendererText()
|
|
|
|
renderer.set_data('column', 1)
|
2004-01-24 21:32:51 +01:00
|
|
|
self.treeview.insert_column_with_attributes(-1, 'Server', \
|
|
|
|
renderer, text=1)
|
2004-01-18 23:56:28 +01:00
|
|
|
xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
|
|
|
xml.signal_connect('on_row_activated', self.on_row_activated)
|
|
|
|
xml.signal_connect('on_new_clicked', self.on_new_clicked)
|
|
|
|
xml.signal_connect('on_delete_clicked', self.on_delete_clicked)
|
|
|
|
xml.signal_connect('on_modify_clicked', self.on_modify_clicked)
|
2003-12-11 23:26:29 +01:00
|
|
|
self.init_accounts()
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class confirm_Window:
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Class for confirmation window :
|
|
|
|
window that appears to confirm the removal of a contact"""
|
2003-11-30 23:40:24 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
2003-11-30 23:40:24 +01:00
|
|
|
self.window.destroy()
|
|
|
|
|
|
|
|
def req_usub(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When Ok button is clicked :
|
2004-01-24 21:32:51 +01:00
|
|
|
Send a message to the core to remove the user
|
|
|
|
and remove it from the roster"""
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.r.tree.get_model()
|
|
|
|
jid = model.get_value(self.iter, 2)
|
|
|
|
self.r.queueOUT.put(('UNSUB', jid))
|
2004-01-22 00:09:03 +01:00
|
|
|
self.r.remove_user(self.r.l_contact[jid]['user'])
|
2004-01-18 23:56:28 +01:00
|
|
|
del self.r.l_contact[jid]
|
2003-11-30 23:40:24 +01:00
|
|
|
self.delete_event(self)
|
|
|
|
|
|
|
|
def __init__(self, roster, iter):
|
2004-02-17 03:23:38 +01:00
|
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'Confirm')
|
2004-01-18 23:56:28 +01:00
|
|
|
self.window = xml.get_widget('Confirm')
|
2003-11-30 23:40:24 +01:00
|
|
|
self.r = roster
|
|
|
|
self.iter = iter
|
2004-01-18 23:56:28 +01:00
|
|
|
jid = self.r.tree.get_model().get_value(iter, 2)
|
2004-01-24 21:32:51 +01:00
|
|
|
xml.get_widget('label_confirm').set_text(\
|
|
|
|
'Are you sure you want to remove ' + jid + ' from your roster ?')
|
2004-01-18 23:56:28 +01:00
|
|
|
xml.signal_connect('on_okbutton_clicked', self.req_usub)
|
|
|
|
xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class authorize_Window:
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Class for authorization window :
|
|
|
|
window that appears when a user wants to add us to his/her roster"""
|
2003-11-30 23:40:24 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
2003-11-30 23:40:24 +01:00
|
|
|
self.window.destroy()
|
|
|
|
|
|
|
|
def auth(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Accept the request"""
|
2003-11-30 23:40:24 +01:00
|
|
|
self.r.queueOUT.put(('AUTH', self.jid))
|
|
|
|
self.delete_event(self)
|
2003-12-28 01:47:40 +01:00
|
|
|
if not self.r.l_contact.has_key(self.jid):
|
2004-02-17 03:23:38 +01:00
|
|
|
addContact_Window(self.r, self.jid)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
def deny(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""refuse the request"""
|
2003-11-30 23:40:24 +01:00
|
|
|
self.r.queueOUT.put(('DENY', self.jid))
|
|
|
|
self.delete_event(self)
|
|
|
|
|
2004-02-25 01:33:06 +01:00
|
|
|
def __init__(self, roster, jid, txt):
|
2004-02-17 03:23:38 +01:00
|
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'Sub_req')
|
2004-01-18 23:56:28 +01:00
|
|
|
self.window = xml.get_widget('Sub_req')
|
2003-11-30 23:40:24 +01:00
|
|
|
self.r = roster
|
|
|
|
self.jid = jid
|
2004-01-18 23:56:28 +01:00
|
|
|
xml.get_widget('label').set_text('Subscription request from ' + self.jid)
|
2004-02-25 01:33:06 +01:00
|
|
|
xml.get_widget("textview_sub").get_buffer().set_text(txt)
|
2004-01-18 23:56:28 +01:00
|
|
|
xml.signal_connect('on_button_auth_clicked', self.auth)
|
|
|
|
xml.signal_connect('on_button_deny_clicked', self.deny)
|
|
|
|
xml.signal_connect('on_button_close_clicked', self.delete_event)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class agentRegistration_Window:
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Class for agent registration window :
|
|
|
|
window that appears when we want to subscribe to an agent"""
|
2003-11-30 23:40:24 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
2003-11-30 23:40:24 +01:00
|
|
|
self.window.destroy()
|
|
|
|
|
|
|
|
def draw_table(self):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Draw the table in the window"""
|
2004-01-18 23:56:28 +01:00
|
|
|
nbrow = 0
|
2003-11-30 23:40:24 +01:00
|
|
|
for name in self.infos.keys():
|
|
|
|
if name != 'key' and name != 'instructions' and name != 'x':
|
2004-01-18 23:56:28 +01:00
|
|
|
nbrow = nbrow + 1
|
|
|
|
self.table.resize(rows=nbrow, columns=2)
|
2003-11-30 23:40:24 +01:00
|
|
|
label = gtk.Label(name)
|
2004-01-18 23:56:28 +01:00
|
|
|
self.table.attach(label, 0, 1, nbrow-1, nbrow, 0, 0, 0, 0)
|
2003-11-30 23:40:24 +01:00
|
|
|
entry = gtk.Entry()
|
|
|
|
entry.set_text(self.infos[name])
|
2004-01-18 23:56:28 +01:00
|
|
|
self.table.attach(entry, 1, 2, nbrow-1, nbrow, 0, 0, 0, 0)
|
2003-11-30 23:40:24 +01:00
|
|
|
self.entries[name] = entry
|
2004-01-18 23:56:28 +01:00
|
|
|
if nbrow == 1:
|
2003-11-30 23:40:24 +01:00
|
|
|
entry.grab_focus()
|
|
|
|
self.table.show_all()
|
|
|
|
|
|
|
|
def on_ok(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When Ok button is clicked :
|
|
|
|
send registration info to the core"""
|
2003-11-30 23:40:24 +01:00
|
|
|
for name in self.entries.keys():
|
|
|
|
self.infos[name] = self.entries[name].get_text()
|
|
|
|
self.r.queueOUT.put(('REG_AGENT', self.agent))
|
|
|
|
self.delete_event(self)
|
|
|
|
|
|
|
|
def __init__(self, agent, infos, roster):
|
2004-02-17 03:23:38 +01:00
|
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'agent_reg')
|
2004-01-18 23:56:28 +01:00
|
|
|
self.agent = agent
|
2003-11-30 23:40:24 +01:00
|
|
|
self.infos = infos
|
|
|
|
self.r = roster
|
2004-01-18 23:56:28 +01:00
|
|
|
self.window = xml.get_widget('agent_reg')
|
|
|
|
self.table = xml.get_widget('table')
|
2003-11-30 23:40:24 +01:00
|
|
|
self.window.set_title('Register to ' + agent)
|
2004-01-18 23:56:28 +01:00
|
|
|
xml.get_widget('label').set_text(infos['instructions'])
|
2003-11-30 23:40:24 +01:00
|
|
|
self.entries = {}
|
|
|
|
self.draw_table()
|
2004-01-18 23:56:28 +01:00
|
|
|
xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
|
|
|
xml.signal_connect('on_button_cancel_clicked', self.delete_event)
|
|
|
|
xml.signal_connect('on_button_ok_clicked', self.on_ok)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class browseAgent_Window:
|
|
|
|
"""Class for bowser agent window :
|
2004-01-20 13:46:27 +01:00
|
|
|
to know the agents on the selected server"""
|
2003-11-30 23:40:24 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
2004-02-17 03:23:38 +01:00
|
|
|
global browserWindow
|
|
|
|
browserWindow = 0
|
2003-11-30 23:40:24 +01:00
|
|
|
self.window.destroy()
|
|
|
|
|
|
|
|
def browse(self):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Send a request to the core to know the available agents"""
|
2003-11-30 23:40:24 +01:00
|
|
|
self.r.queueOUT.put(('REQ_AGENTS', None))
|
|
|
|
|
|
|
|
def agents(self, agents):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When list of available agent arrive :
|
|
|
|
Fill the treeview with it"""
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.treeview.get_model()
|
2003-11-30 23:40:24 +01:00
|
|
|
for jid in agents.keys():
|
2004-01-18 23:56:28 +01:00
|
|
|
iter = model.append()
|
2004-03-04 21:56:39 +01:00
|
|
|
# model.set(iter, 0, agents[jid]['name'], 1, agents[jid]['service'])
|
|
|
|
model.set(iter, 0, agents[jid]['name'], 1, jid)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
def on_refresh(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When refresh button is clicked :
|
|
|
|
refresh list : clear and rerequest it"""
|
2004-01-18 23:56:28 +01:00
|
|
|
self.treeview.get_model().clear()
|
2003-11-30 23:40:24 +01:00
|
|
|
self.browse()
|
|
|
|
|
|
|
|
def on_row_activated(self, widget, path, col=0):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When a row is activated :
|
|
|
|
Ask specific informations about the selected agent and close the window"""
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.treeview.get_model()
|
|
|
|
iter = model.get_iter(path)
|
|
|
|
service = model.get_value(iter, 1)
|
2003-11-30 23:40:24 +01:00
|
|
|
self.r.queueOUT.put(('REQ_AGENT_INFO', service))
|
|
|
|
self.delete_event(self)
|
|
|
|
|
|
|
|
def __init__(self, roster):
|
2004-02-17 03:23:38 +01:00
|
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'browser')
|
2004-01-18 23:56:28 +01:00
|
|
|
self.window = xml.get_widget('browser')
|
|
|
|
self.treeview = xml.get_widget('treeview')
|
2003-11-30 23:40:24 +01:00
|
|
|
self.r = roster
|
2004-01-18 23:56:28 +01:00
|
|
|
model = gtk.ListStore(gobject.TYPE_STRING, gobject.TYPE_STRING)
|
|
|
|
self.treeview.set_model(model)
|
2003-11-30 23:40:24 +01:00
|
|
|
#columns
|
|
|
|
renderer = gtk.CellRendererText()
|
|
|
|
renderer.set_data('column', 0)
|
|
|
|
self.treeview.insert_column_with_attributes(-1, 'Name', renderer, text=0)
|
|
|
|
renderer = gtk.CellRendererText()
|
|
|
|
renderer.set_data('column', 1)
|
2004-01-24 21:32:51 +01:00
|
|
|
self.treeview.insert_column_with_attributes(-1, 'Service', \
|
|
|
|
renderer, text=1)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-01-18 23:56:28 +01:00
|
|
|
xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
|
|
|
xml.signal_connect('on_refresh_clicked', self.on_refresh)
|
|
|
|
xml.signal_connect('on_row_activated', self.on_row_activated)
|
2004-01-21 13:46:06 +01:00
|
|
|
if self.r.connected:
|
|
|
|
self.browse()
|
|
|
|
else:
|
2004-02-17 03:23:38 +01:00
|
|
|
warning_Window("You must be connected to view Agents")
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class message_Window:
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Class for chat window"""
|
2003-11-30 23:40:24 +01:00
|
|
|
def delete_event(self, widget):
|
2004-01-17 16:38:29 +01:00
|
|
|
"""close window"""
|
2003-11-30 23:40:24 +01:00
|
|
|
del self.r.tab_messages[self.user.jid]
|
|
|
|
self.window.destroy()
|
|
|
|
|
2003-12-28 01:47:40 +01:00
|
|
|
def print_conversation(self, txt, contact = None, tim = None):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Print a line in the conversation :
|
|
|
|
if contact is set to status : it's a status message
|
|
|
|
if contact is set to another value : it's an outgoing message
|
|
|
|
if contact is not set : it's an incomming message"""
|
2004-01-18 23:56:28 +01:00
|
|
|
buffer = self.conversation.get_buffer()
|
2003-12-27 03:17:28 +01:00
|
|
|
if not txt:
|
|
|
|
txt = ""
|
2004-01-18 23:56:28 +01:00
|
|
|
end_iter = buffer.get_end_iter()
|
2003-12-28 01:47:40 +01:00
|
|
|
if not tim:
|
|
|
|
tim = time.strftime("[%H:%M:%S]")
|
2004-01-18 23:56:28 +01:00
|
|
|
buffer.insert(end_iter, tim)
|
2003-11-30 23:40:24 +01:00
|
|
|
if contact:
|
2003-12-02 13:39:28 +01:00
|
|
|
if contact == 'status':
|
2004-01-18 23:56:28 +01:00
|
|
|
buffer.insert_with_tags_by_name(end_iter, txt+'\n', \
|
2003-12-02 13:39:28 +01:00
|
|
|
'status')
|
|
|
|
else:
|
2004-01-18 23:56:28 +01:00
|
|
|
buffer.insert_with_tags_by_name(end_iter, '<moi> ', 'outgoing')
|
|
|
|
buffer.insert(end_iter, txt+'\n')
|
2003-11-30 23:40:24 +01:00
|
|
|
else:
|
2004-01-24 21:32:51 +01:00
|
|
|
buffer.insert_with_tags_by_name(end_iter, '<' + \
|
|
|
|
self.user.name + '> ', 'incoming')
|
2004-01-18 23:56:28 +01:00
|
|
|
buffer.insert(end_iter, txt+'\n')
|
2004-01-20 13:46:27 +01:00
|
|
|
#scroll to the end of the textview
|
2003-11-30 23:40:24 +01:00
|
|
|
self.conversation.scroll_to_mark(\
|
2004-01-18 23:56:28 +01:00
|
|
|
buffer.get_mark('end'), 0.1, 0, 0, 0)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
def read_queue(self, q):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""read queue and print messages containted in it"""
|
2003-11-30 23:40:24 +01:00
|
|
|
while not q.empty():
|
2003-12-28 01:47:40 +01:00
|
|
|
evt = q.get()
|
|
|
|
self.print_conversation(evt[0], tim = evt[1])
|
2003-11-30 23:40:24 +01:00
|
|
|
del self.r.tab_queues[self.user.jid]
|
|
|
|
for i in self.r.l_contact[self.user.jid]['iter']:
|
|
|
|
if self.r.pixbufs.has_key(self.user.show):
|
2004-01-24 21:32:51 +01:00
|
|
|
self.r.tree.get_model().set_value(i, 0, \
|
|
|
|
self.r.pixbufs[self.user.show])
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
def on_msg_key_press_event(self, widget, event):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When a key is pressed :
|
2004-01-24 21:32:51 +01:00
|
|
|
if enter is pressed without the shit key, message (if not empty) is sent
|
|
|
|
and printed in the conversation"""
|
2003-11-30 23:40:24 +01:00
|
|
|
if event.keyval == gtk.keysyms.Return:
|
|
|
|
if (event.state & gtk.gdk.SHIFT_MASK):
|
|
|
|
return 0
|
|
|
|
txt_buffer = widget.get_buffer()
|
|
|
|
start_iter = txt_buffer.get_start_iter()
|
|
|
|
end_iter = txt_buffer.get_end_iter()
|
|
|
|
txt = txt_buffer.get_text(start_iter, end_iter, 0)
|
2003-12-27 03:17:28 +01:00
|
|
|
if txt != '':
|
|
|
|
self.r.queueOUT.put(('MSG',(self.user.jid, txt)))
|
|
|
|
txt_buffer.set_text('', -1)
|
|
|
|
self.print_conversation(txt, self.user.jid)
|
|
|
|
widget.grab_focus()
|
2003-11-30 23:40:24 +01:00
|
|
|
return 1
|
|
|
|
return 0
|
|
|
|
|
2004-01-02 00:41:47 +01:00
|
|
|
def on_clear(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When clear button is pressed :
|
|
|
|
clear the conversation"""
|
2004-01-18 23:56:28 +01:00
|
|
|
buffer = self.conversation.get_buffer()
|
|
|
|
deb, end = buffer.get_bounds()
|
|
|
|
buffer.delete(deb, end)
|
2004-01-02 00:41:47 +01:00
|
|
|
|
2003-11-30 23:40:24 +01:00
|
|
|
def __init__(self, user, roster):
|
|
|
|
self.user = user
|
|
|
|
self.r = roster
|
2004-02-17 03:23:38 +01:00
|
|
|
xml = gtk.glade.XML(GTKGUI_GLADE, 'Chat')
|
2004-01-21 13:46:06 +01:00
|
|
|
self.hbox = xml.get_widget('hbox1')
|
|
|
|
self.hbox.set_property('resize-mode', 2)
|
2004-01-18 23:56:28 +01:00
|
|
|
self.window = xml.get_widget('Chat')
|
2003-11-30 23:40:24 +01:00
|
|
|
self.window.set_title('Chat with ' + user.name)
|
2004-01-18 23:56:28 +01:00
|
|
|
self.img = xml.get_widget('image')
|
2003-11-30 23:40:24 +01:00
|
|
|
self.img.set_from_pixbuf(self.r.pixbufs[user.show])
|
2004-02-17 03:23:38 +01:00
|
|
|
xml.get_widget('button_contact').set_label(user.name + ' <'\
|
2003-11-30 23:40:24 +01:00
|
|
|
+ user.jid + '>')
|
2004-02-17 03:23:38 +01:00
|
|
|
xml.get_widget('button_contact').set_resize_mode(gtk.RESIZE_QUEUE)
|
2004-01-18 23:56:28 +01:00
|
|
|
self.message = xml.get_widget('message')
|
2003-11-30 23:40:24 +01:00
|
|
|
self.message.grab_focus()
|
2004-01-18 23:56:28 +01:00
|
|
|
self.conversation = xml.get_widget('conversation')
|
|
|
|
buffer = self.conversation.get_buffer()
|
|
|
|
end_iter = buffer.get_end_iter()
|
|
|
|
buffer.create_mark('end', end_iter, 0)
|
|
|
|
xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
|
|
|
xml.signal_connect('on_clear_button_clicked', self.on_clear)
|
|
|
|
xml.signal_connect('on_msg_key_press_event', self.on_msg_key_press_event)
|
|
|
|
self.tagIn = buffer.create_tag("incoming")
|
2004-01-24 21:32:51 +01:00
|
|
|
color = self.r.plugin.config['inmsgcolor']
|
2003-11-30 23:40:24 +01:00
|
|
|
if not color:
|
2003-12-29 19:37:31 +01:00
|
|
|
color = '#ff0000' #red
|
|
|
|
self.tagIn.set_property("foreground", color)
|
2004-01-18 23:56:28 +01:00
|
|
|
self.tagOut = buffer.create_tag("outgoing")
|
2004-01-24 21:32:51 +01:00
|
|
|
color = self.r.plugin.config['outmsgcolor']
|
2003-11-30 23:40:24 +01:00
|
|
|
if not color:
|
2003-12-29 19:37:31 +01:00
|
|
|
color = '#0000ff' #blue
|
|
|
|
self.tagOut.set_property("foreground", color)
|
2004-01-18 23:56:28 +01:00
|
|
|
self.tagStatus = buffer.create_tag("status")
|
2004-01-24 21:32:51 +01:00
|
|
|
color = self.r.plugin.config['statusmsgcolor']
|
2003-12-02 13:39:28 +01:00
|
|
|
if not color:
|
2004-01-21 13:46:06 +01:00
|
|
|
color = '#00ff00' #green
|
2003-12-29 19:37:31 +01:00
|
|
|
self.tagStatus.set_property("foreground", color)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-02-17 03:23:38 +01:00
|
|
|
class roster_Window:
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Class for main gtk window"""
|
2004-03-13 04:09:12 +01:00
|
|
|
|
|
|
|
def get_account_iter(self, name):
|
|
|
|
model = self.tree.get_model()
|
|
|
|
fin = False
|
2004-03-16 19:53:49 +01:00
|
|
|
account = model.get_iter_root()
|
|
|
|
if not account:
|
|
|
|
return None
|
2004-03-13 04:09:12 +01:00
|
|
|
while not fin:
|
|
|
|
account_name = model.get_value(account, 3)
|
2004-03-16 19:53:49 +01:00
|
|
|
if name == account_name:
|
2004-03-13 04:09:12 +01:00
|
|
|
return account
|
|
|
|
if not model.iter_next(account):
|
|
|
|
fin = True
|
|
|
|
return None
|
|
|
|
|
|
|
|
def get_group_iter(self, name, account):
|
|
|
|
model = self.tree.get_model()
|
2004-03-16 19:53:49 +01:00
|
|
|
root = self.get_account_iter(account)
|
2004-03-13 04:09:12 +01:00
|
|
|
fin = False
|
|
|
|
group = model.iter_children(root)
|
|
|
|
if not group:
|
|
|
|
fin = True
|
|
|
|
while not fin:
|
|
|
|
group_name = model.get_value(group, 3)
|
|
|
|
if name == group_name:
|
|
|
|
return group
|
|
|
|
if not model.iter_next(group):
|
|
|
|
fin = True
|
|
|
|
return None
|
|
|
|
|
|
|
|
def get_user_iter(self, jid, account):
|
|
|
|
model = self.tree.get_model()
|
2004-03-16 19:53:49 +01:00
|
|
|
acct = self.get_account_iter(account)
|
2004-03-13 04:09:12 +01:00
|
|
|
found = []
|
|
|
|
fin = False
|
2004-03-16 19:53:49 +01:00
|
|
|
group = model.iter_children(acct)
|
2004-03-13 04:09:12 +01:00
|
|
|
if not group:
|
|
|
|
return found
|
|
|
|
while not fin:
|
|
|
|
fin2 = False
|
|
|
|
user = model.iter_children(group)
|
2004-03-16 19:53:49 +01:00
|
|
|
if not user:
|
|
|
|
fin2=True
|
2004-03-13 04:09:12 +01:00
|
|
|
while not fin2:
|
|
|
|
if jid == model.get_value(user, 3):
|
|
|
|
found.append(user)
|
|
|
|
if not model.iter_next(user):
|
|
|
|
fin2 = True
|
|
|
|
if not model.iter_next(group):
|
|
|
|
fin = True
|
|
|
|
return found
|
|
|
|
|
|
|
|
def add_account_to_roster(self, account):
|
2004-03-16 19:53:49 +01:00
|
|
|
model = self.tree.get_model()
|
2004-03-13 04:09:12 +01:00
|
|
|
if self.get_account_iter(account):
|
|
|
|
return
|
|
|
|
model.append(None, (self.pixbufs['closed'], account, 'account', account, \
|
|
|
|
FALSE))
|
|
|
|
|
|
|
|
def add_user_to_roster(self, user, account):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Add a user to the roster and add groups if they aren't in roster"""
|
2003-12-20 23:42:10 +01:00
|
|
|
newgrp = 0
|
2004-03-16 16:39:36 +01:00
|
|
|
showOffline = self.plugin.config['showoffline']
|
2004-03-16 19:53:49 +01:00
|
|
|
# self.contacts[account][user.jid] = user
|
2004-03-13 04:09:12 +01:00
|
|
|
if user.groups == []:
|
|
|
|
if string.find(user.jid, "@") <= 0:
|
|
|
|
user.groups.append('Agents')
|
2003-12-20 23:42:10 +01:00
|
|
|
else:
|
2004-03-13 04:09:12 +01:00
|
|
|
user.groups.append('general')
|
2004-03-16 16:39:36 +01:00
|
|
|
if user.show != 'offline' or showOffline or 'Agents' in user.groups:
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.tree.get_model()
|
2004-03-13 04:09:12 +01:00
|
|
|
for g in user.groups:
|
2004-03-16 19:53:49 +01:00
|
|
|
iterG = self.get_group_iter(g, account)
|
|
|
|
if not iterG:
|
|
|
|
self.groups[account][g] = {'drawn': True, 'expand':True}
|
|
|
|
acct = self.get_account_iter(account)
|
|
|
|
iterG = model.append(self.get_account_iter(account), \
|
2004-03-13 04:09:12 +01:00
|
|
|
(self.pixbufs['closed'], g, 'group', g, FALSE))
|
2003-12-20 23:42:10 +01:00
|
|
|
newgrp = 1
|
|
|
|
if g == 'Agents':
|
2004-03-13 04:09:12 +01:00
|
|
|
model.append(iterG, (self.pixbufs[user.show], \
|
|
|
|
user.name, 'agent', user.jid, TRUE))
|
2003-12-20 23:42:10 +01:00
|
|
|
else:
|
2004-03-13 04:09:12 +01:00
|
|
|
model.append(iterG, (self.pixbufs[user.show], \
|
|
|
|
user.name, 'user', user.jid, TRUE))
|
2003-12-20 23:42:10 +01:00
|
|
|
if newgrp == 1:
|
|
|
|
#expand new groups
|
2004-01-18 23:56:28 +01:00
|
|
|
self.tree.expand_row(model.get_path(iterG), FALSE)
|
2004-01-22 00:09:03 +01:00
|
|
|
|
2004-03-13 04:09:12 +01:00
|
|
|
def remove_user(self, user, account):
|
2004-01-22 00:09:03 +01:00
|
|
|
model = self.tree.get_model()
|
2004-03-13 04:09:12 +01:00
|
|
|
for i in self.get_user_iter(user.jid, account):
|
2004-01-22 00:09:03 +01:00
|
|
|
parent_i = model.iter_parent(i)
|
2004-03-13 04:09:12 +01:00
|
|
|
model.remove(i)
|
|
|
|
if model.iter_n_children(parent_i) == 0:
|
2004-01-22 00:09:03 +01:00
|
|
|
model.remove(parent_i)
|
2003-12-31 11:55:13 +01:00
|
|
|
|
|
|
|
def draw_roster(self):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Clear and draw roster"""
|
2004-01-18 23:56:28 +01:00
|
|
|
self.tree.get_model().clear()
|
2004-03-16 16:39:36 +01:00
|
|
|
for acct in self.contacts.keys():
|
2004-03-13 04:09:12 +01:00
|
|
|
self.add_account_to_roster(acct)
|
2004-03-16 19:53:49 +01:00
|
|
|
for user in self.contacts[acct].values():
|
2004-03-13 04:09:12 +01:00
|
|
|
self.add_user_to_roster(user, acct)
|
2003-12-20 23:42:10 +01:00
|
|
|
|
2004-03-13 04:09:12 +01:00
|
|
|
def mklists(self, array, account):
|
|
|
|
"""fill self.contacts and self.groups"""
|
|
|
|
self.contacts[account] = {}
|
|
|
|
self.groups[account] = {}
|
|
|
|
for jid in array.keys():
|
|
|
|
jids = string.split(jid, '/')
|
|
|
|
#get jid
|
|
|
|
ji = jids[0]
|
|
|
|
#get resource
|
|
|
|
resource = ''
|
|
|
|
if len(jids) > 1:
|
|
|
|
resource = jids[1:]
|
|
|
|
#get name
|
|
|
|
name = array[jid]['name']
|
2003-11-30 23:40:24 +01:00
|
|
|
if not name:
|
|
|
|
if string.find(ji, "@") <= 0:
|
|
|
|
name = ji
|
|
|
|
else:
|
2003-12-27 03:17:28 +01:00
|
|
|
name = string.split(jid, '@')[0]
|
2004-03-13 04:09:12 +01:00
|
|
|
#get show
|
|
|
|
show = array[jid]['show']
|
2003-11-30 23:40:24 +01:00
|
|
|
if not show:
|
|
|
|
show = 'offline'
|
|
|
|
|
2004-03-13 04:09:12 +01:00
|
|
|
user1 = user(ji, name, array[jid]['groups'], show, \
|
|
|
|
array[jid]['status'], array[jid]['sub'], resource)
|
|
|
|
self.contacts[account][ji] = user1
|
|
|
|
for g in array[jid]['groups'] :
|
|
|
|
if not g in self.groups[account].keys():
|
|
|
|
self.groups[account][g] = {'drawn':False, 'expand':True}
|
|
|
|
|
|
|
|
def chg_user_status(self, user, show, status, account):
|
2004-03-11 22:14:09 +01:00
|
|
|
"""When a user change his status"""
|
2004-03-16 16:39:36 +01:00
|
|
|
showOffline = self.plugin.config['showoffline']
|
2004-03-16 19:53:49 +01:00
|
|
|
iters = self.get_user_iter(user.jid, account)
|
2004-03-16 16:39:36 +01:00
|
|
|
if not iters:
|
2004-03-16 19:53:49 +01:00
|
|
|
self.add_user_to_roster(user, account)
|
2003-11-30 23:40:24 +01:00
|
|
|
else:
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.tree.get_model()
|
2004-03-16 16:39:36 +01:00
|
|
|
if show == 'offline' and not showOffline:
|
2004-03-11 22:14:09 +01:00
|
|
|
self.remove_user(user)
|
2003-11-30 23:40:24 +01:00
|
|
|
else:
|
2004-03-16 16:39:36 +01:00
|
|
|
for i in iters:
|
2003-11-30 23:40:24 +01:00
|
|
|
if self.pixbufs.has_key(show):
|
2004-01-18 23:56:28 +01:00
|
|
|
model.set_value(i, 0, self.pixbufs[show])
|
2004-03-16 16:39:36 +01:00
|
|
|
user.show = show
|
|
|
|
user.status = status
|
2004-03-11 22:14:09 +01:00
|
|
|
#Print status in chat window
|
2004-03-16 16:39:36 +01:00
|
|
|
if self.plugin.windows[account].has_key(user.jid):
|
|
|
|
self.plugin.windows[account][user.jid].img.set_from_pixbuf(self.pixbufs[show])
|
|
|
|
self.plugin.windows[account][user.jid].print_conversation(\
|
2004-03-11 22:14:09 +01:00
|
|
|
"%s is now %s (%s)" % (user.name, show, status), 'status')
|
2004-01-14 02:06:27 +01:00
|
|
|
|
2004-03-16 16:39:36 +01:00
|
|
|
def on_info(self, widget, user, account):
|
2004-02-17 03:23:38 +01:00
|
|
|
"""Call infoUser_Window class to display user's information"""
|
2004-03-16 16:39:36 +01:00
|
|
|
if not self.plugin.windows[account].has_key('infos'+user.jid):
|
|
|
|
self.plugin.windows[account]['infos'+user.jid] = infoUser_Window(user, self.plugin)
|
2004-03-04 21:56:39 +01:00
|
|
|
|
2004-03-16 16:39:36 +01:00
|
|
|
def on_agent_logging(self, widget, jid, state, account):
|
2004-03-04 21:56:39 +01:00
|
|
|
"""When an agent is requested to log in or off"""
|
2004-03-16 16:39:36 +01:00
|
|
|
self.plugin.send('AGENT_LOGGING', account, (jid, state))
|
2004-03-04 21:56:39 +01:00
|
|
|
|
2004-03-16 16:39:36 +01:00
|
|
|
def mk_menu_user(self, event, iter):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Make user's popup menu"""
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.tree.get_model()
|
2004-03-16 16:39:36 +01:00
|
|
|
jid = model.get_value(iter, 3)
|
2004-01-18 23:56:28 +01:00
|
|
|
path = model.get_path(iter)
|
2004-03-04 21:56:39 +01:00
|
|
|
menu = gtk.Menu()
|
2003-11-30 23:40:24 +01:00
|
|
|
item = gtk.MenuItem("Start chat")
|
2004-03-04 21:56:39 +01:00
|
|
|
menu.append(item)
|
2003-11-30 23:40:24 +01:00
|
|
|
item.connect("activate", self.on_row_activated, path)
|
|
|
|
item = gtk.MenuItem("Rename")
|
2004-03-04 21:56:39 +01:00
|
|
|
menu.append(item)
|
2004-01-24 21:32:51 +01:00
|
|
|
#item.connect("activate", self.on_rename, iter)
|
2003-11-30 23:40:24 +01:00
|
|
|
item = gtk.MenuItem()
|
2004-03-04 21:56:39 +01:00
|
|
|
menu.append(item)
|
2003-11-30 23:40:24 +01:00
|
|
|
item = gtk.MenuItem("Subscription")
|
2004-03-04 21:56:39 +01:00
|
|
|
menu.append(item)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
menu_sub = gtk.Menu()
|
|
|
|
item.set_submenu(menu_sub)
|
|
|
|
item = gtk.MenuItem("Resend authorization to")
|
|
|
|
menu_sub.append(item)
|
|
|
|
item.connect("activate", self.authorize, jid)
|
|
|
|
item = gtk.MenuItem("Rerequest authorization from")
|
|
|
|
menu_sub.append(item)
|
2004-01-24 21:32:51 +01:00
|
|
|
item.connect("activate", self.req_sub, jid, \
|
|
|
|
'I would like to add you to my contact list, please.')
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
item = gtk.MenuItem()
|
2004-03-04 21:56:39 +01:00
|
|
|
menu.append(item)
|
2003-11-30 23:40:24 +01:00
|
|
|
item = gtk.MenuItem("Remove")
|
2004-03-04 21:56:39 +01:00
|
|
|
menu.append(item)
|
2003-11-30 23:40:24 +01:00
|
|
|
item.connect("activate", self.on_req_usub, iter)
|
2004-01-14 02:06:27 +01:00
|
|
|
|
|
|
|
item = gtk.MenuItem()
|
2004-03-04 21:56:39 +01:00
|
|
|
menu.append(item)
|
2004-01-14 02:06:27 +01:00
|
|
|
item = gtk.MenuItem("Informations")
|
2004-03-04 21:56:39 +01:00
|
|
|
menu.append(item)
|
2004-01-14 02:06:27 +01:00
|
|
|
item.connect("activate", self.on_info, jid)
|
|
|
|
|
2004-03-04 21:56:39 +01:00
|
|
|
menu.popup(None, None, None, event.button, event.time)
|
|
|
|
menu.show_all()
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
def mk_menu_g(self, event):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Make group's popup menu"""
|
2004-03-04 21:56:39 +01:00
|
|
|
menu = gtk.Menu()
|
2003-11-30 23:40:24 +01:00
|
|
|
item = gtk.MenuItem("grp1")
|
2004-03-04 21:56:39 +01:00
|
|
|
menu.append(item)
|
2003-11-30 23:40:24 +01:00
|
|
|
item = gtk.MenuItem("grp2")
|
2004-03-04 21:56:39 +01:00
|
|
|
menu.append(item)
|
2003-11-30 23:40:24 +01:00
|
|
|
item = gtk.MenuItem("grp3")
|
2004-03-04 21:56:39 +01:00
|
|
|
menu.append(item)
|
|
|
|
menu.popup(None, None, None, event.button, event.time)
|
|
|
|
menu.show_all()
|
|
|
|
|
|
|
|
def mk_menu_agent(self, event, iter):
|
|
|
|
"""Make agent's popup menu"""
|
|
|
|
model = self.tree.get_model()
|
2004-03-16 16:39:36 +01:00
|
|
|
jid = model.get_value(iter, 3)
|
2004-03-04 21:56:39 +01:00
|
|
|
menu = gtk.Menu()
|
|
|
|
item = gtk.MenuItem("Log on")
|
2004-03-16 16:39:36 +01:00
|
|
|
if self.contacts[jid].show != 'offline':
|
2004-03-04 21:56:39 +01:00
|
|
|
item.set_sensitive(FALSE)
|
|
|
|
menu.append(item)
|
|
|
|
item.connect("activate", self.on_agent_logging, jid, 'available')
|
|
|
|
|
|
|
|
item = gtk.MenuItem("Log off")
|
2004-03-16 16:39:36 +01:00
|
|
|
if self.contacts[jid].show == 'offline':
|
2004-03-04 21:56:39 +01:00
|
|
|
item.set_sensitive(FALSE)
|
|
|
|
menu.append(item)
|
|
|
|
item.connect("activate", self.on_agent_logging, jid, 'unavailable')
|
|
|
|
|
|
|
|
menu.popup(None, None, None, event.button, event.time)
|
|
|
|
menu.show_all()
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-03-16 16:39:36 +01:00
|
|
|
def authorize(self, widget, jid, account):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Authorize a user"""
|
2004-03-16 16:39:36 +01:00
|
|
|
self.plugin.send('AUTH', account, jid)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-03-16 16:39:36 +01:00
|
|
|
def req_sub(self, widget, jid, txt, account):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Request subscription to a user"""
|
2004-03-16 16:39:36 +01:00
|
|
|
self.plugin.send('SUB', account, (jid, txt))
|
|
|
|
if not self.contacts[account].has_key(jid):
|
2004-01-24 21:32:51 +01:00
|
|
|
user1 = user(jid, jid, ['general'], 'requested', \
|
|
|
|
'requested', 'sub', '')
|
2004-03-16 19:53:49 +01:00
|
|
|
self.add_user_to_roster(user1, account)
|
2004-01-05 16:02:03 +01:00
|
|
|
|
2003-11-30 23:40:24 +01:00
|
|
|
def on_treeview_event(self, widget, event):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""popup user's group's or agent menu"""
|
2003-11-30 23:40:24 +01:00
|
|
|
if (event.button == 3) & (event.type == gtk.gdk.BUTTON_PRESS):
|
|
|
|
try:
|
2004-01-24 21:32:51 +01:00
|
|
|
path, column, x, y = self.tree.get_path_at_pos(int(event.x), \
|
|
|
|
int(event.y))
|
2003-11-30 23:40:24 +01:00
|
|
|
except TypeError:
|
|
|
|
return
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.tree.get_model()
|
|
|
|
iter = model.get_iter(path)
|
2004-03-16 16:39:36 +01:00
|
|
|
type = model.get_value(iter, 2)
|
2003-11-30 23:40:24 +01:00
|
|
|
if data == 'group':
|
|
|
|
self.mk_menu_g(event)
|
|
|
|
elif data == 'agent':
|
2004-03-04 21:56:39 +01:00
|
|
|
self.mk_menu_agent(event, iter)
|
2004-03-16 16:39:36 +01:00
|
|
|
elif data == 'user':
|
|
|
|
self.mk_menu_user(event, iter)
|
2003-11-30 23:40:24 +01:00
|
|
|
return gtk.TRUE
|
|
|
|
return gtk.FALSE
|
2004-03-16 16:39:36 +01:00
|
|
|
|
2003-11-30 23:40:24 +01:00
|
|
|
def on_req_usub(self, widget, iter):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Remove a user"""
|
2004-02-17 03:23:38 +01:00
|
|
|
window_confirm = confirm_Window(self, iter)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-03-11 22:14:09 +01:00
|
|
|
def on_optionmenu_changed(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When we change our status"""
|
2004-03-11 22:14:09 +01:00
|
|
|
optionmenu = self.xml.get_widget('optionmenu')
|
|
|
|
history = optionmenu.get_history()
|
|
|
|
status = optionmenu.get_menu().get_children()[history].name
|
|
|
|
if status != 'online' and status != 'offline':
|
2004-02-17 03:23:38 +01:00
|
|
|
w = awayMsg_Window()
|
2004-01-14 02:06:27 +01:00
|
|
|
txt = w.run()
|
|
|
|
else:
|
2004-03-11 22:14:09 +01:00
|
|
|
txt = status
|
2004-03-16 19:53:49 +01:00
|
|
|
accounts = self.plugin.accounts.keys()
|
2004-03-16 16:39:36 +01:00
|
|
|
if len(accounts) == 0:
|
2004-02-25 01:33:06 +01:00
|
|
|
warning_Window("You must setup an account before connecting to jabber network.")
|
2004-03-16 16:39:36 +01:00
|
|
|
return
|
|
|
|
for acct in accounts:
|
|
|
|
self.plugin.send('STATUS', acct, (status, txt))
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-03-11 22:14:09 +01:00
|
|
|
def on_status_changed(self, account, status):
|
2004-03-16 16:39:36 +01:00
|
|
|
"""the core tells us that our status has changed"""
|
2004-03-11 22:14:09 +01:00
|
|
|
optionmenu = self.xml.get_widget('optionmenu')
|
|
|
|
for i in range(7):
|
|
|
|
if optionmenu.get_menu().get_children()[i].name == status:
|
|
|
|
optionmenu.set_history(i)
|
|
|
|
break
|
|
|
|
if status == 'offline':
|
|
|
|
self.plugin.connected[account] = 0
|
|
|
|
self.plugin.sleeper = None
|
2004-03-16 16:39:36 +01:00
|
|
|
for jid in self.contacts.keys():
|
|
|
|
user = self.contacts[jid]
|
|
|
|
self.chg_user_status(user, 'offline', 'Disconnected', account)
|
|
|
|
elif self.plugin.connected[account] == 0:
|
|
|
|
self.plugin.connected[account] = 1
|
2004-03-11 22:14:09 +01:00
|
|
|
self.plugin.sleeper = None#common.sleepy.Sleepy(\
|
2004-03-16 19:53:49 +01:00
|
|
|
#self.plugin.config['autoawaytime']*60, \
|
|
|
|
#self.plugin.config['autoxatime']*60)
|
2004-03-11 22:14:09 +01:00
|
|
|
|
|
|
|
def on_message(self, jid, msg, account):
|
|
|
|
"""when we receive a message"""
|
2004-03-16 16:39:36 +01:00
|
|
|
if not self.contacts.has_key(jid):
|
2004-03-11 22:14:09 +01:00
|
|
|
user1 = user(jid, jid, ['not in list'], \
|
|
|
|
'not in list', 'not in list', 'none', '')
|
2004-03-16 19:53:49 +01:00
|
|
|
self.add_user_to_roster(user1, account)
|
2004-03-11 22:14:09 +01:00
|
|
|
autopopup = self.plugin.config['autopopup']
|
2004-03-16 16:39:36 +01:00
|
|
|
if autopopup == 0 and not self.plugin.windows[account].has_key(jid):
|
2004-03-11 22:14:09 +01:00
|
|
|
#We save it in a queue
|
2004-03-16 16:39:36 +01:00
|
|
|
if not self.plugin.queues[account].has_key(jid):
|
2004-03-11 22:14:09 +01:00
|
|
|
model = self.tree.get_model()
|
2004-03-16 16:39:36 +01:00
|
|
|
self.plugin.queues[account][jid] = Queue.Queue(50)
|
|
|
|
for i in self.get_user_iter(jid, account):
|
2004-03-11 22:14:09 +01:00
|
|
|
model.set_value(i, 0, self.pixbufs['message'])
|
|
|
|
tim = time.strftime("[%H:%M:%S]")
|
2004-03-16 16:39:36 +01:00
|
|
|
self.plugin.queues[account][jid].put((msg, tim))
|
2004-03-11 22:14:09 +01:00
|
|
|
else:
|
2004-03-16 16:39:36 +01:00
|
|
|
if not self.plugin.windows[account].has_key(jid):
|
|
|
|
self.plugin.windows[account][jid] = \
|
|
|
|
message_Window(self.contacts[account][jid], self)
|
|
|
|
self.plugin.windows[account][jid].print_conversation(msg)
|
2004-03-11 22:14:09 +01:00
|
|
|
|
2003-12-29 19:37:31 +01:00
|
|
|
def on_prefs(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When preferences is selected :
|
2004-02-17 03:23:38 +01:00
|
|
|
call the preference_Window class"""
|
2004-03-16 16:39:36 +01:00
|
|
|
if not self.plugin.windows.has_key('preferences'):
|
|
|
|
self.plugin.windows['preferences'] = preference_Window(self)
|
2003-12-29 19:37:31 +01:00
|
|
|
|
2003-11-30 23:40:24 +01:00
|
|
|
def on_add(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When add user is selected :
|
|
|
|
call the add class"""
|
2004-03-16 16:39:36 +01:00
|
|
|
addContact_Window(self)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
def on_about(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When about is selected :
|
|
|
|
call the about class"""
|
2004-03-16 16:39:36 +01:00
|
|
|
if not self.plugin.windows.has_key('about'):
|
|
|
|
self.plugin.windows['about'] = about_Window()
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
def on_accounts(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When accounts is seleted :
|
|
|
|
call the accounts class to modify accounts"""
|
2004-03-16 16:39:36 +01:00
|
|
|
if not self.plugin.windows.has_key('accounts'):
|
|
|
|
self.plugin.windows['accounts'] = accounts_Window(self)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
def on_quit(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When we quit the gtk plugin :
|
|
|
|
tell that to the core and exit gtk"""
|
2004-03-16 16:39:36 +01:00
|
|
|
self.plugin.send('QUIT', None, '')
|
2004-02-17 03:23:38 +01:00
|
|
|
print "plugin gtkgui stopped"
|
2003-11-30 23:40:24 +01:00
|
|
|
gtk.mainquit()
|
|
|
|
|
|
|
|
def on_row_activated(self, widget, path, col=0):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When an iter is dubble clicked :
|
|
|
|
open the chat window"""
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.tree.get_model()
|
2004-03-16 16:39:36 +01:00
|
|
|
acct_iter = model.get_iter((path[0]))
|
|
|
|
account = model.get_value(acct_iter, 3)
|
2004-01-18 23:56:28 +01:00
|
|
|
iter = model.get_iter(path)
|
2004-03-16 16:39:36 +01:00
|
|
|
type = model.get_value(iter, 2)
|
|
|
|
jid = model.get_value(iter, 3)
|
|
|
|
if (type == 'group'):
|
2003-12-10 12:03:57 +01:00
|
|
|
if (self.tree.row_expanded(path)):
|
|
|
|
self.tree.collapse_row(path)
|
|
|
|
else:
|
|
|
|
self.tree.expand_row(path, FALSE)
|
|
|
|
else:
|
2004-03-16 16:39:36 +01:00
|
|
|
if self.plugin.windows[account].has_key(jid):
|
|
|
|
self.plugin.windows[account][jid].window.present()
|
|
|
|
elif self.contacts[account].has_key(jid):
|
|
|
|
self.plugin.windows[account][jid] = \
|
|
|
|
message_Window(self.contacts[account][jid], self)
|
|
|
|
if self.plugin.queues[account].has_key(jid):
|
|
|
|
self.plugin.windows[account][jid].read_queue(\
|
|
|
|
self.plugin.queues[account][jid])
|
2003-12-10 12:03:57 +01:00
|
|
|
|
|
|
|
def on_row_expanded(self, widget, iter, path):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When a row is expanded :
|
|
|
|
change the icon of the arrow"""
|
2004-01-18 23:56:28 +01:00
|
|
|
self.tree.get_model().set_value(iter, 0, self.pixbufs['opened'])
|
2003-12-10 12:03:57 +01:00
|
|
|
|
|
|
|
def on_row_collapsed(self, widget, iter, path):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When a row is collapsed :
|
|
|
|
change the icon of the arrow"""
|
2004-01-18 23:56:28 +01:00
|
|
|
self.tree.get_model().set_value(iter, 0, self.pixbufs['closed'])
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
def on_cell_edited (self, cell, row, new_text):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When an iter is editer :
|
|
|
|
if text has changed, rename the user
|
|
|
|
else open chat window"""
|
2004-01-18 23:56:28 +01:00
|
|
|
model = self.tree.get_model()
|
|
|
|
iter = model.get_iter_from_string(row)
|
|
|
|
jid = model.get_value(iter, 2)
|
2003-11-30 23:40:24 +01:00
|
|
|
old_text = self.l_contact[jid]['user'].name
|
|
|
|
#If it is a double click, old_text == new_text
|
|
|
|
if old_text == new_text:
|
|
|
|
if self.tab_messages.has_key(jid):
|
|
|
|
self.tab_messages[jid].window.present()
|
|
|
|
elif self.l_contact.has_key(jid):
|
2004-02-17 03:23:38 +01:00
|
|
|
self.tab_messages[jid] = message_Window(self.l_contact[jid]['user'], self)
|
2003-11-30 23:40:24 +01:00
|
|
|
if self.tab_queues.has_key(jid):
|
|
|
|
self.tab_messages[jid].read_queue(self.tab_queues[jid])
|
|
|
|
else:
|
2004-01-18 23:56:28 +01:00
|
|
|
model.set_value(iter, 1, new_text)
|
2003-11-30 23:40:24 +01:00
|
|
|
self.l_contact[jid]['user'].name = new_text
|
2004-01-24 21:32:51 +01:00
|
|
|
self.queueOUT.put(('UPDUSER', (jid, new_text, \
|
|
|
|
self.l_contact[jid]['user'].groups)))
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
def on_browse(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""When browse agent is selected :
|
|
|
|
Call browse class"""
|
2004-03-16 16:39:36 +01:00
|
|
|
if not self.plugin.windows.has_key('browser'):
|
|
|
|
self.plugin.windows['browser'] = browseAgent_Window(self)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2003-12-30 02:07:38 +01:00
|
|
|
def mkpixbufs(self):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""initialise pixbufs array"""
|
2004-03-16 16:39:36 +01:00
|
|
|
iconstyle = self.plugin.config['iconstyle']
|
|
|
|
if not iconstyle:
|
|
|
|
iconstyle = 'sun'
|
|
|
|
self.path = 'plugins/gtkgui/icons/' + iconstyle + '/'
|
2003-12-30 02:07:38 +01:00
|
|
|
self.pixbufs = {}
|
2004-01-24 21:32:51 +01:00
|
|
|
for state in ('online', 'away', 'xa', 'dnd', 'offline', \
|
|
|
|
'requested', 'message', 'opened', 'closed', 'not in list'):
|
2004-02-17 03:23:38 +01:00
|
|
|
# try to open a pixfile with the correct method
|
|
|
|
files = []
|
|
|
|
files.append(self.path + state + '.gif')
|
|
|
|
files.append(self.path + state + '.png')
|
|
|
|
files.append(self.path + state + '.xpm')
|
|
|
|
self.pixbufs[state] = None
|
|
|
|
for file in files:
|
|
|
|
if not os.path.exists(file):
|
|
|
|
continue
|
|
|
|
fct = gtk.gdk.pixbuf_new_from_file
|
|
|
|
if file.find('.gif') != -1:
|
|
|
|
fct = gtk.gdk.pixbufAnimation
|
|
|
|
pix = fct(file)
|
2003-12-30 02:07:38 +01:00
|
|
|
self.pixbufs[state] = pix
|
2004-02-17 03:23:38 +01:00
|
|
|
break
|
2003-12-30 02:07:38 +01:00
|
|
|
|
2003-12-31 11:55:13 +01:00
|
|
|
def on_show_off(self, widget):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""when show offline option is changed :
|
|
|
|
redraw the treeview"""
|
2004-03-16 16:39:36 +01:00
|
|
|
self.plugin.config['showoffline'] = 1 - self.plugin.config['showoffline']
|
2003-12-31 11:55:13 +01:00
|
|
|
self.redraw_roster()
|
|
|
|
|
2004-03-11 22:14:09 +01:00
|
|
|
def __init__(self, plugin):
|
2003-11-30 23:40:24 +01:00
|
|
|
# FIXME : handle no file ...
|
2004-03-11 22:14:09 +01:00
|
|
|
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'Gajim')
|
|
|
|
self.tree = self.xml.get_widget('treeview')
|
|
|
|
self.plugin = plugin
|
2004-03-16 19:53:49 +01:00
|
|
|
self.groups = {}
|
2004-03-16 16:39:36 +01:00
|
|
|
self.contacts = {}
|
|
|
|
for a in self.plugin.accounts.keys():
|
|
|
|
self.contacts[a] = {}
|
2004-03-13 04:09:12 +01:00
|
|
|
#(icon, name, type, jid, editable)
|
|
|
|
model = gtk.TreeStore(gtk.gdk.Pixbuf, str, str, str, \
|
|
|
|
gobject.TYPE_BOOLEAN)
|
2004-01-18 23:56:28 +01:00
|
|
|
self.tree.set_model(model)
|
2003-12-30 02:07:38 +01:00
|
|
|
self.mkpixbufs()
|
2003-12-04 20:57:06 +01:00
|
|
|
# map = self.tree.get_colormap()
|
|
|
|
# colour = map.alloc_color("red") # light red
|
|
|
|
# colour2 = map.alloc_color("blue") # light red
|
|
|
|
# colour = map.alloc_color("#FF9999") # light red
|
|
|
|
# st = self.tree.get_style().copy()
|
|
|
|
# st.bg[gtk.STATE_NORMAL] = colour
|
|
|
|
# st.fg[gtk.STATE_NORMAL] = colour
|
|
|
|
# st.bg[gtk.STATE_ACTIVE] = colour2
|
|
|
|
# st.fg[gtk.STATE_ACTIVE] = colour2
|
|
|
|
# st.bg[gtk.STATE_INSENSITIVE] = colour
|
|
|
|
# st.bg[gtk.STATE_PRELIGHT] = colour
|
|
|
|
# st.bg[gtk.STATE_SELECTED] = colour
|
|
|
|
# st.fg[gtk.STATE_SELECTED] = colour2
|
|
|
|
# st.white = colour
|
|
|
|
# print st.bg
|
|
|
|
# print self.tree.get_property('expander-column')
|
|
|
|
# self.tree.set_style(st)
|
2004-03-11 22:14:09 +01:00
|
|
|
self.xml.get_widget('optionmenu').set_history(6)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
2004-03-16 16:39:36 +01:00
|
|
|
showOffline = self.plugin.config['showoffline']
|
|
|
|
self.xml.get_widget('show_offline').set_active(showOffline)
|
2003-12-04 20:57:06 +01:00
|
|
|
|
2003-11-30 23:40:24 +01:00
|
|
|
#columns
|
2004-01-18 23:56:28 +01:00
|
|
|
col = gtk.TreeViewColumn()
|
2003-11-30 23:40:24 +01:00
|
|
|
render_pixbuf = gtk.CellRendererPixbuf()
|
2004-01-18 23:56:28 +01:00
|
|
|
col.pack_start(render_pixbuf, expand = False)
|
|
|
|
col.add_attribute(render_pixbuf, 'pixbuf', 0)
|
2003-11-30 23:40:24 +01:00
|
|
|
render_text = gtk.CellRendererText()
|
|
|
|
render_text.connect('edited', self.on_cell_edited)
|
2004-01-18 23:56:28 +01:00
|
|
|
col.pack_start(render_text, expand = True)
|
|
|
|
col.add_attribute(render_text, 'text', 1)
|
2004-03-13 04:09:12 +01:00
|
|
|
col.add_attribute(render_text, 'editable', 4)
|
2004-01-18 23:56:28 +01:00
|
|
|
self.tree.append_column(col)
|
|
|
|
col = gtk.TreeViewColumn()
|
2003-12-10 12:03:57 +01:00
|
|
|
render_pixbuf = gtk.CellRendererPixbuf()
|
2004-01-18 23:56:28 +01:00
|
|
|
col.pack_start(render_pixbuf, expand = False)
|
|
|
|
self.tree.append_column(col)
|
|
|
|
col.set_visible(FALSE)
|
2004-03-16 19:53:49 +01:00
|
|
|
# self.tree.set_expander_column(col)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
#signals
|
2004-03-16 16:39:36 +01:00
|
|
|
self.xml.signal_connect('gtk_main_quit', self.on_quit)
|
|
|
|
self.xml.signal_connect('on_preferences_activate', self.on_prefs)
|
|
|
|
self.xml.signal_connect('on_accounts_activate', self.on_accounts)
|
|
|
|
self.xml.signal_connect('on_browse_agents_activate', self.on_browse)
|
|
|
|
self.xml.signal_connect('on_add_activate', self.on_add)
|
|
|
|
self.xml.signal_connect('on_show_offline_activate', self.on_show_off)
|
|
|
|
self.xml.signal_connect('on_about_activate', self.on_about)
|
|
|
|
self.xml.signal_connect('on_quit_activate', self.on_quit)
|
|
|
|
self.xml.signal_connect('on_treeview_event', self.on_treeview_event)
|
|
|
|
self.xml.signal_connect('on_status_changed', self.on_status_changed)
|
|
|
|
self.xml.signal_connect('on_optionmenu_changed', self.on_optionmenu_changed)
|
|
|
|
self.xml.signal_connect('on_row_activated', self.on_row_activated)
|
|
|
|
self.xml.signal_connect('on_row_expanded', self.on_row_expanded)
|
|
|
|
self.xml.signal_connect('on_row_collapsed', self.on_row_collapsed)
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
class plugin:
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Class called by the core in a new thread"""
|
2004-03-11 22:14:09 +01:00
|
|
|
|
|
|
|
class accounts:
|
|
|
|
"""Class where are stored the accounts and users in them"""
|
|
|
|
def __init__(self):
|
|
|
|
self.__accounts = {}
|
|
|
|
|
|
|
|
def add_account(self, account, users=()):
|
|
|
|
#users must be like (user1, user2)
|
|
|
|
self.__accounts[account] = users
|
|
|
|
|
|
|
|
def add_user_to_account(self, account, user):
|
|
|
|
if self.__accounts.has_key(account):
|
|
|
|
self.__accounts[account].append(user)
|
|
|
|
else :
|
|
|
|
return 1
|
|
|
|
|
|
|
|
def get_accounts(self):
|
|
|
|
return self.__accounts.keys();
|
|
|
|
|
|
|
|
def get_users(self, account):
|
|
|
|
if self.__accounts.has_key(account):
|
|
|
|
return self.__accounts[account]
|
|
|
|
else :
|
|
|
|
return None
|
|
|
|
|
|
|
|
def which_account(self, user):
|
|
|
|
for a in self.__accounts.keys():
|
|
|
|
if user in self.__accounts[a]:
|
|
|
|
return a
|
|
|
|
return None
|
|
|
|
|
|
|
|
def send(self, event, account, data):
|
|
|
|
self.queueOUT.put((event, account, data))
|
|
|
|
|
2004-01-24 21:32:51 +01:00
|
|
|
def wait(self, what):
|
|
|
|
"""Wait for a message from Core"""
|
2004-02-17 03:23:38 +01:00
|
|
|
#TODO: timeout
|
|
|
|
temp_q = Queue.Queue(50)
|
2004-01-24 21:32:51 +01:00
|
|
|
while 1:
|
|
|
|
if not self.queueIN.empty():
|
|
|
|
ev = self.queueIN.get()
|
2004-03-11 22:14:09 +01:00
|
|
|
if ev[0] == what and ev[2][0] == 'GtkGui':
|
2004-02-17 03:23:38 +01:00
|
|
|
#Restore messages
|
|
|
|
while not temp_q.empty():
|
|
|
|
ev2 = temp_q.get()
|
2004-02-17 19:40:14 +01:00
|
|
|
self.queueIN.put(ev2)
|
2004-03-11 22:14:09 +01:00
|
|
|
return ev[2][1]
|
2004-02-17 03:23:38 +01:00
|
|
|
else:
|
|
|
|
#Save messages
|
|
|
|
temp_q.put(ev)
|
2004-01-24 21:32:51 +01:00
|
|
|
time.sleep(0.1)
|
|
|
|
|
2003-11-30 23:40:24 +01:00
|
|
|
def read_queue(self):
|
2004-01-20 13:46:27 +01:00
|
|
|
"""Read queue from the core and execute commands from it"""
|
2004-03-11 22:14:09 +01:00
|
|
|
model = self.roster.tree.get_model()
|
2003-11-30 23:40:24 +01:00
|
|
|
while self.queueIN.empty() == 0:
|
|
|
|
ev = self.queueIN.get()
|
|
|
|
if ev[0] == 'ROSTER':
|
2004-03-16 19:53:49 +01:00
|
|
|
self.roster.mklists(ev[2], ev[1])
|
2004-03-11 22:14:09 +01:00
|
|
|
self.roster.draw_roster()
|
2004-01-08 00:49:23 +01:00
|
|
|
elif ev[0] == 'WARNING':
|
2004-03-11 22:14:09 +01:00
|
|
|
warning_Window(ev[2])
|
|
|
|
#('STATUS', account, status)
|
2004-01-08 00:49:23 +01:00
|
|
|
elif ev[0] == 'STATUS':
|
2004-03-11 22:14:09 +01:00
|
|
|
self.roster.on_status_changed(ev[1], ev[2])
|
|
|
|
#('NOTIFY', account, (jid, status, message, resource))
|
2003-11-30 23:40:24 +01:00
|
|
|
elif ev[0] == 'NOTIFY':
|
2004-03-11 22:14:09 +01:00
|
|
|
jid = string.split(ev[2][0], '/')[0]
|
|
|
|
resource = ev[2][3]
|
|
|
|
if not resource:
|
|
|
|
resource = ''
|
2003-12-31 11:55:13 +01:00
|
|
|
if string.find(jid, "@") <= 0:
|
|
|
|
#It must be an agent
|
|
|
|
ji = string.replace(jid, '@', '')
|
|
|
|
else:
|
|
|
|
ji = jid
|
2003-12-02 13:39:28 +01:00
|
|
|
#Update user
|
2004-03-16 19:53:49 +01:00
|
|
|
if self.roster.contacts[ev[1]].has_key(ji):
|
|
|
|
user = self.roster.contacts[ev[1]][ji]
|
2004-03-11 22:14:09 +01:00
|
|
|
user.show = ev[2][1]
|
|
|
|
user.status = ev[2][2]
|
|
|
|
user.resource = resource
|
2003-11-30 23:40:24 +01:00
|
|
|
if string.find(jid, "@") <= 0:
|
|
|
|
#It must be an agent
|
2004-03-16 19:53:49 +01:00
|
|
|
if not self.roster.contacts[ev[1]].has_key(ji):
|
2004-03-11 22:14:09 +01:00
|
|
|
user1 = user(ji, ji, ['Agents'], ev[2][1], \
|
|
|
|
ev[2][2], 'from', resource)
|
2004-03-16 19:53:49 +01:00
|
|
|
self.roster.add_user_to_roster(user1, ev[1])
|
2003-11-30 23:40:24 +01:00
|
|
|
else:
|
2004-01-20 13:46:27 +01:00
|
|
|
#Update existing iter
|
2004-03-16 19:53:49 +01:00
|
|
|
for i in self.roster.get_user_iter(ji, ev[1]):
|
2004-03-11 22:14:09 +01:00
|
|
|
if self.roster.pixbufs.has_key(ev[2][1]):
|
|
|
|
model.set_value(i, 0, self.r.pixbufs[ev[2][1]])
|
2004-03-16 19:53:49 +01:00
|
|
|
elif self.roster.contacts[ev[1]].has_key(ji):
|
2003-11-30 23:40:24 +01:00
|
|
|
#It isn't an agent
|
2004-03-16 19:53:49 +01:00
|
|
|
self.roster.chg_user_status(user, ev[2][1], ev[2][2], ev[1])
|
2004-03-11 22:14:09 +01:00
|
|
|
#('MSG', account, (user, msg))
|
2003-11-30 23:40:24 +01:00
|
|
|
elif ev[0] == 'MSG':
|
2004-03-11 22:14:09 +01:00
|
|
|
if string.find(ev[2][0], "@") <= 0:
|
|
|
|
jid = string.replace(ev[2][0], '@', '')
|
2003-11-30 23:40:24 +01:00
|
|
|
else:
|
2004-03-11 22:14:09 +01:00
|
|
|
jid = ev[2][0]
|
|
|
|
self.roster.on_message(jid, ev[2][1], ev[1])
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
elif ev[0] == 'SUBSCRIBE':
|
2004-03-11 22:14:09 +01:00
|
|
|
authorize_Window(self.roster, ev[2][0], ev[2][1])
|
|
|
|
#('SUBSCRIBED', account, (jid, nom, resource))
|
2003-11-30 23:40:24 +01:00
|
|
|
elif ev[0] == 'SUBSCRIBED':
|
2004-03-11 22:14:09 +01:00
|
|
|
if self.roster.l_contact.has_key(ev[2][0]):
|
|
|
|
u = self.roster.l_contact[ev[2][0]]['user']
|
|
|
|
u.name = ev[2][1]
|
|
|
|
u.resource = ev[2][2]
|
|
|
|
for i in self.roster.l_contact[u.jid]['iter']:
|
2004-01-18 23:56:28 +01:00
|
|
|
model.set_value(i, 1, u.name)
|
2003-11-30 23:40:24 +01:00
|
|
|
else:
|
2004-03-11 22:14:09 +01:00
|
|
|
user1 = user(ev[2][0], ev[2][0], ['general'], 'online', \
|
|
|
|
'online', 'to', ev[2][2])
|
|
|
|
self.roster.add_user(user1)
|
|
|
|
warning_Window("You are now authorized by " + ev[2][0])
|
2004-01-22 00:09:03 +01:00
|
|
|
elif ev[0] == 'UNSUBSCRIBED':
|
2004-02-17 03:23:38 +01:00
|
|
|
warning_Window("You are now unsubscribed by " + jid)
|
2004-01-22 00:09:03 +01:00
|
|
|
#TODO: change icon
|
2004-03-11 22:14:09 +01:00
|
|
|
#('AGENTS', account, agents)
|
2003-11-30 23:40:24 +01:00
|
|
|
elif ev[0] == 'AGENTS':
|
2004-03-16 16:39:36 +01:00
|
|
|
if self.windows[ev[1]].has_key('browser'):
|
|
|
|
self.windows[ev[1]]['browser'].agents(ev[2])
|
2004-03-11 22:14:09 +01:00
|
|
|
#('AGENTS_INFO', account, (agent, infos))
|
2003-11-30 23:40:24 +01:00
|
|
|
elif ev[0] == 'AGENT_INFO':
|
2004-03-11 22:14:09 +01:00
|
|
|
if not ev[2][1].has_key('instructions'):
|
|
|
|
warning_Window('error contacting %s' % ev[2][0])
|
2003-12-20 14:22:37 +01:00
|
|
|
else:
|
2004-03-11 22:14:09 +01:00
|
|
|
agentRegistration_Window(ev[2][0], ev[2][1], self.roster)
|
|
|
|
#('ACC_OK', account, (hostname, login, pasword, name, ressource))
|
2003-12-14 01:47:00 +01:00
|
|
|
elif ev[0] == 'ACC_OK':
|
2004-03-11 22:14:09 +01:00
|
|
|
self.accounts[ev[2][3]] = {'ressource': ev[2][4], \
|
|
|
|
'password': ev[2][2], 'hostname': ev[2][0], 'name': ev[2][1]}
|
2004-03-16 16:39:36 +01:00
|
|
|
self.send('CONFIG', None, ('accounts', self.accounts))
|
|
|
|
if self.windows.has_key('accounts'):
|
2004-03-11 22:14:09 +01:00
|
|
|
self.windows['accounts'].init_accounts()
|
2004-01-17 16:38:29 +01:00
|
|
|
elif ev[0] == 'QUIT':
|
2004-03-11 22:14:09 +01:00
|
|
|
self.roster.on_quit(self)
|
2004-02-19 05:20:40 +01:00
|
|
|
elif ev[0] == 'VCARD':
|
2004-03-11 22:14:09 +01:00
|
|
|
if self.roster.tab_vcard.has_key(ev[2]['jid']):
|
|
|
|
self.roster.tab_vcard[ev[2]['jid']].set_values(ev[2])
|
2003-11-30 23:40:24 +01:00
|
|
|
return 1
|
2004-01-02 16:21:02 +01:00
|
|
|
|
2004-01-20 13:46:27 +01:00
|
|
|
def read_sleepy(self):
|
|
|
|
"""Check if we are idle"""
|
2004-03-11 22:14:09 +01:00
|
|
|
if self.sleeper and (self.config['autoaway'] or self.config['autoxa'])\
|
|
|
|
and (self.roster.optionmenu.get_history()==0 or \
|
2004-01-03 00:27:28 +01:00
|
|
|
self.sleeper_state!=common.sleepy.STATE_AWAKE):
|
2004-01-02 16:21:02 +01:00
|
|
|
self.sleeper.poll()
|
|
|
|
state = self.sleeper.getState()
|
|
|
|
if state != self.sleeper_state:
|
2004-01-03 00:27:28 +01:00
|
|
|
if state == common.sleepy.STATE_AWAKE:
|
2004-01-20 13:46:27 +01:00
|
|
|
#we go online
|
2004-03-11 22:14:09 +01:00
|
|
|
self.roster.optionmenu.set_history(0)
|
|
|
|
self.send('STATUS', None, ('online', ''))
|
2004-03-16 19:53:49 +01:00
|
|
|
if state == common.sleepy.STATE_AWAY and self.config['autoaway']:
|
2004-01-20 13:46:27 +01:00
|
|
|
#we go away
|
2004-03-11 22:14:09 +01:00
|
|
|
self.roster.optionmenu.set_history(1)
|
|
|
|
self.send('STATUS', None, ('away', 'auto away (idle)'))
|
2004-03-16 19:53:49 +01:00
|
|
|
if state == common.sleepy.STATE_XAWAY and self.config['autoxa']:
|
2004-01-20 13:46:27 +01:00
|
|
|
#we go extanded away
|
2004-03-11 22:14:09 +01:00
|
|
|
self.roster.optionmenu.set_history(2)
|
|
|
|
self.send('STATUS',('xa', 'auto away (idel)'))
|
2004-01-02 16:21:02 +01:00
|
|
|
self.sleeper_state = state
|
|
|
|
return 1
|
2003-11-30 23:40:24 +01:00
|
|
|
|
|
|
|
def __init__(self, quIN, quOUT):
|
|
|
|
gtk.threads_init()
|
|
|
|
gtk.threads_enter()
|
|
|
|
self.queueIN = quIN
|
2004-03-11 22:14:09 +01:00
|
|
|
self.queueOUT = quOUT
|
|
|
|
self.send('ASK_CONFIG', None, ('GtkGui', 'GtkGui', {'autopopup':1,\
|
2004-02-25 01:33:06 +01:00
|
|
|
'showoffline':0,\
|
|
|
|
'autoaway':0,\
|
|
|
|
'autoawaytime':10,\
|
|
|
|
'autoxa':0,\
|
|
|
|
'autoxatime':20,\
|
|
|
|
'iconstyle':'sun',\
|
2004-03-01 02:39:12 +01:00
|
|
|
'inmsgcolor':'#ff0000',\
|
2004-02-25 01:33:06 +01:00
|
|
|
'outmsgcolor': '#0000ff',\
|
2004-03-11 22:14:09 +01:00
|
|
|
'statusmsgcolor':'#1eaa1e'}))
|
2004-01-24 21:32:51 +01:00
|
|
|
self.config = self.wait('CONFIG')
|
2004-03-11 22:14:09 +01:00
|
|
|
self.send('ASK_CONFIG', None, ('GtkGui', 'accounts'))
|
2004-01-24 21:32:51 +01:00
|
|
|
self.accounts = self.wait('CONFIG')
|
2004-03-16 16:39:36 +01:00
|
|
|
self.windows = {}
|
|
|
|
self.queues = {}
|
2004-03-16 19:53:49 +01:00
|
|
|
self.connected = {}
|
2004-03-16 16:39:36 +01:00
|
|
|
for a in self.accounts.keys():
|
|
|
|
self.windows[a] = {}
|
|
|
|
self.queues[a] = {}
|
2004-03-16 19:53:49 +01:00
|
|
|
self.connected[a] = 0
|
2004-03-11 22:14:09 +01:00
|
|
|
self.roster = roster_Window(self)
|
|
|
|
gtk.timeout_add(200, self.read_queue)
|
2004-01-02 16:21:02 +01:00
|
|
|
gtk.timeout_add(1000, self.read_sleepy)
|
|
|
|
self.sleeper = None
|
|
|
|
self.sleeper_state = None
|
2003-11-30 23:40:24 +01:00
|
|
|
gtk.main()
|
|
|
|
gtk.threads_leave()
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
plugin(None, None)
|
|
|
|
|
|
|
|
print "plugin gtkgui loaded"
|