Changed how EventPage works. Cleanup work on NarrativeWeb. Changed some elements in stylesheet that is specific to Visually impaired only.

svn: r13773
This commit is contained in:
Rob G. Healey 2009-12-12 07:38:10 +00:00
parent ec24ff86fb
commit bfbba59482
2 changed files with 50 additions and 112 deletions

View File

@ -697,7 +697,7 @@ div#EventDetail table.eventlist tbody tr td.ColumnAttribute {
text-transform: uppercase;
width: 20%;
}
div#EventDetail table.eventlist tbody tr td.ColumnEvent {
div#EventDetail table.eventlist tbody tr td.ColumnDate {
background-color: #D8F3D6;
border-top: solid 1px #5D835F;
}
@ -1240,8 +1240,8 @@ div#narrative {
/* Subsections : Source References
----------------------------------------------------- */
div#sourcerefs {
height:2.64cm;
overflow:auto;
padding: 0;
margin: 0 auto;
}
div#sourcerefs ol {
list-style-type:decimal;

View File

@ -461,14 +461,20 @@ class BasePage(object):
else:
self.place_list[place_handle] = [lnk]
# begin event table row
trow = Html("tr")
# get event type and hyperlink to it or not?
etype = str(evt.type)
evt_hyper = self.event_link(etype, evt_ref.ref, evt.gramps_id, subdirs) if hyp else etype
trow += Html("td", evt_hyper, class_ = "ColumnEvent")
# get event data
"""
for more information: see get_event_data()
"""
event_data = self.get_event_data(evt, evt_ref, showplc, showdescr, subdirs, hyp)
event_data = self.get_event_data(evt, evt_ref, showplc, showdescr, subdirs)
# begin event table row
trow = Html("tr")
trow.extend(
Html("td", data or " ", class_ = "Column" + colclass,
inline = (not data or colclass == "Date"))
@ -500,7 +506,7 @@ class BasePage(object):
else:
return eventtype
def get_event_data(self, evt, evt_ref, showplc, showdescr, up, hyp, gid = None):
def get_event_data(self, evt, evt_ref, showplc, showdescr, up, gid = None):
"""
retrieve event data from event and evt_ref
@ -509,14 +515,9 @@ class BasePage(object):
@param: showplc = show the event place or not?
@param: showdescr = to show the event description or not?
@param: up = either True or False; add subdirs or not?
@param: hyp = to hyperlink the event type or not?
"""
db = self.report.database
# get event type and hyperlink to it or not?
etype = str(evt.type)
evt_hyper = self.event_link(etype, evt_ref.ref, gid, up) if hyp else etype
# get place name
place = None
place_handle = evt.get_place_handle()
@ -532,7 +533,6 @@ class BasePage(object):
# position 0 = translatable label, position 1 = column class
# position 2 = data
info = [
[_EVENT, "Event", evt_hyper],
[DHEAD, "Date", _dd.display(evt.get_date_object() )]
]
@ -1552,7 +1552,7 @@ class BasePage(object):
if tmp:
list1 = Html("li", inline = True) + (
Html("a", ';   '.join(tmp),
Html("a", ";   ".join(tmp),
name = "sref%d%s" % (cindex, key))
)
@ -2447,36 +2447,32 @@ class EventListPage(BasePage):
return Html("a", grampsid, href = url, alt = grampsid)
class EventPage(BasePage):
def __init__(self, report, title, evt_type, person, event, evt_ref):
def __init__(self, report, title, event_handle):
"""
Creates the individual event page
@param: title -- is the title of the web pages
@param: evt_type -- the event type
@param: event -- the event for this page
@param: evt_ref -- the event reference
@param: event_handle -- the event handle for the database
"""
BasePage.__init__(self, report, title, event.gramps_id)
self.up = True
db = report.database
event = db.get_event_from_handle(event_handle)
evt_gid = event.gramps_id
BasePage.__init__(self, report, title, evt_gid)
self.up = True
subdirs = True
self.bibli = Bibliography()
of = self.report.create_file(evt_ref.ref, "evt")
of = self.report.create_file(event_handle, "evt")
eventpage, body = self.write_header(_("Events"), _KEYEVENT)
# start event page division
# start event detail division
with Html("div", class_ = "content", id = "EventDetail") as eventdetail:
body += eventdetail
# display page itle
person_name = self.get_name(person)
title = _("%(type)s of %(name)s") % {'type' : evt_type.lower(),
'name' : person_name }
# line is in place for Peter Lundgren
title = title[0].upper() + title[1:]
# display page title
evt_type = str(event.type)
title = "%(eventtype)s --> %(eventtype)s" % {'eventtype' : evt_type }
eventdetail += Html("h3", title, inline = True)
# begin eventdetail table
@ -2490,25 +2486,23 @@ class EventPage(BasePage):
"""
for more information: see get_event_data()
"""
event_data = self.get_event_data(event, evt_ref, True, True, subdirs,
False, event.gramps_id)
event_data = self.get_event_data(event, event_handle, True, True, subdirs, evt_gid)
for (label, colclass, data) in event_data:
if data:
trow = Html("tr")
tbody += trow
trow += Html("td", label, class_ = "ColumnAttribute", inline = True) + (
trow = Html("tr") + (
Html("td", label, class_ = "ColumnAttribute", inline = True),
Html('td', data, class_ = "Column" + colclass)
)
tbody += trow
# Person
if evt_type in ["Divorce", "Marriage"]:
handle_list = db.find_backlink_handles(evt_ref.ref,
handle_list = db.find_backlink_handles(event_handle,
include_classes = ['Person', 'Family'])
else:
handle_list = db.find_backlink_handles(evt_ref.ref, include_classes = ['Person'])
handle_list = db.find_backlink_handles(event_handle, include_classes = ['Person'])
if handle_list:
first_person = True
@ -2557,21 +2551,21 @@ class EventPage(BasePage):
first_person = False
# Narrative subsection
# evt_ref = event.get_reference()
notelist = event.get_note_list()
notelist.extend(evt_ref.get_note_list() )
# notelist.extend(evt_ref.get_note_list() )
notelist = self.display_note_list(notelist)
if notelist is not None:
eventdetail += notelist
# get attribute list
attrlist = event.get_attribute_list()
attrlist.extend(evt_ref.get_attribute_list() )
# attrlist.extend(evt_ref.get_attribute_list() )
attrlist = self.display_attr_list(attrlist, True)
if attrlist is not None:
eventdetail += attrlist
# event source references
srcrefs = event.get_source_references()
srcrefs = self.display_ind_sources(event)
if srcrefs is not None:
eventdetail += srcrefs
@ -5219,67 +5213,6 @@ class NavWebReport(Report):
from_path = os.path.join(const.IMAGE_DIR, fname)
self.copy_file(from_path, fname, "images")
def build_events(self, ind_list):
"""
build a list of events for classes EventListPage and EventPage
@param: ind_list = list of handles for persons in this database
"""
db = self.database
event_dict, event_types = [], []
for person_handle in ind_list:
person = db.get_person_from_handle(person_handle)
# begin event list new for each person
event_list = []
# get sort name for sorting later
last_name = person.get_primary_name().get_surname()
first_name = person.get_primary_name().get_first_name()
sort_name = ', '.join([last_name, first_name])
for family_handle in person.get_family_handle_list():
family = db.get_family_from_handle(family_handle)
for evt_ref in family.get_event_ref_list():
event = db.get_event_from_handle(evt_ref.ref)
# get sot date as year/month/day, 2009/09/09,
# or 0000/00/00 for non-existing date
event_date = event.get_date_object()
year = event_date.get_year() or 0
month = event_date.get_month() or 0
day = event_date.get_day() or 0
sort_date = '%04d/%02d/%02d' % (year, month, day)
# add event data
event_types.append(str(event.type))
event_list.append( [str(event.type), sort_date, sort_name, event, evt_ref] )
for evt_ref in person.get_primary_event_ref_list():
event = db.get_event_from_handle(evt_ref.ref)
# get sot date as year/month/day, see above for further info
event_date = event.get_date_object()
year = event_date.get_year() or 0
month = event_date.get_month() or 0
day = event_date.get_day() or 0
sort_date = '%04d/%02d/%02d' % (year, month, day)
# add event data
event_types.append(str(event.type))
event_list.append( [str(event.type), sort_date, sort_name, event, evt_ref] )
# sort the event_list
event_list.sort()
# combine person and their events together
event_dict.append([person, event_list])
# return the events for EventListPage and EventPage
return event_dict, event_types
def build_attributes(self, person):
""" build a list of attributes for each person """
db = self.database
@ -5399,25 +5332,30 @@ class NavWebReport(Report):
a dump of all the events sorted by event type, date, and surname
for classes EventListPage and EventPage
"""
db = self.database
# set up progress bar for event pages; using ind list because it was taking too long at the end
event_handle_list = self.database.get_event_handles()
event_handle_list = db.get_event_handles()
self.progress.set_pass(_("Creating event pages"), len(event_handle_list))
# gather the information that we will need for these two classes
event_dict, event_types = self.build_events(ind_list)
event_types = []
for event_handle in event_handle_list:
event = self.database.get_event_from_handle(event_handle)
event_types.append( str(event.type) )
# send all data to the events list page
EventListPage(self, self.title, event_types, event_handle_list)
for (person, event_list) in event_dict:
index = 0
for event_handle in event_handle_list:
self.progress.set_header(_("Creating event page %02d of %02d" % (index + 1, len(event_handle_list))))
for (evt_type, sort_date, sort_name, event, evt_ref) in event_list:
# create individual event pages
EventPage(self, self.title, event_handle)
# create individual event page
EventPage(self, self.title, evt_type, person, event, evt_ref)
# increment the progress bar
index += 1
self.progress.step()
def gallery_pages(self, source_list):