Fixes to context menu
svn: r3222
This commit is contained in:
parent
900f1aaa79
commit
8b4bbf154f
@ -371,15 +371,7 @@ class PedigreeView:
|
|||||||
# button. The menu consists of the children of the current root
|
# button. The menu consists of the children of the current root
|
||||||
# person of the tree. Attach a child to each menu item.
|
# person of the tree. Attach a child to each menu item.
|
||||||
|
|
||||||
def find_children(p):
|
childlist = find_children(self.parent.db,self.active_person)
|
||||||
childlist = []
|
|
||||||
for family_id in p.get_family_id_list():
|
|
||||||
family = self.parent.db.find_family_from_id(family_id)
|
|
||||||
for child_id in family.get_child_id_list():
|
|
||||||
childlist.append(child_id)
|
|
||||||
return childlist
|
|
||||||
|
|
||||||
childlist = find_children(self.active_person)
|
|
||||||
if len(childlist) == 1:
|
if len(childlist) == 1:
|
||||||
child = self.parent.db.try_to_find_person_from_id(childlist[0])
|
child = self.parent.db.try_to_find_person_from_id(childlist[0])
|
||||||
if child:
|
if child:
|
||||||
@ -390,7 +382,7 @@ class PedigreeView:
|
|||||||
child = self.parent.db.try_to_find_person_from_id(child_id)
|
child = self.parent.db.try_to_find_person_from_id(child_id)
|
||||||
cname = GrampsCfg.nameof(child)
|
cname = GrampsCfg.nameof(child)
|
||||||
menuitem = gtk.MenuItem(None)
|
menuitem = gtk.MenuItem(None)
|
||||||
if find_children(child):
|
if find_children(self.parent.db,child):
|
||||||
label = gtk.Label('<b><i>%s</i></b>' % cname)
|
label = gtk.Label('<b><i>%s</i></b>' % cname)
|
||||||
else:
|
else:
|
||||||
label = gtk.Label(cname)
|
label = gtk.Label(cname)
|
||||||
@ -525,13 +517,14 @@ class PedigreeView:
|
|||||||
def on_canvas_press(self,obj,event):
|
def on_canvas_press(self,obj,event):
|
||||||
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 3:
|
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 3:
|
||||||
self.build_nav_menu(event)
|
self.build_nav_menu(event)
|
||||||
|
return gtk.TRUE
|
||||||
|
|
||||||
def build_nav_menu(self,event):
|
def add_nav_portion_to_menu(self,menu):
|
||||||
"""Builds the menu with only history-based navigation."""
|
"""
|
||||||
|
This function adds a common history-navigation portion
|
||||||
menu = gtk.Menu()
|
to the context menu. Used by both build_nav_menu() and
|
||||||
menu.set_title(_('People Menu'))
|
build_full_nav_menu() methods.
|
||||||
|
"""
|
||||||
back_sensitivity = self.parent.hindex > 0
|
back_sensitivity = self.parent.hindex > 0
|
||||||
fwd_sensitivity = self.parent.hindex + 1 < len(self.parent.history)
|
fwd_sensitivity = self.parent.hindex + 1 < len(self.parent.history)
|
||||||
entries = [
|
entries = [
|
||||||
@ -557,12 +550,19 @@ class PedigreeView:
|
|||||||
item.set_sensitive(sensitivity)
|
item.set_sensitive(sensitivity)
|
||||||
item.show()
|
item.show()
|
||||||
menu.append(item)
|
menu.append(item)
|
||||||
|
|
||||||
|
def build_nav_menu(self,event):
|
||||||
|
"""Builds the menu with only history-based navigation."""
|
||||||
|
|
||||||
|
menu = gtk.Menu()
|
||||||
|
menu.set_title(_('People Menu'))
|
||||||
|
self.add_nav_portion_to_menu(menu)
|
||||||
menu.popup(None,None,None,event.button,event.time)
|
menu.popup(None,None,None,event.button,event.time)
|
||||||
|
|
||||||
def build_full_nav_menu(self,event,person):
|
def build_full_nav_menu(self,event,person):
|
||||||
"""
|
"""
|
||||||
Builds the full menu (including Siblings, Spouses, etc)
|
Builds the full menu (including Siblings, Spouses, Children,
|
||||||
with navigation.
|
and Parents) with navigation.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
menu = gtk.Menu()
|
menu = gtk.Menu()
|
||||||
@ -628,33 +628,82 @@ class PedigreeView:
|
|||||||
item.set_sensitive(0)
|
item.set_sensitive(0)
|
||||||
item.show()
|
item.show()
|
||||||
menu.append(item)
|
menu.append(item)
|
||||||
|
|
||||||
|
# Go over children and build their menu
|
||||||
|
item = gtk.MenuItem(_("Children"))
|
||||||
|
no_children = 1
|
||||||
|
childlist = find_children(self.parent.db,person)
|
||||||
|
for child_id in childlist:
|
||||||
|
child = self.parent.db.try_to_find_person_from_id(child_id)
|
||||||
|
if not child:
|
||||||
|
continue
|
||||||
|
|
||||||
|
if no_children:
|
||||||
|
no_children = 0
|
||||||
|
item.set_submenu(gtk.Menu())
|
||||||
|
child_menu = item.get_submenu()
|
||||||
|
|
||||||
back_sensitivity = self.parent.hindex > 0
|
if find_children(self.parent.db,child):
|
||||||
fwd_sensitivity = self.parent.hindex + 1 < len(self.parent.history)
|
label = gtk.Label('<b><i>%s</i></b>' % GrampsCfg.nameof(child))
|
||||||
entries = [
|
else:
|
||||||
(None,None,0),
|
label = gtk.Label(GrampsCfg.nameof(child))
|
||||||
(gtk.STOCK_GO_BACK,self.parent.back_clicked,back_sensitivity),
|
|
||||||
(gtk.STOCK_GO_FORWARD,self.parent.fwd_clicked,fwd_sensitivity),
|
|
||||||
#FIXME: revert to stock item when German gtk translation is fixed
|
|
||||||
#(gtk.STOCK_HOME,self.parent.on_home_clicked,1),
|
|
||||||
(_("Home"),self.parent.on_home_clicked,1),
|
|
||||||
(None,None,0),
|
|
||||||
(_("Set anchor"),self.on_anchor_set,1),
|
|
||||||
(_("Remove anchor"),self.on_anchor_removed,1),
|
|
||||||
]
|
|
||||||
|
|
||||||
for stock_id,callback,sensitivity in entries:
|
child_item = gtk.MenuItem(None)
|
||||||
item = gtk.ImageMenuItem(stock_id)
|
label.set_use_markup(gtk.TRUE)
|
||||||
#FIXME: remove when German gtk translation is fixed
|
label.show()
|
||||||
if stock_id == _("Home"):
|
label.set_alignment(0,0)
|
||||||
im = gtk.image_new_from_stock(gtk.STOCK_HOME,gtk.ICON_SIZE_MENU)
|
child_item.add(label)
|
||||||
im.show()
|
child_item.set_data(_PERSON,child_id)
|
||||||
item.set_image(im)
|
child_item.connect("activate",self.on_childmenu_changed)
|
||||||
if callback:
|
child_item.show()
|
||||||
item.connect("activate",callback)
|
child_menu.append(child_item)
|
||||||
item.set_sensitive(sensitivity)
|
|
||||||
item.show()
|
if no_children:
|
||||||
menu.append(item)
|
item.set_sensitive(0)
|
||||||
|
item.show()
|
||||||
|
menu.append(item)
|
||||||
|
|
||||||
|
# Go over parents and build their menu
|
||||||
|
item = gtk.MenuItem(_("Parents"))
|
||||||
|
no_parents = 1
|
||||||
|
par_list = find_parents(self.parent.db,person)
|
||||||
|
for par_id in par_list:
|
||||||
|
par = self.parent.db.try_to_find_person_from_id(par_id)
|
||||||
|
if not par:
|
||||||
|
continue
|
||||||
|
|
||||||
|
if no_parents:
|
||||||
|
no_parents = 0
|
||||||
|
item.set_submenu(gtk.Menu())
|
||||||
|
par_menu = item.get_submenu()
|
||||||
|
|
||||||
|
if find_parents(self.parent.db,par):
|
||||||
|
label = gtk.Label('<b><i>%s</i></b>' % GrampsCfg.nameof(par))
|
||||||
|
else:
|
||||||
|
label = gtk.Label(GrampsCfg.nameof(par))
|
||||||
|
|
||||||
|
par_item = gtk.MenuItem(None)
|
||||||
|
label.set_use_markup(gtk.TRUE)
|
||||||
|
label.show()
|
||||||
|
label.set_alignment(0,0)
|
||||||
|
par_item.add(label)
|
||||||
|
par_item.set_data(_PERSON,par_id)
|
||||||
|
par_item.connect("activate",self.on_childmenu_changed)
|
||||||
|
par_item.show()
|
||||||
|
par_menu.append(par_item)
|
||||||
|
|
||||||
|
if no_parents:
|
||||||
|
item.set_sensitive(0)
|
||||||
|
item.show()
|
||||||
|
menu.append(item)
|
||||||
|
|
||||||
|
# Add separator
|
||||||
|
item = gtk.MenuItem(None)
|
||||||
|
item.show()
|
||||||
|
menu.append(item)
|
||||||
|
|
||||||
|
# Add history-based navigation
|
||||||
|
self.add_nav_portion_to_menu(menu)
|
||||||
menu.popup(None,None,None,event.button,event.time)
|
menu.popup(None,None,None,event.button,event.time)
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
@ -707,11 +756,45 @@ def get_distance(db,orig_person,other_person):
|
|||||||
firstRel = None
|
firstRel = None
|
||||||
secondRel = None
|
secondRel = None
|
||||||
|
|
||||||
length = len(common)
|
|
||||||
|
|
||||||
person_id = common[0]
|
person_id = common[0]
|
||||||
secondRel = secondMap[person_id]
|
secondRel = secondMap[person_id]
|
||||||
firstRel = firstMap[person_id]
|
firstRel = firstMap[person_id]
|
||||||
if firstRel == None or secondRel == None:
|
if firstRel == None or secondRel == None:
|
||||||
return None
|
return None
|
||||||
return firstRel-secondRel
|
return firstRel-secondRel
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# Function to return children's list of a person
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def find_children(db,p):
|
||||||
|
"""
|
||||||
|
Returns the list of all children's IDs for a person.
|
||||||
|
"""
|
||||||
|
childlist = []
|
||||||
|
for family_id in p.get_family_id_list():
|
||||||
|
family = db.find_family_from_id(family_id)
|
||||||
|
for child_id in family.get_child_id_list():
|
||||||
|
childlist.append(child_id)
|
||||||
|
return childlist
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# Function to return parent's list of a person
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def find_parents(db,p):
|
||||||
|
"""
|
||||||
|
Returns the unique list of all parents' IDs for a person.
|
||||||
|
"""
|
||||||
|
parentlist = []
|
||||||
|
for (f,mrel,frel) in p.get_parent_family_id_list():
|
||||||
|
family = db.find_family_from_id(f)
|
||||||
|
father_id = family.get_father_id()
|
||||||
|
mother_id = family.get_mother_id()
|
||||||
|
if father_id not in parentlist:
|
||||||
|
parentlist.append(father_id)
|
||||||
|
if mother_id not in parentlist:
|
||||||
|
parentlist.append(mother_id)
|
||||||
|
return parentlist
|
||||||
|
Loading…
x
Reference in New Issue
Block a user