typos and logical fixes for chatstates

This commit is contained in:
Nikos Kouremenos 2005-08-07 23:04:36 +00:00
parent 1c8b7c0a09
commit b164f4a1ea
2 changed files with 14 additions and 11 deletions

View File

@ -113,6 +113,7 @@ class Contact:
# None if no info about peer
# False if peer does not support jep85
# 'ask' if we sent the first 'active' chatstate and are waiting for reply
# this holds what WE SEND to contact (the current chatstate)
self.chatstate = chatstate
import roster_window

View File

@ -164,7 +164,6 @@ class TabbedChatWindow(chat.Chat):
chatstate = helpers.get_uf_chatstate(chatstate)
else:
chatstate = ''
print chatstate
label_text = \
'<span weight="heavy" size="x-large">%s</span> %s' % (name, chatstate)
else:
@ -276,7 +275,7 @@ class TabbedChatWindow(chat.Chat):
def on_tabbed_chat_window_focus_in_event(self, widget, event):
chat.Chat.on_chat_window_focus_in_event(self, widget, event)
# on focus in, send 'active' chatstate
# on focus in, send 'active' chatstate to current tab
self.send_chatstate('active')
def on_tabbed_chat_window_focus_out_event(self, widget, event):
@ -330,7 +329,7 @@ class TabbedChatWindow(chat.Chat):
if dialog.get_response() != gtk.RESPONSE_OK:
return
# chatstates - window is destroyed, send gone
# chatstates - tab is destroyed, send gone
self.send_chatstate('gone', jid)
chat.Chat.remove_tab(self, jid, 'chats')
@ -393,9 +392,9 @@ class TabbedChatWindow(chat.Chat):
return False # stop looping
if self.mouse_over_in_last_5_secs:
self.send_chatstate('active')
self.send_chatstate('active', contact.jid)
elif self.kbd_activity_in_last_5_secs:
self.send_chatstate('composing')
self.send_chatstate('composing', contact.jid)
else:
if self.chatstates[contact.jid] == 'composing':
self.send_chatstate('paused', contact.jid) # pause composing
@ -515,9 +514,10 @@ class TabbedChatWindow(chat.Chat):
self.send_chatstate('composing', jid)
def send_chatstate(self, state, jid = None):
''' sends our chatstate as STANDLONE chat state message (eg. no body)
to the current tab only if new chatstate is different
from the previous one'''
''' sends OUR chatstate as STANDLONE chat state message (eg. no body)
to jid only if new chatstate is different
from the previous one
if jid is not specified, send to active tab'''
# JEP 85 does not allow resending the same chatstate
# this function checks for that and just returns so it's safe to call it
# with same state.
@ -545,7 +545,8 @@ class TabbedChatWindow(chat.Chat):
if contact.chatstate is False: # jid cannot do jep85
return
# if current state equals previous state, return
# if the new state we wanna send (state) equals
# the current state (contact.chastate) then return
if contact.chatstate == state:
return
@ -565,14 +566,17 @@ class TabbedChatWindow(chat.Chat):
if state == 'paused' and not contact.chatstate == 'composing':
gajim.connections[self.account].send_message(jid, None, None,
chatstate = 'active') # go active before
contact.chatstate = 'active'
# if we're inactive prevent composing (JEP violation)
if contact.chatstate == 'inactive' and state == 'composing':
gajim.connections[self.account].send_message(jid, None, None,
chatstate = 'active') # go active before
contact.chatstate = 'active'
gajim.connections[self.account].send_message(jid, None, None,
chatstate = state)
contact.chatstate = state
def send_message(self, message):
"""Send the given message to the active tab"""
@ -632,8 +636,6 @@ class TabbedChatWindow(chat.Chat):
gajim.connections[self.account].send_message(jid, message, keyID,
chatstate = chatstate_to_send)
contact.chatstate = chatstate_to_send
message_buffer.set_text('')
self.print_conversation(message, jid, jid, encrypted = encrypted)