Clean up handing of merged families
svn: r883
This commit is contained in:
parent
9188e8e7bd
commit
dd4f68dd2a
194
src/MergeData.py
194
src/MergeData.py
@ -56,7 +56,9 @@ class MergePeople:
|
|||||||
"destroy_passed_object" : Utils.destroy_passed_object,
|
"destroy_passed_object" : Utils.destroy_passed_object,
|
||||||
})
|
})
|
||||||
|
|
||||||
label_text = "Merge %s and %s" % (GrampsCfg.nameof(person1),GrampsCfg.nameof(person2))
|
fname = GrampsCfg.nameof(person1)
|
||||||
|
mname = GrampsCfg.nameof(person2)
|
||||||
|
label_text = "Merge %s and %s" % (fname,mname)
|
||||||
self.glade.get_widget("progress").set_text(label_text)
|
self.glade.get_widget("progress").set_text(label_text)
|
||||||
f1 = person1.getMainParents()
|
f1 = person1.getMainParents()
|
||||||
f2 = person2.getMainParents()
|
f2 = person2.getMainParents()
|
||||||
@ -92,24 +94,18 @@ class MergePeople:
|
|||||||
father2 = ""
|
father2 = ""
|
||||||
mother2 = ""
|
mother2 = ""
|
||||||
|
|
||||||
self.glade.get_widget("id1_text").set_text(person1.getId())
|
self.set_field(self.glade.get_widget("id1_text"),person1.getId())
|
||||||
self.glade.get_widget("id2_text").set_text(person2.getId())
|
self.set_field(self.glade.get_widget("id2_text"),person2.getId())
|
||||||
self.glade.get_widget("name1_text").set_text(name1)
|
self.set_field(self.glade.get_widget("name1_text"),name1)
|
||||||
self.glade.get_widget("name1_text").set_position(0)
|
self.set_field(self.glade.get_widget("name2_text"),name2)
|
||||||
self.glade.get_widget("name2_text").set_text(name2)
|
|
||||||
self.glade.get_widget("name2_text").set_position(0)
|
|
||||||
|
|
||||||
self.bname1 = self.glade.get_widget("bname1")
|
self.bname1 = self.glade.get_widget("bname1")
|
||||||
self.bname1.set_active(1)
|
self.bname1.set_active(1)
|
||||||
|
|
||||||
self.glade.get_widget("birth1_text").set_text(birth1)
|
self.set_field(self.glade.get_widget("birth1_text"),birth1)
|
||||||
self.glade.get_widget("birth1_text").set_position(0)
|
self.set_field(self.glade.get_widget("birth2_text"),birth2)
|
||||||
self.glade.get_widget("birth2_text").set_text(birth2)
|
self.set_field(self.glade.get_widget("bplace1_text"),bplace1)
|
||||||
self.glade.get_widget("birth2_text").set_position(0)
|
self.set_field(self.glade.get_widget("bplace2_text"),bplace2)
|
||||||
self.glade.get_widget("bplace1_text").set_text(bplace1)
|
|
||||||
self.glade.get_widget("bplace1_text").set_position(0)
|
|
||||||
self.glade.get_widget("bplace2_text").set_text(bplace2)
|
|
||||||
self.glade.get_widget("bplace2_text").set_position(0)
|
|
||||||
|
|
||||||
if ((not birth1 and not bplace1) and (birth2 or bplace2) or
|
if ((not birth1 and not bplace1) and (birth2 or bplace2) or
|
||||||
(not birth1 or not bplace1) and (birth2 and bplace2)):
|
(not birth1 or not bplace1) and (birth2 and bplace2)):
|
||||||
@ -123,57 +119,18 @@ class MergePeople:
|
|||||||
else:
|
else:
|
||||||
self.glade.get_widget('death1').set_active(1)
|
self.glade.get_widget('death1').set_active(1)
|
||||||
|
|
||||||
self.glade.get_widget("death1_text").set_text(death1)
|
self.set_field(self.glade.get_widget("death1_text"),death1)
|
||||||
self.glade.get_widget("death1_text").set_position(0)
|
self.set_field(self.glade.get_widget("dplace1_text"),dplace1)
|
||||||
self.glade.get_widget("dplace1_text").set_text(dplace1)
|
self.set_field(self.glade.get_widget("death2_text"),death2)
|
||||||
self.glade.get_widget("dplace1_text").set_position(0)
|
self.set_field(self.glade.get_widget("dplace2_text"),dplace2)
|
||||||
|
|
||||||
self.glade.get_widget("death2_text").set_text(death2)
|
self.set_field(self.glade.get_widget("father1"),father1)
|
||||||
self.glade.get_widget("death2_text").set_position(0)
|
self.set_field(self.glade.get_widget("father2"),father2)
|
||||||
self.glade.get_widget("dplace2_text").set_text(dplace2)
|
self.set_field(self.glade.get_widget("mother1"),mother1)
|
||||||
self.glade.get_widget("dplace2_text").set_position(0)
|
self.set_field(self.glade.get_widget("mother2"),mother2)
|
||||||
|
|
||||||
self.glade.get_widget("father1").set_text(father1)
|
self.build_spouse_list(person1,self.glade.get_widget('spouse1'))
|
||||||
self.glade.get_widget("father1").set_position(0)
|
self.build_spouse_list(person2,self.glade.get_widget('spouse2'))
|
||||||
self.glade.get_widget("father2").set_text(father2)
|
|
||||||
self.glade.get_widget("father2").set_position(0)
|
|
||||||
self.glade.get_widget("mother1").set_text(mother1)
|
|
||||||
self.glade.get_widget("mother1").set_position(0)
|
|
||||||
self.glade.get_widget("mother2").set_text(mother2)
|
|
||||||
self.glade.get_widget("mother2").set_position(0)
|
|
||||||
|
|
||||||
p1list = person1.getFamilyList()
|
|
||||||
p2list = person2.getFamilyList()
|
|
||||||
|
|
||||||
length = min(len(p1list),3)
|
|
||||||
self.glade.get_widget("spouse1").clear()
|
|
||||||
for index in range(0,3):
|
|
||||||
if index < length and p1list[index]:
|
|
||||||
if person1.getGender() == RelLib.Person.male:
|
|
||||||
spouse = p1list[index].getMother()
|
|
||||||
else:
|
|
||||||
spouse = p1list[index].getFather()
|
|
||||||
|
|
||||||
if spouse == None:
|
|
||||||
name = "unknown"
|
|
||||||
else:
|
|
||||||
name = "%s (%s)" % (GrampsCfg.nameof(spouse),spouse.getId())
|
|
||||||
self.glade.get_widget("spouse1").append([name])
|
|
||||||
|
|
||||||
length = min(len(p2list),3)
|
|
||||||
self.glade.get_widget("spouse2").clear()
|
|
||||||
for index in range(0,3):
|
|
||||||
if index < length and p2list[index]:
|
|
||||||
if person2.getGender() == RelLib.Person.male:
|
|
||||||
spouse = p2list[index].getMother()
|
|
||||||
else:
|
|
||||||
spouse = p2list[index].getFather()
|
|
||||||
|
|
||||||
if spouse == None:
|
|
||||||
name = "unknown"
|
|
||||||
else:
|
|
||||||
name = "%s (%s)" % (GrampsCfg.nameof(spouse),spouse.getId())
|
|
||||||
self.glade.get_widget("spouse2").append([name])
|
|
||||||
|
|
||||||
if name1 != name2:
|
if name1 != name2:
|
||||||
self.altname.set_sensitive(1)
|
self.altname.set_sensitive(1)
|
||||||
@ -196,6 +153,30 @@ class MergePeople:
|
|||||||
else:
|
else:
|
||||||
self.altdeath.set_active(0)
|
self.altdeath.set_active(0)
|
||||||
|
|
||||||
|
def build_spouse_list(self,person,widget):
|
||||||
|
plist = person.getFamilyList()
|
||||||
|
|
||||||
|
length = min(len(plist),3)
|
||||||
|
widget.clear()
|
||||||
|
for index in range(0,3):
|
||||||
|
if index < length and plist[index]:
|
||||||
|
if person.getGender() == RelLib.Person.male:
|
||||||
|
spouse = plist[index].getMother()
|
||||||
|
else:
|
||||||
|
spouse = plist[index].getFather()
|
||||||
|
|
||||||
|
if spouse == None:
|
||||||
|
name = "unknown"
|
||||||
|
else:
|
||||||
|
sname = GrampsCfg.nameof(spouse)
|
||||||
|
name = "%s (%s)" % (sname,spouse.getId())
|
||||||
|
widget.append([name])
|
||||||
|
|
||||||
|
def set_field(self,widget,value):
|
||||||
|
"""Sets the string of the entry field at positions it a space 0"""
|
||||||
|
widget.set_text(value)
|
||||||
|
widget.set_position(0)
|
||||||
|
|
||||||
def place_name(self,event):
|
def place_name(self,event):
|
||||||
place = event.getPlace()
|
place = event.getPlace()
|
||||||
if place:
|
if place:
|
||||||
@ -225,11 +206,6 @@ class MergePeople:
|
|||||||
else:
|
else:
|
||||||
one.addSourceRef(xsrc)
|
one.addSourceRef(xsrc)
|
||||||
|
|
||||||
#---------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#---------------------------------------------------------------------
|
|
||||||
def on_merge_clicked(self,obj):
|
def on_merge_clicked(self,obj):
|
||||||
Utils.modified()
|
Utils.modified()
|
||||||
|
|
||||||
@ -336,6 +312,7 @@ class MergePeople:
|
|||||||
|
|
||||||
if self.p1.getNickName() == "":
|
if self.p1.getNickName() == "":
|
||||||
self.p1.setNickName(self.p2.getNickName())
|
self.p1.setNickName(self.p2.getNickName())
|
||||||
|
|
||||||
if self.p2.getNote() != "":
|
if self.p2.getNote() != "":
|
||||||
old_note = self.p1.getNote()
|
old_note = self.p1.getNote()
|
||||||
if old_note:
|
if old_note:
|
||||||
@ -349,11 +326,6 @@ class MergePeople:
|
|||||||
self.update(self.p1,self.p2)
|
self.update(self.p1,self.p2)
|
||||||
Utils.destroy_passed_object(self.top)
|
Utils.destroy_passed_object(self.top)
|
||||||
|
|
||||||
#---------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#---------------------------------------------------------------------
|
|
||||||
def find_family(self,family):
|
def find_family(self,family):
|
||||||
if self.p1.getGender() == RelLib.Person.male:
|
if self.p1.getGender() == RelLib.Person.male:
|
||||||
mother = family.getMother()
|
mother = family.getMother()
|
||||||
@ -366,14 +338,8 @@ class MergePeople:
|
|||||||
if myfamily.getFather() == father and \
|
if myfamily.getFather() == father and \
|
||||||
myfamily.getMother() == mother:
|
myfamily.getMother() == mother:
|
||||||
return myfamily
|
return myfamily
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
#---------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#---------------------------------------------------------------------
|
|
||||||
def merge_families(self):
|
def merge_families(self):
|
||||||
|
|
||||||
family_num = 0
|
family_num = 0
|
||||||
@ -389,7 +355,6 @@ class MergePeople:
|
|||||||
|
|
||||||
tgt_family = self.find_family(src_family)
|
tgt_family = self.find_family(src_family)
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# This is the case where a new family to be added to the
|
# This is the case where a new family to be added to the
|
||||||
# p1 as a result of the merge already exists as a
|
# p1 as a result of the merge already exists as a
|
||||||
@ -409,25 +374,23 @@ class MergePeople:
|
|||||||
|
|
||||||
for child in src_family.getChildList():
|
for child in src_family.getChildList():
|
||||||
if child not in tgt_family.getChildList():
|
if child not in tgt_family.getChildList():
|
||||||
|
parents = child.getParentList()
|
||||||
tgt_family.addChild(child)
|
tgt_family.addChild(child)
|
||||||
if child.getMainParents() == src_family:
|
if child.getMainParents() == src_family:
|
||||||
child.setMainParents(tgt_family)
|
child.setMainParents(tgt_family)
|
||||||
else:
|
i = 0
|
||||||
index = 0
|
for fam in parents[:]:
|
||||||
for fam in child.getParentList()[:]:
|
if fam[0] == src_family:
|
||||||
if fam[0] == src_family:
|
parents[i] = (tgt_family,fam[1],fam[2])
|
||||||
child.getParentList()[index] = (tgt_family,fam[1],fam[2])
|
i = i + 1
|
||||||
index = index + 1
|
|
||||||
|
|
||||||
# delete the old source family
|
# delete the old source family
|
||||||
del self.db.getFamilyMap()[src_family.getId()]
|
del self.db.getFamilyMap()[src_family.getId()]
|
||||||
|
|
||||||
continue
|
continue
|
||||||
|
|
||||||
#
|
|
||||||
# This is the case where a new family to be added
|
# This is the case where a new family to be added
|
||||||
# and it is not already in the list.
|
# and it is not already in the list.
|
||||||
#
|
|
||||||
|
|
||||||
if tgt_family:
|
if tgt_family:
|
||||||
|
|
||||||
@ -440,15 +403,15 @@ class MergePeople:
|
|||||||
|
|
||||||
for child in src_family.getChildList():
|
for child in src_family.getChildList():
|
||||||
if child not in tgt_family.getChildList():
|
if child not in tgt_family.getChildList():
|
||||||
|
parents = child.getParentList()
|
||||||
tgt_family.addChild(child)
|
tgt_family.addChild(child)
|
||||||
if child.getMainParents() == src_family:
|
if child.getMainParents() == src_family:
|
||||||
child.setMainParents(tgt_family)
|
child.setMainParents(tgt_family)
|
||||||
else:
|
i = 0
|
||||||
index = 0
|
for fam in parents[:]:
|
||||||
for fam in child.getParentList()[:]:
|
if fam[0] == src_family:
|
||||||
if fam[0] == src_family:
|
parents[i] = (tgt_family,fam[1],fam[2])
|
||||||
child.getParentList()[index] = (tgt_family,fam[1],fam[2])
|
i = i + 1
|
||||||
index = index + 1
|
|
||||||
|
|
||||||
# add family events from the old to the new
|
# add family events from the old to the new
|
||||||
for event in src_family.getEventList():
|
for event in src_family.getEventList():
|
||||||
@ -611,7 +574,6 @@ def compare_people(p1,p2):
|
|||||||
|
|
||||||
return chance
|
return chance
|
||||||
|
|
||||||
|
|
||||||
#-----------------------------------------------------------------
|
#-----------------------------------------------------------------
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
@ -653,31 +615,35 @@ def date_match(date1,date2):
|
|||||||
#
|
#
|
||||||
#-----------------------------------------------------------------
|
#-----------------------------------------------------------------
|
||||||
def range_compare(date1,date2):
|
def range_compare(date1,date2):
|
||||||
|
d1_start = date1.get_start_date()
|
||||||
|
d2_start = date2.get_start_date()
|
||||||
|
d1_stop = date1.get_stop_date()
|
||||||
|
d2_stop = date2.get_stop_date()
|
||||||
|
|
||||||
if date1.isRange() and date2.isRange():
|
if date1.isRange() and date2.isRange():
|
||||||
if date1.get_start_date() >= date2.get_start_date() and \
|
if d1_start >= d2_start and d1_start <= d2_stop or \
|
||||||
date1.get_start_date() <= date2.get_stop_date() or \
|
d2_start >= d1_start and d2_start <= d1_stop or \
|
||||||
date2.get_start_date() >= date1.get_start_date() and \
|
d1_stop >= d2_start and d1_stop <= d2_stop or \
|
||||||
date2.get_start_date() <= date1.get_stop_date() or \
|
d2_stop >= d1_start and d2_stop <= d1_stop:
|
||||||
date1.get_stop_date() >= date2.get_start_date() and \
|
|
||||||
date1.get_stop_date() <= date2.get_stop_date() or \
|
|
||||||
date2.get_stop_date() >= date1.get_start_date() and \
|
|
||||||
date2.get_stop_date() <= date1.get_stop_date():
|
|
||||||
return 0.5
|
return 0.5
|
||||||
else:
|
else:
|
||||||
return -1.0
|
return -1.0
|
||||||
elif date2.isRange():
|
elif date2.isRange():
|
||||||
if date1.get_start_date() >= date2.get_start_date() and \
|
if d1_start >= d2_start and d1_start <= d2_stop:
|
||||||
date1.get_start_date() <= date2.get_stop_date():
|
|
||||||
return 0.5
|
return 0.5
|
||||||
else:
|
else:
|
||||||
return -1.0
|
return -1.0
|
||||||
else:
|
else:
|
||||||
if date2.get_start_date() >= date1.get_start_date() and \
|
if d2_start >= d1_start and d2_start <= d1_stop:
|
||||||
date2.get_start_date() <= date1.get_stop_date():
|
|
||||||
return 0.5
|
return 0.5
|
||||||
else:
|
else:
|
||||||
return -1.0
|
return -1.0
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#---------------------------------------------------------------------
|
||||||
def name_match(name,name1):
|
def name_match(name,name1):
|
||||||
|
|
||||||
if not name1 or not name:
|
if not name1 or not name:
|
||||||
@ -786,6 +752,11 @@ def is_initial(name):
|
|||||||
else:
|
else:
|
||||||
return name[0] in string.uppercase
|
return name[0] in string.uppercase
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#---------------------------------------------------------------------
|
||||||
def ancestors_of(p1,list):
|
def ancestors_of(p1,list):
|
||||||
if p1 == None:
|
if p1 == None:
|
||||||
return
|
return
|
||||||
@ -795,10 +766,15 @@ def ancestors_of(p1,list):
|
|||||||
ancestors_of(f1.getFather(),list)
|
ancestors_of(f1.getFather(),list)
|
||||||
ancestors_of(f1.getMother(),list)
|
ancestors_of(f1.getMother(),list)
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#---------------------------------------------------------------------
|
||||||
def name_of(p):
|
def name_of(p):
|
||||||
if not p:
|
if not p:
|
||||||
return ""
|
return ""
|
||||||
return "%s (%s)" % ( GrampsCfg.nameof(p),p.getId())
|
return "%s (%s)" % (GrampsCfg.nameof(p),p.getId())
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
|
Loading…
x
Reference in New Issue
Block a user