* src/Editors/_EditPerson.py (reorder_child_ref_list): Use child_ref_list

svn: r6329
This commit is contained in:
Alex Roitman 2006-04-13 16:49:52 +00:00
parent 92ca2e8d02
commit 6699353c39

View File

@ -448,13 +448,13 @@ class EditPerson(EditPrimary):
family = self.obj.get_main_parents_family_handle() family = self.obj.get_main_parents_family_handle()
if (family): if (family):
f = self.db.find_family_from_handle(family, trans) f = self.db.find_family_from_handle(family, trans)
new_order = self.reorder_child_list(self.obj, new_order = self.reorder_child_ref_list(self.obj,
f.get_child_handle_list()) f.get_child_ref_list())
f.set_child_handle_list(new_order) f.set_child_handle_list(new_order)
for (family, rel1, rel2) in self.obj.get_parent_family_handle_list(): for (family, rel1, rel2) in self.obj.get_parent_family_handle_list():
f = self.db.find_family_from_handle(family, trans) f = self.db.find_family_from_handle(family, trans)
new_order = self.reorder_child_list(self.obj, new_order = self.reorder_child_ref_list(self.obj,
f.get_child_handle_list()) f.get_child_ref_list())
f.set_child_handle_list(new_order) f.set_child_handle_list(new_order)
error = False error = False
@ -580,13 +580,14 @@ class EditPerson(EditPrimary):
else: else:
self.load_photo(None) self.load_photo(None)
def birth_dates_in_order(self, child_list): def birth_dates_in_order(self, child_ref_list):
"""Check any *valid* birthdates in the list to insure that they are in """Check any *valid* birthdates in the list to insure that they are in
numerically increasing order.""" numerically increasing order."""
inorder = True inorder = True
prev_date = 0 prev_date = 0
for i in range(len(child_list)): handle_list = [ref.ref for ref in child_ref_list]
child_handle = child_list[i] for i in range(len(handle_list)):
child_handle = handle_list[i]
child = self.db.get_person_from_handle(child_handle) child = self.db.get_person_from_handle(child_handle)
if child.get_birth_ref(): if child.get_birth_ref():
event_handle = child.get_birth_ref().ref event_handle = child.get_birth_ref().ref
@ -600,13 +601,13 @@ class EditPerson(EditPrimary):
inorder = False inorder = False
return inorder return inorder
def reorder_child_list(self, person, child_list): def reorder_child_ref_list(self, person, child_ref_list):
"""Reorder the child list to put the specified person in his/her """Reorder the child list to put the specified person in his/her
correct birth order. Only check *valid* birthdates. Move the person correct birth order. Only check *valid* birthdates. Move the person
as short a distance as possible.""" as short a distance as possible."""
if self.birth_dates_in_order(child_list): if self.birth_dates_in_order(child_ref_list):
return(child_list) return(child_ref_list)
# Build the person's date string once # Build the person's date string once
event_ref = person.get_birth_ref() event_ref = person.get_birth_ref()
@ -617,11 +618,12 @@ class EditPerson(EditPrimary):
person_bday = 0 person_bday = 0
# First, see if the person needs to be moved forward in the list # First, see if the person needs to be moved forward in the list
handle_list = [ref.ref for ref in child_ref_list]
index = child_list.index(person.get_handle()) index = handle_list.index(person.get_handle())
target = index target = index
for i in range(index-1, -1, -1): for i in range(index-1, -1, -1):
other = self.db.get_person_from_handle(child_list[i]) other = self.db.get_person_from_handle(handle_list[i])
event_ref = other.get_birth_ref() event_ref = other.get_birth_ref()
if event_ref: if event_ref:
event = self.db.get_event_from_handle(event_ref.ref) event = self.db.get_event_from_handle(event_ref.ref)
@ -635,8 +637,8 @@ class EditPerson(EditPrimary):
# Now try moving to a later position in the list # Now try moving to a later position in the list
if (target == index): if (target == index):
for i in range(index, len(child_list)): for i in range(index, len(handle_list)):
other = self.db.get_person_from_handle(child_list[i]) other = self.db.get_person_from_handle(handle_list[i])
event_ref = other.get_birth_ref() event_ref = other.get_birth_ref()
if event_ref: if event_ref:
event = self.db.get_event_from_handle(event_ref.ref) event = self.db.get_event_from_handle(event_ref.ref)
@ -650,7 +652,7 @@ class EditPerson(EditPrimary):
# Actually need to move? Do it now. # Actually need to move? Do it now.
if (target != index): if (target != index):
child_list.remove(person.get_handle()) ref = child_ref_list.pop(index)
child_list.insert(target, person.get_handle()) child_ref_list.insert(target, ref)
return child_list return child_ref_list