do not allow to have two windows of join_gc for the same account and changing the join gc window title if multiple accounts
This commit is contained in:
parent
58fc9bd255
commit
f7123afe34
|
@ -458,19 +458,28 @@ class subscription_request_window:
|
|||
|
||||
class Join_groupchat_window:
|
||||
def __init__(self, plugin, account, server='', room = ''):
|
||||
if gajim.connections[account].connected < 2:
|
||||
Error_dialog(_('You must be connected to join a groupchat'))
|
||||
return
|
||||
self.plugin = plugin
|
||||
self.account = account
|
||||
if gajim.connections[account].connected < 2:
|
||||
Error_dialog(_('You must be connected to join a groupchat'))
|
||||
# remove us from open windows
|
||||
del self.plugin.windows[self.account]['join_gc']
|
||||
return
|
||||
self.xml = gtk.glade.XML(GTKGUI_GLADE, 'join_groupchat_window', APP)
|
||||
self.window = self.xml.get_widget('join_groupchat_window')
|
||||
self.xml.get_widget('server_entry').set_text(server)
|
||||
self.xml.get_widget('room_entry').set_text(room)
|
||||
self.xml.get_widget('nickname_entry').\
|
||||
set_text(self.plugin.nicks[self.account])
|
||||
self.xml.get_widget('nickname_entry').set_text(
|
||||
self.plugin.nicks[self.account])
|
||||
self.xml.signal_autoconnect(self)
|
||||
self.plugin.windows[account]['join_gc'] = self #now add us to open windows
|
||||
our_jid = gajim.config.get_per('accounts', self.account, 'name') + '@' + \
|
||||
gajim.config.get_per('accounts', self.account, 'hostname')
|
||||
if len(gajim.connections) > 1:
|
||||
title = 'Join Groupchat as ' + our_jid
|
||||
else:
|
||||
title = 'Join Groupchat'
|
||||
self.window.set_title(title)
|
||||
|
||||
self.recently_combobox = self.xml.get_widget('recently_combobox')
|
||||
liststore = gtk.ListStore(str)
|
||||
|
|
|
@ -924,10 +924,11 @@ class Roster_window:
|
|||
dialogs.Add_new_contact_window(self.plugin, account)
|
||||
|
||||
def on_join_gc_activate(self, widget, account):
|
||||
if not self.plugin.windows[account].has_key('join_gc'):
|
||||
dialogs.Join_groupchat_window(self.plugin, account)
|
||||
if self.plugin.windows[account].has_key('join_gc'):
|
||||
self.plugin.windows[account]['join_gc'].window.present()
|
||||
else:
|
||||
self.plugin.windows[account]['join_gc'].window.present()
|
||||
self.plugin.windows[account]['join_gc'] = dialogs.Join_groupchat_window(self.plugin, account)
|
||||
|
||||
|
||||
def on_new_message_menuitem_activate(self, widget, account):
|
||||
dialogs.New_message_dialog(self.plugin, account)
|
||||
|
|
Loading…
Reference in New Issue