Indicate if a person is dead in the birthdays report

Added a text option to have a string that will show after a persons name
in the birthday and anniversary report. This works for both birthdays
and anniversaries.

Issue #3540
This commit is contained in:
Jgon6 2018-03-05 20:10:44 -05:00 committed by Nick Hall
parent d98a1857dc
commit 5dc06d023d

View File

@ -65,6 +65,7 @@ def _T_(value): # enable deferred translations (see Python docs 22.1.3.4)
_TITLE0 = _T_("Birthday and Anniversary Report") _TITLE0 = _T_("Birthday and Anniversary Report")
_TITLE1 = _T_("My Birthday Report") _TITLE1 = _T_("My Birthday Report")
_TITLE2 = _T_("Produced with Gramps") _TITLE2 = _T_("Produced with Gramps")
_DEADTXT = _T_("")
#------------------------------------------------------------------------ #------------------------------------------------------------------------
# #
@ -316,15 +317,19 @@ class BirthdayReport(Report):
if relation: if relation:
# FIXME this won't work for RTL languages # FIXME this won't work for RTL languages
comment = " --- %s" % relation comment = " --- %s" % relation
deadtxt = ""
if (not alive):
deadtxt = _DEADTXT
if nyears == 0: if nyears == 0:
text = self._('%(person)s, birth%(relation)s') % { text = self._('%(person)s, birth%(relation)s') % {
'person' : short_name, 'person' : short_name,
'relation' : comment} 'relation' : comment}
else: else:
# translators: leave all/any {...} untranslated # translators: leave all/any {...} untranslated
text = ngettext('{person}, {age}{relation}', text = ngettext('{person}{dead}, {age}{relation}',
'{person}, {age}{relation}', '{person}{dead}, {age}{relation}',
nyears).format(person=short_name, nyears).format(person=short_name,
dead=deadtxt,
age=nyears, age=nyears,
relation=comment) relation=comment)
@ -369,21 +374,26 @@ class BirthdayReport(Report):
nyears = self.year - year nyears = self.year - year
if event_obj.is_valid(): if event_obj.is_valid():
prob_alive_date = Date(self.year, month, day)
alive1 = probably_alive(person, self.database,
prob_alive_date)
alive2 = probably_alive(spouse, self.database,
prob_alive_date)
deadtxt1 = ""
deadtxt2 = ""
if (not alive1):
deadtxt1 = _DEADTXT
if (not alive2):
deadtxt2 = _DEADTXT
if nyears == 0: if nyears == 0:
text = self._("%(spouse)s and\n %(person)s, wedding") % { text = self._("%(spouse)s and\n %(person)s, wedding") % {
'spouse' : spouse_name, 'spouse' : spouse_name,
'person' : short_name} 'person' : short_name}
else: else:
# translators: leave all/any {...} untranslated # translators: leave all/any {...} untranslated
text = ngettext("{spouse} and\n {person}, {nyears}", text = ngettext("{spouse}{deadtxt2} and\n {person}{deadtxt1}, {nyears}",
"{spouse} and\n {person}, {nyears}", "{spouse}{deadtxt2} and\n {person}{deadtxt1}, {nyears}",
nyears).format(spouse=spouse_name, person=short_name, nyears=nyears) nyears).format(spouse=spouse_name, deadtxt2=deadtxt2, person=short_name, deadtxt1=deadtxt1, nyears=nyears)
prob_alive_date = Date(self.year, month, day)
alive1 = probably_alive(person, self.database,
prob_alive_date)
alive2 = probably_alive(spouse, self.database,
prob_alive_date)
if (self.alive and alive1 and alive2) or not self.alive: if (self.alive and alive1 and alive2) or not self.alive:
self.add_day_item(text, month, day, spouse) self.add_day_item(text, month, day, spouse)
@ -446,6 +456,10 @@ class BirthdayOptions(MenuReportOptions):
alive.set_help(_("Include only living people in the report")) alive.set_help(_("Include only living people in the report"))
menu.add_option(category_name, "alive", alive) menu.add_option(category_name, "alive", alive)
deadtxt = StringOption(_("Dead Symbol"), _(_DEADTXT))
deadtxt.set_help(_("This will show after name to indicate that person is dead"))
menu.add_option(category_name, "deadtxt", deadtxt)
self.__update_filters() self.__update_filters()
stdoptions.add_localization_option(menu, category_name) stdoptions.add_localization_option(menu, category_name)