Fixed ReportLab's desire to always use A4 when using the SimpleBaseDoc
svn: r119
This commit is contained in:
parent
6598b3eef4
commit
fd1614a49b
@ -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):
|
||||||
|
Loading…
x
Reference in New Issue
Block a user