* src/plugins/DetDescendantReport.py (write_mate): Swap mate and
person variables, clear code a bit. (make_report, add+user_options): Allow same set of options as the detailed ancestral report. svn: r1634
This commit is contained in:
parent
8b9c073555
commit
6766d5ad7b
@ -1,7 +1,7 @@
|
|||||||
#
|
#
|
||||||
# Gramps - a GTK+/GNOME based genealogy program
|
# Gramps - a GTK+/GNOME based genealogy program
|
||||||
#
|
#
|
||||||
# Copyright (C) 2000 Bruce J. DeGrasse
|
# Copyright (C) 2000-2003 Bruce J. DeGrasse
|
||||||
#
|
#
|
||||||
# This program is free software; you can redistribute it and/or modify
|
# This program is free software; you can redistribute it and/or modify
|
||||||
# it under the terms of the GNU General Public License as published by
|
# it under the terms of the GNU General Public License as published by
|
||||||
@ -18,7 +18,7 @@
|
|||||||
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
#
|
#
|
||||||
|
|
||||||
"Generate files/Detailed Ancestral Report"
|
"Generate files/Detailed Descendant Report"
|
||||||
|
|
||||||
import RelLib
|
import RelLib
|
||||||
import os
|
import os
|
||||||
@ -510,44 +510,37 @@ class DetDescendantReport(Report):
|
|||||||
if t != "": self.doc.write_text(t)
|
if t != "": self.doc.write_text(t)
|
||||||
if fam_num == len(famList): self.doc.write_text(".")
|
if fam_num == len(famList): self.doc.write_text(".")
|
||||||
|
|
||||||
def write_mate(self, mate, rptOptions):
|
def write_mate(self, person, rptOptions):
|
||||||
"""Output birth, death, parentage, marriage and notes information """
|
"""Output birth, death, parentage, marriage and notes information """
|
||||||
|
|
||||||
famList= mate.getFamilyList()
|
for fam in person.getFamilyList():
|
||||||
|
mate = ""
|
||||||
if len(famList) > 0:
|
if person.getGender() == RelLib.Person.male:
|
||||||
for fam in famList:
|
heshe = _("He")
|
||||||
person= ""
|
if fam.getMother():
|
||||||
if mate.getGender() == RelLib.Person.male:
|
mate = fam.getMother()
|
||||||
if fam.getMother() != None:
|
mateName = mate.getPrimaryName().getRegularName()
|
||||||
ind= fam.getMother()
|
mateFirstName = mate.getPrimaryName().getFirstName()
|
||||||
person= fam.getMother().getPrimaryName().getRegularName()
|
|
||||||
firstName= fam.getMother().getPrimaryName().getFirstName()
|
|
||||||
heshe= _("He")
|
|
||||||
else:
|
else:
|
||||||
heshe= _("She")
|
heshe = _("She")
|
||||||
if fam.getFather() != None:
|
if fam.getFather():
|
||||||
ind= fam.getFather()
|
mate = fam.getFather()
|
||||||
person= fam.getFather().getPrimaryName().getRegularName()
|
mateName = mate.getPrimaryName().getRegularName()
|
||||||
firstName= fam.getFather().getPrimaryName().getFirstName()
|
mateFirstName = mate.getPrimaryName().getFirstName()
|
||||||
|
|
||||||
if person != "":
|
if mate:
|
||||||
self.doc.start_paragraph("Entry")
|
self.doc.start_paragraph("Entry")
|
||||||
|
|
||||||
if rptOptions.addImages == reportOptions.Yes:
|
if rptOptions.addImages == reportOptions.Yes:
|
||||||
self.insert_images(ind, rptOptions.imageAttrTag)
|
self.insert_images(mate, rptOptions.imageAttrTag)
|
||||||
|
|
||||||
if rptOptions.firstName == reportOptions.No:
|
if rptOptions.firstName == reportOptions.No:
|
||||||
firstName= heshe
|
mateFirstName = heshe
|
||||||
|
|
||||||
self.doc.write_text(person)
|
|
||||||
|
|
||||||
self.write_birth(ind, rptOptions)
|
|
||||||
|
|
||||||
self.write_death(ind, firstName, rptOptions)
|
|
||||||
|
|
||||||
self.write_parents(ind, firstName)
|
|
||||||
|
|
||||||
|
self.doc.write_text(mateName)
|
||||||
|
self.write_birth(mate, rptOptions)
|
||||||
|
self.write_death(mate, mateFirstName, rptOptions)
|
||||||
|
self.write_parents(mate, mateFirstName)
|
||||||
self.doc.end_paragraph()
|
self.doc.end_paragraph()
|
||||||
|
|
||||||
#if rptOptions.listChildren == reportOptions.Yes \
|
#if rptOptions.listChildren == reportOptions.Yes \
|
||||||
@ -612,11 +605,11 @@ class DetDescendantReport(Report):
|
|||||||
#
|
#
|
||||||
#
|
#
|
||||||
#--------------------------------------------------------------------
|
#--------------------------------------------------------------------
|
||||||
def write_report(self):
|
def write_report(self, rptOpt):
|
||||||
|
|
||||||
self.cur_gen= 1
|
self.cur_gen= 1
|
||||||
self.filter(self.start,1, 1)
|
self.filter(self.start,1, 1)
|
||||||
rptOpt= reportOptions()
|
#rptOpt= reportOptions()
|
||||||
|
|
||||||
name = self.start.getPrimaryName().getRegularName()
|
name = self.start.getPrimaryName().getRegularName()
|
||||||
|
|
||||||
@ -635,7 +628,7 @@ class DetDescendantReport(Report):
|
|||||||
if spouseName != "":
|
if spouseName != "":
|
||||||
name = spouseName + " and " + name
|
name = spouseName + " and " + name
|
||||||
|
|
||||||
title = _("Descendant Report for %s") % name
|
title = _("Detailed Descendant Report for %s") % name
|
||||||
self.doc.write_text(title)
|
self.doc.write_text(title)
|
||||||
self.doc.end_paragraph()
|
self.doc.end_paragraph()
|
||||||
|
|
||||||
@ -761,12 +754,155 @@ class DetDescendantReportDialog(TextReportDialog):
|
|||||||
#
|
#
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
def make_report(self):
|
def make_report(self):
|
||||||
"""Create the object that will produce the Detailed Ancestral
|
"""Create the object that will produce the Detailed Descendant
|
||||||
Report. All user dialog has already been handled and the
|
Report. All user dialog has already been handled and the
|
||||||
output file opened."""
|
output file opened."""
|
||||||
MyReport = DetDescendantReport(self.db, self.person, self.target_path,
|
|
||||||
self.max_gen, self.pg_brk, self.doc)
|
try:
|
||||||
MyReport.write_report()
|
MyReport = DetDescendantReport(self.db, self.person,
|
||||||
|
self.target_path, self.max_gen, self.pg_brk, self.doc)
|
||||||
|
|
||||||
|
rptOpt= reportOptions()
|
||||||
|
rptOpt.firstName= self.firstName
|
||||||
|
rptOpt.fullDate= self.fullDate
|
||||||
|
rptOpt.listChildren= self.listChildren
|
||||||
|
rptOpt.includeNotes= self.includeNotes
|
||||||
|
rptOpt.blankPlace= self.blankPlace
|
||||||
|
rptOpt.blankDate= self.blankDate
|
||||||
|
rptOpt.calcAgeFlag= self.calcAgeFlag
|
||||||
|
rptOpt.dupPersons= self.dupPersons
|
||||||
|
rptOpt.childRef= self.childRef
|
||||||
|
rptOpt.addImages= self.addImages
|
||||||
|
|
||||||
|
MyReport.write_report(rptOpt)
|
||||||
|
except Errors.ReportError, msg:
|
||||||
|
(m1,m2) = msg.messages()
|
||||||
|
ErrorDialog(m1,m2)
|
||||||
|
except Errors.FilterError, msg:
|
||||||
|
(m1,m2) = msg.messages()
|
||||||
|
ErrorDialog(m1,m2)
|
||||||
|
except:
|
||||||
|
import DisplayTrace
|
||||||
|
DisplayTrace.DisplayTrace()
|
||||||
|
|
||||||
|
#*** Begin change
|
||||||
|
def add_user_options(self):
|
||||||
|
# Create a GTK Checkbox widgets
|
||||||
|
|
||||||
|
# Pronoun instead of first name
|
||||||
|
self.first_name_option = gtk.CheckButton(_("Use first names instead of pronouns"))
|
||||||
|
self.first_name_option.set_active(0)
|
||||||
|
|
||||||
|
# Full date usage
|
||||||
|
self.full_date_option = gtk.CheckButton(_("Use full dates instead of only the year"))
|
||||||
|
self.full_date_option.set_active(1)
|
||||||
|
|
||||||
|
# Children List
|
||||||
|
self.list_children_option = gtk.CheckButton(_("List children"))
|
||||||
|
self.list_children_option.set_active(1)
|
||||||
|
|
||||||
|
# Print notes
|
||||||
|
self.include_notes_option = gtk.CheckButton(_("Include notes"))
|
||||||
|
self.include_notes_option.set_active(1)
|
||||||
|
|
||||||
|
# Replace missing Place with ___________
|
||||||
|
self.place_option = gtk.CheckButton(_("Replace Place with ______"))
|
||||||
|
self.place_option.set_active(0)
|
||||||
|
|
||||||
|
# Replace missing dates with __________
|
||||||
|
self.date_option = gtk.CheckButton(_("Replace Dates with ______"))
|
||||||
|
self.date_option.set_active(0)
|
||||||
|
|
||||||
|
# Add "Died at the age of NN" in text
|
||||||
|
self.age_option = gtk.CheckButton(_("Compute age"))
|
||||||
|
self.age_option.set_active(1)
|
||||||
|
|
||||||
|
# Omit duplicate persons, occurs when distant cousins marry
|
||||||
|
self.dupPersons_option = gtk.CheckButton(_("Omit duplicate people"))
|
||||||
|
self.dupPersons_option.set_active(1)
|
||||||
|
|
||||||
|
#Add descendant reference in child list
|
||||||
|
self.childRef_option = gtk.CheckButton(_("Add descendant reference in child list"))
|
||||||
|
self.childRef_option.set_active(1)
|
||||||
|
|
||||||
|
#Add photo/image reference
|
||||||
|
self.image_option = gtk.CheckButton(_("Include Photo/Images from Gallery"))
|
||||||
|
self.image_option.set_active(0)
|
||||||
|
|
||||||
|
# Add new options. The first argument is the tab name for grouping options.
|
||||||
|
# if you want to put everyting in the generic "Options" category, use
|
||||||
|
# self.add_option(text,widget) instead of self.add_frame_option(category,text,widget)
|
||||||
|
|
||||||
|
self.add_frame_option('Content','',self.first_name_option)
|
||||||
|
self.add_frame_option('Content','',self.full_date_option)
|
||||||
|
self.add_frame_option('Content','',self.list_children_option)
|
||||||
|
self.add_frame_option('Content','',self.include_notes_option)
|
||||||
|
self.add_frame_option('Content','',self.place_option)
|
||||||
|
self.add_frame_option('Content','',self.date_option)
|
||||||
|
self.add_frame_option('Content','',self.age_option)
|
||||||
|
self.add_frame_option('Content','',self.dupPersons_option)
|
||||||
|
self.add_frame_option('Content','',self.childRef_option)
|
||||||
|
self.add_frame_option('Content','',self.image_option)
|
||||||
|
|
||||||
|
|
||||||
|
def parse_report_options_frame(self):
|
||||||
|
"""Parse the report options frame of the dialog. Save the user selected choices for later use."""
|
||||||
|
|
||||||
|
# call the parent task to handle normal options
|
||||||
|
ReportDialog.parse_report_options_frame(self)
|
||||||
|
|
||||||
|
# get values from the widgets
|
||||||
|
if self.first_name_option.get_active():
|
||||||
|
self.firstName = reportOptions.Yes
|
||||||
|
else:
|
||||||
|
self.firstName = reportOptions.No
|
||||||
|
|
||||||
|
if self.full_date_option.get_active():
|
||||||
|
self.fullDate = reportOptions.Yes
|
||||||
|
else:
|
||||||
|
self.fullDate = reportOptions.No
|
||||||
|
|
||||||
|
if self.list_children_option.get_active():
|
||||||
|
self.listChildren = reportOptions.Yes
|
||||||
|
else:
|
||||||
|
self.listChildren = reportOptions.No
|
||||||
|
|
||||||
|
if self.include_notes_option.get_active():
|
||||||
|
self.includeNotes = reportOptions.Yes
|
||||||
|
else:
|
||||||
|
self.includeNotes = reportOptions.No
|
||||||
|
|
||||||
|
if self.place_option.get_active():
|
||||||
|
self.blankPlace = reportOptions.Yes
|
||||||
|
else:
|
||||||
|
self.blankPlace = reportOptions.No
|
||||||
|
|
||||||
|
if self.date_option.get_active():
|
||||||
|
self.blankDate = reportOptions.Yes
|
||||||
|
else:
|
||||||
|
self.blankDate = reportOptions.No
|
||||||
|
|
||||||
|
if self.age_option.get_active():
|
||||||
|
self.calcAgeFlag = reportOptions.Yes
|
||||||
|
else:
|
||||||
|
self.calcAgeFlag = reportOptions.No
|
||||||
|
|
||||||
|
if self.dupPersons_option.get_active():
|
||||||
|
self.dupPersons = reportOptions.Yes
|
||||||
|
else:
|
||||||
|
self.dupPersons = reportOptions.No
|
||||||
|
|
||||||
|
if self.childRef_option.get_active():
|
||||||
|
self.childRef = reportOptions.Yes
|
||||||
|
else:
|
||||||
|
self.childRef = reportOptions.No
|
||||||
|
|
||||||
|
if self.image_option.get_active():
|
||||||
|
self.addImages = reportOptions.Yes
|
||||||
|
else:
|
||||||
|
self.addImages = reportOptions.No
|
||||||
|
|
||||||
|
#*** End of change
|
||||||
|
|
||||||
|
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
|
Loading…
Reference in New Issue
Block a user