* src/edit_person.glade: re-add edit_person.glade

* src/EditPerson.py: start of new EditPerson dialog
* src/ListModel.py: enhancements for the start of inline editing
* src/Makefile.am: add edit_person.glade
* src/ReadXML.py: commit transactions properly
* src/const.py.in: add edit_person.glade back in


svn: r4375
This commit is contained in:
Don Allingham 2005-04-19 04:20:17 +00:00
parent 159d22fd2d
commit 4dfc846191
8 changed files with 3576 additions and 394 deletions

View File

@ -1,3 +1,11 @@
2005-04-18 Don Allingham <don@gramps-project.org>
* src/edit_person.glade: re-add edit_person.glade
* src/EditPerson.py: start of new EditPerson dialog
* src/ListModel.py: enhancements for the start of inline editing
* src/Makefile.am: add edit_person.glade
* src/ReadXML.py: commit transactions properly
* src/const.py.in: add edit_person.glade back in
2005-04-17 Don Allingham <don@gramps-project.org> 2005-04-17 Don Allingham <don@gramps-project.org>
* src/GrampsBSDDB.py: actually perform the commits during the * src/GrampsBSDDB.py: actually perform the commits during the
transaction_commit task, instead of the commit_* tasks transaction_commit task, instead of the commit_* tasks

View File

