Geography : Adding bookmarks (follow bug 7240)
This commit is contained in:
parent
32c312f7d9
commit
16fecf125b
@ -183,6 +183,18 @@ class GeoGraphyView(OsmGps, NavigationView):
|
|||||||
pathu = path.encode(glocale.getfilesystemencoding())
|
pathu = path.encode(glocale.getfilesystemencoding())
|
||||||
self.geo_othermap[ident] = cairo.ImageSurface.create_from_png(pathu)
|
self.geo_othermap[ident] = cairo.ImageSurface.create_from_png(pathu)
|
||||||
|
|
||||||
|
def add_bookmark(self, menu, handle):
|
||||||
|
if handle:
|
||||||
|
self.uistate.set_active(handle, self.navigation_type())
|
||||||
|
self.bookmarks.add(handle)
|
||||||
|
self.bookmarks.redraw()
|
||||||
|
else:
|
||||||
|
from gramps.gui.dialog import WarningDialog
|
||||||
|
WarningDialog(
|
||||||
|
_("Could Not Set a Bookmark"),
|
||||||
|
_("A bookmark could not be set because "
|
||||||
|
"no one was selected."))
|
||||||
|
|
||||||
def change_page(self):
|
def change_page(self):
|
||||||
"""
|
"""
|
||||||
Called when the page changes.
|
Called when the page changes.
|
||||||
@ -231,6 +243,7 @@ class GeoGraphyView(OsmGps, NavigationView):
|
|||||||
"""
|
"""
|
||||||
if self.active:
|
if self.active:
|
||||||
self.bookmarks.redraw()
|
self.bookmarks.redraw()
|
||||||
|
self.build_tree()
|
||||||
|
|
||||||
def can_configure(self):
|
def can_configure(self):
|
||||||
"""
|
"""
|
||||||
@ -331,7 +344,7 @@ class GeoGraphyView(OsmGps, NavigationView):
|
|||||||
# Add specific module menu
|
# Add specific module menu
|
||||||
self.add_specific_menu(menu, event, lat, lon)
|
self.add_specific_menu(menu, event, lat, lon)
|
||||||
# Add a separator line
|
# Add a separator line
|
||||||
add_item = Gtk.MenuItem(label=None)
|
add_item = Gtk.MenuItem()
|
||||||
add_item.show()
|
add_item.show()
|
||||||
menu.append(add_item)
|
menu.append(add_item)
|
||||||
|
|
||||||
|
@ -150,6 +150,7 @@ class GeoClose(GeoGraphyView):
|
|||||||
self.minyear = 9999
|
self.minyear = 9999
|
||||||
self.maxyear = 0
|
self.maxyear = 0
|
||||||
self.refperson = None
|
self.refperson = None
|
||||||
|
self.refperson_bookmark = None
|
||||||
self.nbplaces = 0
|
self.nbplaces = 0
|
||||||
self.nbmarkers = 0
|
self.nbmarkers = 0
|
||||||
self.sort = []
|
self.sort = []
|
||||||
@ -196,17 +197,6 @@ class GeoClose(GeoGraphyView):
|
|||||||
"""
|
"""
|
||||||
return 'Person'
|
return 'Person'
|
||||||
|
|
||||||
def add_bookmark(self, obj):
|
|
||||||
mlist = self.selected_handles()
|
|
||||||
if mlist:
|
|
||||||
self.bookmarks.add(mlist[0])
|
|
||||||
else:
|
|
||||||
from gramps.gui.dialog import WarningDialog
|
|
||||||
WarningDialog(
|
|
||||||
_("Could Not Set a Bookmark"),
|
|
||||||
_("A bookmark could not be set because "
|
|
||||||
"no one was selected."))
|
|
||||||
|
|
||||||
def goto_handle(self, handle=None):
|
def goto_handle(self, handle=None):
|
||||||
"""
|
"""
|
||||||
Rebuild the tree with the given person handle as the root.
|
Rebuild the tree with the given person handle as the root.
|
||||||
@ -240,6 +230,9 @@ class GeoClose(GeoGraphyView):
|
|||||||
else:
|
else:
|
||||||
self.message_layer.add_message(_("The other person is unknown"))
|
self.message_layer.add_message(_("The other person is unknown"))
|
||||||
self._createmap(self.refperson, color, self.place_list_ref, True)
|
self._createmap(self.refperson, color, self.place_list_ref, True)
|
||||||
|
if self.refperson_bookmark is None:
|
||||||
|
self.refperson_bookmark = self.refperson.get_handle()
|
||||||
|
self.add_bookmark(None, self.refperson_bookmark)
|
||||||
else:
|
else:
|
||||||
self.message_layer.add_message(_("You must choose one reference person."))
|
self.message_layer.add_message(_("You must choose one reference person."))
|
||||||
self.message_layer.add_message(_("Go to the person view and select "
|
self.message_layer.add_message(_("Go to the person view and select "
|
||||||
@ -303,6 +296,8 @@ class GeoClose(GeoGraphyView):
|
|||||||
"""
|
"""
|
||||||
self.track = []
|
self.track = []
|
||||||
self.skip_list = []
|
self.skip_list = []
|
||||||
|
self.refperson = None
|
||||||
|
self.refperson_bookmark = None
|
||||||
SelectPerson = SelectorFactory('Person')
|
SelectPerson = SelectorFactory('Person')
|
||||||
sel = SelectPerson(self.dbstate, self.uistate, self.track,
|
sel = SelectPerson(self.dbstate, self.uistate, self.track,
|
||||||
_("Select the person which will be our reference."),
|
_("Select the person which will be our reference."),
|
||||||
@ -553,7 +548,7 @@ class GeoClose(GeoGraphyView):
|
|||||||
add_item = Gtk.MenuItem()
|
add_item = Gtk.MenuItem()
|
||||||
add_item.show()
|
add_item.show()
|
||||||
menu.append(add_item)
|
menu.append(add_item)
|
||||||
add_item = Gtk.MenuItem(label=_("Choose the reference person"))
|
add_item = Gtk.MenuItem(label=_("Choose and bookmark the new reference person"))
|
||||||
add_item.connect("activate", self.selectPerson)
|
add_item.connect("activate", self.selectPerson)
|
||||||
add_item.show()
|
add_item.show()
|
||||||
menu.append(add_item)
|
menu.append(add_item)
|
||||||
|
@ -168,17 +168,6 @@ class GeoEvents(GeoGraphyView):
|
|||||||
"""
|
"""
|
||||||
return 'Event'
|
return 'Event'
|
||||||
|
|
||||||
def add_bookmark(self, obj):
|
|
||||||
mlist = self.selected_handles()
|
|
||||||
if mlist:
|
|
||||||
self.bookmarks.add(mlist[0])
|
|
||||||
else:
|
|
||||||
from gramps.gui.dialog import WarningDialog
|
|
||||||
WarningDialog(
|
|
||||||
_("Could Not Set a Bookmark"),
|
|
||||||
_("A bookmark could not be set because "
|
|
||||||
"no one was selected."))
|
|
||||||
|
|
||||||
def goto_handle(self, handle=None):
|
def goto_handle(self, handle=None):
|
||||||
"""
|
"""
|
||||||
Rebuild the tree with the given events handle as the root.
|
Rebuild the tree with the given events handle as the root.
|
||||||
@ -343,6 +332,12 @@ class GeoEvents(GeoGraphyView):
|
|||||||
center.connect("activate", self.center_here,
|
center.connect("activate", self.center_here,
|
||||||
event, lat, lon, prevmark)
|
event, lat, lon, prevmark)
|
||||||
itemoption.append(center)
|
itemoption.append(center)
|
||||||
|
evt = self.dbstate.db.get_event_from_gramps_id(mark[10])
|
||||||
|
hdle = evt.get_handle()
|
||||||
|
bookm = Gtk.MenuItem(label=_("Bookmark this event"))
|
||||||
|
bookm.show()
|
||||||
|
bookm.connect("activate", self.add_bookmark, hdle)
|
||||||
|
itemoption.append(bookm)
|
||||||
if mark[0] != oldplace:
|
if mark[0] != oldplace:
|
||||||
message = "%s :" % mark[0]
|
message = "%s :" % mark[0]
|
||||||
self.add_place_bubble_message(event, lat, lon,
|
self.add_place_bubble_message(event, lat, lon,
|
||||||
@ -369,6 +364,12 @@ class GeoEvents(GeoGraphyView):
|
|||||||
center.show()
|
center.show()
|
||||||
center.connect("activate", self.center_here, event, lat, lon, prevmark)
|
center.connect("activate", self.center_here, event, lat, lon, prevmark)
|
||||||
itemoption.append(center)
|
itemoption.append(center)
|
||||||
|
evt = self.dbstate.db.get_event_from_gramps_id(mark[10])
|
||||||
|
hdle = evt.get_handle()
|
||||||
|
bookm = Gtk.MenuItem(label=_("Bookmark this event"))
|
||||||
|
bookm.show()
|
||||||
|
bookm.connect("activate", self.add_bookmark, hdle)
|
||||||
|
itemoption.append(bookm)
|
||||||
menu.popup(None, None,
|
menu.popup(None, None,
|
||||||
lambda menu, data: (event.get_root_coords()[0],
|
lambda menu, data: (event.get_root_coords()[0],
|
||||||
event.get_root_coords()[1], True),
|
event.get_root_coords()[1], True),
|
||||||
|
@ -148,6 +148,7 @@ class GeoFamClose(GeoGraphyView):
|
|||||||
self.minyear = 9999
|
self.minyear = 9999
|
||||||
self.maxyear = 0
|
self.maxyear = 0
|
||||||
self.reffamily = None
|
self.reffamily = None
|
||||||
|
self.reffamily_bookmark = None
|
||||||
self.nbplaces = 0
|
self.nbplaces = 0
|
||||||
self.nbmarkers = 0
|
self.nbmarkers = 0
|
||||||
self.sort = []
|
self.sort = []
|
||||||
@ -194,17 +195,6 @@ class GeoFamClose(GeoGraphyView):
|
|||||||
"""
|
"""
|
||||||
return 'Family'
|
return 'Family'
|
||||||
|
|
||||||
def add_bookmark(self, obj):
|
|
||||||
mlist = self.selected_handles()
|
|
||||||
if mlist:
|
|
||||||
self.bookmarks.add(mlist[0])
|
|
||||||
else:
|
|
||||||
from gramps.gui.dialog import WarningDialog
|
|
||||||
WarningDialog(
|
|
||||||
_("Could Not Set a Bookmark"),
|
|
||||||
_("A bookmark could not be set because "
|
|
||||||
"no one was selected."))
|
|
||||||
|
|
||||||
def family_label(self,family):
|
def family_label(self,family):
|
||||||
if family is None:
|
if family is None:
|
||||||
return "Unknown"
|
return "Unknown"
|
||||||
@ -263,6 +253,9 @@ class GeoFamClose(GeoGraphyView):
|
|||||||
self.message_layer.add_message(_("The other family : %s") % self.family_label(f1))
|
self.message_layer.add_message(_("The other family : %s") % self.family_label(f1))
|
||||||
else:
|
else:
|
||||||
self.message_layer.add_message(_("The other family : %s") % _("Unknown"))
|
self.message_layer.add_message(_("The other family : %s") % _("Unknown"))
|
||||||
|
if self.reffamily_bookmark is None:
|
||||||
|
self.reffamily_bookmark = self.reffamily.get_handle()
|
||||||
|
self.add_bookmark(None, self.reffamily_bookmark)
|
||||||
else:
|
else:
|
||||||
self.message_layer.add_message(_("You must choose one reference family."))
|
self.message_layer.add_message(_("You must choose one reference family."))
|
||||||
self.message_layer.add_message(_("Go to the family view and select "
|
self.message_layer.add_message(_("Go to the family view and select "
|
||||||
@ -293,6 +286,8 @@ class GeoFamClose(GeoGraphyView):
|
|||||||
"""
|
"""
|
||||||
self.track = []
|
self.track = []
|
||||||
self.skip_list = []
|
self.skip_list = []
|
||||||
|
self.ref_family = None
|
||||||
|
self.reffamily_bookmark = None
|
||||||
selectFamily = SelectorFactory('Family')
|
selectFamily = SelectorFactory('Family')
|
||||||
sel = selectFamily(self.dbstate, self.uistate)
|
sel = selectFamily(self.dbstate, self.uistate)
|
||||||
self.reffamily = sel.run()
|
self.reffamily = sel.run()
|
||||||
@ -696,7 +691,7 @@ class GeoFamClose(GeoGraphyView):
|
|||||||
add_item = Gtk.MenuItem()
|
add_item = Gtk.MenuItem()
|
||||||
add_item.show()
|
add_item.show()
|
||||||
menu.append(add_item)
|
menu.append(add_item)
|
||||||
add_item = Gtk.MenuItem(label=_("Choose the reference family"))
|
add_item = Gtk.MenuItem(label=_("Choose and bookmark the new reference family"))
|
||||||
add_item.connect("activate", self.selectFamily)
|
add_item.connect("activate", self.selectFamily)
|
||||||
add_item.show()
|
add_item.show()
|
||||||
menu.append(add_item)
|
menu.append(add_item)
|
||||||
|
@ -167,17 +167,6 @@ class GeoFamily(GeoGraphyView):
|
|||||||
"""
|
"""
|
||||||
return 'Family'
|
return 'Family'
|
||||||
|
|
||||||
def add_bookmark(self, obj):
|
|
||||||
mlist = self.selected_handles()
|
|
||||||
if mlist:
|
|
||||||
self.bookmarks.add(mlist[0])
|
|
||||||
else:
|
|
||||||
from gramps.gui.dialog import WarningDialog
|
|
||||||
WarningDialog(
|
|
||||||
_("Could Not Set a Bookmark"),
|
|
||||||
_("A bookmark could not be set because "
|
|
||||||
"no one was selected."))
|
|
||||||
|
|
||||||
def goto_handle(self, handle=None):
|
def goto_handle(self, handle=None):
|
||||||
"""
|
"""
|
||||||
Rebuild the tree with the given person handle as the root.
|
Rebuild the tree with the given person handle as the root.
|
||||||
|
@ -198,17 +198,6 @@ class GeoMoves(GeoGraphyView):
|
|||||||
"""
|
"""
|
||||||
return 'Person'
|
return 'Person'
|
||||||
|
|
||||||
def add_bookmark(self, obj):
|
|
||||||
mlist = self.selected_handles()
|
|
||||||
if mlist:
|
|
||||||
self.bookmarks.add(mlist[0])
|
|
||||||
else:
|
|
||||||
from gramps.gui.dialog import WarningDialog
|
|
||||||
WarningDialog(
|
|
||||||
_("Could Not Set a Bookmark"),
|
|
||||||
_("A bookmark could not be set because "
|
|
||||||
"no one was selected."))
|
|
||||||
|
|
||||||
def goto_handle(self, handle=None):
|
def goto_handle(self, handle=None):
|
||||||
"""
|
"""
|
||||||
Rebuild the tree with the given family handle as reference.
|
Rebuild the tree with the given family handle as reference.
|
||||||
@ -614,6 +603,12 @@ class GeoMoves(GeoGraphyView):
|
|||||||
center.connect("activate", self.center_here,
|
center.connect("activate", self.center_here,
|
||||||
event, lat, lon, prevmark)
|
event, lat, lon, prevmark)
|
||||||
itemoption.append(center)
|
itemoption.append(center)
|
||||||
|
person = self.dbstate.db.get_person_from_gramps_id(mark[8])
|
||||||
|
hdle = person.get_handle()
|
||||||
|
bookm = Gtk.MenuItem(label=_("Bookmark this person"))
|
||||||
|
bookm.show()
|
||||||
|
bookm.connect("activate", self.add_bookmark, hdle)
|
||||||
|
itemoption.append(bookm)
|
||||||
menu.show()
|
menu.show()
|
||||||
menu.popup(None, None,
|
menu.popup(None, None,
|
||||||
lambda menu, data: (event.get_root_coords()[0],
|
lambda menu, data: (event.get_root_coords()[0],
|
||||||
|
@ -197,17 +197,6 @@ class GeoPerson(GeoGraphyView):
|
|||||||
"""
|
"""
|
||||||
return 'Person'
|
return 'Person'
|
||||||
|
|
||||||
def add_bookmark(self, obj):
|
|
||||||
mlist = self.selected_handles()
|
|
||||||
if mlist:
|
|
||||||
self.bookmarks.add(mlist[0])
|
|
||||||
else:
|
|
||||||
from gramps.gui.dialog import WarningDialog
|
|
||||||
WarningDialog(
|
|
||||||
_("Could Not Set a Bookmark"),
|
|
||||||
_("A bookmark could not be set because "
|
|
||||||
"no one was selected."))
|
|
||||||
|
|
||||||
def goto_handle(self, handle=None):
|
def goto_handle(self, handle=None):
|
||||||
"""
|
"""
|
||||||
Rebuild the tree with the given person handle as the root.
|
Rebuild the tree with the given person handle as the root.
|
||||||
|
@ -168,17 +168,6 @@ class GeoPlaces(GeoGraphyView):
|
|||||||
"""
|
"""
|
||||||
return 'Place'
|
return 'Place'
|
||||||
|
|
||||||
def add_bookmark(self, obj):
|
|
||||||
mlist = self.selected_handles()
|
|
||||||
if mlist:
|
|
||||||
self.bookmarks.add(mlist[0])
|
|
||||||
else:
|
|
||||||
from gramps.gui.dialog import WarningDialog
|
|
||||||
WarningDialog(
|
|
||||||
_("Could Not Set a Bookmark"),
|
|
||||||
_("A bookmark could not be set because "
|
|
||||||
"no one was selected."))
|
|
||||||
|
|
||||||
def goto_handle(self, handle=None):
|
def goto_handle(self, handle=None):
|
||||||
"""
|
"""
|
||||||
Rebuild the tree with the given places handle as the root.
|
Rebuild the tree with the given places handle as the root.
|
||||||
@ -341,6 +330,12 @@ class GeoPlaces(GeoGraphyView):
|
|||||||
center.connect("activate", self.center_here,
|
center.connect("activate", self.center_here,
|
||||||
event, lat, lon, prevmark)
|
event, lat, lon, prevmark)
|
||||||
itemoption.append(center)
|
itemoption.append(center)
|
||||||
|
place = self.dbstate.db.get_place_from_gramps_id(mark[9])
|
||||||
|
hdle = place.get_handle()
|
||||||
|
bookm = Gtk.MenuItem(label=_("Bookmark this place"))
|
||||||
|
bookm.show()
|
||||||
|
bookm.connect("activate", self.add_bookmark, hdle)
|
||||||
|
itemoption.append(bookm)
|
||||||
message = "%s" % mark[0]
|
message = "%s" % mark[0]
|
||||||
prevmark = mark
|
prevmark = mark
|
||||||
add_item = Gtk.MenuItem(label=message)
|
add_item = Gtk.MenuItem(label=message)
|
||||||
@ -359,6 +354,12 @@ class GeoPlaces(GeoGraphyView):
|
|||||||
center.show()
|
center.show()
|
||||||
center.connect("activate", self.center_here, event, lat, lon, prevmark)
|
center.connect("activate", self.center_here, event, lat, lon, prevmark)
|
||||||
itemoption.append(center)
|
itemoption.append(center)
|
||||||
|
place = self.dbstate.db.get_place_from_gramps_id(mark[9])
|
||||||
|
hdle = place.get_handle()
|
||||||
|
bookm = Gtk.MenuItem(label=_("Bookmark this place"))
|
||||||
|
bookm.show()
|
||||||
|
bookm.connect("activate", self.add_bookmark, hdle)
|
||||||
|
itemoption.append(bookm)
|
||||||
menu.popup(None, None,
|
menu.popup(None, None,
|
||||||
lambda menu, data: (event.get_root_coords()[0],
|
lambda menu, data: (event.get_root_coords()[0],
|
||||||
event.get_root_coords()[1], True),
|
event.get_root_coords()[1], True),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user