add TOC and index entries, for book report

svn: r21952
This commit is contained in:
Paul Franklin 2013-04-10 20:26:35 +00:00
parent d96c766cb1
commit 87c11877f4

View File

@ -45,7 +45,8 @@ from gramps.gen.lib import NameType, EventType, Name, Date, Person, Surname
from gramps.gen.relationship import get_relationship_calculator from gramps.gen.relationship import get_relationship_calculator
from gramps.gen.plug.docgen import (FontStyle, ParagraphStyle, GraphicsStyle, from gramps.gen.plug.docgen import (FontStyle, ParagraphStyle, GraphicsStyle,
FONT_SERIF, PARA_ALIGN_RIGHT, FONT_SERIF, PARA_ALIGN_RIGHT,
PARA_ALIGN_LEFT, PARA_ALIGN_CENTER) PARA_ALIGN_LEFT, PARA_ALIGN_CENTER,
IndexMark, INDEX_TYPE_TOC)
from gramps.gen.plug.menu import (BooleanOption, StringOption, NumberOption, from gramps.gen.plug.menu import (BooleanOption, StringOption, NumberOption,
EnumeratedListOption, FilterOption, PersonOption) EnumeratedListOption, FilterOption, PersonOption)
from gramps.gen.plug.report import Report from gramps.gen.plug.report import Report
@ -123,11 +124,11 @@ class BirthdayReport(Report):
name = Name(primary_name) name = Name(primary_name)
return self._name_display.display_name(name) return self._name_display.display_name(name)
def add_day_item(self, text, month, day): def add_day_item(self, text, month, day, person=None):
""" Add an item to a day. """ """ Add an item to a day. """
month_dict = self.calendar.get(month, {}) month_dict = self.calendar.get(month, {})
day_list = month_dict.get(day, []) day_list = month_dict.get(day, [])
day_list.append(text) day_list.append((text, person))
month_dict[day] = day_list month_dict[day] = day_list
self.calendar[month] = month_dict self.calendar[month] = month_dict
@ -153,7 +154,9 @@ class BirthdayReport(Report):
self.collect_data() self.collect_data()
# generate the report: # generate the report:
self.doc.start_paragraph('BIR-Title') self.doc.start_paragraph('BIR-Title')
self.doc.write_text(str(self.titletext) + ": " + str(self.year)) title = str(self.titletext) + ": " + str(self.year)
mark = IndexMark(title, INDEX_TYPE_TOC, 1)
self.doc.write_text(title, mark)
self.doc.end_paragraph() self.doc.end_paragraph()
if self.text1.strip() != "": if self.text1.strip() != "":
self.doc.start_paragraph('BIR-Text1style') self.doc.start_paragraph('BIR-Text1style')
@ -170,9 +173,11 @@ class BirthdayReport(Report):
if self.relationships: if self.relationships:
name = self.center_person.get_primary_name() name = self.center_person.get_primary_name()
self.doc.start_paragraph('BIR-Text3style') self.doc.start_paragraph('BIR-Text3style')
mark = ReportUtils.get_person_mark(self.database,
self.center_person)
# feature request 2356: avoid genitive form # feature request 2356: avoid genitive form
self.doc.write_text(_("Relationships shown are to %s") % self.doc.write_text(_("Relationships shown are to %s") %
self._name_display.display_name(name)) self._name_display.display_name(name), mark)
self.doc.end_paragraph() self.doc.end_paragraph()
self._user.begin_progress(_('Birthday and Anniversary Report'), self._user.begin_progress(_('Birthday and Anniversary Report'),
_('Formatting months...'), 12) _('Formatting months...'), 12)
@ -194,7 +199,8 @@ class BirthdayReport(Report):
thisday = current_date.fromordinal(current_ord) thisday = current_date.fromordinal(current_ord)
if thisday.month == month: if thisday.month == month:
list = self.calendar.get(month, {}).get(thisday.day, []) list = self.calendar.get(month, {}).get(thisday.day, [])
for p in list: for p, p_obj in list:
mark = ReportUtils.get_person_mark(self.database, p_obj)
p = p.replace("\n", " ") p = p.replace("\n", " ")
if thisday not in started_day: if thisday not in started_day:
self.doc.start_paragraph("BIR-Daystyle") self.doc.start_paragraph("BIR-Daystyle")
@ -202,7 +208,7 @@ class BirthdayReport(Report):
self.doc.end_paragraph() self.doc.end_paragraph()
started_day[thisday] = 1 started_day[thisday] = 1
self.doc.start_paragraph("BIR-Datastyle") self.doc.start_paragraph("BIR-Datastyle")
self.doc.write_text(p) self.doc.write_text(p, mark)
self.doc.end_paragraph() self.doc.end_paragraph()
current_ord += 1 current_ord += 1
@ -285,7 +291,7 @@ class BirthdayReport(Report):
'age' : nyears, 'age' : nyears,
'relation' : comment}) 'relation' : comment})
self.add_day_item(text, month, day) self.add_day_item(text, month, day, person)
if self.anniversaries: if self.anniversaries:
family_list = person.get_family_handle_list() family_list = person.get_family_handle_list()
for fhandle in family_list: for fhandle in family_list:
@ -341,7 +347,7 @@ class BirthdayReport(Report):
alive2 = probably_alive(spouse, self.database, alive2 = probably_alive(spouse, self.database,
prob_alive_date) 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) self.add_day_item(text, month, day, spouse)
self._user.end_progress() self._user.end_progress()
#------------------------------------------------------------------------ #------------------------------------------------------------------------