@ -77,8 +77,7 @@ _PICTURE_WIDTH = 200.0
_temple_names = const.lds_temple_codes.keys() _temple_names = const.lds_temple_codes.keys()
_temple_names.sort() _temple_names.sort()
_temple_names = [""] + _temple_names _temple_names = [""] + _temple_names
_select_gender = ((True,False,False),(False,True,False),(False,False,True))
_use_patronymic = [ _use_patronymic = [
"ru","RU","ru_RU","koi8r","ru_koi8r","russian","Russian", "ru","RU","ru_RU","koi8r","ru_koi8r","russian","Russian",
] ]
@ -134,12 +133,14 @@ class EditPerson:
self.window.set_title("%s - GRAMPS" % _('Edit Person')) self.window.set_title("%s - GRAMPS" % _('Edit Person'))
self.icon_list = self.top.get_widget("iconlist") self.icon_list = self.top.get_widget("iconlist")
self.gallery = ImageSelect.Gallery(person, self.db.commit_person, #self.gallery = ImageSelect.Gallery(person, self.db.commit_person,
self.path, self.icon_list, # self.path, self.icon_list,
self.db, self, self.window) # self.db, self, self.window)
self.complete = self.get_widget('complete') self.complete = self.get_widget('complete')
self.complete.set_sensitive(mod) self.complete.set_sensitive(mod)
self.gender = self.get_widget('gender')
self.gender.set_sensitive(mod)
self.private = self.get_widget('private') self.private = self.get_widget('private')
self.private.set_sensitive(mod) self.private.set_sensitive(mod)
self.name_delete_btn = self.top.get_widget('aka_delete') self.name_delete_btn = self.top.get_widget('aka_delete')
@ -147,7 +148,7 @@ class EditPerson:
self.web_delete_btn = self.top.get_widget('delete_url') self.web_delete_btn = self.top.get_widget('delete_url')
self.web_edit_btn = self.top.get_widget('edit_url') self.web_edit_btn = self.top.get_widget('edit_url')
self.event_delete_btn = self.top.get_widget('event_del') self.event_delete_btn = self.top.get_widget('event_del')
self.event_edit_btn = self.top.get_widget('event_edit_btn') self.event_edit_btn = self.top.get_widget('event_edit')
self.attr_delete_btn = self.top.get_widget('attr_del') self.attr_delete_btn = self.top.get_widget('attr_del')
self.attr_edit_btn = self.top.get_widget('attr_edit_btn') self.attr_edit_btn = self.top.get_widget('attr_edit_btn')
self.addr_delete_btn = self.top.get_widget('addr_del') self.addr_delete_btn = self.top.get_widget('addr_del')
@ -159,13 +160,6 @@ class EditPerson:
self.flowed.set_sensitive(mod) self.flowed.set_sensitive(mod)
self.preform = self.get_widget("preform") self.preform = self.get_widget("preform")
self.preform.set_sensitive(mod) self.preform.set_sensitive(mod)
self.event_name_field = self.get_widget("eventName")
self.event_place_field = self.get_widget("eventPlace")
self.event_cause_field = self.get_widget("eventCause")
self.event_date_field = self.get_widget("eventDate")
self.event_descr_field = self.get_widget("eventDescription")
self.event_src_field = self.get_widget("event_srcinfo")
self.event_conf_field = self.get_widget("event_conf")
self.attr_conf_field = self.get_widget("attr_conf") self.attr_conf_field = self.get_widget("attr_conf")
self.addr_conf_field = self.get_widget("addr_conf") self.addr_conf_field = self.get_widget("addr_conf")
self.name_conf_field = self.get_widget("name_conf") self.name_conf_field = self.get_widget("name_conf")
@ -204,26 +198,10 @@ class EditPerson:
self.prefix.set_editable(mod) self.prefix.set_editable(mod)
self.given = self.get_widget("givenName") self.given = self.get_widget("givenName")
self.given.set_editable(mod) self.given.set_editable(mod)
self.nick = self.get_widget("nickname")
self.nick.set_editable(mod)
self.title = self.get_widget("title") self.title = self.get_widget("title")
self.title.set_editable(mod) self.title.set_editable(mod)
self.bdate = self.get_widget("birthDate")
self.bdate.set_editable(mod)
self.bplace = self.get_widget("birth_place")
self.bplace.set_editable(mod)
self.surname = self.get_widget("surname") self.surname = self.get_widget("surname")
self.surname.set_editable(mod) self.surname.set_editable(mod)
self.ddate = self.get_widget("deathDate")
self.ddate.set_editable(mod)
self.dplace = self.get_widget("death_place")
self.dplace.set_editable(mod)
self.is_male = self.get_widget("genderMale")
self.is_male.set_sensitive(mod)
self.is_female = self.get_widget("genderFemale")
self.is_female.set_sensitive(mod)
self.is_unknown = self.get_widget("genderUnknown")
self.is_unknown.set_sensitive(mod)
self.addr_note = self.get_widget("addr_note") self.addr_note = self.get_widget("addr_note")
self.addr_source = self.get_widget("addr_source") self.addr_source = self.get_widget("addr_source")
self.attr_note = self.get_widget("attr_note") self.attr_note = self.get_widget("attr_note")
@ -235,7 +213,6 @@ class EditPerson:
self.slist = self.get_widget("slist") self.slist = self.get_widget("slist")
self.general_label = self.get_widget("general_label") self.general_label = self.get_widget("general_label")
self.names_label = self.get_widget("names_label") self.names_label = self.get_widget("names_label")
self.events_label = self.get_widget("events_label")
self.attr_label = self.get_widget("attr_label") self.attr_label = self.get_widget("attr_label")
self.addr_label = self.get_widget("addr_label") self.addr_label = self.get_widget("addr_label")
self.notes_label = self.get_widget("notes_label") self.notes_label = self.get_widget("notes_label")
@ -246,9 +223,6 @@ class EditPerson:
self.person_photo = self.get_widget("personPix") self.person_photo = self.get_widget("personPix")
self.eventbox = self.get_widget("eventbox1") self.eventbox = self.get_widget("eventbox1")
self.get_widget("birth_stat").set_sensitive(mod)
self.get_widget("death_stat").set_sensitive(mod)
self.prefix_label = self.get_widget('prefix_label') self.prefix_label = self.get_widget('prefix_label')
if self.use_patronymic: if self.use_patronymic:
@ -273,7 +247,13 @@ class EditPerson:
self.birth = RelLib.Event(self.orig_birth) self.birth = RelLib.Event(self.orig_birth)
self.pname = RelLib.Name(person.get_primary_name()) self.pname = RelLib.Name(person.get_primary_name())
self.elist = person.get_event_list()[:] self.gender.set_active(person.get_gender())
self.elist = []
for val in [birth_handle, death_handle] + person.get_event_list():
if val:
self.elist.append(val)
self.nlist = person.get_alternate_names()[:] self.nlist = person.get_alternate_names()[:]
self.alist = person.get_attribute_list()[:] self.alist = person.get_attribute_list()[:]
self.ulist = person.get_url_list()[:] self.ulist = person.get_url_list()[:]
@ -284,21 +264,19 @@ class EditPerson:
else: else:
self.srcreflist = [] self.srcreflist = []
Utils.bold_label(self.general_label) #Utils.bold_label(self.general_label)
if self.srcreflist: #if self.srcreflist:
Utils.bold_label(self.sources_label) # Utils.bold_label(self.sources_label)
if self.elist: #if self.nlist:
Utils.bold_label(self.events_label) # Utils.bold_label(self.names_label)
if self.nlist: #if self.alist:
Utils.bold_label(self.names_label) # Utils.bold_label(self.attr_label)
if self.alist: #if self.ulist:
Utils.bold_label(self.attr_label) # Utils.bold_label(self.inet_label)
if self.ulist: #if self.plist:
Utils.bold_label(self.inet_label) # Utils.bold_label(self.addr_label)
if self.plist: #if self.person.get_media_list():
Utils.bold_label(self.addr_label) # Utils.bold_label(self.gallery_label)
if self.person.get_media_list():
Utils.bold_label(self.gallery_label)
# event display # event display
@ -351,8 +329,6 @@ class EditPerson:
self.place_list = self.pdmap.keys() self.place_list = self.pdmap.keys()
self.place_list.sort() self.place_list.sort()
build_dropdown(self.bplace,self.place_list)
build_dropdown(self.dplace,self.place_list)
build_dropdown(self.surname,self.db.get_surname_list()) build_dropdown(self.surname,self.db.get_surname_list())
gid = person.get_gramps_id() gid = person.get_gramps_id()
@ -370,24 +346,16 @@ class EditPerson:
or (not self.lds_sealing.is_empty()): or (not self.lds_sealing.is_empty()):
self.get_widget("lds_tab").show() self.get_widget("lds_tab").show()
self.get_widget("lds_page").show() self.get_widget("lds_page").show()
if (not self.lds_baptism.is_empty()) \ #if (not self.lds_baptism.is_empty()) \
or (not self.lds_endowment.is_empty()) \ # or (not self.lds_endowment.is_empty()) \
or (not self.lds_sealing.is_empty()): # or (not self.lds_sealing.is_empty()):
Utils.bold_label(self.lds_tab) # Utils.bold_label(self.lds_tab)
types = const.NameTypesMap.get_values() types = const.NameTypesMap.get_values()
types.sort() types.sort()
AutoComp.fill_combo(self.ntype_field,types) AutoComp.fill_combo(self.ntype_field,types)
self.write_primary_name() self.write_primary_name()
if person.get_gender() == RelLib.Person.MALE:
self.is_male.set_active(1)
elif person.get_gender() == RelLib.Person.FEMALE:
self.is_female.set_active(1)
else:
self.is_unknown.set_active(1)
self.nick.set_text(person.get_nick_name())
self.load_person_image() self.load_person_image()
# set notes data # set notes data
@ -398,7 +366,7 @@ class EditPerson:
self.preform.set_active(1) self.preform.set_active(1)
else: else:
self.flowed.set_active(1) self.flowed.set_active(1)
Utils.bold_label(self.notes_label) #Utils.bold_label(self.notes_label)
self.name_list.drag_dest_set(gtk.DEST_DEFAULT_ALL, self.name_list.drag_dest_set(gtk.DEST_DEFAULT_ALL,
[DdTargets.NAME.target()], [DdTargets.NAME.target()],
@ -452,19 +420,6 @@ class EditPerson:
self.addr_list.connect('drag_data_received',self.ad_drag_data_received) self.addr_list.connect('drag_data_received',self.ad_drag_data_received)
self.addr_list.connect('drag_begin', self.ad_drag_begin) self.addr_list.connect('drag_begin', self.ad_drag_begin)
self.birth_date_object = self.birth.get_date_object()
self.death_date_object = self.death.get_date_object()
self.bdate_check = DateEdit.DateEdit(
self.birth_date_object, self.bdate,
self.get_widget("birth_stat"), self.window)
self.ddate_check = DateEdit.DateEdit(
self.death_date_object, self.ddate,
self.get_widget("death_stat"), self.window)
self.update_birth_death()
self.top.signal_autoconnect({ self.top.signal_autoconnect({
"destroy_passed_object" : self.on_cancel_edit, "destroy_passed_object" : self.on_cancel_edit,
"on_up_clicked" : self.on_up_clicked, "on_up_clicked" : self.on_up_clicked,
@ -473,8 +428,8 @@ class EditPerson:
"on_add_aka_clicked" : self.on_add_aka_clicked, "on_add_aka_clicked" : self.on_add_aka_clicked,
"on_add_attr_clicked" : self.on_add_attr_clicked, "on_add_attr_clicked" : self.on_add_attr_clicked,
"on_add_url_clicked" : self.on_add_url_clicked, "on_add_url_clicked" : self.on_add_url_clicked,
"on_addphoto_clicked" : self.gallery.on_add_media_clicked, # "on_addphoto_clicked" : self.gallery.on_add_media_clicked,
"on_selectphoto_clicked" : self.gallery.on_select_media_clicked, # "on_selectphoto_clicked" : self.gallery.on_select_media_clicked,
"on_aka_delete_clicked" : self.on_aka_delete_clicked, "on_aka_delete_clicked" : self.on_aka_delete_clicked,
"on_aka_update_clicked" : self.on_aka_update_clicked, "on_aka_update_clicked" : self.on_aka_update_clicked,
"on_apply_person_clicked" : self.on_apply_person_clicked, "on_apply_person_clicked" : self.on_apply_person_clicked,
@ -484,9 +439,9 @@ class EditPerson:
"on_delete_attr_clicked" : self.on_delete_attr_clicked, "on_delete_attr_clicked" : self.on_delete_attr_clicked,
"on_delete_event" : self.on_delete_event, "on_delete_event" : self.on_delete_event,
"on_delete_url_clicked" : self.on_delete_url_clicked, "on_delete_url_clicked" : self.on_delete_url_clicked,
"on_deletephoto_clicked" : self.gallery.on_delete_media_clicked, # "on_deletephoto_clicked" : self.gallery.on_delete_media_clicked,
"on_edit_properties_clicked": self.gallery.popup_change_description, # "on_edit_properties_clicked": self.gallery.popup_change_description,
"on_editphoto_clicked" : self.gallery.on_edit_media_clicked, # "on_editphoto_clicked" : self.gallery.on_edit_media_clicked,
"on_editperson_switch_page" : self.on_switch_page, "on_editperson_switch_page" : self.on_switch_page,
"on_event_add_clicked" : self.on_event_add_clicked, "on_event_add_clicked" : self.on_event_add_clicked,
"on_event_delete_clicked" : self.on_event_delete_clicked, "on_event_delete_clicked" : self.on_event_delete_clicked,
@ -523,11 +478,11 @@ class EditPerson:
self.redraw_name_list() self.redraw_name_list()
self.redraw_url_list() self.redraw_url_list()
self.get_widget("notebook").set_current_page(0) self.get_widget("notebook").set_current_page(0)
self.given.grab_focus() self.surname.grab_focus()
self.add_itself_to_winsmenu() self.add_itself_to_winsmenu()
for i in ["ok", "add_aka", "aka_delete", "event_del", for i in ["ok", "add_aka", "aka_delete", "event_add", "event_del",
"event_add", "attr_add", "attr_del", "addr_add", "attr_add", "attr_del", "addr_add",
"addr_del", "media_add", "media_sel", "media_del", "addr_del", "media_add", "media_sel", "media_del",
"add_url", "delete_url", "add_src", "del_src" ]: "add_url", "delete_url", "add_src", "del_src" ]:
self.get_widget(i).set_sensitive(not self.db.readonly) self.get_widget(i).set_sensitive(not self.db.readonly)
@ -609,7 +564,7 @@ class EditPerson:
if not self.db.readonly: if not self.db.readonly:
self.db.metadata['event_order'] = event_list self.db.metadata['event_order'] = event_list
self.gallery.close() #self.gallery.close()
self.close_child_windows() self.close_child_windows()
self.remove_itself_from_winsmenu() self.remove_itself_from_winsmenu()
self.window.destroy() self.window.destroy()
@ -645,7 +600,10 @@ class EditPerson:
def build_columns(self,tree,list): def build_columns(self,tree,list):
cnum = 0 cnum = 0
for name in list: for name in list:
renderer = gtk.CellRendererText() if cnum == 0:
renderer = gtk.CellRendererCombo()
else:
renderer = gtk.CellRendererText()
column = gtk.TreeViewColumn(name[0],renderer,text=cnum) column = gtk.TreeViewColumn(name[0],renderer,text=cnum)
column.set_min_width(name[1]) column.set_min_width(name[1])
cnum = cnum + 1 cnum = cnum + 1
@ -778,14 +736,6 @@ class EditPerson:
if not self.should_guess_gender: if not self.should_guess_gender:
return return
gender = self.db.genderStats.guess_gender(unicode(entry.get_text ()))
if gender == RelLib.Person.UNKNOWN:
self.is_unknown.set_active(True)
elif gender == RelLib.Person.MALE:
self.is_male.set_active(True)
else:
self.is_female.set_active(True)
def build_menu(self,list,task,opt_menu,type): def build_menu(self,list,task,opt_menu,type):
cell = gtk.CellRendererText() cell = gtk.CellRendererText()
opt_menu.pack_start(cell,True) opt_menu.pack_start(cell,True)
@ -1022,9 +972,9 @@ class EditPerson:
self.nmap[str(name)] = node self.nmap[str(name)] = node
if self.nlist: if self.nlist:
self.ntree.select_row(0) self.ntree.select_row(0)
Utils.bold_label(self.names_label) # Utils.bold_label(self.names_label)
else: # else:
Utils.unbold_label(self.names_label) # Utils.unbold_label(self.names_label)
def redraw_url_list(self): def redraw_url_list(self):
"""redraws the url list, disabling the go button if no url """redraws the url list, disabling the go button if no url
@ -1038,12 +988,12 @@ class EditPerson:
if len(self.ulist) > 0: if len(self.ulist) > 0:
self.web_go.set_sensitive(False) self.web_go.set_sensitive(False)
self.wtree.select_row(0) self.wtree.select_row(0)
Utils.bold_label(self.inet_label) # Utils.bold_label(self.inet_label)
else: else:
self.web_go.set_sensitive(False) self.web_go.set_sensitive(False)
self.web_url.set_text("") # self.web_url.set_text("")
self.web_description.set_text("") # self.web_description.set_text("")
Utils.unbold_label(self.inet_label) # Utils.unbold_label(self.inet_label)
def redraw_addr_list(self): def redraw_addr_list(self):
"""Redraws the address list""" """Redraws the address list"""
@ -1056,9 +1006,9 @@ class EditPerson:
self.pmap[str(addr)] = node self.pmap[str(addr)] = node
if self.plist: if self.plist:
self.ptree.select_row(0) self.ptree.select_row(0)
Utils.bold_label(self.addr_label) # Utils.bold_label(self.addr_label)
else: # else:
Utils.unbold_label(self.addr_label) # Utils.unbold_label(self.addr_label)
def redraw_attr_list(self): def redraw_attr_list(self):
"""redraws the attribute list for the person""" """redraws the attribute list for the person"""
@ -1069,9 +1019,9 @@ class EditPerson:
self.amap[str(attr)] = node self.amap[str(attr)] = node
if self.alist: if self.alist:
self.atree.select_row(0) self.atree.select_row(0)
Utils.bold_label(self.attr_label) # Utils.bold_label(self.attr_label)
else: # else:
Utils.unbold_label(self.attr_label) # Utils.unbold_label(self.attr_label)
def name_edit_callback(self,name): def name_edit_callback(self,name):
self.redraw_name_list() self.redraw_name_list()
@ -1114,31 +1064,7 @@ class EditPerson:
event.get_description(), event.get_description(),
event.get_date(),pname],event) event.get_date(),pname],event)
self.emap[str(event)] = node self.emap[str(event)] = node
if self.elist: node = self.etree.add(["","","",""],None)
self.etree.select_row(0)
Utils.bold_label(self.events_label)
else:
Utils.unbold_label(self.events_label)
# Remember old combo list input
bplace_text = unicode(self.bplace.get_text())
dplace_text = unicode(self.dplace.get_text())
prev_btext = self.strip_id(bplace_text)
prev_dtext = self.strip_id(dplace_text)
# Update birth with new values, make sure death values don't change
if self.update_birth:
self.update_birth = False
self.update_birth_info()
self.dplace.set_text(prev_dtext)
# Update death with new values, make sure birth values don't change
if self.update_death:
self.update_death = False
self.update_death_info()
self.bplace.set_text(prev_btext)
def strip_id(self,text): def strip_id(self,text):
index = text.rfind('[') index = text.rfind('[')
@ -1197,42 +1123,12 @@ class EditPerson:
def on_edit_birth_clicked(self,obj): def on_edit_birth_clicked(self,obj):
"""Brings up the EventEditor for the birth record, event """Brings up the EventEditor for the birth record, event
name cannot be changed""" name cannot be changed"""
pass
import EventEdit
self.update_birth = True
pname = self.name_display.display(self.person)
event = self.birth
event.set_date_object(Date.Date(self.birth_date_object))
def_placename = unicode(self.bplace.get_text())
p = self.get_place(self.bplace)
if p:
event.set_place_handle(p)
EventEdit.EventEditor(
self,pname, const.personalEvents,
const.personal_events,event,def_placename,1,
self.event_edit_callback,
noedit=self.db.readonly)
def on_edit_death_clicked(self,obj): def on_edit_death_clicked(self,obj):
"""Brings up the EventEditor for the death record, event """Brings up the EventEditor for the death record, event
name cannot be changed""" name cannot be changed"""
pass
import EventEdit
self.update_death = True
pname = self.name_display.display(self.person)
event = self.death
event.set_date_object(Date.Date(self.death_date_object))
def_placename = unicode(self.dplace.get_text())
p = self.get_place(self.dplace)
if p:
event.set_place_handle(p)
EventEdit.EventEditor(
self,pname,const.personalEvents,
const.personal_events,event,def_placename,1,
self.event_edit_callback,
noedit=self.db.readonly)
def on_aka_delete_clicked(self,obj): def on_aka_delete_clicked(self,obj):
"""Deletes the selected name from the name list""" """Deletes the selected name from the name list"""
@ -1313,18 +1209,12 @@ class EditPerson:
orig record""" orig record"""
surname = unicode(self.surname.get_text()) surname = unicode(self.surname.get_text())
self.birth.set_date_object(self.birth_date_object)
self.death.set_date_object(self.death_date_object)
ntype = unicode(self.ntype_field.child.get_text()) ntype = unicode(self.ntype_field.child.get_text())
suffix = unicode(self.suffix.get_text()) suffix = unicode(self.suffix.get_text())
prefix = unicode(self.prefix.get_text()) prefix = unicode(self.prefix.get_text())
given = unicode(self.given.get_text()) given = unicode(self.given.get_text())
nick = unicode(self.nick.get_text())
title = unicode(self.title.get_text()) title = unicode(self.title.get_text())
male = self.is_male.get_active()
female = self.is_female.get_active()
unknown = self.is_unknown.get_active()
start = self.notes_buffer.get_start_iter() start = self.notes_buffer.get_start_iter()
end = self.notes_buffer.get_end_iter() end = self.notes_buffer.get_end_iter()
@ -1357,8 +1247,6 @@ class EditPerson:
changed = True changed = True
if given != name.get_first_name(): if given != name.get_first_name():
changed = True changed = True
if nick != self.person.get_nick_name():
changed = True
if title != name.get_title(): if title != name.get_title():
changed = True changed = True
if self.pname.get_note() != name.get_note(): if self.pname.get_note() != name.get_note():
@ -1366,27 +1254,8 @@ class EditPerson:
if not self.lds_not_loaded and self.check_lds(): if not self.lds_not_loaded and self.check_lds():
changed = True changed = True
bplace = unicode(self.bplace.get_text().strip()) (female,male,unknown) = _select_gender[self.gender.get_active()]
dplace = unicode(self.dplace.get_text().strip())
if self.pdmap.has_key(bplace):
self.birth.set_place_handle(self.pdmap[bplace])
else:
if bplace != "":
changed = True
self.birth.set_place_handle('')
if self.pdmap.has_key(dplace):
self.death.set_place_handle(self.pdmap[dplace])
else:
if dplace != "":
changed = True
self.death.set_place_handle('')
if not self.birth.are_equal(self.orig_birth):
changed = True
if not self.death.are_equal(self.orig_death):
changed = True
if male and self.person.get_gender() != RelLib.Person.MALE: if male and self.person.get_gender() != RelLib.Person.MALE:
changed = True changed = True
elif female and self.person.get_gender() != RelLib.Person.FEMALE: elif female and self.person.get_gender() != RelLib.Person.FEMALE:
@ -1443,11 +1312,7 @@ class EditPerson:
self.redraw_event_list() self.redraw_event_list()
def update_birth_death(self): def update_birth_death(self):
self.bplace.set_text(place_title(self.db,self.birth)) pass
self.dplace.set_text(place_title(self.db,self.death))
self.bdate_check.update_after_editor(self.birth_date_object)
self.ddate_check.update_after_editor(self.death_date_object)
def on_update_attr_clicked(self,obj): def on_update_attr_clicked(self,obj):
import AttrEdit import AttrEdit
@ -1488,148 +1353,51 @@ class EditPerson:
self.event_edit_callback,noedit=self.db.readonly) self.event_edit_callback,noedit=self.db.readonly)
def on_event_select_row(self,obj): def on_event_select_row(self,obj):
store,node = obj.get_selected() store,iter = obj.get_selected()
if node: if iter:
row = store.get_path(node) self.event_delete_btn.set_sensitive(True)
event = self.db.get_event_from_handle(self.elist[row[0]]) self.event_edit_btn.set_sensitive(True)
self.event_date_field.set_text(event.get_date())
self.event_place_field.set_text(place_title(self.db,event))
self.event_name_field.set_text(const.display_pevent(event.get_name()))
self.event_cause_field.set_text(event.get_cause())
self.event_descr_field.set_text(short(event.get_description()))
if len(event.get_source_references()) > 0:
psrc_ref = event.get_source_references()[0]
psrc_id = psrc_ref.get_base_handle()
psrc = self.db.get_source_from_handle(psrc_id)
self.event_src_field.set_text(short(psrc.get_title()))
self.event_conf_field.set_text(const.confidence[psrc_ref.get_confidence_level()])
else:
self.event_src_field.set_text('')
self.event_conf_field.set_text('')
if not self.db.readonly:
self.event_delete_btn.set_sensitive(1)
self.event_edit_btn.set_sensitive(1)
else: else:
self.event_date_field.set_text('') self.event_delete_btn.set_sensitive(True)
self.event_place_field.set_text('') self.event_edit_btn.set_sensitive(True)
self.event_name_field.set_text('')
self.event_cause_field.set_text('')
self.event_descr_field.set_text('')
self.event_src_field.set_text('')
self.event_conf_field.set_text('')
self.event_delete_btn.set_sensitive(0)
self.event_edit_btn.set_sensitive(0)
def on_addr_select_row(self,obj): def on_addr_select_row(self,obj):
store,node = self.ptree.get_selected() store,node = self.ptree.get_selected()
if node: if node:
addr = self.ptree.get_object(node) self.addr_delete_btn.set_sensitive(True)
self.addr_start.set_text(addr.get_date()) self.addr_edit_btn.set_sensitive(True)
self.addr_street.set_text(addr.get_street())
self.addr_city.set_text(addr.get_city())
self.addr_state.set_text(addr.get_state())
self.addr_country.set_text(addr.get_country())
self.addr_postal.set_text(addr.get_postal_code())
self.addr_phone.set_text(addr.get_phone())
if len(addr.get_source_references()) > 0:
psrc_ref = addr.get_source_references()[0]
psrc_id = psrc_ref.get_base_handle()
psrc = self.db.get_source_from_handle(psrc_id)
self.addr_conf_field.set_text(const.confidence[psrc_ref.get_confidence_level()])
self.addr_src_field.set_text(short(psrc.get_title()))
else:
self.addr_src_field.set_text('')
self.addr_conf_field.set_text('')
self.addr_delete_btn.set_sensitive(1)
self.addr_edit_btn.set_sensitive(1)
else: else:
self.addr_start.set_text('') self.addr_delete_btn.set_sensitive(False)
self.addr_street.set_text('') self.addr_edit_btn.set_sensitive(False)
self.addr_city.set_text('')
self.addr_state.set_text('')
self.addr_country.set_text('')
self.addr_postal.set_text('')
self.addr_phone.set_text('')
self.addr_conf_field.set_text('')
self.addr_src_field.set_text('')
self.addr_delete_btn.set_sensitive(0)
self.addr_edit_btn.set_sensitive(0)
def on_name_select_row(self,obj): def on_name_select_row(self,obj):
store,node = self.ntree.get_selected() store,node = self.ntree.get_selected()
if node: if node:
name = self.ntree.get_object(node) self.name_delete_btn.set_sensitive(True)
self.alt_given_field.set_text(name.get_first_name()) self.name_edit_btn.set_sensitive(True)
self.alt_title_field.set_text(name.get_title())
self.alt_last_field.set_text(name.get_surname())
self.alt_suffix_field.set_text(name.get_suffix())
self.alt_prefix_field.set_text(name.get_surname_prefix())
self.name_type_field.set_text(const.NameTypesMap.find_value(name.get_type()))
if len(name.get_source_references()) > 0:
psrc_ref = name.get_source_references()[0]
psrc_id = psrc_ref.get_base_handle()
psrc = self.db.get_source_from_handle(psrc_id)
self.name_src_field.set_text(short(psrc.get_title()))
self.name_conf_field.set_text(const.confidence[psrc_ref.get_confidence_level()])
else:
self.name_src_field.set_text('')
self.name_conf_field.set_text('')
self.name_delete_btn.set_sensitive(1)
self.name_edit_btn.set_sensitive(1)
else: else:
self.alt_given_field.set_text('') self.name_delete_btn.set_sensitive(False)
self.alt_title_field.set_text('') self.name_edit_btn.set_sensitive(False)
self.alt_last_field.set_text('')
self.alt_suffix_field.set_text('')
self.alt_prefix_field.set_text('')
self.name_type_field.set_text('')
self.name_src_field.set_text('')
self.name_conf_field.set_text('')
self.name_delete_btn.set_sensitive(0)
self.name_edit_btn.set_sensitive(0)
def on_web_select_row(self,obj): def on_web_select_row(self,obj):
store,node = self.wtree.get_selected() store,node = self.wtree.get_selected()
if node: if node:
url = self.wtree.get_object(node) self.web_go.set_sensitive(True)
path = url.get_path() self.web_delete_btn.set_sensitive(True)
self.web_url.set_text(path) self.web_edit_btn.set_sensitive(True)
self.web_description.set_text(url.get_description())
self.web_go.set_sensitive(0)
self.web_go.set_sensitive(1)
self.web_delete_btn.set_sensitive(1)
self.web_edit_btn.set_sensitive(1)
else: else:
self.web_url.set_text('') self.web_go.set_sensitive(False)
self.web_description.set_text('') self.web_delete_btn.set_sensitive(False)
self.web_go.set_sensitive(0) self.web_edit_btn.set_sensitive(False)
self.web_delete_btn.set_sensitive(0)
self.web_edit_btn.set_sensitive(0)
def on_attr_select_row(self,obj): def on_attr_select_row(self,obj):
store,node = self.atree.get_selected() store,node = self.atree.get_selected()
if node: if node:
attr = self.atree.get_object(node) self.attr_delete_btn.set_sensitive(True)
self.attr_type.set_text(const.display_pattr(attr.get_type())) self.attr_edit_btn.set_sensitive(True)
self.attr_value.set_text(short(attr.get_value()))
if len(attr.get_source_references()) > 0:
psrc_ref = attr.get_source_references()[0]
psrc_id = psrc_ref.get_base_handle()
psrc = self.db.get_source_from_handle(psrc_id)
self.attr_src_field.set_text(short(psrc.get_title()))
self.attr_conf_field.set_text(const.confidence[psrc_ref.get_confidence_level()])
else:
self.attr_src_field.set_text('')
self.attr_conf_field.set_text('')
self.attr_delete_btn.set_sensitive(1)
self.attr_edit_btn.set_sensitive(1)
else: else:
self.attr_type.set_text('') self.attr_delete_btn.set_sensitive(False)
self.attr_value.set_text('') self.attr_edit_btn.set_sensitive(False)
self.attr_src_field.set_text('')
self.attr_conf_field.set_text('')
self.attr_delete_btn.set_sensitive(0)
self.attr_edit_btn.set_sensitive(0)
def aka_double_click(self,obj,event): def aka_double_click(self,obj,event):
if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1: if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1:
@ -1660,7 +1428,7 @@ class EditPerson:
try: try:
i = pixbuf_new_from_file(photo) i = pixbuf_new_from_file(photo)
ratio = float(max(i.get_height(),i.get_width())) ratio = float(max(i.get_height(),i.get_width()))
scale = float(_PICTURE_WIDTH)/ratio scale = float(100.0)/ratio
x = int(scale*(i.get_width())) x = int(scale*(i.get_width()))
y = int(scale*(i.get_height())) y = int(scale*(i.get_height()))
i = i.scale_simple(x,y,INTERP_BILINEAR) i = i.scale_simple(x,y,INTERP_BILINEAR)
@ -1702,15 +1470,11 @@ class EditPerson:
prefix = unicode(self.prefix.get_text()) prefix = unicode(self.prefix.get_text())
ntype = unicode(self.ntype_field.child.get_text()) ntype = unicode(self.ntype_field.child.get_text())
given = unicode(self.given.get_text()) given = unicode(self.given.get_text())
nick = unicode(self.nick.get_text())
title = unicode(self.title.get_text()) title = unicode(self.title.get_text())
idval = unicode(self.gid.get_text()) idval = unicode(self.gid.get_text())
name = self.pname name = self.pname
self.birth.set_date_object(self.birth_date_object)
self.birth.set_place_handle(self.get_place(self.bplace,1))
if idval != self.person.get_gramps_id(): if idval != self.person.get_gramps_id():
person = self.db.get_person_from_gramps_id(idval) person = self.db.get_person_from_gramps_id(idval)
if not person: if not person:
@ -1756,9 +1520,6 @@ class EditPerson:
if name != self.person.get_primary_name(): if name != self.person.get_primary_name():
self.person.set_primary_name(name) self.person.set_primary_name(name)
if nick != self.person.get_nick_name():
self.person.set_nick_name(nick)
self.pdmap.clear() self.pdmap.clear()
for key in self.db.get_place_handles(): for key in self.db.get_place_handles():
p = self.db.get_place_from_handle(key).get_display_info() p = self.db.get_place_from_handle(key).get_display_info()
@ -1782,19 +1543,8 @@ class EditPerson:
new_order = self.reorder_child_list(self.person,f.get_child_handle_list()) new_order = self.reorder_child_list(self.person,f.get_child_handle_list())
f.set_child_handle_list(new_order) f.set_child_handle_list(new_order)
self.death.set_date_object(self.death_date_object)
self.death.set_place_handle(self.get_place(self.dplace,1))
if not self.orig_death.are_equal(self.death):
if self.orig_death.is_empty():
self.db.add_event(self.death,trans)
self.person.set_death_handle(self.death.get_handle())
self.db.commit_event(self.death,trans)
male = self.is_male.get_active()
female = self.is_female.get_active()
unknown = self.is_unknown.get_active()
error = False error = False
(female,male,unknown) = _select_gender[self.gender.get_active()]
if male and self.person.get_gender() != RelLib.Person.MALE: if male and self.person.get_gender() != RelLib.Person.MALE:
self.person.set_gender(RelLib.Person.MALE) self.person.set_gender(RelLib.Person.MALE)
for temp_family in self.person.get_family_handle_list(): for temp_family in self.person.get_family_handle_list():
@ -1972,17 +1722,14 @@ class EditPerson:
self.load_photo(None) self.load_photo(None)
def update_birth_info(self): def update_birth_info(self):
self.bdate_check.update_after_editor(self.birth.get_date_object()) pass
self.bplace.set_text(place_title(self.db,self.birth))
def update_death_info(self): def update_death_info(self):
self.ddate_check.update_after_editor(self.death.get_date_object()) pass
self.dplace.set_text(place_title(self.db,self.death))
def on_switch_page(self,obj,a,page): def on_switch_page(self,obj,a,page):
if page == 0: if page == 0:
self.load_person_image() self.load_person_image()
elif page == 2:
self.redraw_event_list() self.redraw_event_list()
elif page == 7 and self.not_loaded: elif page == 7 and self.not_loaded:
self.not_loaded = False self.not_loaded = False
@ -1992,19 +1739,19 @@ class EditPerson:
note_buf = self.notes_buffer note_buf = self.notes_buffer
text = unicode(note_buf.get_text(note_buf.get_start_iter(), text = unicode(note_buf.get_text(note_buf.get_start_iter(),
note_buf.get_end_iter(),False)) note_buf.get_end_iter(),False))
if text: # if text:
Utils.bold_label(self.notes_label) # Utils.bold_label(self.notes_label)
else: # else:
Utils.unbold_label(self.notes_label) # Utils.unbold_label(self.notes_label)
if not self.lds_not_loaded: if not self.lds_not_loaded:
self.check_lds() self.check_lds()
if self.lds_baptism.is_empty() \ # if self.lds_baptism.is_empty() \
and self.lds_endowment.is_empty() \ # and self.lds_endowment.is_empty() \
and self.lds_sealing.is_empty(): # and self.lds_sealing.is_empty():
Utils.unbold_label(self.lds_tab) # Utils.unbold_label(self.lds_tab)
else: # else:
Utils.bold_label(self.lds_tab) # Utils.bold_label(self.lds_tab)
def change_name(self,obj): def change_name(self,obj):
sel_objs = self.ntree.get_selected_objects() sel_objs = self.ntree.get_selected_objects()
@ -2021,8 +1768,8 @@ class EditPerson:
def write_primary_name(self): def write_primary_name(self):
# initial values # initial values
name = '<span size="larger" weight="bold">%s</span>' % self.name_display.display(self.person) name = '<span size="larger" weight="bold">%s</span>' % self.name_display.display(self.person)
self.get_widget("activepersonTitle").set_text(name) # self.get_widget("activepersonTitle").set_text(name)
self.get_widget("activepersonTitle").set_use_markup(True) # self.get_widget("activepersonTitle").set_use_markup(True)
self.suffix.set_text(self.pname.get_suffix()) self.suffix.set_text(self.pname.get_suffix())
if self.use_patronymic: if self.use_patronymic:
self.prefix.set_text(self.pname.get_patronymic()) self.prefix.set_text(self.pname.get_patronymic())
@ -2108,7 +1855,6 @@ class EditPerson:
list.insert(target,person.get_handle()) list.insert(target,person.get_handle())
return list return list
def short(val,size=60): def short(val,size=60):
if len(val) > size: if len(val) > size:
return "%s..." % val[0:size] return "%s..." % val[0:size]

