recommit. sorry yann
This commit is contained in:
parent
bfac48aac3
commit
136b9051dc
2 changed files with 109 additions and 112 deletions
|
@ -572,8 +572,7 @@ Copyright © 2003-2005 Gajim Team
|
||||||
<b>Gajim Team</b>
|
<b>Gajim Team</b>
|
||||||
Vincent Hanquez (tab@snarc.org)
|
Vincent Hanquez (tab@snarc.org)
|
||||||
Yann Le Boulanger (asterix@lagaule.org)
|
Yann Le Boulanger (asterix@lagaule.org)
|
||||||
Nikos Kouremenos (nkour@jabber.org)
|
Nikos Kouremenos (nkour@jabber.org)</property>
|
||||||
Alex Podaras (bigpod@jabber.org)</property>
|
|
||||||
<property name="use_underline">False</property>
|
<property name="use_underline">False</property>
|
||||||
<property name="use_markup">True</property>
|
<property name="use_markup">True</property>
|
||||||
<property name="justify">GTK_JUSTIFY_LEFT</property>
|
<property name="justify">GTK_JUSTIFY_LEFT</property>
|
||||||
|
@ -4827,7 +4826,7 @@ Custom</property>
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkLabel" id="label199">
|
<widget class="GtkLabel" id="label199">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="label" translatable="yes">Browser:</property>
|
<property name="label" translatable="yes">Browser</property>
|
||||||
<property name="use_underline">False</property>
|
<property name="use_underline">False</property>
|
||||||
<property name="use_markup">False</property>
|
<property name="use_markup">False</property>
|
||||||
<property name="justify">GTK_JUSTIFY_LEFT</property>
|
<property name="justify">GTK_JUSTIFY_LEFT</property>
|
||||||
|
@ -4851,7 +4850,7 @@ Custom</property>
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkLabel" id="label200">
|
<widget class="GtkLabel" id="label200">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="label" translatable="yes">Mail :</property>
|
<property name="label" translatable="yes">Mail app</property>
|
||||||
<property name="use_underline">False</property>
|
<property name="use_underline">False</property>
|
||||||
<property name="use_markup">False</property>
|
<property name="use_markup">False</property>
|
||||||
<property name="justify">GTK_JUSTIFY_LEFT</property>
|
<property name="justify">GTK_JUSTIFY_LEFT</property>
|
||||||
|
|
|
@ -366,9 +366,6 @@ class tabbed_chat_window:
|
||||||
self.chat_notebook.set_show_tabs(False)
|
self.chat_notebook.set_show_tabs(False)
|
||||||
self.show_title()
|
self.show_title()
|
||||||
|
|
||||||
def hyperlink_handler(self, *args):
|
|
||||||
pass
|
|
||||||
|
|
||||||
def new_user(self, user):
|
def new_user(self, user):
|
||||||
self.nb_unread[user.jid] = 0
|
self.nb_unread[user.jid] = 0
|
||||||
self.users[user.jid] = user
|
self.users[user.jid] = user
|
||||||
|
@ -377,9 +374,7 @@ class tabbed_chat_window:
|
||||||
conversation_textview = \
|
conversation_textview = \
|
||||||
self.xmls[user.jid].get_widget('conversation_textview')
|
self.xmls[user.jid].get_widget('conversation_textview')
|
||||||
conversation_buffer = conversation_textview.get_buffer()
|
conversation_buffer = conversation_textview.get_buffer()
|
||||||
self.link_tag = conversation_buffer.create_tag('hyperlink', foreground='blue')
|
|
||||||
end_iter = conversation_buffer.get_end_iter()
|
end_iter = conversation_buffer.get_end_iter()
|
||||||
self.link_tag.connect('event', self.hyperlink_handler)
|
|
||||||
conversation_buffer.create_mark('end', end_iter, 0)
|
conversation_buffer.create_mark('end', end_iter, 0)
|
||||||
self.tagIn[user.jid] = conversation_buffer.create_tag('incoming')
|
self.tagIn[user.jid] = conversation_buffer.create_tag('incoming')
|
||||||
color = self.plugin.config['inmsgcolor']
|
color = self.plugin.config['inmsgcolor']
|
||||||
|
@ -550,25 +545,7 @@ class tabbed_chat_window:
|
||||||
index+=l
|
index+=l
|
||||||
beg = index
|
beg = index
|
||||||
index+=1
|
index+=1
|
||||||
#conversation_buffer.insert(end_iter, otext[beg:])
|
conversation_buffer.insert(end_iter, otext[beg:])
|
||||||
|
|
||||||
linksprefix = ['http://', 'https://', 'news://', 'ftp://', 'mailto:', 'ed2k://', 'www.', 'ftp.']
|
|
||||||
start=0
|
|
||||||
otext_lowered = otext.lower() # make them all small letters
|
|
||||||
for word in otext_lowered.split(): # get each word seperately
|
|
||||||
# word must be larger than the linksprefix items which atm the smaller is 4
|
|
||||||
if len(word) > 4:
|
|
||||||
for travelthru in range(len(linksprefix)): # travel tru linksprefix list
|
|
||||||
# linksprefix[travelthru] is http:// then https:// then news:// etc..
|
|
||||||
if word.startswith(linksprefix[travelthru]):
|
|
||||||
start = otext_lowered.index(word)
|
|
||||||
end = start + len(word)
|
|
||||||
print word, 'is a link and is in otext[%s:%s]' % (start, end)
|
|
||||||
conversation_buffer.insert_with_tags_by_name(end_iter, otext[start:end], 'hyperlink')
|
|
||||||
end_iter = conversation_buffer.get_end_iter()
|
|
||||||
break
|
|
||||||
|
|
||||||
conversation_buffer.insert(end_iter, otext[start:])
|
|
||||||
|
|
||||||
#scroll to the end of the textview
|
#scroll to the end of the textview
|
||||||
conversation_textview.scroll_to_mark(conversation_buffer.get_mark('end'),\
|
conversation_textview.scroll_to_mark(conversation_buffer.get_mark('end'),\
|
||||||
|
@ -579,19 +556,15 @@ class tabbed_chat_window:
|
||||||
self.redraw_tab(jid)
|
self.redraw_tab(jid)
|
||||||
self.show_title()
|
self.show_title()
|
||||||
|
|
||||||
class gc:
|
class Groupchat_window:
|
||||||
def delete_event(self, widget):
|
def on_groupchat_window_destroy(self, widget):
|
||||||
"""close window"""
|
"""close window"""
|
||||||
self.plugin.send('GC_STATUS', self.account, (self.nick, self.jid,\
|
self.plugin.send('GC_STATUS', self.account, (self.nick, self.jid,\
|
||||||
'offline', 'offline'))
|
'offline', 'offline'))
|
||||||
del self.plugin.windows[self.account]['gc'][self.jid]
|
del self.plugin.windows[self.account]['gc'][self.jid]
|
||||||
|
|
||||||
def on_close(self, widget):
|
|
||||||
"""When Cancel button is clicked"""
|
|
||||||
widget.get_toplevel().destroy()
|
|
||||||
|
|
||||||
def get_role_iter(self, name):
|
def get_role_iter(self, name):
|
||||||
model = self.tree.get_model()
|
model = self.list_treeview.get_model()
|
||||||
fin = False
|
fin = False
|
||||||
iter = model.get_iter_root()
|
iter = model.get_iter_root()
|
||||||
if not iter:
|
if not iter:
|
||||||
|
@ -606,7 +579,7 @@ class gc:
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def get_user_iter(self, jid):
|
def get_user_iter(self, jid):
|
||||||
model = self.tree.get_model()
|
model = self.list_treeview.get_model()
|
||||||
fin = False
|
fin = False
|
||||||
role = model.get_iter_root()
|
role = model.get_iter_root()
|
||||||
if not role:
|
if not role:
|
||||||
|
@ -628,7 +601,7 @@ class gc:
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def get_user_list(self):
|
def get_user_list(self):
|
||||||
model = self.tree.get_model()
|
model = self.list_treeview.get_model()
|
||||||
list = []
|
list = []
|
||||||
fin = False
|
fin = False
|
||||||
role = model.get_iter_root()
|
role = model.get_iter_root()
|
||||||
|
@ -652,7 +625,7 @@ class gc:
|
||||||
|
|
||||||
def remove_user(self, nick):
|
def remove_user(self, nick):
|
||||||
"""Remove a user from the roster"""
|
"""Remove a user from the roster"""
|
||||||
model = self.tree.get_model()
|
model = self.list_treeview.get_model()
|
||||||
iter = self.get_user_iter(nick)
|
iter = self.get_user_iter(nick)
|
||||||
if not iter:
|
if not iter:
|
||||||
return
|
return
|
||||||
|
@ -662,18 +635,18 @@ class gc:
|
||||||
model.remove(parent_iter)
|
model.remove(parent_iter)
|
||||||
|
|
||||||
def add_user_to_roster(self, nick, show, role, jid):
|
def add_user_to_roster(self, nick, show, role, jid):
|
||||||
model = self.tree.get_model()
|
model = self.list_treeview.get_model()
|
||||||
img = self.plugin.roster.pixbufs[show]
|
img = self.plugin.roster.pixbufs[show]
|
||||||
role_iter = self.get_role_iter(role)
|
role_iter = self.get_role_iter(role)
|
||||||
if not role_iter:
|
if not role_iter:
|
||||||
role_iter = model.append(None, (self.plugin.roster.pixbufs['closed']\
|
role_iter = model.append(None, (self.plugin.roster.pixbufs['closed']\
|
||||||
, role, role))
|
, role, role))
|
||||||
iter = model.append(role_iter, (img, nick, jid))
|
iter = model.append(role_iter, (img, nick, jid))
|
||||||
self.tree.expand_row((model.get_path(role_iter)), False)
|
self.list_treeview.expand_row((model.get_path(role_iter)), False)
|
||||||
return iter
|
return iter
|
||||||
|
|
||||||
def get_role(self, jid_iter):
|
def get_role(self, jid_iter):
|
||||||
model = self.tree.get_model()
|
model = self.list_treeview.get_model()
|
||||||
path = model.get_path(jid_iter)[0]
|
path = model.get_path(jid_iter)[0]
|
||||||
iter = model.get_iter(path)
|
iter = model.get_iter(path)
|
||||||
return model.get_value(iter, 1)
|
return model.get_value(iter, 1)
|
||||||
|
@ -681,7 +654,7 @@ class gc:
|
||||||
def chg_user_status(self, nick, show, status, role, affiliation, jid, \
|
def chg_user_status(self, nick, show, status, role, affiliation, jid, \
|
||||||
reason, actor, statusCode, account):
|
reason, actor, statusCode, account):
|
||||||
"""When a user change his status"""
|
"""When a user change his status"""
|
||||||
model = self.tree.get_model()
|
model = self.list_treeview.get_model()
|
||||||
if show == 'offline' or show == 'error':
|
if show == 'offline' or show == 'error':
|
||||||
if statusCode == '307':
|
if statusCode == '307':
|
||||||
self.print_conversation(_('%s has been kicked by %s: %s') % (nick, \
|
self.print_conversation(_('%s has been kicked by %s: %s') % (nick, \
|
||||||
|
@ -703,41 +676,63 @@ class gc:
|
||||||
img = self.plugin.roster.pixbufs[show]
|
img = self.plugin.roster.pixbufs[show]
|
||||||
model.set_value(iter, 0, img)
|
model.set_value(iter, 0, img)
|
||||||
|
|
||||||
|
def show_title(self):
|
||||||
|
"""redraw the window's title"""
|
||||||
|
#FIXME when multi tabs will be ok
|
||||||
|
unread = 0
|
||||||
|
# for jid in self.nb_unread:
|
||||||
|
# unread += self.nb_unread[jid]
|
||||||
|
unread = self.nb_unread
|
||||||
|
start = ""
|
||||||
|
if unread > 1:
|
||||||
|
start = "[" + str(unread) + "] "
|
||||||
|
elif unread == 1:
|
||||||
|
start = "* "
|
||||||
|
chat = 'Groupchat in ' + self.jid
|
||||||
|
# if len(self.xmls) > 1:
|
||||||
|
if 0:
|
||||||
|
chat = 'Groupchat'
|
||||||
|
self.window.set_title(start + chat + ' (' + self.account + ')')
|
||||||
|
|
||||||
def set_subject(self, subject):
|
def set_subject(self, subject):
|
||||||
self.xml.get_widget('subject_entry').set_text(subject)
|
self.xml.get_widget('subject_entry').set_text(subject)
|
||||||
|
|
||||||
def on_subject_entry_key_press_event(self, widget, event):
|
def on_subject_entry_key_press_event(self, widget, event):
|
||||||
if event.keyval == gtk.keysyms.Return:
|
if event.keyval == gtk.keysyms.Return:
|
||||||
subject = self.xml.get_widget('subject_entry').get_text()
|
subject = widget.get_text()
|
||||||
self.plugin.send('GC_SUBJECT', self.account, (self.jid, subject))
|
self.plugin.send('GC_SUBJECT', self.account, (self.jid, subject))
|
||||||
|
|
||||||
def on_msg_key_press_event(self, widget, event):
|
def on_set_button_clicked(self, widget):
|
||||||
|
subject = self.xml.get_widget('subject_entry').get_text()
|
||||||
|
self.plugin.send('GC_SUBJECT', self.account, (self.jid, subject))
|
||||||
|
|
||||||
|
def on_message_textview_key_press_event(self, widget, event):
|
||||||
"""When a key is pressed :
|
"""When a key is pressed :
|
||||||
if enter is pressed without the shit key, message (if not empty) is sent
|
if enter is pressed without the shit key, message (if not empty) is sent
|
||||||
and printed in the conversation"""
|
and printed in the conversation"""
|
||||||
if event.keyval == gtk.keysyms.Return:
|
if event.keyval == gtk.keysyms.Return:
|
||||||
if (event.state & gtk.gdk.SHIFT_MASK):
|
if (event.state & gtk.gdk.SHIFT_MASK):
|
||||||
return 0
|
return 0
|
||||||
txt_buffer = widget.get_buffer()
|
message_buffer = widget.get_buffer()
|
||||||
start_iter = txt_buffer.get_start_iter()
|
start_iter = message_buffer.get_start_iter()
|
||||||
end_iter = txt_buffer.get_end_iter()
|
end_iter = message_buffer.get_end_iter()
|
||||||
txt = txt_buffer.get_text(start_iter, end_iter, 0)
|
txt = message_buffer.get_text(start_iter, end_iter, 0)
|
||||||
if txt != '':
|
if txt != '':
|
||||||
self.plugin.send('GC_MSG', self.account, (self.jid, txt))
|
self.plugin.send('GC_MSG', self.account, (self.jid, txt))
|
||||||
txt_buffer.set_text('', -1)
|
message_buffer.set_text('', -1)
|
||||||
widget.grab_focus()
|
widget.grab_focus()
|
||||||
return 1
|
return 1
|
||||||
elif event.keyval == gtk.keysyms.Tab:
|
elif event.keyval == gtk.keysyms.Tab:
|
||||||
list_nick = self.get_user_list()
|
list_nick = self.get_user_list()
|
||||||
txt_buffer = widget.get_buffer()
|
message_buffer = widget.get_buffer()
|
||||||
start_iter = txt_buffer.get_start_iter()
|
start_iter = message_buffer.get_start_iter()
|
||||||
cursor_position = txt_buffer.get_insert()
|
cursor_position = message_buffer.get_insert()
|
||||||
end_iter = txt_buffer.get_iter_at_mark(cursor_position)
|
end_iter = message_buffer.get_iter_at_mark(cursor_position)
|
||||||
txt = txt_buffer.get_text(start_iter, end_iter, 0)
|
txt = message_buffer.get_text(start_iter, end_iter, 0)
|
||||||
begin = txt.split()[-1]
|
begin = txt.split()[-1]
|
||||||
for nick in list_nick:
|
for nick in list_nick:
|
||||||
if nick.find(begin) == 0:
|
if nick.find(begin) == 0:
|
||||||
txt_buffer.insert_at_cursor(nick[len(begin):] + ' ')
|
message_buffer.insert_at_cursor(nick[len(begin):] + ' ')
|
||||||
return 1
|
return 1
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
|
@ -745,28 +740,32 @@ class gc:
|
||||||
"""Print a line in the conversation :
|
"""Print a line in the conversation :
|
||||||
if contact is set : it's a message from someone
|
if contact is set : it's a message from someone
|
||||||
if contact is not set : it's a message from the server"""
|
if contact is not set : it's a message from the server"""
|
||||||
conversation = self.xml.get_widget('conversation')
|
conversation_textview = self.xml.get_widget('conversation_textview')
|
||||||
buffer = conversation.get_buffer()
|
conversation_buffer = conversation_textview.get_buffer()
|
||||||
if not txt:
|
if not txt:
|
||||||
txt = ""
|
txt = ""
|
||||||
end_iter = buffer.get_end_iter()
|
end_iter = conversation_buffer.get_end_iter()
|
||||||
if not tim:
|
if not tim:
|
||||||
tim = time.localtime()
|
tim = time.localtime()
|
||||||
tims = time.strftime('[%H:%M:%S]', tim)
|
tims = time.strftime('[%H:%M:%S]', tim)
|
||||||
buffer.insert(end_iter, tims)
|
conversation_buffer.insert(end_iter, tims)
|
||||||
if contact:
|
if contact:
|
||||||
if contact == self.nick:
|
if contact == self.nick:
|
||||||
buffer.insert_with_tags_by_name(end_iter, '<'+contact+'> ', \
|
conversation_buffer.insert_with_tags_by_name(end_iter, '<' + \
|
||||||
'outgoing')
|
contact + '> ', 'outgoing')
|
||||||
else:
|
else:
|
||||||
buffer.insert_with_tags_by_name(end_iter, '<' + contact + '> ', \
|
conversation_buffer.insert_with_tags_by_name(end_iter, '<' + \
|
||||||
'incoming')
|
contact + '> ', 'incoming')
|
||||||
buffer.insert(end_iter, txt+'\n')
|
conversation_buffer.insert(end_iter, txt + '\n')
|
||||||
else:
|
else:
|
||||||
buffer.insert_with_tags_by_name(end_iter, txt+'\n', \
|
conversation_buffer.insert_with_tags_by_name(end_iter, txt + '\n', \
|
||||||
'status')
|
'status')
|
||||||
#scroll to the end of the textview
|
#scroll to the end of the textview
|
||||||
conversation.scroll_to_mark(buffer.get_mark('end'), 0.1, 0, 0, 0)
|
conversation_textview.scroll_to_mark(conversation_buffer.get_mark('end'),\
|
||||||
|
0.1, 0, 0, 0)
|
||||||
|
if not self.window.is_active() and contact != 'status':
|
||||||
|
self.nb_unread += 1
|
||||||
|
self.show_title()
|
||||||
|
|
||||||
def kick(self, widget, room_jid, nick):
|
def kick(self, widget, room_jid, nick):
|
||||||
"""kick a user"""
|
"""kick a user"""
|
||||||
|
@ -834,7 +833,7 @@ class gc:
|
||||||
|
|
||||||
def mk_menu(self, event, iter):
|
def mk_menu(self, event, iter):
|
||||||
"""Make user's popup menu"""
|
"""Make user's popup menu"""
|
||||||
model = self.tree.get_model()
|
model = self.list_treeview.get_model()
|
||||||
nick = model.get_value(iter, 1)
|
nick = model.get_value(iter, 1)
|
||||||
jid = model.get_value(iter, 2)
|
jid = model.get_value(iter, 2)
|
||||||
|
|
||||||
|
@ -896,57 +895,63 @@ class gc:
|
||||||
menu.show_all()
|
menu.show_all()
|
||||||
menu.reposition()
|
menu.reposition()
|
||||||
|
|
||||||
def on_focus(self, widget, event):
|
def on_groupchat_window_focus_in_event(self, widget, event):
|
||||||
"""When window get focus"""
|
"""When window get focus"""
|
||||||
self.plugin.systray.remove_jid(self.jid, self.account)
|
if self.nb_unread > 0:
|
||||||
|
self.nb_unread = 0
|
||||||
|
self.show_title()
|
||||||
|
self.plugin.systray.remove_jid(self.jid, self.account)
|
||||||
|
|
||||||
def on_treeview_event(self, widget, event):
|
def on_list_treeview_button_press_event(self, widget, event):
|
||||||
"""popup user's group's or agent menu"""
|
"""popup user's group's or agent menu"""
|
||||||
if event.type == gtk.gdk.BUTTON_PRESS:
|
if event.type == gtk.gdk.BUTTON_PRESS:
|
||||||
if event.button == 3:
|
if event.button == 3:
|
||||||
try:
|
try:
|
||||||
path, column, x, y = self.tree.get_path_at_pos(int(event.x), \
|
path, column, x, y = self.list_treeview.get_path_at_pos(\
|
||||||
int(event.y))
|
int(event.x), int(event.y))
|
||||||
except TypeError:
|
except TypeError:
|
||||||
self.tree.get_selection().unselect_all()
|
self.list_treeview.get_selection().unselect_all()
|
||||||
return False
|
return False
|
||||||
model = self.tree.get_model()
|
model = self.list_treeview.get_model()
|
||||||
iter = model.get_iter(path)
|
iter = model.get_iter(path)
|
||||||
if len(path) == 2:
|
if len(path) == 2:
|
||||||
self.mk_menu(event, iter)
|
self.mk_menu(event, iter)
|
||||||
return True
|
return True
|
||||||
if event.button == 1:
|
if event.button == 1:
|
||||||
try:
|
try:
|
||||||
path, column, x, y = self.tree.get_path_at_pos(int(event.x), \
|
path, column, x, y = self.list_treeview.get_path_at_pos(\
|
||||||
int(event.y))
|
int(event.x), int(event.y))
|
||||||
except TypeError:
|
except TypeError:
|
||||||
self.tree.get_selection().unselect_all()
|
self.list_treeview.get_selection().unselect_all()
|
||||||
if event.type == gtk.gdk.KEY_RELEASE:
|
|
||||||
if event.keyval == gtk.keysyms.Escape:
|
|
||||||
self.tree.get_selection().unselect_all()
|
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def on_row_activated(self, widget, path, col=0):
|
def on_list_treeview_key_release_event(self, widget, event):
|
||||||
|
if event.type == gtk.gdk.KEY_RELEASE:
|
||||||
|
if event.keyval == gtk.keysyms.Escape:
|
||||||
|
self.list_treeview.get_selection().unselect_all()
|
||||||
|
return False
|
||||||
|
|
||||||
|
def on_list_treeview_row_activated(self, widget, path, col=0):
|
||||||
"""When an iter is dubble clicked :
|
"""When an iter is dubble clicked :
|
||||||
open the chat window"""
|
open the chat window"""
|
||||||
model = self.tree.get_model()
|
model = self.list_treeview.get_model()
|
||||||
iter = model.get_iter(path)
|
iter = model.get_iter(path)
|
||||||
if len(path) == 1:
|
if len(path) == 1:
|
||||||
if (self.tree.row_expanded(path)):
|
if (self.list_treeview.row_expanded(path)):
|
||||||
self.tree.collapse_row(path)
|
self.list_treeview.collapse_row(path)
|
||||||
else:
|
else:
|
||||||
self.tree.expand_row(path, False)
|
self.list_treeview.expand_row(path, False)
|
||||||
|
|
||||||
def on_row_expanded(self, widget, iter, path):
|
def on_list_treeview_row_expanded(self, widget, iter, path):
|
||||||
"""When a row is expanded :
|
"""When a row is expanded :
|
||||||
change the icon of the arrow"""
|
change the icon of the arrow"""
|
||||||
model = self.tree.get_model()
|
model = self.list_treeview.get_model()
|
||||||
model.set_value(iter, 0, self.plugin.roster.pixbufs['opened'])
|
model.set_value(iter, 0, self.plugin.roster.pixbufs['opened'])
|
||||||
|
|
||||||
def on_row_collapsed(self, widget, iter, path):
|
def on_list_treeview_row_collapsed(self, widget, iter, path):
|
||||||
"""When a row is collapsed :
|
"""When a row is collapsed :
|
||||||
change the icon of the arrow"""
|
change the icon of the arrow"""
|
||||||
model = self.tree.get_model()
|
model = self.list_treeview.get_model()
|
||||||
model.set_value(iter, 0, self.plugin.roster.pixbufs['closed'])
|
model.set_value(iter, 0, self.plugin.roster.pixbufs['closed'])
|
||||||
|
|
||||||
def __init__(self, jid, nick, plugin, account):
|
def __init__(self, jid, nick, plugin, account):
|
||||||
|
@ -954,9 +959,10 @@ class gc:
|
||||||
self.nick = nick
|
self.nick = nick
|
||||||
self.plugin = plugin
|
self.plugin = plugin
|
||||||
self.account = account
|
self.account = account
|
||||||
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'Gc', APP)
|
self.nb_unread = 0
|
||||||
self.window = self.xml.get_widget('Gc')
|
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'groupchat_window', APP)
|
||||||
self.tree = self.xml.get_widget('list')
|
self.window = self.xml.get_widget('groupchat_window')
|
||||||
|
self.list_treeview = self.xml.get_widget('list_treeview')
|
||||||
#status_image, nickname, real_jid
|
#status_image, nickname, real_jid
|
||||||
store = gtk.TreeStore(gtk.Image, str, str)
|
store = gtk.TreeStore(gtk.Image, str, str)
|
||||||
column = gtk.TreeViewColumn('contacts')
|
column = gtk.TreeViewColumn('contacts')
|
||||||
|
@ -967,38 +973,30 @@ class gc:
|
||||||
column.pack_start(render_text, expand = True)
|
column.pack_start(render_text, expand = True)
|
||||||
column.add_attribute(render_text, 'text', 1)
|
column.add_attribute(render_text, 'text', 1)
|
||||||
|
|
||||||
self.tree.append_column(column)
|
self.list_treeview.append_column(column)
|
||||||
self.tree.set_model(store)
|
self.list_treeview.set_model(store)
|
||||||
|
|
||||||
col = gtk.TreeViewColumn()
|
col = gtk.TreeViewColumn()
|
||||||
render = gtk.CellRendererPixbuf()
|
render = gtk.CellRendererPixbuf()
|
||||||
col.pack_start(render, expand = False)
|
col.pack_start(render, expand = False)
|
||||||
self.tree.append_column(col)
|
self.list_treeview.append_column(col)
|
||||||
col.set_visible(False)
|
col.set_visible(False)
|
||||||
self.tree.set_expander_column(col)
|
self.list_treeview.set_expander_column(col)
|
||||||
|
|
||||||
conversation = self.xml.get_widget('conversation')
|
conversation_textview = self.xml.get_widget('conversation_textview')
|
||||||
buffer = conversation.get_buffer()
|
conversation_buffer = conversation_textview.get_buffer()
|
||||||
end_iter = buffer.get_end_iter()
|
end_iter = conversation_buffer.get_end_iter()
|
||||||
buffer.create_mark('end', end_iter, 0)
|
conversation_buffer.create_mark('end', end_iter, 0)
|
||||||
self.tagIn = buffer.create_tag('incoming')
|
self.tagIn = conversation_buffer.create_tag('incoming')
|
||||||
color = self.plugin.config['inmsgcolor']
|
color = self.plugin.config['inmsgcolor']
|
||||||
self.tagIn.set_property('foreground', color)
|
self.tagIn.set_property('foreground', color)
|
||||||
self.tagOut = buffer.create_tag('outgoing')
|
self.tagOut = conversation_buffer.create_tag('outgoing')
|
||||||
color = self.plugin.config['outmsgcolor']
|
color = self.plugin.config['outmsgcolor']
|
||||||
self.tagOut.set_property('foreground', color)
|
self.tagOut.set_property('foreground', color)
|
||||||
self.tagStatus = buffer.create_tag('status')
|
self.tagStatus = conversation_buffer.create_tag('status')
|
||||||
color = self.plugin.config['statusmsgcolor']
|
color = self.plugin.config['statusmsgcolor']
|
||||||
self.tagStatus.set_property('foreground', color)
|
self.tagStatus.set_property('foreground', color)
|
||||||
self.xml.signal_connect('gtk_widget_destroy', self.delete_event)
|
self.xml.signal_autoconnect(self)
|
||||||
self.xml.signal_connect('on_focus', self.on_focus)
|
|
||||||
self.xml.signal_connect('on_msg_key_press_event', \
|
|
||||||
self.on_msg_key_press_event)
|
|
||||||
self.xml.signal_connect('on_treeview_event', self.on_treeview_event)
|
|
||||||
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)
|
|
||||||
self.xml.signal_connect('on_subject_entry_key_press_event', self.on_subject_entry_key_press_event)
|
|
||||||
|
|
||||||
class history_window:
|
class history_window:
|
||||||
"""Class for bowser agent window :
|
"""Class for bowser agent window :
|
||||||
|
|
Loading…
Add table
Reference in a new issue