d9a1acc4f5
svn: r9985
154 lines
4.7 KiB
Python
154 lines
4.7 KiB
Python
#
|
|
# Gramps - a GTK+/GNOME based genealogy program
|
|
#
|
|
# Copyright (C) 2007 Brian G. Matherly
|
|
#
|
|
# 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
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
#
|
|
# $Id$
|
|
|
|
"""
|
|
Provide utilities for printing endnotes in text reports.
|
|
"""
|
|
|
|
import BaseDoc
|
|
from gettext import gettext as _
|
|
|
|
def add_endnote_styles(style_sheet):
|
|
"""
|
|
Add paragraph styles to a style sheet to be used for displaying endnotes.
|
|
|
|
@param style_sheet: Style sheet
|
|
@type style_sheet: L{Basedoc.StyleSheet}
|
|
"""
|
|
font = BaseDoc.FontStyle()
|
|
font.set(face=BaseDoc.FONT_SANS_SERIF, size=14, italic=1)
|
|
para = BaseDoc.ParagraphStyle()
|
|
para.set_font(font)
|
|
para.set_header_level(2)
|
|
para.set_top_margin(0.25)
|
|
para.set_bottom_margin(0.25)
|
|
para.set_description(_('The style used for the generation header.'))
|
|
style_sheet.add_paragraph_style("Endnotes-Header", para)
|
|
|
|
para = BaseDoc.ParagraphStyle()
|
|
para.set(first_indent=-0.75, lmargin=.75)
|
|
para.set_top_margin(0.25)
|
|
para.set_bottom_margin(0.25)
|
|
para.set_description(_('The basic style used for the endnotes source display.'))
|
|
style_sheet.add_paragraph_style("Endnotes-Source", para)
|
|
|
|
para = BaseDoc.ParagraphStyle()
|
|
para.set(lmargin=1.5)
|
|
para.set_top_margin(0.25)
|
|
para.set_bottom_margin(0.25)
|
|
para.set_description(_('The basic style used for the endnotes reference display.'))
|
|
style_sheet.add_paragraph_style("Endnotes-Ref", para)
|
|
|
|
def cite_source(bibliography, obj):
|
|
"""
|
|
Cite any sources for the object and add them to the bibliography.
|
|
|
|
@param bibliography: The bibliography to contain the citations.
|
|
@type bibliography: L{Bibliography}
|
|
@param obj: An object with source references.
|
|
@type obj: L{Relib.SourceBase}
|
|
"""
|
|
txt = ""
|
|
slist = obj.get_source_references()
|
|
if slist:
|
|
first = 1
|
|
for ref in slist:
|
|
if not first:
|
|
txt += ', '
|
|
first = 0
|
|
(cindex, key) = bibliography.add_reference(ref)
|
|
txt += "%d" % (cindex + 1)
|
|
if key != None:
|
|
txt += key
|
|
return txt
|
|
|
|
def write_endnotes(bibliography, database, doc):
|
|
"""
|
|
Write all the entries in the bibliography as endnotes.
|
|
|
|
@param bibliography: The bibliography that contains the citations.
|
|
@type bibliography: L{Bibliography}
|
|
@param database: The database that the sources come from.
|
|
@type database: GrampsDbBase
|
|
@param doc: The document to write the endnotes into.
|
|
@type doc: L{BaseDoc.TextDoc}
|
|
"""
|
|
if bibliography.get_citation_count() == 0:
|
|
return
|
|
|
|
doc.start_paragraph('Endnotes-Header')
|
|
doc.write_text(_('Endnotes'))
|
|
doc.end_paragraph()
|
|
|
|
cindex = 0
|
|
for citation in bibliography.get_citation_list():
|
|
cindex += 1
|
|
source = database.get_source_from_handle(citation.get_source_handle())
|
|
first = True
|
|
|
|
doc.start_paragraph('Endnotes-Source', "%d." % cindex)
|
|
|
|
src_txt = _format_source_text(source)
|
|
|
|
doc.write_text(src_txt)
|
|
doc.end_paragraph()
|
|
|
|
ref_list = citation.get_ref_list()
|
|
|
|
if ref_list:
|
|
doc.start_paragraph('Endnotes-Ref')
|
|
|
|
first = True
|
|
rindex = 0
|
|
for key, ref in ref_list:
|
|
txt = "%s: %s" % (key, ref.get_page())
|
|
if first:
|
|
doc.write_text(txt)
|
|
first = False
|
|
else:
|
|
doc.write_text('\n%s' % txt)
|
|
|
|
rindex += 1
|
|
doc.end_paragraph()
|
|
|
|
def _format_source_text(source):
|
|
src_txt = ""
|
|
|
|
if source.get_author():
|
|
src_txt += source.get_author()
|
|
|
|
if source.get_title():
|
|
if src_txt:
|
|
src_txt += ", "
|
|
src_txt += '"%s"' % source.get_title()
|
|
|
|
if source.get_publication_info():
|
|
if src_txt:
|
|
src_txt += ", "
|
|
src_txt += source.get_publication_info()
|
|
|
|
if source.get_abbreviation():
|
|
if src_txt:
|
|
src_txt += ", "
|
|
src_txt += "(%s)" % source.get_abbreviation()
|
|
|
|
return src_txt
|