* src/DataViews/_PersonView.py: merge functionality

* src/ViewManager.py: merge functionality
	* src/MergePeople.py: fix merge (ui and birth/death events)
	* src/GrampsDb/_WriteXML.py: remove redundant birth/death entries


svn: r6773
This commit is contained in:
Don Allingham 2006-05-25 04:08:05 +00:00
parent 57bb0ce78c
commit 00a5154a67
5 changed files with 93 additions and 46 deletions

@ -1,4 +1,8 @@
2006-05-24 Don Allingham <don@gramps-project.org> 2006-05-24 Don Allingham <don@gramps-project.org>
* src/DataViews/_PersonView.py: merge functionality
* src/ViewManager.py: merge functionality
* src/MergePeople.py: fix merge (ui and birth/death events)
* src/GrampsDb/_WriteXML.py: remove redundant birth/death entries
* src/GrampsDb/_DbUtils.py: fix index setting of death index * src/GrampsDb/_DbUtils.py: fix index setting of death index
* src/GrampsDb/_WriteGedcom.py: remove redundant birth/death * src/GrampsDb/_WriteGedcom.py: remove redundant birth/death
references references

@ -136,6 +136,59 @@ class PersonView(PageView.PersonNavView):
self.add_action('ColumnEdit', gtk.STOCK_PROPERTIES, self.add_action('ColumnEdit', gtk.STOCK_PROPERTIES,
_('_Column Editor'), callback=self.column_editor,) _('_Column Editor'), callback=self.column_editor,)
self.add_action('CmpMerge', None, _('_Compare and merge'),
callback=self.cmp_merge)
self.add_action('FastMerge', None, _('_Fast merge'),
callback=self.fast_merge)
def cmp_merge(self, obj):
mlist = self.get_selected_objects()
if len(mlist) != 2:
from QuestionDialog import ErrorDialog
msg = _("Cannot merge people")
msg2 = _("Exactly two people must be selected to perform a merge. "
"A second person can be selected by holding down the "
"control key while clicking on the desired person.")
ErrorDialog(msg,msg2)
else:
from QuestionDialog import ErrorDialog
import MergePeople
p1 = self.db.get_person_from_handle(mlist[0])
p2 = self.db.get_person_from_handle(mlist[1])
if p1 and p2:
merger = MergePeople.Compare(self.dbstate, self.uistate, p1, p2)
else:
msg = _("Cannot merge people")
msg2 = _("Exactly two people must be selected to perform a merge. "
"A second person can be selected by holding down the "
"control key while clicking on the desired person.")
ErrorDialog(msg,msg2)
def fast_merge(self, obj):
mlist = self.get_selected_objects()
if len(mlist) != 2:
msg = _("Cannot merge people")
msg2 = _("Exactly two people must be selected to perform a merge. "
"A second person can be selected by holding down the "
"control key while clicking on the desired person.")
ErrorDialog(msg,msg2)
else:
from MergePeople import MergePeopleUI
p1 = self.db.get_person_from_handle(mlist[0])
p2 = self.db.get_person_from_handle(mlist[1])
if p1 and p2:
MergePeopleUI(self.dbstate, self.uistate, p1, p2)
else:
msg = _("Cannot merge people")
msg2 = _("Exactly two people must be selected to perform a merge. "
"A second person can be selected by holding down the "
"control key while clicking on the desired person.")
ErrorDialog(msg,msg2)
def column_editor(self,obj): def column_editor(self,obj):
import ColumnOrder import ColumnOrder
@ -254,6 +307,10 @@ class PersonView(PageView.PersonNavView):
</placeholder> </placeholder>
<menuitem action="SetActive"/> <menuitem action="SetActive"/>
<menuitem action="ColumnEdit"/> <menuitem action="ColumnEdit"/>
<placeholder name="Merge">
<menuitem action="CmpMerge"/>
<menuitem action="FastMerge"/>
</placeholder>
</menu> </menu>
</menubar> </menubar>
<toolbar name="ToolBar"> <toolbar name="ToolBar">

