handle new chat menuitem separatly from other menuitems because it has an accelerator. Fixes #5967

This commit is contained in:
Yann Leboulanger 2010-10-06 15:23:40 +02:00
parent 3876638860
commit 917cffc98d
1 changed files with 41 additions and 38 deletions

View File

@ -2177,7 +2177,7 @@ class RosterWindow:
for contact in [c for c in lcontact if ( for contact in [c for c in lcontact if (
(c.show != 'offline' or c.is_transport()) and not ctrl)]: (c.show != 'offline' or c.is_transport()) and not ctrl)]:
self.chg_contact_status(contact, 'offline', '', account) self.chg_contact_status(contact, 'offline', '', account)
self.actions_menu_needs_rebuild = True self.set_actions_menu_needs_rebuild()
self.update_status_combobox() self.update_status_combobox()
def get_status_message(self, show, on_response, show_pep=True, def get_status_message(self, show, on_response, show_pep=True,
@ -4836,11 +4836,6 @@ class RosterWindow:
self.service_disco_handler_id) self.service_disco_handler_id)
self.service_disco_handler_id = None self.service_disco_handler_id = None
if self.new_chat_menuitem_handler_id:
new_chat_menuitem.handler_disconnect(
self.new_chat_menuitem_handler_id)
self.new_chat_menuitem_handler_id = None
if self.single_message_menuitem_handler_id: if self.single_message_menuitem_handler_id:
single_message_menuitem.handler_disconnect( single_message_menuitem.handler_disconnect(
self.single_message_menuitem_handler_id) self.single_message_menuitem_handler_id)
@ -4856,17 +4851,9 @@ class RosterWindow:
service_disco_menuitem.remove_submenu() service_disco_menuitem.remove_submenu()
join_gc_menuitem.remove_submenu() join_gc_menuitem.remove_submenu()
single_message_menuitem.remove_submenu() single_message_menuitem.remove_submenu()
new_chat_menuitem.remove_submenu()
advanced_menuitem.remove_submenu() advanced_menuitem.remove_submenu()
profile_avatar_menuitem.remove_submenu() profile_avatar_menuitem.remove_submenu()
# remove the existing accelerator
if self.have_new_chat_accel:
ag = gtk.accel_groups_from_object(self.window)[0]
new_chat_menuitem.remove_accelerator(ag, gtk.keysyms.n,
gtk.gdk.CONTROL_MASK)
self.have_new_chat_accel = False
gc_sub_menu = gtk.Menu() # gc is always a submenu gc_sub_menu = gtk.Menu() # gc is always a submenu
join_gc_menuitem.set_submenu(gc_sub_menu) join_gc_menuitem.set_submenu(gc_sub_menu)
@ -4894,17 +4881,6 @@ class RosterWindow:
new_chat_menuitem.set_submenu(new_chat_sub_menu) new_chat_menuitem.set_submenu(new_chat_sub_menu)
new_chat_sub_menu.show_all() new_chat_sub_menu.show_all()
elif connected_accounts == 1: # user has only one account
for account in gajim.connections:
if gajim.account_is_connected(account): # THE connected account
# new chat
if not self.new_chat_menuitem_handler_id:
self.new_chat_menuitem_handler_id = new_chat_menuitem.\
connect('activate',
self.on_new_chat_menuitem_activate, account)
break
# menu items that don't apply to zeroconf connections # menu items that don't apply to zeroconf connections
if connected_accounts == 1 or (connected_accounts == 2 and \ if connected_accounts == 1 or (connected_accounts == 2 and \
gajim.zeroconf_is_connected()): gajim.zeroconf_is_connected()):
@ -4936,14 +4912,6 @@ class RosterWindow:
single_message_menuitem.connect('activate', \ single_message_menuitem.connect('activate', \
self.on_send_single_message_menuitem_activate, account) self.on_send_single_message_menuitem_activate, account)
# new chat accel
if not self.have_new_chat_accel:
ag = gtk.accel_groups_from_object(self.window)[0]
new_chat_menuitem.add_accelerator('activate', ag,
gtk.keysyms.n, gtk.gdk.CONTROL_MASK,
gtk.ACCEL_VISIBLE)
self.have_new_chat_accel = True
break # No other account connected break # No other account connected
else: else:
# 2 or more 'real' accounts are connected, make submenus # 2 or more 'real' accounts are connected, make submenus
@ -5862,6 +5830,41 @@ class RosterWindow:
def set_actions_menu_needs_rebuild(self): def set_actions_menu_needs_rebuild(self):
self.actions_menu_needs_rebuild = True self.actions_menu_needs_rebuild = True
# Just handle new_chat_menuitem to have ctrl+N working even if we don't
# open the menu
new_chat_menuitem = self.xml.get_object('new_chat_menuitem')
ag = gtk.accel_groups_from_object(self.window)[0]
# remove the existing accelerator
if self.have_new_chat_accel:
new_chat_menuitem.remove_accelerator(ag, gtk.keysyms.n,
gtk.gdk.CONTROL_MASK)
self.have_new_chat_accel = False
if self.new_chat_menuitem_handler_id:
new_chat_menuitem.handler_disconnect(
self.new_chat_menuitem_handler_id)
self.new_chat_menuitem_handler_id = None
new_chat_menuitem.remove_submenu()
connected_accounts = gajim.get_number_of_connected_accounts()
if connected_accounts == 1 or (connected_accounts == 2 and \
gajim.zeroconf_is_connected()):
# only one 'real' (non-zeroconf) account is connected, don't need
# submenus
accounts_list = sorted(gajim.contacts.get_accounts())
for account in accounts_list:
if gajim.account_is_connected(account) and \
not gajim.config.get_per('accounts', account, 'is_zeroconf'):
if not self.new_chat_menuitem_handler_id:
self.new_chat_menuitem_handler_id = new_chat_menuitem.\
connect('activate',
self.on_new_chat_menuitem_activate, account)
if not self.have_new_chat_accel:
new_chat_menuitem.add_accelerator('activate', ag,
gtk.keysyms.n, gtk.gdk.CONTROL_MASK,
gtk.ACCEL_VISIBLE)
self.have_new_chat_accel = True
def show_appropriate_context_menu(self, event, iters): def show_appropriate_context_menu(self, event, iters):
# iters must be all of the same type # iters must be all of the same type
@ -5951,15 +5954,15 @@ class RosterWindow:
self.new_chat_menuitem_handler_id = False self.new_chat_menuitem_handler_id = False
self.single_message_menuitem_handler_id = False self.single_message_menuitem_handler_id = False
self.profile_avatar_menuitem_handler_id = False self.profile_avatar_menuitem_handler_id = False
self.actions_menu_needs_rebuild = True #FIXME: When list_accel_closures will be wrapped in pygtk
# no need of this variable
self.have_new_chat_accel = False # Is the "Ctrl+N" shown ?
self.set_actions_menu_needs_rebuild()
self.regroup = gajim.config.get('mergeaccounts') self.regroup = gajim.config.get('mergeaccounts')
self.clicked_path = None # Used remember on wich row we clicked self.clicked_path = None # Used remember on wich row we clicked
if len(gajim.connections) < 2: if len(gajim.connections) < 2:
# Do not merge accounts if only one exists # Do not merge accounts if only one exists
self.regroup = False self.regroup = False
#FIXME: When list_accel_closures will be wrapped in pygtk
# no need of this variable
self.have_new_chat_accel = False # Is the "Ctrl+N" shown ?
gtkgui_helpers.resize_window(self.window, gtkgui_helpers.resize_window(self.window,
gajim.config.get('roster_width'), gajim.config.get('roster_width'),
gajim.config.get('roster_height')) gajim.config.get('roster_height'))