Re-add nk's 'Profile, Avatar' menu, make it working
This commit is contained in:
parent
522aa0e5fa
commit
b72e3aa100
13
src/gajim.py
13
src/gajim.py
|
@ -307,14 +307,17 @@ class Interface:
|
||||||
|
|
||||||
self.roster.on_status_changed(account, status)
|
self.roster.on_status_changed(account, status)
|
||||||
if account in self.show_vcard_when_connect:
|
if account in self.show_vcard_when_connect:
|
||||||
jid = gajim.get_jid_from_account(account)
|
self.edit_own_details(account)
|
||||||
if not self.instances[account]['infos'].has_key(jid):
|
|
||||||
self.instances[account]['infos'][jid] = \
|
|
||||||
vcard.VcardWindow(jid, account, True)
|
|
||||||
gajim.connections[account].request_vcard(jid)
|
|
||||||
if self.remote_ctrl:
|
if self.remote_ctrl:
|
||||||
self.remote_ctrl.raise_signal('AccountPresence', (status, account))
|
self.remote_ctrl.raise_signal('AccountPresence', (status, account))
|
||||||
|
|
||||||
|
def edit_own_details(self, account):
|
||||||
|
jid = gajim.get_jid_from_account(account)
|
||||||
|
if not self.instances[account]['infos'].has_key(jid):
|
||||||
|
self.instances[account]['infos'][jid] = \
|
||||||
|
vcard.VcardWindow(jid, account, True)
|
||||||
|
gajim.connections[account].request_vcard(jid)
|
||||||
|
|
||||||
def handle_event_notify(self, account, array):
|
def handle_event_notify(self, account, array):
|
||||||
# 'NOTIFY' (account, (jid, status, status message, resource, priority,
|
# 'NOTIFY' (account, (jid, status, status message, resource, priority,
|
||||||
# keyID, timestamp))
|
# keyID, timestamp))
|
||||||
|
|
|
@ -188,6 +188,7 @@
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="label" translatable="yes">_Edit</property>
|
<property name="label" translatable="yes">_Edit</property>
|
||||||
<property name="use_underline">True</property>
|
<property name="use_underline">True</property>
|
||||||
|
<signal name="activate" handler="on_edit_menuitem_activate" last_modification_time="Fri, 07 Apr 2006 22:46:56 GMT"/>
|
||||||
|
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkMenu" id="edit_menu_menu">
|
<widget class="GtkMenu" id="edit_menu_menu">
|
||||||
|
@ -236,6 +237,26 @@
|
||||||
</widget>
|
</widget>
|
||||||
</child>
|
</child>
|
||||||
|
|
||||||
|
<child>
|
||||||
|
<widget class="GtkImageMenuItem" id="profile_avatar_menuitem">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="label" translatable="yes">Profile, Avatar</property>
|
||||||
|
<property name="use_underline">True</property>
|
||||||
|
|
||||||
|
<child internal-child="image">
|
||||||
|
<widget class="GtkImage" id="image1305">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="stock">gtk-properties</property>
|
||||||
|
<property name="icon_size">1</property>
|
||||||
|
<property name="xalign">0.5</property>
|
||||||
|
<property name="yalign">0.5</property>
|
||||||
|
<property name="xpad">0</property>
|
||||||
|
<property name="ypad">0</property>
|
||||||
|
</widget>
|
||||||
|
</child>
|
||||||
|
</widget>
|
||||||
|
</child>
|
||||||
|
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkSeparatorMenuItem" id="separator2">
|
<widget class="GtkSeparatorMenuItem" id="separator2">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
|
|
|
@ -533,6 +533,10 @@ class RosterWindow:
|
||||||
def on_actions_menuitem_activate(self, widget):
|
def on_actions_menuitem_activate(self, widget):
|
||||||
self.make_menu()
|
self.make_menu()
|
||||||
|
|
||||||
|
def on_edit_menuitem_activate(self, widget):
|
||||||
|
'''need 'Profile, Avatar' menuitem/submenu'''
|
||||||
|
self.make_menu()
|
||||||
|
|
||||||
def on_bookmark_menuitem_activate(self, widget, account, bookmark):
|
def on_bookmark_menuitem_activate(self, widget, account, bookmark):
|
||||||
self.join_gc_room(account, bookmark['jid'], bookmark['nick'],
|
self.join_gc_room(account, bookmark['jid'], bookmark['nick'],
|
||||||
bookmark['password'])
|
bookmark['password'])
|
||||||
|
@ -627,6 +631,7 @@ class RosterWindow:
|
||||||
advanced_menuitem = self.xml.get_widget('advanced_menuitem')
|
advanced_menuitem = self.xml.get_widget('advanced_menuitem')
|
||||||
show_offline_contacts_menuitem = self.xml.get_widget(
|
show_offline_contacts_menuitem = self.xml.get_widget(
|
||||||
'show_offline_contacts_menuitem')
|
'show_offline_contacts_menuitem')
|
||||||
|
profile_avatar_menuitem = self.xml.get_widget('profile_avatar_menuitem')
|
||||||
|
|
||||||
# destroy old advanced menus
|
# destroy old advanced menus
|
||||||
for m in self.advanced_menus:
|
for m in self.advanced_menus:
|
||||||
|
@ -650,12 +655,19 @@ class RosterWindow:
|
||||||
self.new_message_menuitem_handler_id)
|
self.new_message_menuitem_handler_id)
|
||||||
self.new_message_menuitem_handler_id = None
|
self.new_message_menuitem_handler_id = None
|
||||||
|
|
||||||
|
if self.profile_avatar_menuitem_handler_id:
|
||||||
|
profile_avatar_menuitem.handler_disconnect(
|
||||||
|
self.profile_avatar_menuitem_handler_id)
|
||||||
|
self.profile_avatar_menuitem_handler_id = None
|
||||||
|
|
||||||
|
|
||||||
# remove the existing submenus
|
# remove the existing submenus
|
||||||
add_new_contact_menuitem.remove_submenu()
|
add_new_contact_menuitem.remove_submenu()
|
||||||
service_disco_menuitem.remove_submenu()
|
service_disco_menuitem.remove_submenu()
|
||||||
join_gc_menuitem.remove_submenu()
|
join_gc_menuitem.remove_submenu()
|
||||||
new_message_menuitem.remove_submenu()
|
new_message_menuitem.remove_submenu()
|
||||||
advanced_menuitem.remove_submenu()
|
advanced_menuitem.remove_submenu()
|
||||||
|
profile_avatar_menuitem.remove_submenu()
|
||||||
|
|
||||||
# remove the existing accelerator
|
# remove the existing accelerator
|
||||||
if self.have_new_message_accel:
|
if self.have_new_message_accel:
|
||||||
|
@ -672,6 +684,7 @@ class RosterWindow:
|
||||||
add_sub_menu = gtk.Menu()
|
add_sub_menu = gtk.Menu()
|
||||||
disco_sub_menu = gtk.Menu()
|
disco_sub_menu = gtk.Menu()
|
||||||
new_message_sub_menu = gtk.Menu()
|
new_message_sub_menu = gtk.Menu()
|
||||||
|
profile_avatar_sub_menu = gtk.Menu()
|
||||||
|
|
||||||
for account in gajim.connections:
|
for account in gajim.connections:
|
||||||
if gajim.connections[account].connected <= 1:
|
if gajim.connections[account].connected <= 1:
|
||||||
|
@ -716,6 +729,15 @@ class RosterWindow:
|
||||||
new_message_menuitem.set_submenu(new_message_sub_menu)
|
new_message_menuitem.set_submenu(new_message_sub_menu)
|
||||||
new_message_sub_menu.show_all()
|
new_message_sub_menu.show_all()
|
||||||
|
|
||||||
|
# profile, avatar
|
||||||
|
profile_avatar_item = gtk.MenuItem(_('of account %s') % account,
|
||||||
|
False)
|
||||||
|
profile_avatar_sub_menu.append(profile_avatar_item)
|
||||||
|
profile_avatar_item.connect('activate',
|
||||||
|
self.on_profile_avatar_menuitem_activate, account)
|
||||||
|
profile_avatar_menuitem.set_submenu(profile_avatar_sub_menu)
|
||||||
|
profile_avatar_sub_menu.show_all()
|
||||||
|
|
||||||
elif connected_accounts == 1: # user has only one account
|
elif connected_accounts == 1: # user has only one account
|
||||||
for account in gajim.connections:
|
for account in gajim.connections:
|
||||||
if gajim.connections[account].connected > 1: # THE connected account
|
if gajim.connections[account].connected > 1: # THE connected account
|
||||||
|
@ -742,6 +764,12 @@ class RosterWindow:
|
||||||
gtk.keysyms.n, gtk.gdk.CONTROL_MASK, gtk.ACCEL_VISIBLE)
|
gtk.keysyms.n, gtk.gdk.CONTROL_MASK, gtk.ACCEL_VISIBLE)
|
||||||
self.have_new_message_accel = True
|
self.have_new_message_accel = True
|
||||||
|
|
||||||
|
# profile, avatar
|
||||||
|
if not self.profile_avatar_menuitem_handler_id:
|
||||||
|
self.profile_avatar_menuitem_handler_id = \
|
||||||
|
profile_avatar_menuitem.connect('activate', self.\
|
||||||
|
on_profile_avatar_menuitem_activate, account)
|
||||||
|
|
||||||
break # No other account connected
|
break # No other account connected
|
||||||
|
|
||||||
if connected_accounts == 0:
|
if connected_accounts == 0:
|
||||||
|
@ -750,12 +778,13 @@ class RosterWindow:
|
||||||
join_gc_menuitem.set_sensitive(False)
|
join_gc_menuitem.set_sensitive(False)
|
||||||
add_new_contact_menuitem.set_sensitive(False)
|
add_new_contact_menuitem.set_sensitive(False)
|
||||||
service_disco_menuitem.set_sensitive(False)
|
service_disco_menuitem.set_sensitive(False)
|
||||||
|
profile_avatar_menuitem.set_sensitive(False)
|
||||||
else: # we have one or more connected accounts
|
else: # we have one or more connected accounts
|
||||||
new_message_menuitem.set_sensitive(True)
|
new_message_menuitem.set_sensitive(True)
|
||||||
join_gc_menuitem.set_sensitive(True)
|
join_gc_menuitem.set_sensitive(True)
|
||||||
add_new_contact_menuitem.set_sensitive(True)
|
add_new_contact_menuitem.set_sensitive(True)
|
||||||
service_disco_menuitem.set_sensitive(True)
|
service_disco_menuitem.set_sensitive(True)
|
||||||
|
profile_avatar_menuitem.set_sensitive(True)
|
||||||
# show the 'manage gc bookmarks' item
|
# show the 'manage gc bookmarks' item
|
||||||
newitem = gtk.SeparatorMenuItem() # separator
|
newitem = gtk.SeparatorMenuItem() # separator
|
||||||
gc_sub_menu.append(newitem)
|
gc_sub_menu.append(newitem)
|
||||||
|
@ -2240,6 +2269,9 @@ _('If "%s" accepts this request you will know his or her status.') % jid)
|
||||||
def on_manage_bookmarks_menuitem_activate(self, widget):
|
def on_manage_bookmarks_menuitem_activate(self, widget):
|
||||||
config.ManageBookmarksWindow()
|
config.ManageBookmarksWindow()
|
||||||
|
|
||||||
|
def on_profile_avatar_menuitem_activate(self, widget, account):
|
||||||
|
gajim.interface.edit_own_details(account)
|
||||||
|
|
||||||
def close_all(self, dic):
|
def close_all(self, dic):
|
||||||
'''close all the windows in the given dictionary'''
|
'''close all the windows in the given dictionary'''
|
||||||
for w in dic.values():
|
for w in dic.values():
|
||||||
|
@ -3208,6 +3240,7 @@ _('If "%s" accepts this request you will know his or her status.') % jid)
|
||||||
self.add_new_contact_handler_id = False
|
self.add_new_contact_handler_id = False
|
||||||
self.service_disco_handler_id = False
|
self.service_disco_handler_id = False
|
||||||
self.new_message_menuitem_handler_id = False
|
self.new_message_menuitem_handler_id = False
|
||||||
|
self.profile_avatar_menuitem_handler_id = False
|
||||||
self.actions_menu_needs_rebuild = True
|
self.actions_menu_needs_rebuild = True
|
||||||
self.regroup = gajim.config.get('mergeaccounts')
|
self.regroup = gajim.config.get('mergeaccounts')
|
||||||
if len(gajim.connections) < 2: # Do not merge accounts if only one exists
|
if len(gajim.connections) < 2: # Do not merge accounts if only one exists
|
||||||
|
|
Loading…
Reference in New Issue