View File

@ -992,7 +992,8 @@ class GrampsDbBase(GrampsDBCallback.GrampsDBCallback):
def get_default_person(self): def get_default_person(self):
"""returns the default Person of the database""" """returns the default Person of the database"""
if self.metadata: if self.metadata:
data = self.person_map.get(self.metadata['default']) key = self.metadata.get('default')
data = self.person_map.get(key)
if data: if data:
person = Person() person = Person()
person.unserialize(data) person.unserialize(data)

View File

@ -18,8 +18,11 @@
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
# #
from gobject import TYPE_STRING, TYPE_PYOBJECT from gobject import TYPE_STRING, TYPE_PYOBJECT, TYPE_OBJECT
import gtk import gtk
import const
gtk26 = gtk.pygtk_version >= (2,6,0)
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -43,11 +46,30 @@ class ListModel:
self.cid = None self.cid = None
self.cids = [] self.cids = []
self.idmap = {} self.idmap = {}
store = gtk.ListStore(str)
events = const.personalConstantEvents.keys()
events.append('Birth')
events.append('Death')
events.sort()
model = gtk.ListStore(str,TYPE_OBJECT)
for val in events:
model.append((val,store))
cnum = 0 cnum = 0
for name in dlist: for name in dlist:
renderer = gtk.CellRendererText() if gtk26 and cnum == 0:
renderer.set_fixed_height_from_font(1) renderer = gtk.CellRendererCombo()
renderer.set_property('model',model)
renderer.set_property('text_column',0)
renderer.set_property('editable',True)
else:
renderer = gtk.CellRendererText()
renderer.set_property('editable',True)
renderer.set_fixed_height_from_font(True)
renderer.connect('edited',self.edited_cb, cnum)
column = gtk.TreeViewColumn(name[0],renderer,text=cnum) column = gtk.TreeViewColumn(name[0],renderer,text=cnum)
column.set_reorderable(True) column.set_reorderable(True)
column.set_min_width(name[2]) column.set_min_width(name[2])
@ -62,7 +84,7 @@ class ListModel:
column.set_clickable(True) column.set_clickable(True)
column.set_sort_column_id(name[1]) column.set_sort_column_id(name[1])
cnum = cnum + 1 cnum += 1
self.cids.append(name[1]) self.cids.append(name[1])
if name[0] != '': if name[0] != '':
self.tree.append_column(column) self.tree.append_column(column)
@ -75,6 +97,9 @@ class ListModel:
self.double_click = event_func self.double_click = event_func
self.tree.connect('event',self.button_press) self.tree.connect('event',self.button_press)
def edited_cb(self, cell, path, new_text, col):
self.model[path][col] = new_text
def unselect(self): def unselect(self):
self.selection.unselect_all() self.selection.unselect_all()
@ -168,7 +193,7 @@ class ListModel:
def remove(self,node): def remove(self,node):
self.model.remove(node) self.model.remove(node)
self.count = self.count - 1 self.count -= 1
def get_row(self,node): def get_row(self,node):
row = self.model.get_path(node) row = self.model.get_path(node)
@ -184,12 +209,12 @@ class ListModel:
return self.model.get_value(node,self.data_index) return self.model.get_value(node,self.data_index)
def insert(self,position,data,info=None,select=0): def insert(self,position,data,info=None,select=0):
self.count = self.count + 1 self.count += 1
node = self.model.insert(position) node = self.model.insert(position)
col = 0 col = 0
for obj in data: for obj in data:
self.model.set_value(node,col,obj) self.model.set_value(node,col,obj)
col = col + 1 col += 1
self.model.set_value(node,col,info) self.model.set_value(node,col,info)
if info: if info:
self.idmap[str(info)] = node self.idmap[str(info)] = node
@ -201,12 +226,12 @@ class ListModel:
return [ self.model.get_value(node,c) for c in cols ] return [ self.model.get_value(node,c) for c in cols ]
def add(self,data,info=None,select=0): def add(self,data,info=None,select=0):
self.count = self.count + 1 self.count += 1
node = self.model.append() node = self.model.append()
col = 0 col = 0
for obj in data: for obj in data:
self.model.set_value(node,col,obj) self.model.set_value(node,col,obj)
col = col + 1 col += 1
self.model.set_value(node,col,info) self.model.set_value(node,col,info)
if info: if info:
self.idmap[str(info)] = node self.idmap[str(info)] = node
@ -219,7 +244,7 @@ class ListModel:
col = 0 col = 0
for obj in data: for obj in data:
self.model.set_value(node,col,obj) self.model.set_value(node,col,obj)
col = col + 1 col += 1
self.model.set_value(node,col,info) self.model.set_value(node,col,info)
if info: if info:
self.idmap[str(info)] = node self.idmap[str(info)] = node
@ -228,12 +253,12 @@ class ListModel:
return node return node
def add_and_select(self,data,info=None): def add_and_select(self,data,info=None):
self.count = self.count + 1 self.count += 1
node = self.model.append() node = self.model.append()
col = 0 col = 0
for obj in data: for obj in data:
self.model.set_value(node,col,obj) self.model.set_value(node,col,obj)
col = col + 1 col += 1
if info: if info:
self.idmap[str(info)] = node self.idmap[str(info)] = node
self.model.set_value(node,col,info) self.model.set_value(node,col,info)
@ -248,13 +273,11 @@ class ListModel:
def button_press(self,obj,event): def button_press(self,obj,event):
if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1: if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1:
self.double_click(obj) self.double_click(obj)
return 1 return True
return 0 return False
def find(self,info): def find(self,info):
if info in self.idmap.keys(): if info in self.idmap.keys():
node = self.idmap[str(info)] node = self.idmap[str(info)]
self.selection.select_iter(node) self.selection.select_iter(node)
def cleanup(self):
pass

