add a join button in the disco window to join IRC rooms or create new MUC rooms

This commit is contained in:
Yann Leboulanger 2005-12-05 13:33:14 +00:00
parent b9ec8e9109
commit 3cbf89b09b
1 changed files with 37 additions and 2 deletions

View File

@ -284,7 +284,7 @@ class ServicesCache:
# Some services list it in features and respond to # Some services list it in features and respond to
# NS_DISCO_ITEMS anyways. # NS_DISCO_ITEMS anyways.
# Allow browsing for unknown types aswell. # Allow browsing for unknown types aswell.
if (not features and not identities) or\ if (not features and not identities) or\
xmpp.NS_DISCO_ITEMS in features or\ xmpp.NS_DISCO_ITEMS in features or\
xmpp.NS_BROWSE in features: xmpp.NS_BROWSE in features:
browser = AgentBrowser browser = AgentBrowser
@ -771,7 +771,7 @@ class AgentBrowser:
if jid: if jid:
node = model[iter][1].decode('utf-8') node = model[iter][1].decode('utf-8')
self.window.open(jid, node) self.window.open(jid, node)
def update_actions(self): def update_actions(self):
'''When we select a row: '''When we select a row:
activate action buttons based on the agent's info.''' activate action buttons based on the agent's info.'''
@ -1082,6 +1082,18 @@ class ToplevelAgentBrowser(AgentBrowser):
self.window.action_buttonbox.add(self.register_button) self.window.action_buttonbox.add(self.register_button)
self.register_button.show_all() self.register_button.show_all()
self.join_button = gtk.Button()
image = gtk.image_new_from_stock(gtk.STOCK_CONNECT, gtk.ICON_SIZE_BUTTON)
label = gtk.Label(_('_Join'))
label.set_use_underline(True)
hbox = gtk.HBox()
hbox.pack_start(image, False, True, 6)
hbox.pack_end(label, True, True)
self.join_button.add(hbox)
self.join_button.connect('clicked', self.on_join_button_clicked)
self.window.action_buttonbox.add(self.join_button)
self.join_button.show_all()
def _clean_actions(self): def _clean_actions(self):
if self.register_button: if self.register_button:
self.register_button.destroy() self.register_button.destroy()
@ -1111,11 +1123,32 @@ class ToplevelAgentBrowser(AgentBrowser):
gajim.connections[self.account].request_register_agent_info(jid) gajim.connections[self.account].request_register_agent_info(jid)
self.window.destroy(chain = True) self.window.destroy(chain = True)
def on_join_button_clicked(self, widget):
'''When we want to join an IRC room or create a new MUC room:
Opens the join_groupchat_window.'''
model, iter = self.window.services_treeview.get_selection().get_selected()
if not iter:
return
service = model[iter][0].decode('utf-8')
if service.find('@') != -1:
services = service.split('@', 1)
room = services[0]
service = services[1]
else:
room = ''
if not gajim.interface.instances[self.account].has_key('join_gc'):
dialogs.JoinGroupchatWindow(self.account, service, room)
else:
gajim.interface.instances[self.account]['join_gc'].window.present()
self.window.destroy(chain = True)
def update_actions(self): def update_actions(self):
if self.register_button: if self.register_button:
self.register_button.set_sensitive(False) self.register_button.set_sensitive(False)
if self.browse_button: if self.browse_button:
self.browse_button.set_sensitive(False) self.browse_button.set_sensitive(False)
if self.join_button:
self.join_button.set_sensitive(False)
model, iter = self.window.services_treeview.get_selection().get_selected() model, iter = self.window.services_treeview.get_selection().get_selected()
if not iter: if not iter:
return return
@ -1155,6 +1188,8 @@ class ToplevelAgentBrowser(AgentBrowser):
else: else:
self.register_button.set_label(_('Re_gister')) self.register_button.set_label(_('Re_gister'))
self.register_button.set_sensitive(True) self.register_button.set_sensitive(True)
if self.join_button and xmpp.NS_MUC in features:
self.join_button.set_sensitive(True)
def _default_action(self, jid, node, identities, features, data): def _default_action(self, jid, node, identities, features, data):
if AgentBrowser._default_action(self, jid, node, identities, features, data): if AgentBrowser._default_action(self, jid, node, identities, features, data):