fix using change nick button in groupchats
This commit is contained in:
parent
d408610425
commit
779dcbd38b
|
@ -1639,9 +1639,10 @@ class InputDialogCheck(InputDialog):
|
||||||
self.input_entry.set_text(input_str)
|
self.input_entry.set_text(input_str)
|
||||||
self.input_entry.select_region(0, -1) # select all
|
self.input_entry.select_region(0, -1) # select all
|
||||||
|
|
||||||
self.checkbutton = gtk.CheckButton(checktext)
|
if checktext:
|
||||||
self.vbox.pack_start(self.checkbutton, expand=False, fill=True)
|
self.checkbutton = gtk.CheckButton(checktext)
|
||||||
self.checkbutton.show()
|
self.vbox.pack_start(self.checkbutton, expand=False, fill=True)
|
||||||
|
self.checkbutton.show()
|
||||||
|
|
||||||
def on_okbutton_clicked(self, widget):
|
def on_okbutton_clicked(self, widget):
|
||||||
user_input = self.get_text()
|
user_input = self.get_text()
|
||||||
|
@ -1659,16 +1660,18 @@ class InputDialogCheck(InputDialog):
|
||||||
|
|
||||||
def is_checked(self):
|
def is_checked(self):
|
||||||
''' Get active state of the checkbutton '''
|
''' Get active state of the checkbutton '''
|
||||||
return self.checkbutton.get_active()
|
try:
|
||||||
|
return self.checkbutton.get_active()
|
||||||
|
except Exception:
|
||||||
|
# There is no checkbutton
|
||||||
|
return False
|
||||||
|
|
||||||
class ChangeNickDialog(InputDialogCheck):
|
class ChangeNickDialog(InputDialogCheck):
|
||||||
'''Class for changing room nickname in case of conflict'''
|
'''Class for changing room nickname in case of conflict'''
|
||||||
def __init__(self, account, room_jid):
|
def __init__(self, account, room_jid, title, prompt, check_text=None):
|
||||||
title = _('Unable to join group chat')
|
|
||||||
check_text = _('Always use this nickname when there is a conflict')
|
|
||||||
InputDialogCheck.__init__(self, title, '', checktext=check_text,
|
InputDialogCheck.__init__(self, title, '', checktext=check_text,
|
||||||
input_str='', is_modal=True, ok_handler=None, cancel_handler=None)
|
input_str='', is_modal=True, ok_handler=None, cancel_handler=None)
|
||||||
self.room_queue = [(account, room_jid)]
|
self.room_queue = [(account, room_jid, prompt)]
|
||||||
self.check_next()
|
self.check_next()
|
||||||
|
|
||||||
def on_input_dialog_delete_event(self, widget, event):
|
def on_input_dialog_delete_event(self, widget, event):
|
||||||
|
@ -1686,10 +1689,7 @@ class ChangeNickDialog(InputDialogCheck):
|
||||||
self.check_next()
|
self.check_next()
|
||||||
return
|
return
|
||||||
label = self.xml.get_widget('label')
|
label = self.xml.get_widget('label')
|
||||||
prompt = _('Your desired nickname in group chat %s is in use or '
|
label.set_markup(self.prompt)
|
||||||
'registered by another occupant.\nPlease specify another nickname '
|
|
||||||
'below:') % self.room_jid
|
|
||||||
label.set_markup(prompt)
|
|
||||||
self.set_entry(self.gc_control.nick + \
|
self.set_entry(self.gc_control.nick + \
|
||||||
gajim.config.get('gc_proposed_nick_char'))
|
gajim.config.get('gc_proposed_nick_char'))
|
||||||
|
|
||||||
|
@ -1699,7 +1699,7 @@ class ChangeNickDialog(InputDialogCheck):
|
||||||
self.dialog.destroy()
|
self.dialog.destroy()
|
||||||
del gajim.interface.instances['change_nick_dialog']
|
del gajim.interface.instances['change_nick_dialog']
|
||||||
return
|
return
|
||||||
self.account, self.room_jid = self.room_queue.pop(0)
|
self.account, self.room_jid, self.prompt = self.room_queue.pop(0)
|
||||||
self.setup_dialog()
|
self.setup_dialog()
|
||||||
|
|
||||||
if gajim.new_room_nick is not None and not gajim.gc_connected[
|
if gajim.new_room_nick is not None and not gajim.gc_connected[
|
||||||
|
@ -1743,9 +1743,9 @@ class ChangeNickDialog(InputDialogCheck):
|
||||||
self.gc_control.new_nick = ''
|
self.gc_control.new_nick = ''
|
||||||
self.check_next()
|
self.check_next()
|
||||||
|
|
||||||
def add_room(self, account, room_jid):
|
def add_room(self, account, room_jid, pompt):
|
||||||
if (account, room_jid) not in self.room_queue:
|
if (account, room_jid, prompt) not in self.room_queue:
|
||||||
self.room_queue.append((account, room_jid))
|
self.room_queue.append((account, room_jid, prompt))
|
||||||
|
|
||||||
class InputTextDialog(CommonInputDialog):
|
class InputTextDialog(CommonInputDialog):
|
||||||
'''Class for multilines Input dialog (more place than InputDialog)'''
|
'''Class for multilines Input dialog (more place than InputDialog)'''
|
||||||
|
|
10
src/gajim.py
10
src/gajim.py
|
@ -506,11 +506,17 @@ class Interface:
|
||||||
def handle_event_ask_new_nick(self, account, data):
|
def handle_event_ask_new_nick(self, account, data):
|
||||||
#('ASK_NEW_NICK', account, (room_jid,))
|
#('ASK_NEW_NICK', account, (room_jid,))
|
||||||
room_jid = data[0]
|
room_jid = data[0]
|
||||||
|
title = _('Unable to join group chat')
|
||||||
|
prompt = _('Your desired nickname in group chat %s is in use or '
|
||||||
|
'registered by another occupant.\nPlease specify another nickname '
|
||||||
|
'below:') % room_jid
|
||||||
|
check_text = _('Always use this nickname when there is a conflict')
|
||||||
if 'change_nick_dialog' in self.instances:
|
if 'change_nick_dialog' in self.instances:
|
||||||
self.instances['change_nick_dialog'].add_room(account, room_jid)
|
self.instances['change_nick_dialog'].add_room(account, room_jid,
|
||||||
|
prompt)
|
||||||
else:
|
else:
|
||||||
self.instances['change_nick_dialog'] = dialogs.ChangeNickDialog(
|
self.instances['change_nick_dialog'] = dialogs.ChangeNickDialog(
|
||||||
account, room_jid)
|
account, room_jid, title, prompt)
|
||||||
|
|
||||||
def handle_event_http_auth(self, account, data):
|
def handle_event_http_auth(self, account, data):
|
||||||
#('HTTP_AUTH', account, (method, url, transaction_id, iq_obj, msg))
|
#('HTTP_AUTH', account, (method, url, transaction_id, iq_obj, msg))
|
||||||
|
|
|
@ -1939,9 +1939,14 @@ class GroupchatControl(ChatControlBase):
|
||||||
ok_handler=on_ok)
|
ok_handler=on_ok)
|
||||||
|
|
||||||
def _on_change_nick_menuitem_activate(self, widget):
|
def _on_change_nick_menuitem_activate(self, widget):
|
||||||
title = _('Changing Nickname')
|
if 'change_nick_dialog' in gajim.interface.instances:
|
||||||
prompt = _('Please specify the new nickname you want to use:')
|
gajim.interface.instances['change_nick_dialog'].present()
|
||||||
self.show_change_nick_input_dialog(title, prompt)
|
else:
|
||||||
|
title = _('Changing Nickname')
|
||||||
|
prompt = _('Please specify the new nickname you want to use:')
|
||||||
|
gajim.interface.instances['change_nick_dialog'] = \
|
||||||
|
dialogs.ChangeNickDialog(self.account, self.room_jid, title,
|
||||||
|
prompt)
|
||||||
|
|
||||||
def _on_configure_room_menuitem_activate(self, widget):
|
def _on_configure_room_menuitem_activate(self, widget):
|
||||||
c = gajim.contacts.get_gc_contact(self.account, self.room_jid, self.nick)
|
c = gajim.contacts.get_gc_contact(self.account, self.room_jid, self.nick)
|
||||||
|
|
Loading…
Reference in New Issue