View File

@ -126,6 +126,7 @@ gdir_PYTHON = \
# The latter is more portable and POSIX-friendly :) # The latter is more portable and POSIX-friendly :)
GLADEFILES = \ GLADEFILES = \
gramps.glade\ gramps.glade\
edit_person.glade\
mergedata.glade\ mergedata.glade\
gedcomexport.glade\ gedcomexport.glade\
gedcomimport.glade\ gedcomimport.glade\

View File

@ -436,7 +436,7 @@ class GrampsParser:
person = RelLib.Person() person = RelLib.Person()
person.set_handle(intid) person.set_handle(intid)
person.set_gramps_id(gramps_id) person.set_gramps_id(gramps_id)
self.db.add_person(person,None) self.db.add_person(person,self.trans)
self.gid2id[gramps_id] = intid self.gid2id[gramps_id] = intid
return person return person
@ -449,7 +449,7 @@ class GrampsParser:
family = RelLib.Family() family = RelLib.Family()
family.set_handle(intid) family.set_handle(intid)
family.set_gramps_id(gramps_id) family.set_gramps_id(gramps_id)
self.db.add_family(family,None) self.db.add_family(family,self.trans)
self.gid2fid[gramps_id] = intid self.gid2fid[gramps_id] = intid
return family return family
@ -462,7 +462,7 @@ class GrampsParser:
place = RelLib.Place() place = RelLib.Place()
place.set_handle(intid) place.set_handle(intid)
place.set_gramps_id(gramps_id) place.set_gramps_id(gramps_id)
self.db.add_place(place,None) self.db.add_place(place,self.trans)
self.gid2pid[gramps_id] = intid self.gid2pid[gramps_id] = intid
return place return place
@ -475,7 +475,7 @@ class GrampsParser:
source = RelLib.Source() source = RelLib.Source()
source.set_handle(intid) source.set_handle(intid)
source.set_gramps_id(gramps_id) source.set_gramps_id(gramps_id)
self.db.add_source(source,None) self.db.add_source(source,self.trans)
self.gid2sid[gramps_id] = intid self.gid2sid[gramps_id] = intid
return source return source
@ -488,7 +488,7 @@ class GrampsParser:
obj = RelLib.MediaObject() obj = RelLib.MediaObject()
obj.set_handle(intid) obj.set_handle(intid)
obj.set_gramps_id(gramps_id) obj.set_gramps_id(gramps_id)
self.db.add_object(obj,None) self.db.add_object(obj,self.trans)
self.gid2oid[gramps_id] = intid self.gid2oid[gramps_id] = intid
return obj return obj
@ -534,11 +534,8 @@ class GrampsParser:
def parse(self,file,use_trans=True): def parse(self,file,use_trans=True):
if use_trans: self.trans = self.db.transaction_begin()
self.trans = self.db.transaction_begin() self.trans.set_batch(True)
self.trans.set_batch(True)
else:
self.trans = None
self.db.disable_signals() self.db.disable_signals()
@ -601,7 +598,8 @@ class GrampsParser:
def start_place(self,attrs): def start_place(self,attrs):
try: try:
self.placeobj = self.db.find_place_from_handle(attrs['hlink'],self.trans) self.placeobj = self.db.find_place_from_handle(attrs['hlink'],
self.trans)
except KeyError: except KeyError:
handle = self.map_pid(attrs['ref']) handle = self.map_pid(attrs['ref'])
self.placeobj = self.find_place_by_gramps_id(handle) self.placeobj = self.find_place_by_gramps_id(handle)
@ -609,7 +607,8 @@ class GrampsParser:
def start_placeobj(self,attrs): def start_placeobj(self,attrs):
handle = self.map_pid(attrs['id']) handle = self.map_pid(attrs['id'])
try: try:
self.placeobj = self.db.find_place_from_handle(attrs['handle'],self.trans) self.placeobj = self.db.find_place_from_handle(attrs['handle'],
self.trans)
self.placeobj.set_gramps_id(handle) self.placeobj.set_gramps_id(handle)
except KeyError: except KeyError:
self.placeobj = self.find_place_by_gramps_id(handle) self.placeobj = self.find_place_by_gramps_id(handle)
@ -783,14 +782,16 @@ class GrampsParser:
self.count = self.count + 1 self.count = self.count + 1
handle = self.map_fid(attrs["id"]) handle = self.map_fid(attrs["id"])
try: try:
self.family = self.db.find_family_from_handle(attrs["handle"],self.trans) self.family = self.db.find_family_from_handle(
attrs["handle"],self.trans)
self.family.set_gramps_id(handle) self.family.set_gramps_id(handle)
except KeyError: except KeyError:
self.family = self.find_family_by_gramps_id(handle) self.family = self.find_family_by_gramps_id(handle)
if attrs.has_key("type"): if attrs.has_key("type"):
self.family.set_relationship(_FAMILY_TRANS.get(attrs["type"], self.family.set_relationship(
RelLib.Family.UNKNOWN)) _FAMILY_TRANS.get(attrs["type"],
RelLib.Family.UNKNOWN))
if attrs.has_key("complete"): if attrs.has_key("complete"):
self.family.set_complete_flag(int(attrs['complete'])) self.family.set_complete_flag(int(attrs['complete']))
else: else:
@ -891,7 +892,8 @@ class GrampsParser:
def start_source(self,attrs): def start_source(self,attrs):
handle = self.map_sid(attrs["id"]) handle = self.map_sid(attrs["id"])
try: try:
self.source = self.db.find_source_from_handle(attrs["handle"],self.trans) self.source = self.db.find_source_from_handle(attrs["handle"],
self.trans)
self.source.set_gramps_id(handle) self.source.set_gramps_id(handle)
except KeyError: except KeyError:
self.source = self.find_source_by_gramps_id(handle) self.source = self.find_source_by_gramps_id(handle)
@ -922,7 +924,8 @@ class GrampsParser:
def start_object(self,attrs): def start_object(self,attrs):
handle = self.map_oid(attrs['id']) handle = self.map_oid(attrs['id'])
try: try:
self.object = self.db.find_object_from_handle(attrs['handle'],self.trans) self.object = self.db.find_object_from_handle(attrs['handle'],
self.trans)
self.object.set_gramps_id(handle) self.object.set_gramps_id(handle)
except KeyError: except KeyError:
self.object = self.find_object_by_gramps_id(handle) self.object = self.find_object_by_gramps_id(handle)

View File

@ -106,7 +106,7 @@ gladeFile = "%s/gramps.glade" % rootDir
placesFile = "%s/gramps.glade" % rootDir placesFile = "%s/gramps.glade" % rootDir
imageselFile = "%s/gramps.glade" % rootDir imageselFile = "%s/gramps.glade" % rootDir
marriageFile = "%s/gramps.glade" % rootDir marriageFile = "%s/gramps.glade" % rootDir
editPersonFile = "%s/gramps.glade" % rootDir editPersonFile = "%s/edit_person.glade" % rootDir
pluginsFile = "%s/plugins.glade" % rootDir pluginsFile = "%s/plugins.glade" % rootDir
prefsFile = "%s/gramps.glade" % rootDir prefsFile = "%s/gramps.glade" % rootDir
stylesFile = "%s/gramps.glade" % rootDir stylesFile = "%s/gramps.glade" % rootDir

File diff suppressed because it is too large Load Diff