some bugfix : when we recieve a NOTIFY event, we must let the 'message' pixbuf if messages are waiting

This commit is contained in:
Yann Leboulanger 2004-06-09 15:29:32 +00:00
parent 3ca47b0d9c
commit d77e5094fd
1 changed files with 21 additions and 16 deletions

View File

@ -99,10 +99,11 @@ class message_Window:
evt = q.get() evt = q.get()
self.print_conversation(evt[0], tim = evt[1]) self.print_conversation(evt[0], tim = evt[1])
del self.plugin.queues[self.account][self.user.jid] del self.plugin.queues[self.account][self.user.jid]
for i in self.plugin.roster.get_user_iter(self.user.jid, self.account): self.plugin.roster.redraw_jid(self.user.jid, self.account)
if self.plugin.roster.pixbufs.has_key(self.user.show): # for i in self.plugin.roster.get_user_iter(self.user.jid, self.account):
self.plugin.roster.tree.get_model().set_value(i, 0, \ # if self.plugin.roster.pixbufs.has_key(self.user.show):
self.plugin.roster.pixbufs[self.user.show]) # self.plugin.roster.tree.get_model().set_value(i, 0, \
# self.plugin.roster.pixbufs[self.user.show])
self.plugin.set_systray() self.plugin.set_systray()
def on_msg_key_press_event(self, widget, event): def on_msg_key_press_event(self, widget, event):
@ -459,6 +460,9 @@ class roster_Window:
prio = u.priority prio = u.priority
show = u.show show = u.show
for iter in iters: for iter in iters:
if self.plugin.queues[account].has_key(jid):
model.set_value(iter, 0, self.pixbufs['message'])
else:
model.set_value(iter, 0, self.pixbufs[show]) model.set_value(iter, 0, self.pixbufs[show])
model.set_value(iter, 1, name) model.set_value(iter, 1, name)
@ -893,8 +897,7 @@ class roster_Window:
if not self.plugin.queues[account].has_key(jid): if not self.plugin.queues[account].has_key(jid):
model = self.tree.get_model() model = self.tree.get_model()
self.plugin.queues[account][jid] = Queue.Queue(50) self.plugin.queues[account][jid] = Queue.Queue(50)
for i in self.get_user_iter(jid, account): self.redraw_jid(jid, account)
model.set_value(i, 0, self.pixbufs['message'])
self.plugin.set_systray('message') self.plugin.set_systray('message')
tim = time.strftime("[%H:%M:%S]") tim = time.strftime("[%H:%M:%S]")
self.plugin.queues[account][jid].put((msg, tim)) self.plugin.queues[account][jid].put((msg, tim))
@ -1292,9 +1295,10 @@ class plugin:
self.roster.add_user_to_roster(ji, ev[1]) self.roster.add_user_to_roster(ji, ev[1])
else: else:
#Update existing iter #Update existing iter
for i in self.roster.get_user_iter(ji, ev[1]): self.roster.redraw_jid(ji, ev[1])
if self.roster.pixbufs.has_key(ev[2][1]): # for i in self.roster.get_user_iter(ji, ev[1]):
model.set_value(i, 0, self.roster.pixbufs[ev[2][1]]) # if self.roster.pixbufs.has_key(ev[2][1]):
# model.set_value(i, 0, self.roster.pixbufs[ev[2][1]])
elif self.roster.contacts[ev[1]].has_key(ji): elif self.roster.contacts[ev[1]].has_key(ji):
#It isn't an agent #It isn't an agent
self.roster.chg_user_status(user1, ev[2][1], ev[2][2], ev[1]) self.roster.chg_user_status(user1, ev[2][1], ev[2][2], ev[1])
@ -1314,8 +1318,9 @@ class plugin:
u = self.roster.contacts[ev[1]][jid][0] u = self.roster.contacts[ev[1]][jid][0]
u.name = ev[2][1] u.name = ev[2][1]
u.resource = ev[2][2] u.resource = ev[2][2]
for i in self.roster.get_user_iter(u.jid, ev[1]): self.roster.redraw_jid(u.jid, ev[1])
model.set_value(i, 1, u.name) # for i in self.roster.get_user_iter(u.jid, ev[1]):
# model.set_value(i, 1, u.name)
else: else:
user1 = user(jid, jid, ['general'], 'online', \ user1 = user(jid, jid, ['general'], 'online', \
'online', 'to', ev[2][2], 0) 'online', 'to', ev[2][2], 0)
@ -1419,14 +1424,14 @@ class plugin:
def set_systray(self, status=None): def set_systray(self, status=None):
if not status: if not status:
self.nb_msg -= 1 self.nb_msg -= 1
if self.nb_msg == 0:
self.set_systray_img(self.status)
elif status == 'message': elif status == 'message':
self.nb_msg += 1 self.nb_msg += 1
self.set_systray_img('message')
else: else:
self.status = status self.status = status
self.set_systray_img(status) if self.nb_msg == 0:
self.set_systray_img(self.status)
else:
self.set_systray_img('message')
def __init__(self, quIN, quOUT): def __init__(self, quIN, quOUT):
gtk.threads_init() gtk.threads_init()