NarrativeWeb now has Styked Notes! Thanks for being a giant help Benny. Could not have done it without you. Bringing the default print stylesheet up to date with the rest of them.

svn: r12683
This commit is contained in:
Rob G. Healey 2009-06-19 23:53:42 +00:00
parent 4cab1104b0
commit d181d6bd33
2 changed files with 884 additions and 400 deletions

File diff suppressed because it is too large Load Diff

View File

@ -24,7 +24,7 @@
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
# #
# $Id: $ # $Id:$
""" """
Narrative Web Page generator. Narrative Web Page generator.
@ -103,6 +103,9 @@ from libhtmlconst import _CHARACTER_SETS, _CC, _COPY_OPTIONS
# import HTML Class # import HTML Class
from libhtml import Html from libhtml import Html
# import styled notes from
# src/plugins/lib/libhtmlbackend.py
from libhtmlbackend import HtmlBackend
#------------------------------------------------------------------------ #------------------------------------------------------------------------
# #
# constants # constants
@ -191,6 +194,9 @@ class BasePage(object):
gid - Gramps ID gid - Gramps ID
""" """
# class to do conversion of styled notes to html markup
self._backend = HtmlBackend()
self.report = report self.report = report
self.title_str = title self.title_str = title
self.gid = gid self.gid = gid
@ -212,6 +218,49 @@ class BasePage(object):
self.linkhome = report.options['linkhome'] self.linkhome = report.options['linkhome']
self.use_gallery = report.options['gallery'] self.use_gallery = report.options['gallery']
#################################################
#
# Will produce styled notes for NarrativeWeb by using:
# src/plugins/lib/libhtmlbackend.py
#
#################################################
def styled_note(self, styledtext, format):
"""
styledtext : assumed a StyledText object to write
format : = 0 : Flowed, = 1 : Preformatted
style_name : name of the style to use for default presentation
"""
text = str(styledtext)
if not text:
return ''
s_tags = styledtext.get_tags()
#FIXME: following split should be regex to match \n\s*\n instead?
markuptext = self._backend.add_markup_from_styled(text, s_tags,
split='\n\n')
htmllist = Html('div', id='grampsstylednote')
if format == 1:
#preformatted, retain whitespace.
#so use \n\n for paragraph detection
#FIXME: following split should be regex to match \n\s*\n instead?
htmllist += Html('pre', indent=None, inline=True)
for line in markuptext.split('\n\n'):
htmllist += Html('p')
for realline in line.split('\n'):
htmllist += realline
htmllist += Html('br')
elif format == 0:
#flowed
#FIXME: following split should be regex to match \n\s*\n instead?
for line in markuptext.split('\n\n'):
htmllist += Html('p')
htmllist += line
return htmllist
# --------------------------------------------------------------------------------------- # ---------------------------------------------------------------------------------------
# #
# # Web Page Fortmatter and writer # # Web Page Fortmatter and writer
@ -289,8 +338,19 @@ class BasePage(object):
footer_note = self.report.options['footernote'] footer_note = self.report.options['footernote']
if footer_note: if footer_note:
note = db.get_note_from_gramps_id(footer_note) note = db.get_note_from_gramps_id(footer_note)
user_footer = Html('div', id='user_footer') + Html('p', note.get()) note_text = note.get()
footer += user_footer if note_text:
user_footer = Html('div', id='user_footer')
# styled notes
htmlnotetext = self.styled_note(note.get_styledtext(),
note.get_format())
if htmlnotetext:
text = htmlnotetext
else:
text = Html('p', note_text)
user_footer += text
footer += user_footer
value = _dd.display(date.Today()) value = _dd.display(date.Today())
msg = _('Generated by <a href="%(homepage)s">' msg = _('Generated by <a href="%(homepage)s">'
@ -394,14 +454,25 @@ class BasePage(object):
headerdiv = (Html('div', id='header') + headerdiv = (Html('div', id='header') +
Html('h1', html_escape(self.title_str), id='SiteTitle', inline=True) Html('h1', html_escape(self.title_str), id='SiteTitle', inline=True)
) )
header = self.report.options['headernote']
if header:
note = db.get_note_from_gramps_id(header)
p = Html('p', note.get(), id='user_header')
headerdiv += p
body += headerdiv body += headerdiv
header_note = self.report.options['headernote']
if header_note:
note = db.get_note_from_gramps_id(header_note)
note_text = note.get()
if note_text:
user_header = Html('div', id='user_header')
headerdiv += user_header
# styled notes
htmlnotetext = self.styled_note(note.get_styledtext(),
note.get_format())
if htmlnotetext:
text = htmlnotetext
else:
text = Html('p', note_text)
user_header += text
# Begin Navigation Menu # Begin Navigation Menu
navigation = self.display_nav_links(title) navigation = self.display_nav_links(title)
body += navigation body += navigation
@ -597,23 +668,24 @@ class BasePage(object):
for notehandle in notelist: for notehandle in notelist:
note = db.get_note_from_handle(notehandle) note = db.get_note_from_handle(notehandle)
format = note.get_format() note_text = note.get()
text = note.get()
try: try:
text = unicode(text) note_text = unicode(note_text)
except UnicodeDecodeError: except UnicodeDecodeError:
text = unicode(str(text), errors='replace') note_text = unicode(str(note_text), errors='replace')
if text: if note_text:
title = Html('h4', _('Narrative'), inline=True) section += Html('h4', _('Narrative'), inline=True)
section += title
if format: # styled notes
text = u"<pre>%s</pre>" % text htmlnotetext = self.styled_note(note.get_styledtext(),
note.get_format())
if htmlnotetext:
section += htmlnotetext
else: else:
text = u"<br />".join(text.split("\n")) section += Html('p', note_text)
section += Html('p', text)
# return notes narrative to its callers # return notes to its callers
return section return section
def display_url_list(self, urllist=None): def display_url_list(self, urllist=None):
@ -696,7 +768,17 @@ class BasePage(object):
notelist = sref.get_note_list() notelist = sref.get_note_list()
for notehandle in notelist: for notehandle in notelist:
note = db.get_note_from_handle(notehandle) note = db.get_note_from_handle(notehandle)
tmp.append("%s: %s" % (_('Text'), note.get())) note_text = note.get()
if note_text:
# styled notes
htmlnotetext = self.styled_note(note.get_styledtext(),
note.get_format())
if htmlnotetext:
text = htmlnotetext
else:
text = Html('p', note_text)
tmp.append("%s: %s" % (_('Text'), text))
if len(tmp): if len(tmp):
ordered2 += Html('li') + ( ordered2 += Html('li') + (
Html('a', '; &nbsp; '.join(tmp), name=" #sref%d%s " % (cindex+1, key)) Html('a', '; &nbsp; '.join(tmp), name=" #sref%d%s " % (cindex+1, key))
@ -1884,35 +1966,45 @@ class IntroductionPage(BasePage):
def __init__(self, report, title): def __init__(self, report, title):
BasePage.__init__(self, report, title) BasePage.__init__(self, report, title)
db = report.database
of = self.report.create_file(report.intro_fname) of = self.report.create_file(report.intro_fname)
# Note. In old NarrativeWeb.py the content_divid depended on filename. # Note. In old NarrativeWeb.py the content_divid depended on filename.
intro, body = self.write_header(_('Introduction')) intropage, body = self.write_header(_('Introduction'))
sect_intro = Html('div', id='Introduction', class_='content') # begin Introduction division
with Html('div', class_='content', id='Introduction') as section:
body += section
introimg = report.add_image('introimg') introimg = report.add_image('introimg')
if introimg: if introimg is not None:
sect_intro += introimg section += introimg
note_id = report.options['intronote'] note_id = report.options['intronote']
if note_id: note = db.get_note_from_gramps_id(note_id)
note_obj = report.database.get_note_from_gramps_id(note_id) if note:
text = note_obj.get() note_text = note.get()
if note_obj.get_format():
text = Html('pre', text) # styled notes
htmlnotetext = self.styled_note(note.get_styledtext(),
note.get_format())
if htmlnotetext:
text = htmlnotetext
else:
text = Html('pre', note_text)
else: else:
text = Html('p', '<br>'.join(text.split('\n'))) text = None
sect_intro += text text = text or '&nbsp;'
section += text
# add clearline for proper styling
# create footer section # create footer section
# create clear line for proper styling
# bring all body pieces together
footer = self.write_footer() footer = self.write_footer()
body += (sect_intro, fullclear, footer) body += (fullclear, footer)
# send page out for processing # send page out for processing
self.mywriter(intro, of) # and close the file
self.mywriter(intropage, of)
class HomePage(BasePage): class HomePage(BasePage):
""" """
@ -1933,13 +2025,20 @@ class HomePage(BasePage):
note_id = report.options['homenote'] note_id = report.options['homenote']
if note_id: if note_id:
note_obj = report.database.get_note_from_gramps_id(note_id) note = report.database.get_note_from_gramps_id(note_id)
text = note_obj.get() note_text = note.get()
if note_obj.get_format(): if note_text:
text = Html('pre', text, inline=True) user_footer = Html('div', id='user_footer')
else:
text = Html('<br>'.join(text.split('\n')), inline=True) # styled notes
sect_home_page += text htmlnotetext = self.styled_note(note.get_styledtext(),
note.get_format())
if htmlnotetext:
text = htmlnotetext
else:
text = Html('p', note_text)
user_footer += text
sect_home_page += user_footer
# create footer section # create footer section
# create clear line for proper styling # create clear line for proper styling
@ -2354,13 +2453,18 @@ class ContactPage(BasePage):
note_id = report.options['contactnote'] note_id = report.options['contactnote']
if note_id: if note_id:
note_obj = report.database.get_note_from_gramps_id(note_id) note = report.database.get_note_from_gramps_id(note_id)
text = note_obj.get() note_text = note.get()
if note_obj.get_format(): if note_text:
text = u"\t\t<pre>%s</pre>" % text
else: # styled notes
text = u"<br />".join(text.split("\n")) htmlnotetext = self.styled_note(note.get_styledtext(),
summaryarea += Html('p', text, inline=True) note.get_format())
if htmlnotetext:
text = htmlnotetext
else:
text = Html('p', note_text)
summaryarea += text
# add clearline for proper styling # add clearline for proper styling
# add footer section # add footer section
@ -2764,16 +2868,23 @@ class IndividualPage(BasePage):
# display any notes associated with this name # display any notes associated with this name
notelist = name.get_note_list() notelist = name.get_note_list()
if len(notelist) > 0: if len(notelist):
unordered = Html('ul') unordered = Html('ul')
tabcol2 += unordered
for notehandle in notelist: for notehandle in notelist:
note = db.get_note_from_handle(notehandle) note = db.get_note_from_handle(notehandle)
if note: if note:
note_text = note.get() note_text = note.get()
if note_text: if note_text:
txt = u" ".join(note_text.split("\n"))
unordered += Html('li', txt, inline=True) # styled notes
tabcol2 += unordered htmlnotetext = self.styled_note(note.get_styledtext(),
note.get_format())
if htmlnotetext:
text = htmlnotetext
else:
text = Html('pre', note_text)
unordered += text
# finished with this name # finished with this name
tabrow += (tabcol1, tabcol2) tabrow += (tabcol1, tabcol2)
@ -2894,9 +3005,7 @@ class IndividualPage(BasePage):
self.place_list[place_handle] = [lnk] self.place_list[place_handle] = [lnk]
place = self.place_link(place_handle, place = self.place_link(place_handle,
ReportUtils.place_name(db, ReportUtils.place_name(db, place_handle), up=True)
place_handle),
up=True)
else: else:
place = '' place = ''
@ -2975,15 +3084,16 @@ class IndividualPage(BasePage):
note = db.get_note_from_handle(notehandle) note = db.get_note_from_handle(notehandle)
if note: if note:
note_text = note.get() note_text = note.get()
format = note.get_format()
if note_text: if note_text:
tabcol += Html('p', class_='EventNote')
if format: # styled notes
tabcol += Html('pre', note_text) htmlnotetext = self.styled_note(note.get_styledtext(),
note.get_format())
if htmlnotetext:
text = htmlnotetext
else: else:
tabcol += '<br />'.join(note_text.split('\n')) text = Html('p', note_text)
else: tabcol += text
tabcol += '&nbsp;'
tabrow += tabcol tabrow += tabcol
# return events table row to its caller # return events table row to its caller
@ -3416,21 +3526,24 @@ class IndividualPage(BasePage):
for notehandle in notelist: for notehandle in notelist:
note = db.get_note_from_handle(notehandle) note = db.get_note_from_handle(notehandle)
if note: if note:
text = note.get() tabrow = Html('tr')
format = note.get_format() tabcol1 = Html('td', '&nbsp;', class_='ColumnType', inline=True)
if text: tabcol2 = Html('td', _('Narrative'), class_='ColumnAttribute', inline=True)
tabrow = Html('tr') tabcol3 = Html('td', class_='ColumnValue')
tabcol1 = Html('td', '&nbsp;', class_='ColumnType', inline=True)
tabcol2 = Html('td', _('Narrative'), class_='ColumnAttribute', inline=True) note_text = note.get()
tabcol3 = Html('td', class_='ColumnValue') if note_text:
if format:
text = u"<pre>%s</pre>" % text # styled notes
htmlnotetext = self.styled_note(note.get_styledtext(),
note.get_format())
if htmlnotetext:
text = htmlnotetext
else: else:
text = u"<br />".join(text.split("\n")) text = Html('p', note_text)
para = Html('p', text) tabcol3 += text
tabcol3 += para tabrow += (tabcol1, tabcol2, tabcol3)
tabrow += (tabcol1, tabcol2, tabcol3) relation_table += tabrow
relation_table += tabrow
# return table to its caller # return table to its caller
return relation_table return relation_table