* src/plugins/AncestorChart.py: Change from TextDoc and DrawDoc to

BaseDoc. Enable Book item functionality.
* src/plugins/SimpleBookTitle.py: Change from TextDoc to BaseDoc.
* src/plugins/BookReport.py: Likewise.
* src/plugins/FtmStyleDescendants.py: Likewise.


svn: r2049
This commit is contained in:
Alex Roitman 2003-08-26 04:07:00 +00:00
parent d63ec34a2f
commit cd59a4f924
5 changed files with 197 additions and 55 deletions

View File

@ -16,6 +16,11 @@
(set_buttons,change_active_person): Fix enabling the buttons.
* src/PlaceView.py (merge): Change error message from people to places.
* src/docgen/OpenOfficeDoc.py (open): Typos.
* src/plugins/AncestorChart.py: Change from TextDoc and DrawDoc to
BaseDoc. Enable Book item functionality.
* src/plugins/SimpleBookTitle.py: Change from TextDoc to BaseDoc.
* src/plugins/BookReport.py: Likewise.
* src/plugins/FtmStyleDescendants.py: Likewise.
2003-08-24 Don Allingham <dallingham@users.sourceforge.net>
* src/plugins/FanChart.py: remove print statement

View File

@ -41,8 +41,7 @@ import gtk
#
#------------------------------------------------------------------------
import GrampsCfg
import DrawDoc
import TextDoc
import BaseDoc
import Report
import Errors
import FontScale
@ -68,7 +67,7 @@ def pt2cm(pt):
#------------------------------------------------------------------------
class AncestorChart:
def __init__(self,database,person,output,max,doc,display):
def __init__(self,database,person,max,display,doc,output,newpage=0):
self.doc = doc
self.doc.creator(database.getResearcher().getName())
self.map = {}
@ -80,6 +79,13 @@ class AncestorChart:
self.height = 0
self.lines = 0
self.display = display
self.newpage = newpage
self.calc()
if output:
self.standalone = 1
self.doc.open(output)
else:
self.standalone = 0
def filter(self,person,index):
"""traverse the ancestors recursively until either the end
@ -97,7 +103,7 @@ class AncestorChart:
for line in self.display:
self.text[index].append(subst.replace(line))
self.font = self.doc.style_list["Normal"].get_font()
self.font = self.doc.style_list["AC-Normal"].get_font()
for line in self.text[index]:
self.box_width = max(self.box_width,FontScale.string_width(self.font,line))
@ -109,11 +115,9 @@ class AncestorChart:
self.filter(family.getMother(),(index*2)+1)
def write_report(self):
self.calc()
try:
self.doc.open(self.output)
except:
raise Errors.ReportError(_("Could not create %s") % self.output)
if self.newpage:
self.doc.page_break()
generation = 1
done = 0
@ -129,7 +133,9 @@ class AncestorChart:
self.print_page(index, generation, page)
page = page + 1
generation = generation + 3
if self.standalone:
self.doc.close()
#self.doc.close()
def calc(self):
"""
@ -157,15 +163,15 @@ class AncestorChart:
ystart + 9*(uh/16.0), ystart + 11*(uh/16.0),
ystart + 13*(uh/16.0), ystart + 15*(uh/16.0)]
g = DrawDoc.GraphicsStyle()
g = BaseDoc.GraphicsStyle()
g.set_height(self.height)
g.set_width(self.box_width)
g.set_paragraph_style("Normal")
g.set_paragraph_style("AC-Normal")
g.set_shadow(1)
g.set_fill_color((255,255,255))
self.doc.add_draw_style("box",g)
g = DrawDoc.GraphicsStyle()
g = BaseDoc.GraphicsStyle()
self.doc.add_draw_style("line",g)
def get_numbers(self,start,index,vals):
@ -203,6 +209,21 @@ class AncestorChart:
self.draw_graph(index*2,start*2,level+1)
self.draw_graph((index*2)+1,(start*2)+1,level+1)
#------------------------------------------------------------------------
#
#
#
#------------------------------------------------------------------------
def _make_default_style(default_style):
"""Make the default output style for the Ancestor Chart report."""
f = BaseDoc.FontStyle()
f.set_size(9)
f.set_type_face(BaseDoc.FONT_SANS_SERIF)
p = BaseDoc.ParagraphStyle()
p.set_font(f)
p.set_description(_('The basic style used for the text display.'))
default_style.add_style("AC-Normal",p)
#------------------------------------------------------------------------
#
# AncestorChartDialog
@ -239,14 +260,7 @@ class AncestorChartDialog(Report.DrawReportDialog):
_("Allows you to customize the data in the boxes in the report"))
def make_default_style(self):
"""Make the default output style for the Ancestor Chart report."""
f = TextDoc.FontStyle()
f.set_size(9)
f.set_type_face(TextDoc.FONT_SANS_SERIF)
p = TextDoc.ParagraphStyle()
p.set_font(f)
p.set_description(_('The basic style used for the text display.'))
self.default_style.add_style("Normal",p)
_make_default_style(self.default_style)
def make_report(self):
"""Create the object that will produce the Ancestor Chart.
@ -254,8 +268,8 @@ class AncestorChartDialog(Report.DrawReportDialog):
opened."""
try:
MyReport = AncestorChart(self.db, self.person, self.target_path,
self.max_gen, self.doc, self.report_text)
MyReport = AncestorChart(self.db, self.person,
self.max_gen, self.report_text, self.doc,self.target_path)
MyReport.write_report()
except Errors.ReportError, msg:
(m1,m2) = msg.messages()
@ -275,6 +289,118 @@ class AncestorChartDialog(Report.DrawReportDialog):
def report(database,person):
AncestorChartDialog(database,person)
#------------------------------------------------------------------------
#
# Set up sane defaults for the book_item
#
#------------------------------------------------------------------------
_style_file = "ancestor_chart.xml"
_style_name = "default"
_person_id = ""
_max_gen = 10
_disp_format = [ "$n", "%s $b" % _BORN, "%s $d" % _DIED ]
_options = ( _person_id, _max_gen, _disp_format )
#------------------------------------------------------------------------
#
# Book Item Options dialog
#
#------------------------------------------------------------------------
class AncestorChartBareDialog(Report.BareReportDialog):
def __init__(self,database,person,opt,stl):
self.options = opt
self.db = database
if self.options[0]:
self.person = self.db.getPerson(self.options[0])
else:
self.person = person
self.style_name = stl
Report.BareReportDialog.__init__(self,database,self.person)
self.max_gen = int(self.options[1])
self.disp_format = string.join(self.options[2],'\n')
self.new_person = None
self.generations_spinbox.set_value(self.max_gen)
self.extra_textbox.get_buffer().set_text(
self.disp_format,len(self.disp_format))
self.window.run()
#------------------------------------------------------------------------
#
# Customization hooks
#
#------------------------------------------------------------------------
def get_title(self):
"""The window title for this dialog"""
return "%s - GRAMPS Book" % (_("Ancestor Chart"))
def get_header(self, name):
"""The header line at the top of the dialog contents"""
return _("Ancestor Chart for GRAMPS Book")
def get_stylesheet_savefile(self):
"""Where to save styles for this report."""
return _style_file
def get_report_generations(self):
"""Default to 10 generations, no page breaks."""
return (10, 0)
def get_report_extra_textbox_info(self):
"""Label the textbox and provide the default contents."""
return (_("Display Format"), "$n\n%s $b\n%s $d" % (_BORN,_DIED),
_("Allows you to customize the data in the boxes in the report"))
def make_default_style(self):
_make_default_style(self.default_style)
def on_cancel(self, obj):
pass
def on_ok_clicked(self, obj):
"""The user is satisfied with the dialog choices. Parse all options
and close the window."""
# Preparation
self.parse_style_frame()
self.parse_report_options_frame()
if self.new_person:
self.person = self.new_person
self.options = ( self.person.getId(), self.max_gen, self.report_text )
self.style_name = self.selected_style.get_name()
#------------------------------------------------------------------------
#
# Function to write Book Item
#
#------------------------------------------------------------------------
def write_book_item(database,person,doc,options,newpage=0):
"""Write the Ancestor Chart using options set.
All user dialog has already been handled and the output file opened."""
try:
if options[0]:
person = database.getPerson(options[0])
max_gen = int(options[1])
disp_format = options[2]
return AncestorChart(database, person, max_gen,
disp_format, doc, None, newpage )
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()
#------------------------------------------------------------------------
#
#
@ -422,7 +548,7 @@ def get_xpm_image():
#
#
#------------------------------------------------------------------------
from Plugins import register_report
from Plugins import register_report, register_book_item
register_report(
report,
@ -435,3 +561,15 @@ register_report(
author_email="dallingham@users.sourceforge.net"
)
# (name,category,options_dialog,write_book_item,options,style_name,style_file,make_default_style)
register_book_item(
_("Ancestor Chart"),
_("Graphics"),
AncestorChartBareDialog,
write_book_item,
_options,
_style_name,
_style_file,
_make_default_style
)

View File

@ -21,7 +21,7 @@
#
# Written by Alex Roitman,
# largely based on the TextDoc classes by Don Allingham
# largely based on the BaseDoc classes by Don Allingham
#
#-------------------------------------------------------------------------
@ -69,7 +69,7 @@ import ListModel
import GrampsCfg
import Plugins
import Report
import TextDoc
import BaseDoc
from QuestionDialog import WarningDialog
#------------------------------------------------------------------------
@ -818,22 +818,22 @@ class BookReportDialog(Report.ReportDialog):
"""
def __init__(self,database,person,book):
import TextDoc
import BaseDoc
Report.BareReportDialog.__init__(self,database,person)
self.book = book
self.database = database
self.person = person
self.selected_style = TextDoc.StyleSheet()
self.selected_style = BaseDoc.StyleSheet()
for item in self.book.get_item_list():
# Set up default style
default_style = TextDoc.StyleSheet()
default_style = BaseDoc.StyleSheet()
make_default_style = item.get_make_default_style()
make_default_style(default_style)
# Read all style sheets available for this item
style_file = item.get_style_file()
style_list = TextDoc.StyleSheetList(style_file,default_style)
style_list = BaseDoc.StyleSheetList(style_file,default_style)
# Get the selected stylesheet
style_name = item.get_style_name()

View File

@ -38,7 +38,7 @@ import cStringIO
#
#------------------------------------------------------------------------
import Report
import TextDoc
import BaseDoc
import RelLib
import Errors
import Utils
@ -71,7 +71,7 @@ class FtmDescendantReport(Report.Report):
self.sref_index = 1
def setup(self):
tbl = TextDoc.TableStyle()
tbl = BaseDoc.TableStyle()
tbl.set_width(100)
tbl.set_columns(3)
tbl.set_column_width(0,10)
@ -79,7 +79,7 @@ class FtmDescendantReport(Report.Report):
tbl.set_column_width(2,85)
self.doc.add_table_style('FTD-ChildTable',tbl)
cell = TextDoc.TableCellStyle()
cell = BaseDoc.TableCellStyle()
self.doc.add_cell_style('FTD-Normal',cell)
def apply_filter(self,person,index,generation=1):
@ -1132,42 +1132,42 @@ class FtmDescendantReport(Report.Report):
#------------------------------------------------------------------------
def _make_default_style(default_style):
"""Make the default output style for the FTM Style Descendant report."""
font = TextDoc.FontStyle()
font.set(face=TextDoc.FONT_SANS_SERIF,size=16,bold=1,italic=1)
para = TextDoc.ParagraphStyle()
font = BaseDoc.FontStyle()
font.set(face=BaseDoc.FONT_SANS_SERIF,size=16,bold=1,italic=1)
para = BaseDoc.ParagraphStyle()
para.set_font(font)
para.set_header_level(1)
para.set_alignment(TextDoc.PARA_ALIGN_CENTER)
para.set_alignment(BaseDoc.PARA_ALIGN_CENTER)
para.set(pad=0.5)
para.set_description(_('The style used for the title of the page.'))
default_style.add_style("FTD-Title",para)
font = TextDoc.FontStyle()
font.set(face=TextDoc.FONT_SANS_SERIF,size=14,italic=1)
para = TextDoc.ParagraphStyle()
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(pad=0.5)
para.set_alignment(TextDoc.PARA_ALIGN_CENTER)
para.set_alignment(BaseDoc.PARA_ALIGN_CENTER)
para.set_description(_('The style used for the generation header.'))
default_style.add_style("FTD-Generation",para)
para = TextDoc.ParagraphStyle()
para = BaseDoc.ParagraphStyle()
para.set(first_indent=-1.0,lmargin=1.0,pad=0.25)
para.set_description(_('The basic style used for the text display.'))
default_style.add_style("FTD-Entry",para)
para = TextDoc.ParagraphStyle()
para = BaseDoc.ParagraphStyle()
para.set(lmargin=1.0,pad=0.05)
para.set_description(_('The basic style used for the text display.'))
default_style.add_style("FTD-Details",para)
para = TextDoc.ParagraphStyle()
para = BaseDoc.ParagraphStyle()
para.set(lmargin=1.0,pad=0.25)
para.set_description(_('The basic style used for the text display.'))
default_style.add_style("FTD-SubEntry",para)
para = TextDoc.ParagraphStyle()
para = BaseDoc.ParagraphStyle()
para.set(pad=0.05)
para.set_description(_('The basic style used for the text display.'))
default_style.add_style("FTD-Endnotes",para)

View File

@ -32,7 +32,7 @@ import cStringIO
#
#------------------------------------------------------------------------
import Report
import TextDoc
import BaseDoc
import RelLib
import Errors
from QuestionDialog import ErrorDialog
@ -87,23 +87,23 @@ class SimpleBookTitle(Report.Report):
def _make_default_style(default_style):
"""Make the default output style for the Simple Boot Title report."""
font = TextDoc.FontStyle()
font.set(face=TextDoc.FONT_SANS_SERIF,size=16,bold=1,italic=1)
para = TextDoc.ParagraphStyle()
font = BaseDoc.FontStyle()
font.set(face=BaseDoc.FONT_SANS_SERIF,size=16,bold=1,italic=1)
para = BaseDoc.ParagraphStyle()
para.set_font(font)
para.set_header_level(1)
para.set_alignment(TextDoc.PARA_ALIGN_CENTER)
para.set_alignment(BaseDoc.PARA_ALIGN_CENTER)
para.set(pad=0.5)
para.set_description(_('The style used for the title of the page.'))
default_style.add_style("SBT-Title",para)
font = TextDoc.FontStyle()
font.set(face=TextDoc.FONT_SANS_SERIF,size=14,italic=1)
para = TextDoc.ParagraphStyle()
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(pad=0.5)
para.set_alignment(TextDoc.PARA_ALIGN_CENTER)
para.set_alignment(BaseDoc.PARA_ALIGN_CENTER)
para.set_description(_('The style used for the subtitle.'))
default_style.add_style("SBT-Subtitle",para)
@ -364,4 +364,3 @@ register_book_item(
_style_file,
_make_default_style
)