Update
svn: r5484
This commit is contained in:
parent
cf825940d2
commit
53a2368235
@ -35,8 +35,6 @@ from gettext import gettext as _
|
||||
#-------------------------------------------------------------------------
|
||||
import gtk
|
||||
import gtk.glade
|
||||
import gobject
|
||||
import gnome
|
||||
|
||||
try:
|
||||
from gnomevfs import get_mime_type
|
||||
@ -61,6 +59,7 @@ import ReadGrdb
|
||||
import WriteGrdb
|
||||
import WriteXML
|
||||
import WriteGedcom
|
||||
import GrampsDisplay
|
||||
|
||||
from bsddb import db
|
||||
|
||||
@ -93,16 +92,64 @@ class DbPrompter:
|
||||
title = opendb.get_widget('title')
|
||||
|
||||
Utils.set_titles(top,title,_('Open a database'))
|
||||
|
||||
|
||||
recent = opendb.get_widget("recent")
|
||||
existing = opendb.get_widget("existing")
|
||||
new = opendb.get_widget("new")
|
||||
new.set_active(want_new)
|
||||
filelist = opendb.get_widget("filelist")
|
||||
|
||||
# write in recent file into UI
|
||||
gramps_rf = RecentFiles.GrampsRecentFiles()
|
||||
gramps_rf.gramps_recent_files.sort()
|
||||
gramps_rf.gramps_recent_files.reverse()
|
||||
self.recent_files = []
|
||||
if gramps_rf.gramps_recent_files:
|
||||
# if recent files have been stored
|
||||
cell = gtk.CellRendererText()
|
||||
filelist.pack_start(cell,True)
|
||||
filelist.add_attribute(cell,'text',0)
|
||||
store = gtk.ListStore(str)
|
||||
for item in gramps_rf.gramps_recent_files:
|
||||
try:
|
||||
filename = os.path.basename(item.get_path())
|
||||
filetype = get_mime_type(item.get_path())
|
||||
node = store.append()
|
||||
store.set(node,0,unicode(filename))
|
||||
self.recent_files.append( (item.get_path(), filetype))
|
||||
except RuntimeError:
|
||||
pass # ignore no longer existing files
|
||||
if self.recent_files:
|
||||
filelist.set_model(store)
|
||||
filelist.set_active(0)
|
||||
else:
|
||||
recent.set_sensitive(False)
|
||||
filelist.set_sensitive(False)
|
||||
else:
|
||||
recent.set_sensitive(False)
|
||||
filelist.set_sensitive(False)
|
||||
|
||||
if want_new:
|
||||
new.set_active(True)
|
||||
else:
|
||||
if not self.recent_files:
|
||||
existing.set_active(True)
|
||||
|
||||
while 1:
|
||||
top.show()
|
||||
response = top.run()
|
||||
top.hide()
|
||||
if response == gtk.RESPONSE_OK:
|
||||
if new.get_active():
|
||||
if recent.get_active():
|
||||
try:
|
||||
(filename,filetype) = self.recent_files[filelist.get_active()]
|
||||
if open_native(self.parent,filename,filetype):
|
||||
break
|
||||
except RuntimeError,msg:
|
||||
QuestionDialog.ErrorDialog(
|
||||
_("Could not open file: %s") % self.recent_file,
|
||||
str(msg))
|
||||
continue
|
||||
elif new.get_active():
|
||||
prompter = NewNativeDbPrompter(self.parent,
|
||||
self.parent_window)
|
||||
else:
|
||||
@ -113,10 +160,7 @@ class DbPrompter:
|
||||
elif response == gtk.RESPONSE_CANCEL:
|
||||
break
|
||||
elif response == gtk.RESPONSE_HELP:
|
||||
try:
|
||||
gnome.help_display('gramps-manual','choose-db-start')
|
||||
except gobject.GError,msg:
|
||||
QuestionDialog.ErrorDialog(_('Help not available'),msg)
|
||||
GrampsDisplay.help('choose-db-start')
|
||||
|
||||
top.destroy()
|
||||
if response == gtk.RESPONSE_CANCEL:
|
||||
@ -396,11 +440,11 @@ class NewNativeDbPrompter:
|
||||
filename = filename + ".grdb"
|
||||
choose.destroy()
|
||||
try:
|
||||
self.parent.db.close()
|
||||
close(self.parent)
|
||||
except:
|
||||
pass
|
||||
self.parent.db = GrampsBSDDB.GrampsBSDDB()
|
||||
self.read_file(filename)
|
||||
self.parent.read_file(filename)
|
||||
# Add the file to the recent items
|
||||
RecentFiles.recent_files(filename,const.app_gramps)
|
||||
self.parent.build_recent_menu()
|
||||
@ -487,17 +531,17 @@ class NewSaveasDbPrompter:
|
||||
return False
|
||||
if filetype == const.app_gramps:
|
||||
WriteGrdb.exportData(self.parent.db,filename,None,None)
|
||||
self.parent.db.close()
|
||||
close(self.parent)
|
||||
self.parent.db = GrampsBSDDB.GrampsBSDDB()
|
||||
elif filetype == const.app_gramps_xml:
|
||||
WriteXML.exportData(self.parent.db,filename,None,None)
|
||||
self.parent.db.close()
|
||||
close(self.parent)
|
||||
self.parent.db = GrampsXMLDB.GrampsXMLDB()
|
||||
elif filetype == const.app_gedcom:
|
||||
WriteGedcom.exportData(self.parent.db,filename,None,None)
|
||||
self.parent.db.close()
|
||||
close(self.parent)
|
||||
self.parent.db = GrampsGEDDB.GrampsGEDDB()
|
||||
self.read_file(filename)
|
||||
self.parent.read_file(filename)
|
||||
# Add the file to the recent items
|
||||
RecentFiles.recent_files(filename,const.app_gramps)
|
||||
self.parent.build_recent_menu()
|
||||
@ -508,104 +552,55 @@ class NewSaveasDbPrompter:
|
||||
choose.destroy()
|
||||
return False
|
||||
|
||||
def read_file(self,filename,callback=None):
|
||||
mode = "w"
|
||||
filename = os.path.normpath(os.path.abspath(filename))
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# Helper functions
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
def close(parent):
|
||||
# Close existing dialogs
|
||||
for window in parent.child_windows.values():
|
||||
window.close()
|
||||
parent.db.close()
|
||||
|
||||
def open_native(parent,filename,filetype):
|
||||
"""
|
||||
Open native database and return the status.
|
||||
"""
|
||||
|
||||
close(parent)
|
||||
|
||||
(the_path,the_file) = os.path.split(filename)
|
||||
GrampsKeys.save_last_import_dir(the_path)
|
||||
|
||||
if os.path.isdir(filename):
|
||||
ErrorDialog(_('Cannot open database'),
|
||||
_('The selected file is a directory, not '
|
||||
'a file.\nA GRAMPS database must be a file.'))
|
||||
return 0
|
||||
elif os.path.exists(filename):
|
||||
if not os.access(filename,os.R_OK):
|
||||
ErrorDialog(_('Cannot open database'),
|
||||
_('You do not have read access to the selected '
|
||||
'file.'))
|
||||
return 0
|
||||
elif not os.access(filename,os.W_OK):
|
||||
mode = "r"
|
||||
WarningDialog(_('Read only database'),
|
||||
_('You do not have write access to the selected '
|
||||
'file.'))
|
||||
|
||||
try:
|
||||
if self.load_database(filename,callback,mode=mode) == 1:
|
||||
if filename[-1] == '/':
|
||||
filename = filename[:-1]
|
||||
name = os.path.basename(filename)
|
||||
if self.state.db.readonly:
|
||||
self.state.window.set_title("%s (%s) - GRAMPS" % (name,_('Read Only')))
|
||||
else:
|
||||
self.state.window.set_title("%s - GRAMPS" % name)
|
||||
else:
|
||||
GrampsKeys.save_last_file("")
|
||||
ErrorDialog(_('Cannot open database'),
|
||||
_('The database file specified could not be opened.'))
|
||||
return False
|
||||
except ( IOError, OSError, Errors.FileVersionError), msg:
|
||||
ErrorDialog(_('Cannot open database'),str(msg))
|
||||
return False
|
||||
except (db.DBAccessError,db.DBError), msg:
|
||||
ErrorDialog(_('Cannot open database'),
|
||||
_('%s could not be opened.' % filename) + '\n' + msg[1])
|
||||
return False
|
||||
except Exception:
|
||||
DisplayTrace.DisplayTrace()
|
||||
return False
|
||||
|
||||
return True
|
||||
|
||||
def load_database(self,name,callback=None,mode="w"):
|
||||
|
||||
filename = name
|
||||
|
||||
if self.state.db.load(filename,callback,mode) == 0:
|
||||
return 0
|
||||
|
||||
#val = self.post_load(name,callback)
|
||||
return val
|
||||
|
||||
|
||||
def open_native(self,filename,filetype):
|
||||
"""
|
||||
Open native database and return the status.
|
||||
"""
|
||||
|
||||
(the_path,the_file) = os.path.split(filename)
|
||||
GrampsKeys.save_last_import_dir(the_path)
|
||||
|
||||
success = False
|
||||
if filetype == const.app_gramps:
|
||||
state.db = GrampsBSDDB.GrampsBSDDB()
|
||||
msgxml = gtk.glade.XML(const.gladeFile, "load_message","gramps")
|
||||
msg_top = msgxml.get_widget('load_message')
|
||||
msg_label = msgxml.get_widget('message')
|
||||
success = False
|
||||
if filetype == const.app_gramps:
|
||||
state.db = GrampsBSDDB.GrampsBSDDB()
|
||||
msgxml = gtk.glade.XML(const.gladeFile, "load_message","gramps")
|
||||
msg_top = msgxml.get_widget('load_message')
|
||||
msg_label = msgxml.get_widget('message')
|
||||
|
||||
def update_msg(msg):
|
||||
msg_label.set_text("<i>%s</i>" % msg)
|
||||
msg_label.set_use_markup(True)
|
||||
while gtk.events_pending():
|
||||
gtk.main_iteration()
|
||||
|
||||
success = self.read_file(filename,update_msg)
|
||||
msg_top.destroy()
|
||||
elif filetype == const.app_gramps_xml:
|
||||
state.db = GrampsXMLDB.GrampsXMLDB()
|
||||
success = self.read_file(filename)
|
||||
elif filetype == const.app_gedcom:
|
||||
state.db = GrampsGEDDB.GrampsGEDDB()
|
||||
success = self.read_file(filename)
|
||||
|
||||
#if success:
|
||||
# Add the file to the recent items
|
||||
#RecentFiles.recent_files(filename,filetype)
|
||||
#parent.build_recent_menu()
|
||||
|
||||
return success
|
||||
def update_msg(msg):
|
||||
msg_label.set_text("<i>%s</i>" % msg)
|
||||
msg_label.set_use_markup(True)
|
||||
while gtk.events_pending():
|
||||
gtk.main_iteration()
|
||||
|
||||
success = self.read_file(filename,update_msg)
|
||||
msg_top.destroy()
|
||||
elif filetype == const.app_gramps_xml:
|
||||
state.db = GrampsXMLDB.GrampsXMLDB()
|
||||
success = self.read_file(filename)
|
||||
elif filetype == const.app_gedcom:
|
||||
state.db = GrampsGEDDB.GrampsGEDDB()
|
||||
success = self.read_file(filename)
|
||||
|
||||
#if success:
|
||||
# Add the file to the recent items
|
||||
#RecentFiles.recent_files(filename,filetype)
|
||||
#parent.build_recent_menu()
|
||||
|
||||
return success
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
|
@ -26,10 +26,12 @@
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
import os
|
||||
import gc
|
||||
import locale
|
||||
import ListBox
|
||||
import sets
|
||||
from gettext import gettext as _
|
||||
from cgi import escape
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -63,8 +65,11 @@ import NameEdit
|
||||
import NoteEdit
|
||||
import Spell
|
||||
import DisplayState
|
||||
import GrampsDisplay
|
||||
|
||||
from WindowUtils import GladeIf
|
||||
from QuestionDialog import WarningDialog, ErrorDialog, SaveDialog, QuestionDialog2
|
||||
from DdTargets import DdTargets
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -81,7 +86,7 @@ _select_gender = ((True,False,False),(False,True,False),(False,False,True))
|
||||
_use_patronymic = [
|
||||
"ru","RU","ru_RU","koi8r","ru_koi8r","russian","Russian",
|
||||
]
|
||||
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# EditPerson class
|
||||
@ -148,7 +153,8 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
|
||||
self.load_obj = None
|
||||
self.top = gtk.glade.XML(const.editPersonFile, "edit_person","gramps")
|
||||
self.window = self.get_widget("edit_person")
|
||||
self.window = self.top.get_widget("edit_person")
|
||||
self.gladeif = GladeIf(self.top)
|
||||
self.window.set_title("%s - GRAMPS" % _('Edit Person'))
|
||||
|
||||
#self.icon_list = self.top.get_widget("iconlist")
|
||||
@ -156,9 +162,9 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
# self.path, self.icon_list,
|
||||
# self.db, self, self.window)
|
||||
|
||||
self.build_gallery(self.get_widget('iconbox'))
|
||||
self.build_gallery(self.top.get_widget('iconbox'))
|
||||
|
||||
self.marker = self.get_widget('marker')
|
||||
self.marker = self.top.get_widget('marker')
|
||||
self.marker.set_sensitive(mod)
|
||||
if person:
|
||||
try:
|
||||
@ -171,9 +177,11 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
Utils.marker_types, self.marker,
|
||||
RelLib.PrimaryObject.MARKER_CUSTOM, defval)
|
||||
|
||||
self.gender = self.get_widget('gender')
|
||||
self.gender = self.top.get_widget('gender')
|
||||
self.gender.set_sensitive(mod)
|
||||
self.private = self.get_widget('private')
|
||||
self.complete = self.top.get_widget('complete')
|
||||
self.complete.set_sensitive(mod)
|
||||
self.private = self.top.get_widget('private')
|
||||
self.private.set_sensitive(mod)
|
||||
name_delete_btn = self.top.get_widget('aka_del')
|
||||
name_add_btn = self.top.get_widget('aka_add')
|
||||
@ -192,47 +200,87 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
addr_delete_btn = self.top.get_widget('addr_del')
|
||||
addr_edit_btn = self.top.get_widget('addr_edit')
|
||||
|
||||
self.notes_field = self.get_widget("personNotes")
|
||||
self.notes_field = self.top.get_widget("personNotes")
|
||||
self.notes_field.set_editable(mod)
|
||||
self.spell_notes = Spell.Spell(self.notes_field)
|
||||
self.flowed = self.get_widget("flowed")
|
||||
self.flowed = self.top.get_widget("flowed")
|
||||
self.flowed.set_sensitive(mod)
|
||||
self.preform = self.get_widget("preform")
|
||||
self.preform = self.top.get_widget("preform")
|
||||
self.preform.set_sensitive(mod)
|
||||
self.attr_list = self.get_widget("attr_list")
|
||||
self.web_list = self.get_widget("web_list")
|
||||
self.web_go = self.get_widget("web_go")
|
||||
self.addr_list = self.get_widget("address_list")
|
||||
self.event_ref_list = self.get_widget("eventList")
|
||||
self.edit_person = self.get_widget("editPerson")
|
||||
self.name_list = self.get_widget("nameList")
|
||||
self.name_type_field = self.get_widget("name_type")
|
||||
self.ntype_field = self.get_widget("ntype")
|
||||
self.suffix = self.get_widget("suffix")
|
||||
self.event_name_field = self.top.get_widget("eventName")
|
||||
self.event_place_field = self.top.get_widget("eventPlace")
|
||||
self.event_cause_field = self.top.get_widget("eventCause")
|
||||
self.event_date_field = self.top.get_widget("eventDate")
|
||||
self.event_descr_field = self.top.get_widget("eventDescription")
|
||||
self.event_src_field = self.top.get_widget("event_srcinfo")
|
||||
self.event_conf_field = self.top.get_widget("event_conf")
|
||||
self.attr_conf_field = self.top.get_widget("attr_conf")
|
||||
self.addr_conf_field = self.top.get_widget("addr_conf")
|
||||
self.name_conf_field = self.top.get_widget("name_conf")
|
||||
self.attr_src_field = self.top.get_widget("attr_srcinfo")
|
||||
self.name_src_field = self.top.get_widget("name_srcinfo")
|
||||
self.addr_src_field = self.top.get_widget("addr_srcinfo")
|
||||
self.attr_list = self.top.get_widget("attr_list")
|
||||
self.attr_type = self.top.get_widget("attr_type")
|
||||
self.attr_value = self.top.get_widget("attr_value")
|
||||
self.web_list = self.top.get_widget("web_list")
|
||||
self.web_url = self.top.get_widget("web_url")
|
||||
self.web_go = self.top.get_widget("web_go")
|
||||
self.web_description = self.top.get_widget("url_des")
|
||||
self.addr_list = self.top.get_widget("address_list")
|
||||
self.addr_start = self.top.get_widget("address_start")
|
||||
self.addr_street = self.top.get_widget("street")
|
||||
self.addr_city = self.top.get_widget("city")
|
||||
self.addr_state = self.top.get_widget("state")
|
||||
self.addr_country = self.top.get_widget("country")
|
||||
self.addr_postal = self.top.get_widget("postal")
|
||||
self.addr_phone = self.top.get_widget("phone")
|
||||
self.event_list = self.top.get_widget("eventList")
|
||||
self.edit_person = self.top.get_widget("editPerson")
|
||||
self.name_list = self.top.get_widget("nameList")
|
||||
self.alt_given_field = self.top.get_widget("alt_given")
|
||||
self.alt_last_field = self.top.get_widget("alt_last")
|
||||
self.alt_title_field = self.top.get_widget("alt_title")
|
||||
self.alt_suffix_field = self.top.get_widget("alt_suffix")
|
||||
self.alt_prefix_field = self.top.get_widget("alt_prefix")
|
||||
self.name_type_field = self.top.get_widget("name_type")
|
||||
self.ntype_field = self.top.get_widget("ntype")
|
||||
self.ntype_field.set_sensitive(mod)
|
||||
self.suffix = self.top.get_widget("suffix")
|
||||
self.suffix.set_editable(mod)
|
||||
self.prefix = self.get_widget("prefix")
|
||||
self.prefix = self.top.get_widget("prefix")
|
||||
self.prefix.set_editable(mod)
|
||||
self.given = self.get_widget("givenName")
|
||||
self.given = self.top.get_widget("givenName")
|
||||
self.given.set_editable(mod)
|
||||
self.title = self.get_widget("title")
|
||||
self.nick = self.top.get_widget("nickname")
|
||||
self.nick.set_editable(mod)
|
||||
self.title = self.top.get_widget("title")
|
||||
self.title.set_editable(mod)
|
||||
self.surname = self.get_widget("surname")
|
||||
self.surname = self.top.get_widget("surname")
|
||||
self.surname.set_editable(mod)
|
||||
self.gid = self.get_widget("gid")
|
||||
self.addr_note = self.top.get_widget("addr_note")
|
||||
self.addr_source = self.top.get_widget("addr_source")
|
||||
self.attr_note = self.top.get_widget("attr_note")
|
||||
self.attr_source = self.top.get_widget("attr_source")
|
||||
self.name_note = self.top.get_widget("name_note")
|
||||
self.name_source = self.top.get_widget("name_source")
|
||||
self.gid = self.top.get_widget("gid")
|
||||
self.gid.set_editable(mod)
|
||||
self.slist = self.get_widget("slist")
|
||||
names_label = self.get_widget("names_label")
|
||||
events_label = self.get_widget("events_label")
|
||||
attr_label = self.get_widget("attr_label")
|
||||
addr_label = self.get_widget("addr_label")
|
||||
web_label = self.get_widget("inet_label")
|
||||
self.notes_label = self.get_widget("notes_label")
|
||||
self.sources_label = self.get_widget("sources_label")
|
||||
self.gallery_label = self.get_widget("gallery_label")
|
||||
self.lds_tab = self.get_widget("lds_tab")
|
||||
self.person_photo = self.get_widget("personPix")
|
||||
self.eventbox = self.get_widget("eventbox1")
|
||||
self.prefix_label = self.get_widget('prefix_label')
|
||||
|
||||
self.slist = self.top.get_widget("slist")
|
||||
self.general_label = self.top.get_widget("general_label")
|
||||
self.names_label = self.top.get_widget("names_label")
|
||||
self.events_label = self.top.get_widget("events_label")
|
||||
self.attr_label = self.top.get_widget("attr_label")
|
||||
self.addr_label = self.top.get_widget("addr_label")
|
||||
self.notes_label = self.top.get_widget("notes_label")
|
||||
self.sources_label = self.top.get_widget("sources_label")
|
||||
self.inet_label = self.top.get_widget("inet_label")
|
||||
self.gallery_label = self.top.get_widget("gallery_label")
|
||||
self.lds_tab = self.top.get_widget("lds_tab")
|
||||
self.person_photo = self.top.get_widget("personPix")
|
||||
self.eventbox = self.top.get_widget("eventbox1")
|
||||
self.prefix_label = self.top.get_widget('prefix_label')
|
||||
|
||||
if self.use_patronymic:
|
||||
self.prefix_label.set_text(_('Patronymic:'))
|
||||
@ -295,12 +343,19 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
self.lds_endowment = RelLib.LdsOrd(self.person.get_lds_endowment())
|
||||
self.lds_sealing = RelLib.LdsOrd(self.person.get_lds_sealing())
|
||||
|
||||
self.get_widget("lds_tab").show()
|
||||
self.get_widget("lds_page").show()
|
||||
if (not self.lds_baptism.is_empty()) \
|
||||
or (not self.lds_endowment.is_empty()) \
|
||||
or (not self.lds_sealing.is_empty()):
|
||||
Utils.bold_label(self.lds_tab)
|
||||
if GrampsKeys.get_uselds() \
|
||||
or (not self.lds_baptism.is_empty()) \
|
||||
or (not self.lds_endowment.is_empty()) \
|
||||
or (not self.lds_sealing.is_empty()):
|
||||
self.top.get_widget("lds_tab").show()
|
||||
self.top.get_widget("lds_page").show()
|
||||
if (not self.lds_baptism.is_empty()) \
|
||||
or (not self.lds_endowment.is_empty()) \
|
||||
or (not self.lds_sealing.is_empty()):
|
||||
Utils.bold_label(self.lds_tab)
|
||||
else:
|
||||
self.top.get_widget("lds_tab").hide()
|
||||
self.top.get_widget("lds_page").hide()
|
||||
|
||||
self.ntype_selector = \
|
||||
AutoComp.StandardCustomSelector(Utils.name_types,
|
||||
@ -321,26 +376,61 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
self.flowed.set_active(True)
|
||||
Utils.bold_label(self.notes_label)
|
||||
|
||||
self.top.signal_autoconnect({
|
||||
"destroy_passed_object" : self.on_cancel_edit,
|
||||
"on_up_clicked" : self.on_up_clicked,
|
||||
"on_down_clicked" : self.on_down_clicked,
|
||||
"on_apply_person_clicked" : self.on_apply_person_clicked,
|
||||
"on_delete_event" : self.on_delete_event,
|
||||
"on_editperson_switch_page" : self.on_switch_page,
|
||||
"on_edit_name_clicked" : self.on_edit_name_clicked,
|
||||
"on_ldsbap_note_clicked" : self.on_ldsbap_note_clicked,
|
||||
"on_ldsendow_note_clicked" : self.on_ldsendow_note_clicked,
|
||||
"on_ldsseal_note_clicked" : self.on_ldsseal_note_clicked,
|
||||
"on_ldsbap_src_clicked" : self.on_ldsbap_source_clicked,
|
||||
"on_ldsendow_src_clicked" : self.on_ldsendow_source_clicked,
|
||||
"on_ldsseal_src_clicked" : self.on_ldsseal_source_clicked,
|
||||
"on_web_go_clicked" : self.on_web_go_clicked,
|
||||
"on_gender_activate" : self.on_gender_activate,
|
||||
"on_given_focus_out" : self.on_given_focus_out_event,
|
||||
"on_help_person_clicked" : self.on_help_clicked,
|
||||
})
|
||||
self.set_list_dnd(self.name_list, self.name_drag_data_get,
|
||||
self.name_drag_begin, self.name_drag_data_received)
|
||||
|
||||
self.set_list_dnd(self.event_list, self.ev_drag_data_get,
|
||||
self.ev_drag_begin, self.ev_drag_data_received)
|
||||
|
||||
self.set_list_dnd(self.web_list,self.url_drag_data_get,
|
||||
self.url_drag_begin, self.url_drag_data_received)
|
||||
|
||||
self.set_list_dnd(self.attr_list, self.at_drag_data_get,
|
||||
self.at_drag_begin, self.at_drag_data_received)
|
||||
|
||||
self.set_list_dnd(self.addr_list, self.ad_drag_data_get,
|
||||
self.ad_drag_begin, self.ad_drag_data_received)
|
||||
|
||||
|
||||
self.gladeif.connect("editPerson", "delete_event", self.on_delete_event)
|
||||
self.gladeif.connect("button15", "clicked", self.on_cancel_edit)
|
||||
self.gladeif.connect("ok", "clicked", self.on_apply_person_clicked)
|
||||
self.gladeif.connect("button134", "clicked", self.on_help_clicked)
|
||||
self.gladeif.connect("notebook", "switch_page", self.on_switch_page)
|
||||
self.gladeif.connect("genderMale", "toggled", self.on_gender_activate)
|
||||
self.gladeif.connect("genderFemale", "toggled", self.on_gender_activate)
|
||||
self.gladeif.connect("genderUnknown", "toggled", self.on_gender_activate)
|
||||
self.gladeif.connect("givenName", "focus_out_event", self.on_given_focus_out_event)
|
||||
self.gladeif.connect("button177", "clicked", self.on_edit_name_clicked)
|
||||
self.gladeif.connect("button99", "clicked", self.on_edit_birth_clicked)
|
||||
self.gladeif.connect("button126", "clicked", self.on_edit_death_clicked)
|
||||
self.gladeif.connect("add_aka", "clicked", self.on_add_aka_clicked)
|
||||
self.gladeif.connect("aka_edit", "clicked", self.on_aka_update_clicked)
|
||||
self.gladeif.connect("aka_delete", "clicked", self.on_aka_delete_clicked)
|
||||
self.gladeif.connect("event_add", "clicked" , self.on_event_add_clicked)
|
||||
self.gladeif.connect("event_edit_btn", "clicked" ,self.on_event_update_clicked)
|
||||
self.gladeif.connect("event_del", "clicked", self.on_event_delete_clicked)
|
||||
self.gladeif.connect("attr_add", "clicked" , self.on_add_attr_clicked)
|
||||
self.gladeif.connect("attr_edit_btn", "clicked", self.on_update_attr_clicked)
|
||||
self.gladeif.connect("attr_del", "clicked", self.on_delete_attr_clicked)
|
||||
self.gladeif.connect("addr_add", "clicked", self.on_add_addr_clicked)
|
||||
self.gladeif.connect("addr_edit_btn", "clicked", self.on_update_addr_clicked)
|
||||
self.gladeif.connect("addr_del", "clicked", self.on_delete_addr_clicked)
|
||||
self.gladeif.connect("media_add", "clicked", self.gallery.on_add_media_clicked)
|
||||
self.gladeif.connect("media_sel", "clicked", self.gallery.on_select_media_clicked)
|
||||
self.gladeif.connect("image_edit_btn", "clicked", self.gallery.on_edit_media_clicked)
|
||||
self.gladeif.connect("media_del", "clicked", self.gallery.on_delete_media_clicked)
|
||||
self.gladeif.connect("add_url", "clicked", self.on_add_url_clicked)
|
||||
self.gladeif.connect("edit_url", "clicked", self.on_update_url_clicked,)
|
||||
self.gladeif.connect("web_go", "clicked", self.on_web_go_clicked)
|
||||
self.gladeif.connect("delete_url", "clicked", self.on_delete_url_clicked)
|
||||
self.gladeif.connect("button131", "clicked", self.on_ldsbap_source_clicked,)
|
||||
self.gladeif.connect("button128", "clicked", self.on_ldsbap_note_clicked)
|
||||
self.gladeif.connect("button132", "clicked", self.on_ldsendow_source_clicked)
|
||||
self.gladeif.connect("button129", "clicked", self.on_ldsendow_note_clicked)
|
||||
self.gladeif.connect("button133", "clicked", self.on_ldsseal_source_clicked)
|
||||
self.gladeif.connect("button130", "clicked", self.on_ldsseal_note_clicked)
|
||||
|
||||
self.sourcetab = Sources.SourceTab(
|
||||
self.srcreflist, self, self.top, self.window, self.slist,
|
||||
self.top.get_widget('add_src'), self.top.get_widget('edit_src'),
|
||||
@ -355,18 +445,27 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
self.addr_box.redraw()
|
||||
self.name_box.redraw()
|
||||
self.url_box.redraw()
|
||||
self.get_widget("notebook").set_current_page(0)
|
||||
self.surname.grab_focus()
|
||||
self.top.get_widget("notebook").set_current_page(0)
|
||||
self.given.grab_focus()
|
||||
|
||||
if self.db.readonly:
|
||||
for i in ["ok", "aka_add", "aka_del", "event_add", "event_del",
|
||||
"attr_add", "attr_del", "addr_add",
|
||||
"addr_del", "media_add", "media_sel", "media_del",
|
||||
"url_add", "url_del", "add_src", "del_src" ]:
|
||||
self.get_widget(i).set_sensitive(False)
|
||||
for i in ["ok", "add_aka", "aka_delete", "event_del",
|
||||
"event_add", "attr_add", "attr_del", "addr_add",
|
||||
"addr_del", "media_add", "media_sel", "media_del",
|
||||
"add_url", "delete_url", "add_src", "del_src" ]:
|
||||
self.top.get_widget(i).set_sensitive(not self.db.readonly)
|
||||
|
||||
self.window.show()
|
||||
|
||||
def set_list_dnd(self,obj, get, begin, receive):
|
||||
obj.drag_dest_set(gtk.DEST_DEFAULT_ALL, [DdTargets.NAME.target()],
|
||||
gtk.gdk.ACTION_COPY)
|
||||
obj.drag_source_set(gtk.gdk.BUTTON1_MASK,[DdTargets.NAME.target()],
|
||||
gtk.gdk.ACTION_COPY)
|
||||
obj.connect('drag_data_get', get)
|
||||
obj.connect('drag_begin', begin)
|
||||
if not self.db.readonly:
|
||||
obj.connect('drag_data_received', receive)
|
||||
|
||||
def build_pdmap(self):
|
||||
self.pdmap.clear()
|
||||
cursor = self.db.get_place_cursor()
|
||||
@ -468,7 +567,7 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
|
||||
def on_help_clicked(self,obj):
|
||||
"""Display the relevant portion of GRAMPS manual"""
|
||||
gnome.help_display('gramps-manual','gramps-edit-complete')
|
||||
GrampsDisplay.help('adv-pers')
|
||||
|
||||
def lds_field(self,lds_ord,combo,date,place):
|
||||
build_combo(combo,_temple_names)
|
||||
@ -492,51 +591,51 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
"""Draws the LDS window. This window is not always drawn, and in
|
||||
may cases is hidden."""
|
||||
|
||||
self.ldsbap_date = self.get_widget("ldsbapdate")
|
||||
self.ldsbap_date = self.top.get_widget("ldsbapdate")
|
||||
self.ldsbap_date.set_editable(not self.db.readonly)
|
||||
self.ldsbap_temple = self.get_widget("ldsbaptemple")
|
||||
self.ldsbap_temple = self.top.get_widget("ldsbaptemple")
|
||||
self.ldsbap_temple.set_sensitive(not self.db.readonly)
|
||||
self.ldsbapplace = self.get_widget("lds_bap_place")
|
||||
self.ldsbapplace = self.top.get_widget("lds_bap_place")
|
||||
self.ldsbapplace.set_editable(not self.db.readonly)
|
||||
self.ldsbap_date_led = self.get_widget("ldsbap_stat")
|
||||
self.ldsbap_date_led = self.top.get_widget("ldsbap_stat")
|
||||
self.ldsbap_date_led.set_sensitive(not self.db.readonly)
|
||||
self.ldsbap_date_check = DateEdit.DateEdit(
|
||||
self.lds_baptism.get_date_object(), self.ldsbap_date,
|
||||
self.ldsbap_date_led, self.window)
|
||||
|
||||
self.ldsend_date = self.get_widget("endowdate")
|
||||
self.ldsend_date = self.top.get_widget("endowdate")
|
||||
self.ldsend_date.set_editable(not self.db.readonly)
|
||||
self.ldsend_temple = self.get_widget("endowtemple")
|
||||
self.ldsend_temple = self.top.get_widget("endowtemple")
|
||||
self.ldsend_temple.set_sensitive(not self.db.readonly)
|
||||
self.ldsendowplace = self.get_widget("lds_end_place")
|
||||
self.ldsendowplace = self.top.get_widget("lds_end_place")
|
||||
self.ldsendowplace.set_editable(not self.db.readonly)
|
||||
self.ldsendowstat = self.get_widget("endowstat")
|
||||
self.ldsendowstat = self.top.get_widget("endowstat")
|
||||
self.ldsendowstat.set_sensitive(not self.db.readonly)
|
||||
self.ldsend_date_led = self.get_widget("endow_stat")
|
||||
self.ldsend_date_led = self.top.get_widget("endow_stat")
|
||||
self.ldsend_date_led.set_sensitive(not self.db.readonly)
|
||||
self.ldsend_date_check = DateEdit.DateEdit(
|
||||
self.lds_endowment.get_date_object(), self.ldsend_date,
|
||||
self.ldsend_date_led, self.window)
|
||||
|
||||
self.ldsseal_date = self.get_widget("sealdate")
|
||||
self.ldsseal_temple = self.get_widget("sealtemple")
|
||||
self.ldssealplace = self.get_widget("lds_seal_place")
|
||||
self.ldsseal_date = self.top.get_widget("sealdate")
|
||||
self.ldsseal_temple = self.top.get_widget("sealtemple")
|
||||
self.ldssealplace = self.top.get_widget("lds_seal_place")
|
||||
self.ldsseal_date.set_editable(not self.db.readonly)
|
||||
self.ldsseal_temple.set_sensitive(not self.db.readonly)
|
||||
self.ldssealplace.set_editable(not self.db.readonly)
|
||||
self.ldsseal_date_led = self.get_widget("seal_stat")
|
||||
self.ldsseal_date_led = self.top.get_widget("seal_stat")
|
||||
self.ldsseal_date_led.set_sensitive(not self.db.readonly)
|
||||
self.ldsseal_date_check = DateEdit.DateEdit(
|
||||
self.lds_sealing.get_date_object(), self.ldsseal_date,
|
||||
self.ldsseal_date_led, self.window)
|
||||
|
||||
self.ldsseal_fam = self.get_widget("sealparents")
|
||||
self.ldsseal_fam = self.top.get_widget("sealparents")
|
||||
self.ldsseal_fam.set_sensitive(not self.db.readonly)
|
||||
|
||||
self.ldsbapstat = self.get_widget("ldsbapstat")
|
||||
self.ldsbapstat = self.top.get_widget("ldsbapstat")
|
||||
self.ldsbapstat.set_sensitive(not self.db.readonly)
|
||||
|
||||
self.ldssealstat = self.get_widget("sealstat")
|
||||
self.ldssealstat = self.top.get_widget("sealstat")
|
||||
self.ldssealstat.set_sensitive(not self.db.readonly)
|
||||
|
||||
self.bstat = self.lds_field(
|
||||
@ -632,6 +731,78 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
def set_lds_seal(self,obj):
|
||||
self.lds_sealing.set_status(obj.get_active())
|
||||
|
||||
def name_drag_data_get(self,widget, context, sel_data, info, time):
|
||||
name = self.ntree.get_selected_objects()
|
||||
if not name:
|
||||
return
|
||||
bits_per = 8; # we're going to pass a string
|
||||
pickled = pickle.dumps(name[0]);
|
||||
data = str((DdTargets.NAME.drag_type,self.person.get_handle(),pickled));
|
||||
sel_data.set(sel_data.target, bits_per, data)
|
||||
|
||||
def name_drag_begin(self, context, a):
|
||||
return
|
||||
icon = self.ntree.get_icon()
|
||||
t = self.ntree.tree
|
||||
(x,y) = icon.get_size()
|
||||
mask = gtk.gdk.Pixmap(self.window.window,x,y,1)
|
||||
mask.draw_rectangle(t.get_style().white_gc, True, 0,0,x,y)
|
||||
t.drag_source_set_icon(t.get_colormap(),icon,mask)
|
||||
|
||||
def name_drag_data_received(self,widget,context,x,y,sel_data,info,time):
|
||||
if self.db.readonly: # no DnD on readonly database
|
||||
return
|
||||
|
||||
row = self.ntree.get_row_at(x,y)
|
||||
|
||||
if sel_data and sel_data.data:
|
||||
exec 'data = %s' % sel_data.data
|
||||
exec 'mytype = "%s"' % data[0]
|
||||
exec 'person = "%s"' % data[1]
|
||||
if mytype != DdTargets.NAME.drag_type:
|
||||
return
|
||||
elif person == self.person.get_handle():
|
||||
self.move_element(self.nlist,self.ntree.get_selected_row(),row)
|
||||
else:
|
||||
foo = pickle.loads(data[2]);
|
||||
for src in foo.get_source_references():
|
||||
base_handle = src.get_base_handle()
|
||||
newbase = self.db.get_source_from_handle(base_handle)
|
||||
src.set_base_handle(newbase.get_handle())
|
||||
|
||||
self.nlist.insert(row,foo)
|
||||
|
||||
self.lists_changed = True
|
||||
self.redraw_name_list()
|
||||
|
||||
def ev_drag_data_received(self,widget,context,x,y,sel_data,info,time):
|
||||
if self.db.readonly: # no DnD on readonly database
|
||||
return
|
||||
|
||||
row = self.etree.get_row_at(x,y)
|
||||
|
||||
if sel_data and sel_data.data:
|
||||
exec 'data = %s' % sel_data.data
|
||||
exec 'mytype = "%s"' % data[0]
|
||||
exec 'person = "%s"' % data[1]
|
||||
if mytype != DdTargets.EVENT.drag_type:
|
||||
return
|
||||
elif person == self.person.get_handle():
|
||||
self.move_element(self.elist,self.etree.get_selected_row(),row)
|
||||
else:
|
||||
foo = pickle.loads(data[2]);
|
||||
for src in foo.get_source_references():
|
||||
base_handle = src.get_base_handle()
|
||||
newbase = self.db.get_source_from_handle(base_handle)
|
||||
src.set_base_handle(newbase.get_handle())
|
||||
place = foo.get_place_handle()
|
||||
if place:
|
||||
foo.set_place_handle(place.get_handle())
|
||||
self.elist.insert(row,foo.get_handle())
|
||||
|
||||
self.lists_changed = True
|
||||
self.redraw_event_list()
|
||||
|
||||
def move_element(self,list,src,dest):
|
||||
if src == -1:
|
||||
return
|
||||
@ -639,13 +810,134 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
list.remove(obj)
|
||||
list.insert(dest,obj)
|
||||
|
||||
def ev_drag_data_get(self,widget, context, sel_data, info, time):
|
||||
ev = self.etree.get_selected_objects()
|
||||
if not ev:
|
||||
return
|
||||
bits_per = 8; # we're going to pass a string
|
||||
pickled = pickle.dumps(ev[0]);
|
||||
data = str((DdTargets.EVENT.drag_type,self.person.get_handle(),pickled));
|
||||
sel_data.set(sel_data.target, bits_per, data)
|
||||
|
||||
def ev_drag_begin(self, context, a):
|
||||
return
|
||||
icon = self.etree.get_icon()
|
||||
t = self.etree.tree
|
||||
(x,y) = icon.get_size()
|
||||
mask = gtk.gdk.Pixmap(self.window.window,x,y,1)
|
||||
mask.draw_rectangle(t.get_style().white_gc, True, 0,0,x,y)
|
||||
t.drag_source_set_icon(t.get_colormap(),icon,mask)
|
||||
|
||||
def url_drag_data_received(self,widget,context,x,y,sel_data,info,time):
|
||||
if self.db.readonly: # no DnD on readonly database
|
||||
return
|
||||
|
||||
row = self.wtree.get_row_at(x,y)
|
||||
|
||||
if sel_data and sel_data.data:
|
||||
exec 'data = %s' % sel_data.data
|
||||
exec 'mytype = "%s"' % data[0]
|
||||
exec 'person = "%s"' % data[1]
|
||||
if mytype != DdTargets.URL.drag_type:
|
||||
return
|
||||
elif person == self.person.get_handle():
|
||||
self.move_element(self.ulist,self.wtree.get_selected_row(),row)
|
||||
else:
|
||||
foo = pickle.loads(data[2]);
|
||||
self.ulist.append(foo)
|
||||
self.lists_changed = True
|
||||
self.redraw_url_list()
|
||||
|
||||
def url_drag_begin(self, context, a):
|
||||
return
|
||||
|
||||
def url_drag_data_get(self,widget, context, sel_data, info, time):
|
||||
ev = self.wtree.get_selected_objects()
|
||||
|
||||
if len(ev):
|
||||
bits_per = 8; # we're going to pass a string
|
||||
pickled = pickle.dumps(ev[0]);
|
||||
data = str((DdTargets.URL.drag_type,self.person.get_handle(),pickled));
|
||||
sel_data.set(sel_data.target, bits_per, data)
|
||||
|
||||
def at_drag_data_received(self,widget,context,x,y,sel_data,info,time):
|
||||
if self.db.readonly: # no DnD on readonly database
|
||||
return
|
||||
|
||||
row = self.atree.get_row_at(x,y)
|
||||
|
||||
if sel_data and sel_data.data:
|
||||
exec 'data = %s' % sel_data.data
|
||||
exec 'mytype = "%s"' % data[0]
|
||||
exec 'person = "%s"' % data[1]
|
||||
if mytype != DdTargets.ATTRIBUTE.drag_type:
|
||||
return
|
||||
elif person == self.person.get_handle():
|
||||
self.move_element(self.alist,self.atree.get_selected_row(),row)
|
||||
else:
|
||||
foo = pickle.loads(data[2]);
|
||||
for src in foo.get_source_references():
|
||||
base_handle = src.get_base_handle()
|
||||
newbase = self.db.get_source_from_handle(base_handle)
|
||||
src.set_base_handle(newbase.get_handle())
|
||||
self.alist.append(foo)
|
||||
self.lists_changed = True
|
||||
self.redraw_attr_list()
|
||||
|
||||
def at_drag_begin(self, context, a):
|
||||
return
|
||||
|
||||
def at_drag_data_get(self,widget, context, sel_data, info, time):
|
||||
ev = self.atree.get_selected_objects()
|
||||
|
||||
if len(ev):
|
||||
bits_per = 8; # we're going to pass a string
|
||||
pickled = pickle.dumps(ev[0]);
|
||||
data = str((DdTargets.ATTRIBUTE.drag_type,
|
||||
self.person.get_handle(),pickled));
|
||||
sel_data.set(sel_data.target, bits_per, data)
|
||||
|
||||
def ad_drag_data_received(self,widget,context,x,y,sel_data,info,time):
|
||||
if self.db.readonly: # no DnD on readonly database
|
||||
return
|
||||
|
||||
row = self.ptree.get_row_at(x,y)
|
||||
|
||||
if sel_data and sel_data.data:
|
||||
exec 'data = %s' % sel_data.data
|
||||
exec 'mytype = "%s"' % data[0]
|
||||
exec 'person = "%s"' % data[1]
|
||||
if mytype != DdTargets.ADDRESS.drag_type:
|
||||
return
|
||||
elif person == self.person.get_handle():
|
||||
self.move_element(self.plist,self.ptree.get_selected_row(),row)
|
||||
else:
|
||||
foo = pickle.loads(data[2]);
|
||||
for src in foo.get_source_references():
|
||||
base_handle = src.get_base_handle()
|
||||
newbase = self.db.get_source_from_handle(base_handle)
|
||||
src.set_base_handle(newbase.get_handle())
|
||||
self.plist.insert(row,foo)
|
||||
|
||||
self.lists_changed = True
|
||||
self.redraw_addr_list()
|
||||
|
||||
def ad_drag_data_get(self,widget, context, sel_data, info, time):
|
||||
ev = self.ptree.get_selected_objects()
|
||||
|
||||
if len(ev):
|
||||
bits_per = 8; # we're going to pass a string
|
||||
pickled = pickle.dumps(ev[0]);
|
||||
data = str((DdTargets.ADDRESS.drag_type,
|
||||
self.person.get_handle(),pickled));
|
||||
sel_data.set(sel_data.target, bits_per, data)
|
||||
|
||||
def ad_drag_begin(self, context, a):
|
||||
return
|
||||
|
||||
def menu_changed(self,obj):
|
||||
self.ldsfam = self.lds_fam_list[obj.get_active()]
|
||||
|
||||
def get_widget(self,str):
|
||||
"""returns the widget related to the passed string"""
|
||||
return self.top.get_widget(str)
|
||||
|
||||
def strip_id(self,text):
|
||||
index = text.rfind('[')
|
||||
if (index > 0):
|
||||
@ -669,16 +961,16 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
|
||||
def on_web_go_clicked(self,obj):
|
||||
"""Attempts to display the selected URL in a web browser"""
|
||||
text = obj.get()
|
||||
text = self.web_url.get()
|
||||
if text:
|
||||
gnome.url_show(text)
|
||||
GrampsDisplay.url(text)
|
||||
|
||||
def on_cancel_edit(self,obj):
|
||||
"""If the data has changed, give the user a chance to cancel
|
||||
the close window"""
|
||||
|
||||
if self.did_data_change() and not GrampsKeys.get_dont_ask():
|
||||
n = "<i>%s</i>" % self.nd.display(self.person)
|
||||
if not self.db.readonly and self.did_data_change() and not GrampsKeys.get_dont_ask():
|
||||
n = "<i>%s</i>" % escape(self.nd.display(self.person))
|
||||
SaveDialog(_('Save changes to %s?') % n,
|
||||
_('If you close without saving, the changes you '
|
||||
'have made will be lost'),
|
||||
@ -693,8 +985,8 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
def on_delete_event(self,obj,b):
|
||||
"""If the data has changed, give the user a chance to cancel
|
||||
the close window"""
|
||||
if self.did_data_change() and not GrampsKeys.get_dont_ask():
|
||||
n = "<i>%s</i>" % self.nd.display(self.person)
|
||||
if not self.db.readonly and self.did_data_change() and not GrampsKeys.get_dont_ask():
|
||||
n = "<i>%s</i>" % escape(self.nd.display(self.person))
|
||||
SaveDialog(_('Save Changes to %s?') % n,
|
||||
_('If you close without saving, the changes you '
|
||||
'have made will be lost'),
|
||||
@ -913,10 +1205,7 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
else:
|
||||
if prefix != name.get_surname_prefix():
|
||||
name.set_surname_prefix(prefix)
|
||||
|
||||
if ntype != name.get_type():
|
||||
name.set_type(ntype)
|
||||
|
||||
|
||||
if surname != name.get_surname():
|
||||
name.set_surname(surname)
|
||||
|
||||
@ -933,7 +1222,6 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
|
||||
self.build_pdmap()
|
||||
|
||||
|
||||
# Update each of the families child lists to reflect any
|
||||
# change in ordering due to the new birth date
|
||||
family = self.person.get_main_parents_family_handle()
|
||||
@ -1166,6 +1454,10 @@ class EditPerson(DisplayState.ManagedWindow):
|
||||
self.write_primary_name()
|
||||
|
||||
def write_primary_name(self):
|
||||
# initial values
|
||||
name = '<span size="larger" weight="bold">%s</span>' % escape(self.nd.display(self.person))
|
||||
self.top.get_widget("activepersonTitle").set_text( name)
|
||||
self.top.get_widget("activepersonTitle").set_use_markup(True)
|
||||
self.suffix.set_text(self.pname.get_suffix())
|
||||
if self.use_patronymic:
|
||||
self.prefix.set_text(self.pname.get_patronymic())
|
||||
|
@ -26,6 +26,7 @@
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
import cPickle as pickle
|
||||
import gc
|
||||
from gettext import gettext as _
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
@ -36,7 +37,6 @@ from gettext import gettext as _
|
||||
import gobject
|
||||
import gtk
|
||||
import gtk.glade
|
||||
import gnome
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -50,8 +50,12 @@ import ImageSelect
|
||||
import NameDisplay
|
||||
import DisplayState
|
||||
import Spell
|
||||
import GrampsDisplay
|
||||
import RelLib
|
||||
import ListModel
|
||||
|
||||
from DdTargets import DdTargets
|
||||
from WindowUtils import GladeIf
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -60,11 +64,13 @@ from DdTargets import DdTargets
|
||||
#-------------------------------------------------------------------------
|
||||
class EditPlace(DisplayState.ManagedWindow):
|
||||
|
||||
<<<<<<< EditPlace.py
|
||||
def __init__(self,place,dbstate,uistate):
|
||||
self.dbstate = dbstate
|
||||
self.uistate = uistate
|
||||
|
||||
self.ref_not_loaded = place and place.get_handle()
|
||||
self.idle = None
|
||||
self.name_display = NameDisplay.displayer.display
|
||||
self.place = place
|
||||
self.db = dbstate.db
|
||||
@ -77,6 +83,8 @@ class EditPlace(DisplayState.ManagedWindow):
|
||||
self.srcreflist = []
|
||||
|
||||
self.top_window = gtk.glade.XML(const.placesFile,"placeEditor","gramps")
|
||||
self.gladeif = GladeIf(self.top_window)
|
||||
|
||||
self.top = self.top_window.get_widget("placeEditor")
|
||||
self.iconlist = self.top_window.get_widget('iconlist')
|
||||
title_label = self.top_window.get_widget('title')
|
||||
@ -158,7 +166,7 @@ class EditPlace(DisplayState.ManagedWindow):
|
||||
self.country.set_text(mloc.get_country())
|
||||
self.longitude.set_text(place.get_longitude())
|
||||
self.latitude.set_text(place.get_latitude())
|
||||
self.refinfo = self.top_window.get_widget("refinfo")
|
||||
self.plist = self.top_window.get_widget("plist")
|
||||
self.slist = self.top_window.get_widget("slist")
|
||||
self.sources_label = self.top_window.get_widget("sourcesPlaceEdit")
|
||||
self.names_label = self.top_window.get_widget("namesPlaceEdit")
|
||||
@ -188,26 +196,23 @@ class EditPlace(DisplayState.ManagedWindow):
|
||||
else:
|
||||
Utils.unbold_label(self.gallery_label)
|
||||
|
||||
self.top_window.signal_autoconnect({
|
||||
"on_switch_page" : self.on_switch_page,
|
||||
"on_addphoto_clicked" : self.glry.on_add_media_clicked,
|
||||
"on_selectphoto_clicked" : self.glry.on_select_media_clicked,
|
||||
"on_deletephoto_clicked" : self.glry.on_delete_media_clicked,
|
||||
"on_edit_photo_clicked" : self.glry.on_edit_media_clicked,
|
||||
"on_edit_properties_clicked": self.glry.popup_change_description,
|
||||
"on_add_url_clicked" : self.on_add_url_clicked,
|
||||
"on_delete_url_clicked" : self.on_delete_url_clicked,
|
||||
"on_update_url_clicked" : self.on_update_url_clicked,
|
||||
"on_add_loc_clicked" : self.on_add_loc_clicked,
|
||||
"on_delete_loc_clicked" : self.on_delete_loc_clicked,
|
||||
"on_update_loc_clicked" : self.on_update_loc_clicked,
|
||||
"on_web_go_clicked" : self.on_web_go_clicked,
|
||||
"on_help_clicked" : self.on_help_clicked,
|
||||
"on_delete_event" : self.on_delete_event,
|
||||
"on_cancel_clicked" : self.close,
|
||||
"on_apply_clicked" : self.on_place_apply_clicked,
|
||||
})
|
||||
|
||||
self.gladeif.connect('placeEditor', 'delete_event', self.on_delete_event)
|
||||
self.gladeif.connect('button127', 'clicked', self.close)
|
||||
self.gladeif.connect('ok', 'clicked', self.on_place_apply_clicked)
|
||||
self.gladeif.connect('button135', 'clicked', self.on_help_clicked)
|
||||
self.gladeif.connect('notebook3', 'switch_page', self.on_switch_page)
|
||||
self.gladeif.connect('add_name', 'clicked', self.on_add_loc_clicked)
|
||||
self.gladeif.connect('loc_edit', 'clicked', self.on_update_loc_clicked)
|
||||
self.gladeif.connect('del_name', 'clicked', self.on_delete_loc_clicked)
|
||||
self.gladeif.connect('add_photo', 'clicked', self.glry.on_add_media_clicked)
|
||||
self.gladeif.connect('sel_photo', 'clicked', self.glry.on_select_media_clicked)
|
||||
self.gladeif.connect('button134', 'clicked', self.glry.on_edit_media_clicked)
|
||||
self.gladeif.connect('delete_photo', 'clicked', self.glry.on_delete_media_clicked)
|
||||
self.gladeif.connect('add_url', 'clicked', self.on_add_url_clicked)
|
||||
self.gladeif.connect('web_edit', 'clicked', self.on_update_url_clicked)
|
||||
self.gladeif.connect('web_go', 'clicked', self.on_web_go_clicked)
|
||||
self.gladeif.connect('del_url', 'clicked', self.on_delete_url_clicked)
|
||||
|
||||
self.sourcetab = Sources.SourceTab(
|
||||
self.srcreflist,self,
|
||||
self.top_window,self.top,self.slist,
|
||||
@ -228,7 +233,8 @@ class EditPlace(DisplayState.ManagedWindow):
|
||||
gtk.gdk.ACTION_COPY)
|
||||
self.web_list.connect('drag_data_get',
|
||||
self.url_source_drag_data_get)
|
||||
self.web_list.connect('drag_data_received',
|
||||
if not self.db.readonly:
|
||||
self.web_list.connect('drag_data_received',
|
||||
self.url_dest_drag_data_received)
|
||||
|
||||
for name in ['del_name','add_name','sel_photo','add_url','del_url']:
|
||||
@ -251,7 +257,8 @@ class EditPlace(DisplayState.ManagedWindow):
|
||||
|
||||
if self.ref_not_loaded:
|
||||
Utils.temp_label(self.refs_label,self.top)
|
||||
gobject.idle_add(self.display_references)
|
||||
self.cursor_type = None
|
||||
self.idle = gobject.idle_add(self.display_references)
|
||||
self.ref_not_loaded = False
|
||||
|
||||
def build_pdmap(self):
|
||||
@ -265,19 +272,25 @@ class EditPlace(DisplayState.ManagedWindow):
|
||||
cursor.close()
|
||||
|
||||
def on_delete_event(self,obj,b):
|
||||
self.gladeif.close()
|
||||
self.glry.close()
|
||||
self.remove_itself_from_menu()
|
||||
gc.collect()
|
||||
|
||||
def close(self,obj):
|
||||
self.glry.close()
|
||||
self.gladeif.close()
|
||||
self.top.destroy()
|
||||
if self.idle != None:
|
||||
gobject.source_remove(self.idle)
|
||||
gc.collect()
|
||||
|
||||
def present(self,obj):
|
||||
self.top.present()
|
||||
|
||||
def on_help_clicked(self,obj):
|
||||
"""Display the relevant portion of GRAMPS manual"""
|
||||
gnome.help_display('gramps-manual','adv-plc')
|
||||
GrampsDisplay.help('adv-plc')
|
||||
|
||||
def build_columns(self,tree,list):
|
||||
cnum = 0
|
||||
@ -338,9 +351,9 @@ class EditPlace(DisplayState.ManagedWindow):
|
||||
Utils.unbold_label(self.names_label)
|
||||
|
||||
def on_web_go_clicked(self,obj):
|
||||
text = obj.get()
|
||||
text = self.web_url.get()
|
||||
if text != "":
|
||||
gnome.url_show(text)
|
||||
GrampsDisplay.url(text)
|
||||
|
||||
def set(self,field,getf,setf):
|
||||
text = unicode(field.get_text())
|
||||
@ -404,7 +417,7 @@ class EditPlace(DisplayState.ManagedWindow):
|
||||
elif page == 6 and self.ref_not_loaded:
|
||||
self.ref_not_loaded = False
|
||||
Utils.temp_label(self.refs_label,self.top)
|
||||
gobject.idle_add(self.display_references)
|
||||
self.idle = gobject.idle_add(self.display_references)
|
||||
text = unicode(self.note_buffer.get_text(self.note_buffer.get_start_iter(),
|
||||
self.note_buffer.get_end_iter(),False))
|
||||
if text:
|
||||
@ -433,12 +446,12 @@ class EditPlace(DisplayState.ManagedWindow):
|
||||
LocEdit.LocationEditor(self,loc,self.top)
|
||||
|
||||
def on_delete_url_clicked(self,obj):
|
||||
if Utils.delete_selected(obj,self.ulist):
|
||||
if Utils.delete_selected(self.web_list,self.ulist):
|
||||
self.lists_changed = 1
|
||||
self.redraw_url_list()
|
||||
|
||||
def on_delete_loc_clicked(self,obj):
|
||||
if Utils.delete_selected(obj,self.llist):
|
||||
if Utils.delete_selected(self.loc_list,self.llist):
|
||||
self.lists_changed = 1
|
||||
self.redraw_location_list()
|
||||
|
||||
@ -492,64 +505,110 @@ class EditPlace(DisplayState.ManagedWindow):
|
||||
self.loc_parish.set_text(loc.get_parish())
|
||||
self.loc_country.set_text(loc.get_country())
|
||||
|
||||
def button_press(self,obj):
|
||||
data = self.model.get_selected_objects()
|
||||
if not data:
|
||||
return
|
||||
(data_type,handle) = data[0]
|
||||
import EventEdit
|
||||
event = self.db.get_event_from_handle(handle)
|
||||
event_name = event.get_name()
|
||||
if data_type == 0:
|
||||
if event_name in ["Birth","Death"]:
|
||||
EventEdit.PersonEventEditor(
|
||||
self,", ", event, None, 1, None, None, self.db.readonly)
|
||||
else:
|
||||
EventEdit.PersonEventEditor(
|
||||
self,", ", event, None, 0, None, None, self.db.readonly)
|
||||
elif data_type == 1:
|
||||
EventEdit.FamilyEventEditor(
|
||||
self,", ", event, None, 0, None, None, self.db.readonly)
|
||||
|
||||
def display_references(self):
|
||||
pevent = []
|
||||
fevent = []
|
||||
msg = ""
|
||||
for key in self.db.get_person_handles(sort_handles=False):
|
||||
p = self.db.get_person_from_handle(key)
|
||||
place_handle = self.place.get_handle()
|
||||
# Initialize things if we're entering this functioin
|
||||
# for the first time
|
||||
if not self.cursor_type:
|
||||
self.cursor_type = 'Person'
|
||||
self.cursor = self.db.get_person_cursor()
|
||||
self.data = self.cursor.first()
|
||||
|
||||
self.any_refs = False
|
||||
titles = [(_('Type'),0,150),(_('Name'),1,150),
|
||||
(_('ID'),2,75),(_('Event Name'),3,150)]
|
||||
self.model = ListModel.ListModel(self.plist,
|
||||
titles,
|
||||
event_func=self.button_press)
|
||||
|
||||
if self.cursor_type == 'Person':
|
||||
while self.data:
|
||||
handle,val = self.data
|
||||
person = RelLib.Person()
|
||||
person.unserialize(val)
|
||||
for event_handle in [person.get_birth_handle(),
|
||||
person.get_death_handle()] \
|
||||
+ person.get_event_list():
|
||||
event = self.db.get_event_from_handle(event_handle)
|
||||
if event and event.get_place_handle() == place_handle:
|
||||
pname = self.name_display(person)
|
||||
gramps_id = person.get_gramps_id()
|
||||
ename = event.get_name()
|
||||
self.model.add(
|
||||
[_("Personal Event"),pname,gramps_id,ename],
|
||||
(0,event_handle))
|
||||
self.any_refs = True
|
||||
self.data = self.cursor.next()
|
||||
if gtk.events_pending():
|
||||
return True
|
||||
self.cursor.close()
|
||||
|
||||
ref_list = [p.get_birth_ref(), p.get_death_ref()] + p.get_event_ref_list()
|
||||
ref_list = [ ref for ref in ref_list if ref ]
|
||||
|
||||
for event_ref in ref_list:
|
||||
event = self.db.get_event_from_handle(event_ref.ref)
|
||||
if event and event.get_place_handle() == self.place.get_handle():
|
||||
pevent.append((p,event))
|
||||
|
||||
for family_handle in self.db.get_family_handles():
|
||||
f = self.db.get_family_from_handle(family_handle)
|
||||
self.cursor_type = 'Family'
|
||||
self.cursor = self.db.get_family_cursor()
|
||||
self.data = self.cursor.first()
|
||||
|
||||
for event_ref in f.get_event_ref_list():
|
||||
event = self.db.get_event_from_handle(event_ref.ref)
|
||||
if event and event.get_place_handle() == self.place.get_handle():
|
||||
fevent.append((f,event))
|
||||
if self.cursor_type == 'Family':
|
||||
while self.data:
|
||||
handle,val = self.data
|
||||
family = RelLib.Family()
|
||||
family.unserialize(val)
|
||||
for event_handle in family.get_event_list():
|
||||
event = self.db.get_event_from_handle(event_handle)
|
||||
if event and event.get_place_handle() == place_handle:
|
||||
father = family.get_father_handle()
|
||||
mother = family.get_mother_handle()
|
||||
if father and mother:
|
||||
fname = _("%(father)s and %(mother)s") % {
|
||||
"father" : self.name_display(
|
||||
self.db.get_person_from_handle(father)),
|
||||
"mother" : self.name_display(
|
||||
self.db.get_person_from_handle(mother))
|
||||
}
|
||||
elif father:
|
||||
fname = self.name_display(
|
||||
self.db.get_person_from_handle(father))
|
||||
else:
|
||||
fname = self.name_display(
|
||||
self.db.get_person_from_handle(mother))
|
||||
|
||||
any = 0
|
||||
if len(pevent) > 0:
|
||||
any = 1
|
||||
msg = msg + _("People") + "\n"
|
||||
msg = msg + "_________________________\n\n"
|
||||
t = _("%s [%s]: event %s\n")
|
||||
gramps_id = family.get_gramps_id()
|
||||
ename = event.get_name()
|
||||
self.model.add(
|
||||
[_("Family Event"),fname,gramps_id,ename],
|
||||
(1,event_handle))
|
||||
self.any_refs = True
|
||||
self.data = self.cursor.next()
|
||||
if gtk.events_pending():
|
||||
return True
|
||||
self.cursor.close()
|
||||
|
||||
for e in pevent:
|
||||
msg = msg + ( t % (self.name_display(e[0]),e[0].get_gramps_id(),_(e[1].get_type())))
|
||||
|
||||
if len(fevent) > 0:
|
||||
any = 1
|
||||
msg = msg + "\n%s\n" % _("Families")
|
||||
msg = msg + "_________________________\n\n"
|
||||
t = _("%s [%s]: event %s\n")
|
||||
|
||||
for e in fevent:
|
||||
father = e[0].get_father_handle()
|
||||
mother = e[0].get_mother_handle()
|
||||
if father and mother:
|
||||
fname = _("%(father)s and %(mother)s") % {
|
||||
"father" : self.name_display( self.db.get_person_from_handle( father)),
|
||||
"mother" : self.name_display( self.db.get_person_from_handle( mother)) }
|
||||
elif father:
|
||||
fname = self.name_display( self.db.get_person_from_handle( father))
|
||||
else:
|
||||
fname = self.name_display( self.db.get_person_from_handle( mother))
|
||||
|
||||
msg = msg + ( t % (fname,e[0].get_gramps_id(),_(e[1].get_type())))
|
||||
|
||||
self.refinfo.get_buffer().set_text(msg)
|
||||
if any:
|
||||
if self.any_refs:
|
||||
Utils.bold_label(self.refs_label,self.top)
|
||||
else:
|
||||
Utils.unbold_label(self.refs_label,self.top)
|
||||
|
||||
self.ref_not_loaded = 0
|
||||
self.cursor_type = None
|
||||
return False
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
|
@ -26,6 +26,7 @@
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
from gettext import gettext as _
|
||||
import gc
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -34,7 +35,6 @@ from gettext import gettext as _
|
||||
#-------------------------------------------------------------------------
|
||||
import gobject
|
||||
import gtk.glade
|
||||
import gnome
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -49,6 +49,8 @@ import RelLib
|
||||
import NameDisplay
|
||||
import RepositoryRefEdit
|
||||
import Spell
|
||||
import GrampsDisplay
|
||||
from WindowUtils import GladeIf
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -176,6 +178,7 @@ class EditSource:
|
||||
else:
|
||||
self.ref_not_loaded = 0
|
||||
self.db = dbstate.db
|
||||
self.idle = None
|
||||
self.name_display = NameDisplay.displayer.display
|
||||
# if source:
|
||||
# if parent and self.parent.child_windows.has_key(source.get_handle()):
|
||||
@ -194,6 +197,7 @@ class EditSource:
|
||||
|
||||
self.top_window = gtk.glade.XML(const.gladeFile,"sourceEditor","gramps")
|
||||
self.top = self.top_window.get_widget("sourceEditor")
|
||||
self.gladeif = GladeIf(self.top_window)
|
||||
|
||||
Utils.set_titles(self.top,self.top_window.get_widget('title'),
|
||||
_('Source Editor'))
|
||||
@ -261,26 +265,17 @@ class EditSource:
|
||||
else:
|
||||
Utils.unbold_label(self.gallery_label)
|
||||
|
||||
self.top_window.signal_autoconnect({
|
||||
"on_switch_page" : self.on_switch_page,
|
||||
"on_addphoto_clicked" : self.gallery.on_add_media_clicked,
|
||||
"on_selectphoto_clicked" : self.gallery.on_select_media_clicked,
|
||||
"on_deletephoto_clicked" : self.gallery.on_delete_media_clicked,
|
||||
"on_editphoto_clicked" : self.gallery.on_edit_media_clicked,
|
||||
|
||||
"on_add_repos_ref_clicked" : self.on_add_repos_ref_clicked,
|
||||
"on_delete_repos_ref_clicked" : self.on_delete_repos_ref_clicked,
|
||||
"on_edit_repos_ref_clicked" : self.on_edit_repos_ref_clicked,
|
||||
"on_edit_repos_ref_row_activated" : self.on_edit_repos_ref_clicked,
|
||||
|
||||
"on_edit_properties_clicked": self.gallery.popup_change_description,
|
||||
"on_sourceEditor_help_clicked" : self.on_help_clicked,
|
||||
"on_sourceEditor_ok_clicked" : self.on_source_apply_clicked,
|
||||
"on_sourceEditor_cancel_clicked" : self.close,
|
||||
"on_sourceEditor_delete_event" : self.on_delete_event,
|
||||
"on_delete_data_clicked" : self.on_delete_data_clicked,
|
||||
"on_add_data_clicked" : self.on_add_data_clicked,
|
||||
})
|
||||
self.gladeif.connect('sourceEditor','delete_event',self.on_delete_event)
|
||||
self.gladeif.connect('button90','clicked',self.close)
|
||||
self.gladeif.connect('ok','clicked',self.on_source_apply_clicked)
|
||||
self.gladeif.connect('button166','clicked',self.on_help_clicked)
|
||||
self.gladeif.connect('notebook2','switch_page',self.on_switch_page)
|
||||
self.gladeif.connect('add_data','clicked',self.on_add_data_clicked)
|
||||
self.gladeif.connect('del_data','clicked',self.on_delete_data_clicked)
|
||||
self.gladeif.connect('add_photo','clicked',self.gallery.on_add_media_clicked)
|
||||
self.gladeif.connect('sel_photo','clicked',self.gallery.on_select_media_clicked)
|
||||
self.gladeif.connect('edit_photo','clicked',self.gallery.on_edit_media_clicked)
|
||||
self.gladeif.connect('delete_photo','clicked',self.gallery.on_delete_media_clicked)
|
||||
|
||||
if self.source.get_handle() == None or self.db.readonly:
|
||||
self.top_window.get_widget("edit_photo").set_sensitive(False)
|
||||
@ -328,8 +323,8 @@ class EditSource:
|
||||
if self.ref_not_loaded:
|
||||
self.ref_not_loaded = 0
|
||||
Utils.temp_label(self.refs_label,self.top)
|
||||
gobject.idle_add(self.display_references)
|
||||
|
||||
self.cursor_type = None
|
||||
self.idle = gobject.idle_add(self.display_references)
|
||||
self.data_sel = self.datalist.get_selection()
|
||||
|
||||
def on_add_data_clicked(self,widget):
|
||||
@ -377,16 +372,22 @@ class EditSource:
|
||||
def on_delete_event(self,obj,b):
|
||||
self.close_child_windows()
|
||||
self.remove_itself_from_menu()
|
||||
self.gladeif.close()
|
||||
gc.collect()
|
||||
|
||||
def on_help_clicked(self,obj):
|
||||
"""Display the relevant portion of GRAMPS manual"""
|
||||
gnome.help_display('gramps-manual','adv-src')
|
||||
GrampsDisplay.help('adv-src')
|
||||
|
||||
def close(self,obj):
|
||||
self.gallery.close()
|
||||
self.close_child_windows()
|
||||
self.remove_itself_from_menu()
|
||||
self.gladeif.close()
|
||||
self.top.destroy()
|
||||
if self.idle != None:
|
||||
gobject.source_remove(self.idle)
|
||||
gc.collect()
|
||||
|
||||
def close_child_windows(self):
|
||||
return
|
||||
@ -458,68 +459,148 @@ class EditSource:
|
||||
import EditPlace
|
||||
place = self.db.get_place_from_handle(handle)
|
||||
EditPlace.EditPlace(self.parent,place)
|
||||
elif data_type == 4:
|
||||
source = self.db.get_source_from_handle(handle)
|
||||
EditSource(source,self.db,self.parent,None,self.db.readonly)
|
||||
elif data_type == 5:
|
||||
import ImageSelect
|
||||
media = self.db.get_object_from_handle(handle)
|
||||
ImageSelect.GlobalMediaProperties(self.db,media,self)
|
||||
|
||||
def display_references(self):
|
||||
|
||||
(person_list,family_list,event_list,
|
||||
place_list,source_list,media_list
|
||||
) = Utils.get_source_referents(self.source.get_handle(),self.db)
|
||||
source_handle = self.source.get_handle()
|
||||
|
||||
any = person_list or family_list or event_list \
|
||||
or place_list or source_list or media_list
|
||||
# Initialize things if we're entering this functioin
|
||||
# for the first time
|
||||
if not self.cursor_type:
|
||||
self.cursor_type = 'Person'
|
||||
self.cursor = self.db.get_person_cursor()
|
||||
self.data = self.cursor.first()
|
||||
|
||||
slist = self.top_window.get_widget('slist')
|
||||
self.any_refs = False
|
||||
slist = self.top_window.get_widget('slist')
|
||||
titles = [(_('Type'),0,150),(_('ID'),1,75),(_('Name'),2,150)]
|
||||
self.model = ListModel.ListModel(slist,
|
||||
titles,
|
||||
event_func=self.button_press)
|
||||
|
||||
titles = [(_('Type'),0,150),(_('ID'),1,75),(_('Name'),2,150)]
|
||||
|
||||
self.model = ListModel.ListModel(slist,titles,event_func=self.button_press)
|
||||
if self.cursor_type == 'Person':
|
||||
while self.data:
|
||||
handle,val = self.data
|
||||
person = RelLib.Person()
|
||||
person.unserialize(val)
|
||||
if person.has_source_reference(source_handle):
|
||||
name = self.name_display(person)
|
||||
gramps_id = person.get_gramps_id()
|
||||
self.model.add([_("Person"),gramps_id,name],(0,handle))
|
||||
self.any_refs = True
|
||||
self.data = self.cursor.next()
|
||||
if gtk.events_pending():
|
||||
return True
|
||||
self.cursor.close()
|
||||
|
||||
self.cursor_type = 'Family'
|
||||
self.cursor = self.db.get_family_cursor()
|
||||
self.data = self.cursor.first()
|
||||
|
||||
for handle in person_list:
|
||||
person = self.db.get_person_from_handle(handle)
|
||||
name = self.name_display(person)
|
||||
gramps_id = person.get_gramps_id()
|
||||
self.model.add([_("Person"),gramps_id,name],(0,handle))
|
||||
if self.cursor_type == 'Family':
|
||||
while self.data:
|
||||
handle,val = self.data
|
||||
family = RelLib.Family()
|
||||
family.unserialize(val)
|
||||
if family.has_source_reference(source_handle):
|
||||
name = Utils.family_name(family,self.db)
|
||||
gramps_id = family.get_gramps_id()
|
||||
self.model.add([_("Family"),gramps_id,name],(1,handle))
|
||||
self.any_refs = True
|
||||
self.data = self.cursor.next()
|
||||
if gtk.events_pending():
|
||||
return True
|
||||
self.cursor.close()
|
||||
|
||||
self.cursor_type = 'Event'
|
||||
self.cursor = self.db.get_event_cursor()
|
||||
self.data = self.cursor.first()
|
||||
|
||||
for handle in family_list:
|
||||
family = self.db.get_family_from_handle(handle)
|
||||
name = Utils.family_name(family,self.db)
|
||||
gramps_id = family.get_gramps_id()
|
||||
self.model.add([_("Family"),gramps_id,name],(1,handle))
|
||||
if self.cursor_type == 'Event':
|
||||
while self.data:
|
||||
handle,val = self.data
|
||||
event = RelLib.Event()
|
||||
event.unserialize(val)
|
||||
if event.has_source_reference(source_handle):
|
||||
name = event.get_name()
|
||||
gramps_id = event.get_gramps_id()
|
||||
self.model.add([_("Event"),gramps_id,name],(2,handle))
|
||||
self.any_refs = True
|
||||
self.data = self.cursor.next()
|
||||
if gtk.events_pending():
|
||||
return True
|
||||
self.cursor.close()
|
||||
|
||||
self.cursor_type = 'Place'
|
||||
self.cursor = self.db.get_place_cursor()
|
||||
self.data = self.cursor.first()
|
||||
|
||||
for handle in event_list:
|
||||
event = self.db.get_event_from_handle(handle)
|
||||
name = event.get_name()
|
||||
gramps_id = event.get_gramps_id()
|
||||
self.model.add([_("Event"),gramps_id,name],(2,handle))
|
||||
if self.cursor_type == 'Place':
|
||||
while self.data:
|
||||
handle,val = self.data
|
||||
place = RelLib.Place()
|
||||
place.unserialize(val)
|
||||
if place.has_source_reference(source_handle):
|
||||
name = place.get_title()
|
||||
gramps_id = place.get_gramps_id()
|
||||
self.model.add([_("Place"),gramps_id,name],(3,handle))
|
||||
self.any_refs = True
|
||||
self.data = self.cursor.next()
|
||||
if gtk.events_pending():
|
||||
return True
|
||||
self.cursor.close()
|
||||
|
||||
self.cursor_type = 'Source'
|
||||
self.cursor = self.db.get_source_cursor()
|
||||
self.data = self.cursor.first()
|
||||
|
||||
for handle in place_list:
|
||||
place = self.db.get_place_from_handle(handle)
|
||||
name = place.get_title()
|
||||
gramps_id = place.get_gramps_id()
|
||||
self.model.add([_("Place"),gramps_id,name],(3,handle))
|
||||
if self.cursor_type == 'Source':
|
||||
while self.data:
|
||||
handle,val = self.data
|
||||
source = RelLib.Source()
|
||||
source.unserialize(val)
|
||||
if source.has_source_reference(source_handle):
|
||||
name = source.get_title()
|
||||
gramps_id = source.get_gramps_id()
|
||||
self.model.add([_("Source"),gramps_id,name],(4,handle))
|
||||
self.any_refs = True
|
||||
self.data = self.cursor.next()
|
||||
if gtk.events_pending():
|
||||
return True
|
||||
self.cursor.close()
|
||||
|
||||
self.cursor_type = 'Media'
|
||||
self.cursor = self.db.get_media_cursor()
|
||||
self.data = self.cursor.first()
|
||||
|
||||
for handle in source_list:
|
||||
source = self.db.get_source_from_handle(handle)
|
||||
name = source.get_title()
|
||||
gramps_id = source.get_gramps_id()
|
||||
self.model.add([_("Source"),gramps_id,name],(4,handle))
|
||||
if self.cursor_type == 'Media':
|
||||
while self.data:
|
||||
handle,val = self.data
|
||||
obj = RelLib.MediaObject()
|
||||
obj.unserialize(val)
|
||||
if obj.has_source_reference(source_handle):
|
||||
name = obj.get_description()
|
||||
gramps_id = obj.get_gramps_id()
|
||||
self.model.add([_("Media"),gramps_id,name],(5,handle))
|
||||
self.any_refs = True
|
||||
self.data = self.cursor.next()
|
||||
if gtk.events_pending():
|
||||
return True
|
||||
self.cursor.close()
|
||||
|
||||
for handle in media_list:
|
||||
media = self.db.get_object_from_handle(handle)
|
||||
name = media.get_description()
|
||||
gramps_id = media.get_gramps_id()
|
||||
self.model.add([_("Media"),gramps_id,name],(5,handle))
|
||||
|
||||
if any:
|
||||
if self.any_refs:
|
||||
Utils.bold_label(self.refs_label,self.top)
|
||||
else:
|
||||
Utils.unbold_label(self.refs_label,self.top)
|
||||
|
||||
self.ref_not_loaded = 0
|
||||
self.cursor_type = None
|
||||
return False
|
||||
|
||||
def on_source_apply_clicked(self,obj):
|
||||
|
||||
@ -527,8 +608,10 @@ class EditSource:
|
||||
author = unicode(self.author.get_text())
|
||||
pubinfo = unicode(self.pubinfo.get_text())
|
||||
abbrev = unicode(self.abbrev.get_text())
|
||||
note = unicode(self.notes_buffer.get_text(self.notes_buffer.get_start_iter(),
|
||||
self.notes_buffer.get_end_iter(),False))
|
||||
note = unicode(
|
||||
self.notes_buffer.get_text(self.notes_buffer.get_start_iter(),
|
||||
self.notes_buffer.get_end_iter(),
|
||||
False))
|
||||
format = self.preform.get_active()
|
||||
|
||||
if author != self.source.get_author():
|
||||
@ -584,9 +667,12 @@ class EditSource:
|
||||
elif page == 3 and self.ref_not_loaded:
|
||||
self.ref_not_loaded = 0
|
||||
Utils.temp_label(self.refs_label,self.top)
|
||||
gobject.idle_add(self.display_references)
|
||||
text = unicode(self.notes_buffer.get_text(self.notes_buffer.get_start_iter(),
|
||||
self.notes_buffer.get_end_iter(),False))
|
||||
self.idle = gobject.idle_add(self.display_references)
|
||||
text = unicode(
|
||||
self.notes_buffer.get_text(self.notes_buffer.get_start_iter(),
|
||||
self.notes_buffer.get_end_iter(),
|
||||
False)
|
||||
)
|
||||
if text:
|
||||
Utils.bold_label(self.notes_label,self.top)
|
||||
else:
|
||||
|
@ -27,6 +27,8 @@
|
||||
#-------------------------------------------------------------------------
|
||||
from gettext import gettext as _
|
||||
import sets
|
||||
import gc
|
||||
from cgi import escape
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -35,7 +37,6 @@ import sets
|
||||
#-------------------------------------------------------------------------
|
||||
import gtk
|
||||
import gtk.glade
|
||||
import gnome
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -53,8 +54,10 @@ from DateHandler import parser as _dp, displayer as _dd
|
||||
import ImageSelect
|
||||
import DateEdit
|
||||
import Spell
|
||||
import GrampsDisplay
|
||||
|
||||
from QuestionDialog import WarningDialog, ErrorDialog
|
||||
from WindowUtils import GladeIf
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -133,6 +136,7 @@ class EventEditor:
|
||||
self.date = Date.Date(None)
|
||||
|
||||
self.top = gtk.glade.XML(const.dialogFile, "event_edit","gramps")
|
||||
self.gladeif = GladeIf(self.top)
|
||||
|
||||
self.window = self.top.get_widget("event_edit")
|
||||
title_label = self.top.get_widget('title')
|
||||
@ -230,10 +234,11 @@ class EventEditor:
|
||||
Utils.bold_label(self.gallery_label)
|
||||
else:
|
||||
event = RelLib.Event()
|
||||
|
||||
date_stat = self.top.get_widget("date_stat")
|
||||
date_stat.set_sensitive(not self.db.readonly)
|
||||
self.date_check = DateEdit.DateEdit(self.date,
|
||||
self.date_field,
|
||||
self.top.get_widget("date_stat"),
|
||||
date_stat,
|
||||
self.window)
|
||||
|
||||
self.icon_list = self.top.get_widget("iconlist")
|
||||
@ -241,18 +246,15 @@ class EventEditor:
|
||||
self.path, self.icon_list,
|
||||
self.db,self,self.window)
|
||||
|
||||
self.top.signal_autoconnect({
|
||||
"on_switch_page" : self.on_switch_page,
|
||||
"on_help_event_clicked" : self.on_help_clicked,
|
||||
"on_ok_event_clicked" : self.on_event_edit_ok_clicked,
|
||||
"on_cancel_event_clicked" : self.close,
|
||||
"on_event_edit_delete_event": self.on_delete_event,
|
||||
"on_addphoto_clicked" : self.gallery.on_add_media_clicked,
|
||||
"on_selectphoto_clicked" : self.gallery.on_select_media_clicked,
|
||||
"on_deletephoto_clicked" : self.gallery.on_delete_media_clicked,
|
||||
"on_edit_properties_clicked": self.gallery.popup_change_description,
|
||||
"on_editphoto_clicked" : self.gallery.on_edit_media_clicked,
|
||||
})
|
||||
self.gladeif.connect('event_edit','delete_event',self.on_delete_event)
|
||||
self.gladeif.connect('button111','clicked',self.close)
|
||||
self.gladeif.connect('ok','clicked',self.on_event_edit_ok_clicked)
|
||||
self.gladeif.connect('button126','clicked',self.on_help_clicked)
|
||||
self.gladeif.connect('notebook','switch_page',self.on_switch_page)
|
||||
self.gladeif.connect('add_obj','clicked',self.gallery.on_add_media_clicked)
|
||||
self.gladeif.connect('sel_obj','clicked',self.gallery.on_select_media_clicked)
|
||||
self.gladeif.connect('button172','clicked',self.gallery.on_edit_media_clicked)
|
||||
self.gladeif.connect('del_obj','clicked',self.gallery.on_delete_media_clicked)
|
||||
|
||||
self.top.get_widget('del_obj').set_sensitive(not noedit)
|
||||
self.top.get_widget('sel_obj').set_sensitive(not noedit)
|
||||
@ -268,15 +270,19 @@ class EventEditor:
|
||||
self.window.show()
|
||||
|
||||
def on_delete_event(self,obj,b):
|
||||
self.gladeif.close()
|
||||
self.gallery.close()
|
||||
self.close_child_windows()
|
||||
self.remove_itself_from_menu()
|
||||
gc.collect()
|
||||
|
||||
def close(self,obj):
|
||||
self.gladeif.close()
|
||||
self.gallery.close()
|
||||
self.close_child_windows()
|
||||
self.remove_itself_from_menu()
|
||||
self.window.destroy()
|
||||
gc.collect()
|
||||
|
||||
def close_child_windows(self):
|
||||
return
|
||||
@ -322,7 +328,7 @@ class EventEditor:
|
||||
|
||||
def on_help_clicked(self,obj):
|
||||
"""Display the relevant portion of GRAMPS manual"""
|
||||
gnome.help_display('gramps-manual','adv-ev')
|
||||
GrampsDisplay.help('adv-ev')
|
||||
|
||||
def on_event_edit_ok_clicked(self,obj):
|
||||
|
||||
|
@ -48,30 +48,38 @@ import NameDisplay
|
||||
import ListModel
|
||||
import PluginMgr
|
||||
import DateHandler
|
||||
import PeopleModel
|
||||
import Tool
|
||||
|
||||
column_names = [
|
||||
_('Name'),
|
||||
_('ID') ,
|
||||
_('Gender'),
|
||||
_('Birth Date'),
|
||||
_('Birth Place'),
|
||||
_('Death Date'),
|
||||
_('Death Place'),
|
||||
_('Spouse'),
|
||||
_('Last Change'),
|
||||
_('Cause of Death'),
|
||||
]
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
#
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
def runTool(database,person,callback,parent=None):
|
||||
RelCalc(database,person,parent)
|
||||
class RelCalc(Tool.Tool):
|
||||
def __init__(self,db,person,options_class,name,callback=None,parent=None):
|
||||
Tool.Tool.__init__(self,db,person,options_class,name)
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
#
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
class RelCalc:
|
||||
"""
|
||||
Relationship calculator class.
|
||||
"""
|
||||
"""
|
||||
Relationship calculator class.
|
||||
"""
|
||||
|
||||
def __init__(self,database,person,parent):
|
||||
self.person = person
|
||||
self.db = database
|
||||
self.RelClass = PluginMgr.relationship_class
|
||||
self.relationship = self.RelClass(database)
|
||||
self.relationship = self.RelClass(self.db)
|
||||
self.parent = parent
|
||||
self.win_key = self
|
||||
|
||||
@ -90,40 +98,34 @@ class RelCalc:
|
||||
'person_name' : name },
|
||||
self.title)
|
||||
|
||||
self.people = self.glade.get_widget("peopleList")
|
||||
self.tree = self.glade.get_widget("peopleList")
|
||||
|
||||
self.model = PeopleModel.PeopleModel(self.db)
|
||||
self.tree.set_model(self.model)
|
||||
|
||||
self.clist = ListModel.ListModel(self.people,
|
||||
[(_('Name'),3,150),(_('Gender'),1,50),
|
||||
(_('Birth Date'),4,150),
|
||||
('',-1,0),('',-1,0)],
|
||||
self.on_apply_clicked)
|
||||
self.clist.new_model()
|
||||
for key in self.db.get_person_handles(sort_handles=False):
|
||||
p = self.db.get_person_from_handle(key)
|
||||
if p == self.person:
|
||||
column = gtk.TreeViewColumn(_('Name'), gtk.CellRendererText(),text=0)
|
||||
column.set_resizable(True)
|
||||
column.set_min_width(225)
|
||||
column.set_sizing(gtk.TREE_VIEW_COLUMN_FIXED)
|
||||
self.tree.append_column(column)
|
||||
|
||||
index = 1
|
||||
for pair in self.db.get_person_column_order():
|
||||
if not pair[0]:
|
||||
continue
|
||||
bh = p.get_birth_handle()
|
||||
if bh:
|
||||
bdate = DateHandler.get_date(self.db.get_event_from_handle(bh))
|
||||
else:
|
||||
bdate = ""
|
||||
name = p.get_primary_name()
|
||||
if p.get_gender() == RelLib.Person.MALE:
|
||||
gender = _("male")
|
||||
elif p.get_gender() == RelLib.Person.FEMALE:
|
||||
gender = _("female")
|
||||
else:
|
||||
gender = _("unknown")
|
||||
self.clist.add([name.get_name(), gender, bdate,
|
||||
name.get_sort_name(), bdate],
|
||||
p.get_handle())
|
||||
name = column_names[pair[1]]
|
||||
column = gtk.TreeViewColumn(name, gtk.CellRendererText(), markup=pair[1])
|
||||
column.set_resizable(True)
|
||||
column.set_min_width(60)
|
||||
column.set_sizing(gtk.TREE_VIEW_COLUMN_GROW_ONLY)
|
||||
self.tree.append_column(column)
|
||||
index += 1
|
||||
|
||||
self.clist.connect_model()
|
||||
self.tree.get_selection().connect('changed',self.on_apply_clicked)
|
||||
|
||||
self.glade.signal_autoconnect({
|
||||
"on_close_clicked" : self.close,
|
||||
"on_delete_event" : self.on_delete_event,
|
||||
"on_apply_clicked" : self.on_apply_clicked
|
||||
})
|
||||
|
||||
self.add_itself_to_menu()
|
||||
@ -151,17 +153,22 @@ class RelCalc:
|
||||
self.window.present()
|
||||
|
||||
def on_apply_clicked(self,obj):
|
||||
model,node = self.clist.get_selected()
|
||||
model,node = self.tree.get_selection().get_selected()
|
||||
if not node:
|
||||
return
|
||||
|
||||
handle = self.clist.get_object(node)
|
||||
handle = model.get_value(node,len(PeopleModel.COLUMN_DEFS)-1)
|
||||
other_person = self.db.get_person_from_handle(handle)
|
||||
|
||||
(rel_string,common) = self.relationship.get_relationship(self.person,other_person)
|
||||
length = len(common)
|
||||
if other_person != None:
|
||||
(rel_string,common) = self.relationship.get_relationship(self.person,other_person)
|
||||
length = len(common)
|
||||
else:
|
||||
length = 0
|
||||
|
||||
if length == 1:
|
||||
if other_person == None:
|
||||
commontext = ""
|
||||
elif length == 1:
|
||||
person = self.db.get_person_from_handle(common[0])
|
||||
name = person.get_primary_name().get_regular_name()
|
||||
commontext = " " + _("Their common ancestor is %s.") % name
|
||||
@ -185,10 +192,16 @@ class RelCalc:
|
||||
commontext = ""
|
||||
|
||||
text1 = self.glade.get_widget("text1").get_buffer()
|
||||
p1 = NameDisplay.displayer.display(self.person)
|
||||
p2 = NameDisplay.displayer.display(other_person)
|
||||
|
||||
if rel_string == "":
|
||||
if other_person:
|
||||
p1 = NameDisplay.displayer.display(self.person)
|
||||
p2 = NameDisplay.displayer.display(other_person)
|
||||
|
||||
if other_person == None:
|
||||
rstr = ""
|
||||
elif self.person.handle == other_person.handle:
|
||||
rstr = _("%s and %s are the same person.") % (p1,p2)
|
||||
elif rel_string == "":
|
||||
rstr = _("%(person)s and %(active_person)s are not related.") % {
|
||||
'person' : p2, 'active_person' : p1 }
|
||||
else:
|
||||
@ -197,15 +210,33 @@ class RelCalc:
|
||||
|
||||
text1.set_text("%s %s" % (rstr, commontext))
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#------------------------------------------------------------------------
|
||||
#
|
||||
#
|
||||
#
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
#------------------------------------------------------------------------
|
||||
class RelCalcOptions(Tool.ToolOptions):
|
||||
"""
|
||||
Defines options and provides handling interface.
|
||||
"""
|
||||
|
||||
def __init__(self,name,person_id=None):
|
||||
Tool.ToolOptions.__init__(self,name,person_id)
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
#
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
PluginMgr.register_tool(
|
||||
runTool,
|
||||
_("Relationship calculator"),
|
||||
category=_("Utilities"),
|
||||
name = 'relcalc',
|
||||
category = Tool.TOOL_UTILS,
|
||||
tool_class = RelCalc,
|
||||
options_class = RelCalcOptions,
|
||||
modes = Tool.MODE_GUI,
|
||||
translated_name = _("Relationship calculator"),
|
||||
status=(_("Stable")),
|
||||
author_name = "Donald N. Allingham",
|
||||
author_email = "don@gramps-project.org",
|
||||
description=_("Calculates the relationship between two people")
|
||||
)
|
||||
|
Loading…
Reference in New Issue
Block a user