Fixed ReportLab's desire to always use A4 when using the SimpleBaseDoc

svn: r119
This commit is contained in:
Don Allingham 2001-06-12 23:23:11 +00:00
parent 42013778ab
commit a0d9323557

View File

@ -21,7 +21,7 @@
from TextDoc import * from TextDoc import *
import reportlab.platypus.tables import reportlab.platypus.tables
from reportlab.platypus import SimpleDocTemplate, Paragraph, Spacer, PageBreak, Image from reportlab.platypus import *
from reportlab.lib.units import cm from reportlab.lib.units import cm
from reportlab.lib.colors import Color from reportlab.lib.colors import Color
from reportlab.lib.enums import TA_LEFT, TA_RIGHT, TA_CENTER, TA_JUSTIFY from reportlab.lib.enums import TA_LEFT, TA_RIGHT, TA_CENTER, TA_JUSTIFY
@ -35,6 +35,17 @@ try:
except: except:
no_pil = 1 no_pil = 1
#------------------------------------------------------------------------
#
#
#
#------------------------------------------------------------------------
class GrampsDocTemplate(BaseDocTemplate):
def build(self,flowables):
self._calc() #in case we changed margins sizes etc
BaseDocTemplate.build(self,flowables)
#------------------------------------------------------------------------ #------------------------------------------------------------------------
# #
# #
@ -65,8 +76,20 @@ class PdfDoc(TextDoc):
self.filename = filename + ".pdf" self.filename = filename + ".pdf"
else: else:
self.filename = filename self.filename = filename
self.doc = SimpleDocTemplate(self.filename,
pagesize=(self.width*cm,self.height*cm)) self.pagesize = (self.width*cm,self.height*cm)
self.doc = GrampsDocTemplate(self.filename,
pagesize=self.pagesize,
leftMargin=self.lmargin*cm,
rightMargin=self.rmargin*cm,
topMargin=self.tmargin*cm,
bottomMargin=self.bmargin*cm)
frameT = Frame(self.doc.leftMargin, self.doc.bottomMargin, \
self.doc.width, self.doc.height, id='normal')
ptemp = PageTemplate(frames=frameT,pagesize=self.pagesize)
self.doc.addPageTemplates([ptemp])
self.pdfstyles = {} self.pdfstyles = {}
for style_name in self.style_list.keys(): for style_name in self.style_list.keys():
@ -79,12 +102,24 @@ class PdfDoc(TextDoc):
if font.get_type_face() == FONT_SERIF: if font.get_type_face() == FONT_SERIF:
if font.get_bold(): if font.get_bold():
if font.get_italic():
pdf_style.fontName = "Times-BoldItalic"
else:
pdf_style.fontName = "Times-Bold" pdf_style.fontName = "Times-Bold"
else:
if font.get_italic():
pdf_style.fontName = "Times-Italic"
else: else:
pdf_style.fontName = "Times-Roman" pdf_style.fontName = "Times-Roman"
else: else:
if font.get_bold(): if font.get_bold():
if font.get_italic():
pdf_style.fontName = "Helvetica-BoldOblique"
else:
pdf_style.fontName = "Helvetica-Bold" pdf_style.fontName = "Helvetica-Bold"
else:
if font.get_italic():
pdf_style.fontName = "Helvetica-Oblique"
else: else:
pdf_style.fontName = "Helvetica" pdf_style.fontName = "Helvetica"
pdf_style.bulletFontName = pdf_style.fontName pdf_style.bulletFontName = pdf_style.fontName
@ -117,10 +152,7 @@ class PdfDoc(TextDoc):
self.in_table = 0 self.in_table = 0
def close(self): def close(self):
self.doc.build(self.story,onLaterPages=page_def) self.doc.build(self.story)
def start_page(self,orientation=None):
pass
def end_page(self): def end_page(self):
self.story.append(PageBreak()) self.story.append(PageBreak())
@ -168,7 +200,7 @@ class PdfDoc(TextDoc):
colWidths=self.cur_table_cols, colWidths=self.cur_table_cols,
style=ts) style=ts)
self.story.append(tbl) self.story.append(tbl)
self.story.append(Spacer(1,0.5*cm)) # self.story.append(Spacer(1,0.5*cm))
self.in_table = 0 self.in_table = 0
def start_row(self): def start_row(self):