@ -404,8 +404,8 @@ class XmlWriter(UpdateCallback):
for name in person.get_alternate_names(): for name in person.get_alternate_names():
self.dump_name(name,True,index+1) self.dump_name(name,True,index+1)
self.dump_event_ref(person.get_birth_ref(),index+1) #self.dump_event_ref(person.get_birth_ref(),index+1)
self.dump_event_ref(person.get_death_ref(),index+1) #self.dump_event_ref(person.get_death_ref(),index+1)
for event_ref in person.get_event_ref_list(): for event_ref in person.get_event_ref_list():
self.dump_event_ref(event_ref,index+1) self.dump_event_ref(event_ref,index+1)

@ -50,12 +50,13 @@ import QuestionDialog
import GrampsDisplay import GrampsDisplay
import ManagedWindow import ManagedWindow
import Utils import Utils
import GrampsDb
sex = ( _("female"), _("male"), _("unknown")) sex = ( _("female"), _("male"), _("unknown"))
class Compare(ManagedWindow.ManagedWindow): class Compare(ManagedWindow.ManagedWindow):
def __init__(self, dbstate, uistate, person1, person2, update) : def __init__(self, dbstate, uistate, person1, person2, update=None) :
ManagedWindow.ManagedWindow.__init__(self,uistate,[],self.__class__) ManagedWindow.ManagedWindow.__init__(self,uistate,[],self.__class__)
@ -102,7 +103,8 @@ class Compare(ManagedWindow.ManagedWindow):
merge = MergePeople(self.db,self.p2,self.p1) merge = MergePeople(self.db,self.p2,self.p1)
self.close() self.close()
merge.merge() merge.merge()
self.update() if self.update:
self.update()
def add(self, tobj, tag, text): def add(self, tobj, tag, text):
text += "\n" text += "\n"
@ -256,11 +258,17 @@ def check_for_child(p1, p2):
# Merge People UI # Merge People UI
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
class MergePeopleUI: class MergePeopleUI(ManagedWindow.ManagedWindow):
def __init__(self,db,person1,person2,update): def __init__(self, dbstate, uistate, person1, person2, update=None):
ManagedWindow.ManagedWindow.__init__(self,uistate,[],self.__class__)
glade = gtk.glade.XML(const.merge_glade, 'merge_people') glade = gtk.glade.XML(const.merge_glade, 'merge_people')
window = glade.get_widget('merge_people') window = glade.get_widget('merge_people')
self.set_window(window, glade.get_widget('title'), _("Merge People"))
p1 = glade.get_widget('person1') p1 = glade.get_widget('person1')
p2 = glade.get_widget('person2') p2 = glade.get_widget('person2')
n1 = name_of(person1) n1 = name_of(person1)
@ -268,12 +276,12 @@ class MergePeopleUI:
p1.set_label(n1) p1.set_label(n1)
p2.set_label(n2) p2.set_label(n2)
Utils.set_titles(top,glade.get_widget('title'),_("Merge People"))
glade.get_widget('help').connect('clicked',self.help) glade.get_widget('help').connect('clicked',self.help)
ret = gtk.RESPONSE_HELP ret = gtk.RESPONSE_HELP
while ret == gtk.RESPONSE_HELP: while ret == gtk.RESPONSE_HELP:
ret = top.run() ret = window.run()
if ret == gtk.RESPONSE_OK: if ret == gtk.RESPONSE_OK:
@ -290,12 +298,16 @@ class MergePeopleUI:
"them.")) "them."))
else: else:
if p1.get_active(): if p1.get_active():
merge = MergePeople(db,person1,person2) merge = MergePeople(dbstate.db,person1,person2)
else: else:
merge = MergePeople(db,person2,person1) merge = MergePeople(dbstate.db,person2,person1)
merge.merge() merge.merge()
update() if update:
top.destroy() update()
window.destroy()
def build_menu_names(self,obj):
return (_('Merge People'),None)
def help(self,obj): def help(self,obj):
"""Display the relevant portion of GRAMPS manual""" """Display the relevant portion of GRAMPS manual"""
@ -395,15 +407,11 @@ class MergePeople:
# copy names # copy names
self.merge_names(new) self.merge_names(new)
# copy the birth event
self.merge_birth(new,trans)
# copy the death event
self.merge_death(new,trans)
# merge the event lists # merge the event lists
self.merge_event_lists(new) self.merge_event_lists(new)
GrampsDb.set_birth_death_index(self.db, new)
# copy attributes # copy attributes
new.set_attribute_list(self.p1.get_attribute_list() + new.set_attribute_list(self.p1.get_attribute_list() +
self.p2.get_attribute_list()) self.p2.get_attribute_list())
@ -483,17 +491,8 @@ class MergePeople:
ref1 = self.p1.get_birth_ref() ref1 = self.p1.get_birth_ref()
ref2 = self.p2.get_birth_ref() ref2 = self.p2.get_birth_ref()
if ref1: if not ref1.is_equal(ref2):
new.set_birth_ref(ref1) new.add_event_ref(ref2)
if ref2:
event = self.db.get_event_from_handle(ref2.ref)
event.set_name('Alternate Birth')
self.db.add_event(event,trans)
event_ref = RelLib.EventRef()
event_ref.ref = event.get_handle()
new.add_event_ref(event_ref)
elif not ref1 and ref2:
new.set_birth_ref(ref2)
def merge_death(self, new, trans): def merge_death(self, new, trans):
""" """
@ -507,18 +506,8 @@ class MergePeople:
ref1 = self.p1.get_death_ref() ref1 = self.p1.get_death_ref()
ref2 = self.p2.get_death_ref() ref2 = self.p2.get_death_ref()
if ref1: if not ref1.is_equal(ref2):
new.set_death_ref(ref1) new.add_event_ref(ref2)
if ref2:
event = self.db.get_event_from_handle(ref2)
event.set_handle(Utils.create_id())
event.set_name('Alternate Death')
event_ref = RelLib.EventRef()
event_ref.ref = event.get_handle()
new.add_event_ref(event_ref)
self.db.add_event(event,trans)
elif not ref1 and ref2:
new.set_death_ref(ref2)
def merge_event_lists(self, new): def merge_event_lists(self, new):
""" """

