better GTK bug workarround. see #4310

This commit is contained in:
Yann Leboulanger 2008-11-18 20:16:23 +00:00
parent 6b57bf3931
commit 8f6d262901
1 changed files with 13 additions and 99 deletions

View File

@ -128,12 +128,6 @@ class Systray:
def on_new_chat(self, widget, account): def on_new_chat(self, widget, account):
dialogs.NewChatDialog(account) dialogs.NewChatDialog(account)
def on_single_message_menuitem_activate2(self, widget, event, account):
self.on_single_message_menuitem_activate(widget, account)
def on_new_chat2(self, widget, event, account):
self.on_new_chat(widget, account)
def make_menu(self, event_button, event_time): def make_menu(self, event_button, event_time):
'''create chat with and new message (sub) menus/menuitems''' '''create chat with and new message (sub) menus/menuitems'''
for m in self.popup_menus: for m in self.popup_menus:
@ -174,12 +168,6 @@ class Systray:
item = gtk.ImageMenuItem(uf_show) item = gtk.ImageMenuItem(uf_show)
item.set_image(state_images[show]) item.set_image(state_images[show])
sub_menu.append(item) sub_menu.append(item)
if os.name == 'nt':
#FIXME: bug in pygtk, activate is not called.
# see http://trac.gajim.org/ticket/4310
item.connect('button_press_event',
self.on_show_menuitem_activate2, show)
else:
item.connect('activate', self.on_show_menuitem_activate, show) item.connect('activate', self.on_show_menuitem_activate, show)
item = gtk.SeparatorMenuItem() item = gtk.SeparatorMenuItem()
@ -191,12 +179,6 @@ class Systray:
img.set_from_file(path) img.set_from_file(path)
item.set_image(img) item.set_image(img)
sub_menu.append(item) sub_menu.append(item)
if os.name == 'nt':
#FIXME: bug in pygtk, activate is not called.
# see http://trac.gajim.org/ticket/4310
item.connect('button_press_event',
self.on_change_status_message_activate2)
else:
item.connect('activate', self.on_change_status_message_activate) item.connect('activate', self.on_change_status_message_activate)
connected_accounts = gajim.get_number_of_connected_accounts() connected_accounts = gajim.get_number_of_connected_accounts()
@ -210,12 +192,6 @@ class Systray:
item = gtk.ImageMenuItem(uf_show) item = gtk.ImageMenuItem(uf_show)
item.set_image(state_images['offline']) item.set_image(state_images['offline'])
sub_menu.append(item) sub_menu.append(item)
if os.name == 'nt':
#FIXME: bug in pygtk, activate is not called.
# see http://trac.gajim.org/ticket/4310
item.connect('button_press_event',
self.on_show_menuitem_activate2, 'offline')
else:
item.connect('activate', self.on_show_menuitem_activate, 'offline') item.connect('activate', self.on_show_menuitem_activate, 'offline')
iskey = connected_accounts > 0 and not (connected_accounts == 1 and iskey = connected_accounts > 0 and not (connected_accounts == 1 and
@ -242,22 +218,10 @@ class Systray:
# for chat_with # for chat_with
item = gtk.MenuItem(_('using account %s') % account) item = gtk.MenuItem(_('using account %s') % account)
account_menu_for_chat_with.append(item) account_menu_for_chat_with.append(item)
if os.name == 'nt':
#FIXME: bug in pygtk, activate is not called.
# see http://trac.gajim.org/ticket/4310
item.connect('button_press_event',
self.on_new_chat2, account)
else:
item.connect('activate', self.on_new_chat, account) item.connect('activate', self.on_new_chat, account)
# for single message # for single message
item = gtk.MenuItem(_('using account %s') % account) item = gtk.MenuItem(_('using account %s') % account)
if os.name == 'nt':
#FIXME: bug in pygtk, activate is not called.
# see http://trac.gajim.org/ticket/4310
item.connect('button_press_event',
self.on_single_message_menuitem_activate2, account)
else:
item.connect('activate', item.connect('activate',
self.on_single_message_menuitem_activate, account) self.on_single_message_menuitem_activate, account)
account_menu_for_single_message.append(item) account_menu_for_single_message.append(item)
@ -266,11 +230,6 @@ class Systray:
gc_item = gtk.MenuItem(_('using account %s') % account, False) gc_item = gtk.MenuItem(_('using account %s') % account, False)
gc_sub_menu.append(gc_item) gc_sub_menu.append(gc_item)
gc_menuitem_menu = gtk.Menu() gc_menuitem_menu = gtk.Menu()
if os.name == 'nt':
#FIXME: bug in pygtk, activate is not called.
# see http://trac.gajim.org/ticket/4310
self.add_bookmarks_list2(gc_menuitem_menu, account)
else:
gajim.interface.roster.add_bookmarks_list(gc_menuitem_menu, gajim.interface.roster.add_bookmarks_list(gc_menuitem_menu,
account) account)
gc_item.set_submenu(gc_menuitem_menu) gc_item.set_submenu(gc_menuitem_menu)
@ -289,11 +248,6 @@ class Systray:
self.on_single_message_menuitem_activate, account) self.on_single_message_menuitem_activate, account)
# join gc # join gc
if os.name == 'nt':
#FIXME: bug in pygtk, activate is not called.
# see http://trac.gajim.org/ticket/4310
self.add_bookmarks_list2(gc_sub_menu, account)
else:
gajim.interface.roster.add_bookmarks_list(gc_sub_menu, gajim.interface.roster.add_bookmarks_list(gc_sub_menu,
account) account)
break # No other connected account break # No other connected account
@ -303,12 +257,6 @@ class Systray:
newitem = gtk.ImageMenuItem(_('_Manage Bookmarks...')) newitem = gtk.ImageMenuItem(_('_Manage Bookmarks...'))
img = gtk.image_new_from_stock(gtk.STOCK_PREFERENCES, gtk.ICON_SIZE_MENU) img = gtk.image_new_from_stock(gtk.STOCK_PREFERENCES, gtk.ICON_SIZE_MENU)
newitem.set_image(img) newitem.set_image(img)
if os.name == 'nt':
#FIXME: bug in pygtk, activate is not called.
# see http://trac.gajim.org/ticket/4310
newitem.connect('button_press_event',
self.on_manage_bookmarks_menuitem_activate2)
else:
newitem.connect('activate', newitem.connect('activate',
gajim.interface.roster.on_manage_bookmarks_menuitem_activate) gajim.interface.roster.on_manage_bookmarks_menuitem_activate)
gc_sub_menu.append(newitem) gc_sub_menu.append(newitem)
@ -324,37 +272,9 @@ class Systray:
self.added_hide_menuitem = True self.added_hide_menuitem = True
self.systray_context_menu.show_all() self.systray_context_menu.show_all()
self.systray_context_menu.popup(None, None, None, event_button, self.systray_context_menu.popup(None, None, None, 0,
event_time) event_time)
def on_join_gc_activate2(self, widget, event, account):
gajim.interface.roster.on_join_gc_activate(widget, account)
def on_bookmark_menuitem_activate2(self, widget, event, account, bookmark):
gajim.interface.roster.on_bookmark_menuitem_activate(widget, account, bookmark)
def on_manage_bookmarks_menuitem_activate2(self, widget, event):
gajim.interface.roster.on_manage_bookmarks_menuitem_activate(widget)
def add_bookmarks_list2(self, gc_sub_menu, account):
'''Show join new group chat item and bookmarks list for an account'''
item = gtk.ImageMenuItem(_('_Join New Group Chat'))
icon = gtk.image_new_from_stock(gtk.STOCK_NEW, gtk.ICON_SIZE_MENU)
item.set_image(icon)
item.connect('button_press_event', self.on_join_gc_activate2, account)
gc_sub_menu.append(item)
# user has at least one bookmark
if len(gajim.connections[account].bookmarks) > 0:
item = gtk.SeparatorMenuItem() # separator
gc_sub_menu.append(item)
for bookmark in gajim.connections[account].bookmarks:
item = gtk.MenuItem(bookmark['name'], False) # Do not use underline
item.connect('button_press_event', self.on_bookmark_menuitem_activate2,
account, bookmark)
gc_sub_menu.append(item)
def on_show_all_events_menuitem_activate(self, widget): def on_show_all_events_menuitem_activate(self, widget):
events = gajim.events.get_systray_events() events = gajim.events.get_systray_events()
for account in events: for account in events:
@ -447,9 +367,6 @@ class Systray:
if index != current: if index != current:
gajim.interface.roster.status_combobox.set_active(index) gajim.interface.roster.status_combobox.set_active(index)
def on_show_menuitem_activate2(self, widget, event, show):
self.on_show_menuitem_activate(widget, show)
def on_change_status_message_activate(self, widget): def on_change_status_message_activate(self, widget):
model = gajim.interface.roster.status_combobox.get_model() model = gajim.interface.roster.status_combobox.get_model()
active = gajim.interface.roster.status_combobox.get_active() active = gajim.interface.roster.status_combobox.get_active()
@ -467,9 +384,6 @@ class Systray:
dlg = dialogs.ChangeStatusMessageDialog(on_response, status) dlg = dialogs.ChangeStatusMessageDialog(on_response, status)
dlg.window.present() dlg.window.present()
def on_change_status_message_activate2(self, widget, event):
self.on_change_status_message_activate(widget)
def show_tooltip(self, widget): def show_tooltip(self, widget):
position = widget.window.get_origin() position = widget.window.get_origin()
if self.tooltip.id == position: if self.tooltip.id == position: