3996: show divorce information in a "text" descendant report

svn: r16353
This commit is contained in:
Nick Hall 2011-01-09 00:06:55 +00:00
parent bb41511fc4
commit 4264cbb8a0

View File

@ -50,7 +50,8 @@ from gen.plug.report import utils as ReportUtils
from gui.plug.report import MenuReportOptions from gui.plug.report import MenuReportOptions
import DateHandler import DateHandler
import Sort import Sort
from gen.utils import get_birth_or_fallback, get_death_or_fallback from gen.utils import (get_birth_or_fallback, get_death_or_fallback,
get_marriage_or_fallback, get_divorce_or_fallback)
#------------------------------------------------------------------------ #------------------------------------------------------------------------
@ -124,13 +125,14 @@ class Printinfo():
A base class used to help make the individual numbering system classes. A base class used to help make the individual numbering system classes.
This class must first be initialized with set_class_vars This class must first be initialized with set_class_vars
""" """
def __init__(self, doc, database, numbering, showmarriage): def __init__(self, doc, database, numbering, showmarriage, showdivorce):
#classes #classes
self.doc = doc self.doc = doc
self.database = database self.database = database
self.numbering = numbering self.numbering = numbering
#variables #variables
self.showmarriage = showmarriage self.showmarriage = showmarriage
self.showdivorce = showdivorce
def __date_place(self,event): def __date_place(self,event):
if event: if event:
@ -163,8 +165,14 @@ class Printinfo():
if string: if string:
string = " (" + string + ")" string = " (" + string + ")"
if family is not None: if family and self.showmarriage:
tmp = self.__date_place(ReportUtils.find_marriage(self.database, tmp = self.__date_place(get_marriage_or_fallback(self.database,
family))
if tmp:
string += ", " + tmp
if family and self.showdivorce:
tmp = self.__date_place(get_divorce_or_fallback(self.database,
family)) family))
if tmp: if tmp:
string += ", " + tmp string += ", " + tmp
@ -187,10 +195,7 @@ class Printinfo():
self.doc.start_paragraph("DR-Spouse%d" % min(level, 32)) self.doc.start_paragraph("DR-Spouse%d" % min(level, 32))
name = _nd.display(spouse) name = _nd.display(spouse)
self.doc.write_text(_("sp. %(spouse)s") % {'spouse':name}, mark) self.doc.write_text(_("sp. %(spouse)s") % {'spouse':name}, mark)
if self.showmarriage: self.dump_string(spouse, family_handle)
self.dump_string(spouse, family_handle)
else:
self.dump_string(spouse)
self.doc.end_paragraph() self.doc.end_paragraph()
@ -279,9 +284,10 @@ class DescendantReport(Report):
else: else:
raise AttributeError("no such numbering: '%s'" % self.numbering) raise AttributeError("no such numbering: '%s'" % self.numbering)
self.objPrint = Printinfo(self.doc, database, obj, marrs = menu.get_option_by_name('marrs').get_value()
menu.get_option_by_name('marrs').get_value()) divs = menu.get_option_by_name('divs').get_value()
self.objPrint = Printinfo(self.doc, database, obj, marrs, divs)
def write_report(self): def write_report(self):
self.doc.start_paragraph("DR-Title") self.doc.start_paragraph("DR-Title")
@ -331,6 +337,10 @@ class DescendantOptions(MenuReportOptions):
marrs.set_help(_("Whether to show marriage information in the report.")) marrs.set_help(_("Whether to show marriage information in the report."))
menu.add_option(category_name, "marrs", marrs) menu.add_option(category_name, "marrs", marrs)
divs = BooleanOption(_('Show divorce info'), False)
divs.set_help(_("Whether to show divorce information in the report."))
menu.add_option(category_name, "divs", divs)
def make_default_style(self, default_style): def make_default_style(self, default_style):
"""Make the default output style for the Descendant Report.""" """Make the default output style for the Descendant Report."""
f = FontStyle() f = FontStyle()