@ -115,9 +115,8 @@ uidefault = '''<ui>
<separator/> <separator/>
<placeholder name="CommonEdit"/> <placeholder name="CommonEdit"/>
<separator/> <separator/>
<menuitem action="ScratchPad"/> <menuitem action="ScratchPad"/>
<menuitem action="CmpMerge"/> <placeholder name="Merge"/>
<menuitem action="FastMerge"/>
<separator/> <separator/>
<menuitem action="Preferences"/> <menuitem action="Preferences"/>
</menu> </menu>
@ -343,8 +342,6 @@ class ViewManager:
self.export_data), self.export_data),
('Abandon', gtk.STOCK_REVERT_TO_SAVED, ('Abandon', gtk.STOCK_REVERT_TO_SAVED,
_('_Abandon changes and quit'), None, None, self.abort), _('_Abandon changes and quit'), None, None, self.abort),
('CmpMerge', None, _('_Compare and merge')),
('FastMerge', None, _('_Fast merge')),
('ScratchPad', gtk.STOCK_PASTE, _('_ScratchPad'), "", ('ScratchPad', gtk.STOCK_PASTE, _('_ScratchPad'), "",
_("Open the ScratchPad dialog"), self.scratchpad), _("Open the ScratchPad dialog"), self.scratchpad),
('Import', gtk.STOCK_CONVERT, _('_Import'), "<control>i", None, ('Import', gtk.STOCK_CONVERT, _('_Import'), "<control>i", None,