/me works, room subject ellipses, and ui update fixes

This commit is contained in:
Travis Shirk 2006-01-10 01:47:24 +00:00
parent 2a794ba19e
commit 0da89c3996
8 changed files with 29 additions and 35 deletions

View File

@ -50,14 +50,11 @@ class ChatControlBase(MessageControl):
'''A base class containing a banner, ConversationTextview, MessageTextView '''A base class containing a banner, ConversationTextview, MessageTextView
''' '''
def draw_widgets(self):
self.draw_banner()
# Derived types MUST implement this
def draw_banner(self): def draw_banner(self):
self._paint_banner() self._paint_banner()
self._update_banner_state_image() self._update_banner_state_image()
# Derived types SHOULD implement this # Derived types SHOULD implement this
def update_state(self): def update_ui(self):
self.draw_banner() self.draw_banner()
# Derived types SHOULD implement this # Derived types SHOULD implement this
def repaint_themed_widgets(self): def repaint_themed_widgets(self):
@ -66,7 +63,7 @@ class ChatControlBase(MessageControl):
def _update_banner_state_image(self): def _update_banner_state_image(self):
pass # Derived types MAY implement this pass # Derived types MAY implement this
def handle_message_textview_mykey_press(self): def handle_message_textview_mykey_press(self, widget, event_keyval, event_keymod):
pass # Derived should implement this rather than connecting to the event itself. pass # Derived should implement this rather than connecting to the event itself.
def __init__(self, type_id, parent_win, widget_name, display_name, contact, acct): def __init__(self, type_id, parent_win, widget_name, display_name, contact, acct):
@ -684,7 +681,7 @@ class ChatControl(ChatControlBase):
if self.contact.jid in gajim.encrypted_chats[self.account]: if self.contact.jid in gajim.encrypted_chats[self.account]:
self.xml.get_widget('gpg_togglebutton').set_active(True) self.xml.get_widget('gpg_togglebutton').set_active(True)
self.draw_widgets() self.update_ui()
# restore previous conversation # restore previous conversation
self.restore_conversation() self.restore_conversation()
@ -740,9 +737,9 @@ class ChatControl(ChatControlBase):
self.possible_inactive_timeout_id = gobject.timeout_add(30000, self.possible_inactive_timeout_id = gobject.timeout_add(30000,
self.check_for_possible_inactive_chatstate, None) self.check_for_possible_inactive_chatstate, None)
def draw_widgets(self): def update_ui(self):
# The name banner is drawn here # The name banner is drawn here
ChatControlBase.draw_widgets(self) ChatControlBase.update_ui(self)
def _update_banner_state_image(self): def _update_banner_state_image(self):
contact = gajim.contacts.get_contact_with_highest_priority(self.account, contact = gajim.contacts.get_contact_with_highest_priority(self.account,
@ -1324,7 +1321,7 @@ class ChatControl(ChatControlBase):
typ = 'chat' # Is it a normal chat or a pm ? typ = 'chat' # Is it a normal chat or a pm ?
# reset to status image in gc if it is a pm # reset to status image in gc if it is a pm
if is_pm: if is_pm:
control.draw_widgets() control.update_ui()
typ = 'pm' typ = 'pm'
gajim.interface.roster.draw_contact(jid, self.account) gajim.interface.roster.draw_contact(jid, self.account)

View File

@ -2217,6 +2217,7 @@ class Connection:
t.setTagData('password', password) t.setTagData('password', password)
self.to_be_sent.append(p) self.to_be_sent.append(p)
#last date/time in history to avoid duplicate #last date/time in history to avoid duplicate
# FIXME: This JID needs to be normalized; see #1364
jid='%s@%s' % (room, server) jid='%s@%s' % (room, server)
last_log = gajim.logger.get_last_date_that_has_logs(jid) last_log = gajim.logger.get_last_date_that_has_logs(jid)
if last_log is None: if last_log is None:

View File

@ -483,7 +483,7 @@ class PreferencesWindow:
gajim.interface.roster.draw_roster() gajim.interface.roster.draw_roster()
for ctl in gajim.interface.msg_win_mgr.controls(): for ctl in gajim.interface.msg_win_mgr.controls():
if ctl.type_id == message_control.TYPE_GC: if ctl.type_id == message_control.TYPE_GC:
ctl.draw_widgets() ctl.update_ui()
def on_show_avatars_in_roster_checkbutton_toggled(self, widget): def on_show_avatars_in_roster_checkbutton_toggled(self, widget):
self.on_checkbutton_toggled(widget, 'show_avatars_in_roster') self.on_checkbutton_toggled(widget, 'show_avatars_in_roster')

View File

@ -691,7 +691,7 @@ class Interface:
contact = ctl.contact contact = ctl.contact
contact.show = show contact.show = show
contact.status = status contact.status = status
ctl.update_state() ctl.update_ui()
uf_show = helpers.get_uf_show(show) uf_show = helpers.get_uf_show(show)
ctl.print_conversation(_('%s is now %s (%s)') % (nick, uf_show, status), ctl.print_conversation(_('%s is now %s (%s)') % (nick, uf_show, status),
'status') 'status')
@ -966,7 +966,8 @@ class Interface:
# join already open groupchats # join already open groupchats
for gc_control in gajim.interface.msg_win_mgr.get_controls(message_control.TYPE_GC): for gc_control in gajim.interface.msg_win_mgr.get_controls(message_control.TYPE_GC):
room_jid = gc_control.room_jid room_jid = gc_control.room_jid
if gajim.gc_connected[account][room_jid]: if gajim.gc_connected[account].has_key(room_jid) and\
gajim.gc_connected[account][room_jid]:
continue continue
room, server = gajim.get_room_name_and_server_from_room_jid(room_jid) room, server = gajim.get_room_name_and_server_from_room_jid(room_jid)
nick = gc_control.nick nick = gc_control.nick

View File

@ -23,7 +23,6 @@ import message_control
import tooltips import tooltips
import dialogs import dialogs
import vcard import vcard
import chat
import cell_renderer_image import cell_renderer_image
import history_window import history_window
import tooltips import tooltips
@ -173,7 +172,7 @@ class GroupchatControl(ChatControlBase):
self.set_subject('') self.set_subject('')
self.got_disconnected() #init some variables self.got_disconnected() #init some variables
self.draw_widgets() self.update_ui()
self.conv_textview.grab_focus() self.conv_textview.grab_focus()
self.widget.show_all() self.widget.show_all()
@ -273,8 +272,8 @@ class GroupchatControl(ChatControlBase):
tab_image = img_16['muc_active'] tab_image = img_16['muc_active']
return tab_image return tab_image
def update_state(self): def update_ui(self):
ChatControlBase.update_state(self) ChatControlBase.update_ui(self)
self.draw_roster() self.draw_roster()
def prepare_context_menu(self): def prepare_context_menu(self):
@ -508,19 +507,18 @@ class GroupchatControl(ChatControlBase):
def set_subject(self, subject): def set_subject(self, subject):
self.subject = subject self.subject = subject
full_subject = None
self.name_label.set_ellipsize(pango.ELLIPSIZE_END)
subject = gtkgui_helpers.reduce_chars_newlines(subject, 0, 2) subject = gtkgui_helpers.reduce_chars_newlines(subject, 0, 2)
subject = gtkgui_helpers.escape_for_pango_markup(subject) subject = gtkgui_helpers.escape_for_pango_markup(subject)
self.name_label.set_markup( self.name_label.set_markup(
'<span weight="heavy" size="x-large">%s</span>\n%s' % (self.room_jid, subject)) '<span weight="heavy" size="x-large">%s</span>\n%s' % (self.room_jid, subject))
event_box = self.name_label.get_parent() event_box = self.name_label.get_parent()
if subject == '': if subject == '':
subject = _('This room has no subject') self.subject = _('This room has no subject')
if full_subject is not None: # tooltip must always hold ALL the subject
subject = full_subject # tooltip must always hold ALL the subject self.subject_tooltip.set_tip(event_box, self.subject)
self.subject_tooltip.set_tip(event_box, subject)
def save_var(self): def save_var(self):
return { return {
@ -554,10 +552,6 @@ class GroupchatControl(ChatControlBase):
self.msg_textview.set_sensitive(False) self.msg_textview.set_sensitive(False)
self.xml.get_widget('send_button').set_sensitive(False) self.xml.get_widget('send_button').set_sensitive(False)
def draw_widgets(self):
ChatControlBase.draw_widgets(self)
self.draw_roster()
def draw_roster(self): def draw_roster(self):
model = self.list_treeview.get_model() model = self.list_treeview.get_model()
model.clear() model.clear()
@ -766,6 +760,9 @@ class GroupchatControl(ChatControlBase):
if message_array == ['']: if message_array == ['']:
message_array = [] message_array = []
if command == 'me':
return False # This is not really a command
if command == 'nick': if command == 'nick':
# example: /nick foo # example: /nick foo
if len(message_array): if len(message_array):

View File

@ -70,11 +70,9 @@ class MessageControl:
def shutdown(self): def shutdown(self):
# NOTE: Derived classes MUST implement this # NOTE: Derived classes MUST implement this
assert(False) assert(False)
def draw_widgets(self):
pass # NOTE: Derived classes SHOULD implement this
def repaint_themed_widgets(self, theme): def repaint_themed_widgets(self, theme):
pass # NOTE: Derived classes SHOULD implement this pass # NOTE: Derived classes SHOULD implement this
def update_state(self): def update_ui(self):
pass # NOTE: Derived classes SHOULD implement this pass # NOTE: Derived classes SHOULD implement this
def toggle_emoticons(self): def toggle_emoticons(self):
pass # NOTE: Derived classes MAY implement this pass # NOTE: Derived classes MAY implement this

View File

@ -138,7 +138,7 @@ class MessageWindow:
self.redraw_tab(control.contact) self.redraw_tab(control.contact)
control.draw_widgets() control.update_ui()
self.window.show_all() self.window.show_all()
# NOTE: we do not call set_control_active(True) since we don't know whether # NOTE: we do not call set_control_active(True) since we don't know whether
# the tab is the active one. # the tab is the active one.
@ -236,7 +236,7 @@ class MessageWindow:
def redraw_tab(self, contact, chatstate = None): def redraw_tab(self, contact, chatstate = None):
ctl = self._controls[contact.jid] ctl = self._controls[contact.jid]
ctl.update_state() ctl.update_ui()
hbox = self.notebook.get_tab_label(ctl.widget).get_children()[0] hbox = self.notebook.get_tab_label(ctl.widget).get_children()[0]
status_img = hbox.get_children()[0] status_img = hbox.get_children()[0]

View File

@ -636,7 +636,7 @@ class RosterWindow:
# update gc's roster # update gc's roster
for ctl in gajim.interface.msg_win_mgr.controls(): for ctl in gajim.interface.msg_win_mgr.controls():
if ctl.type_id == message_control.TYPE_GC: if ctl.type_id == message_control.TYPE_GC:
ctl.draw_widgets() ctl.update_ui()
def draw_roster(self): def draw_roster(self):
'''Clear and draw roster''' '''Clear and draw roster'''
@ -728,7 +728,7 @@ class RosterWindow:
jid = contact.jid jid = contact.jid
win = gajim.interface.msg_win_mgr.get_window(contact.jid) win = gajim.interface.msg_win_mgr.get_window(contact.jid)
ctl = win.get_control(jid) ctl = win.get_control(jid)
ctl.update_state() ctl.update_ui()
win.redraw_tab(contact) win.redraw_tab(contact)
name = contact.name name = contact.name
@ -920,7 +920,7 @@ class RosterWindow:
u.keyID = keyID[0] u.keyID = keyID[0]
if gajim.interface.msg_win_mgr.has_window(contact.jid): if gajim.interface.msg_win_mgr.has_window(contact.jid):
ctl = gajim.interface.msg_win_mgr.get_control(contact.jid) ctl = gajim.interface.msg_win_mgr.get_control(contact.jid)
ctl.draw_widgets() ctl.update_ui()
keys_str = '' keys_str = ''
for jid in keys: for jid in keys:
keys_str += jid + ' ' + keys[jid] + ' ' keys_str += jid + ' ' + keys[jid] + ' '
@ -2237,7 +2237,7 @@ _('If "%s" accepts this request you will know his or her status.') % jid)
for win in gajim.interface.msg_win_mgr.windows(): for win in gajim.interface.msg_win_mgr.windows():
for ctl in gajim.interface.msg_win_mgr.controls(): for ctl in gajim.interface.msg_win_mgr.controls():
ctl.update_state() ctl.update_ui()
win.redraw_tab(ctl.contact) win.redraw_tab(ctl.contact)
self.update_status_combobox() self.update_status_combobox()