ageondate quickview: show reason why considered alive or dead

svn: r23087
This commit is contained in:
Doug Blank 2013-09-11 10:56:26 +00:00
parent 621615bbd1
commit 6e51929bde

View File

@ -53,20 +53,34 @@ def run(database, document, date):
else: else:
sdoc.title(_("People probably alive and their ages on %s") % sdoc.title(_("People probably alive and their ages on %s") %
displayer.display(date)) displayer.display(date))
stab.columns(_("Person"), _("Age")) # Actual Date makes column unicode stab.columns(_("Person"), _("Age"), _("Status")) # Actual Date makes column unicode
matches = 0 alive_matches = 0
dead_matches = 0
for person in sdb.all_people(): for person in sdb.all_people():
alive, birth, death, explain, relative = \ alive, birth, death, explain, relative = \
probably_alive(person, database, date, return_range=True) probably_alive(person, database, date, return_range=True)
# Doesn't show people probably alive but no way of figuring an age: # Doesn't show people probably alive but no way of figuring an age:
if alive and birth: if alive:
diff_span = (date - birth) if birth:
stab.row(person, str(diff_span)) diff_span = (date - birth)
stab.row_sort_val(1, int(diff_span)) stab.row(person, str(diff_span), _("Alive: %s") % explain)
matches += 1 stab.row_sort_val(1, int(diff_span))
else:
stab.row(person, "", _("Alive: %s") % explain)
stab.row_sort_val(1, 0)
alive_matches += 1
else: # not alive
if birth:
diff_span = (date - birth)
stab.row(person, str(diff_span), _("Deceased: %s") % explain)
stab.row_sort_val(1, int(diff_span))
else:
stab.row(person, "", _("Deceased: %s") % explain)
stab.row_sort_val(1, 1)
dead_matches += 1
document.has_data = matches > 0 document.has_data = (alive_matches + dead_matches) > 0
sdoc.paragraph(_("\n%d matches.\n") % matches) sdoc.paragraph(_("\nLiving matches: %d, Deceased matches: %d\n") % (alive_matches, dead_matches))
stab.write(sdoc) stab.write(sdoc)
sdoc.paragraph("") sdoc.paragraph("")