Fixed and remove database objects that are not in the report database for class SourcePage's Citation Referents.

svn: r18836
This commit is contained in:
Rob G. Healey 2012-02-08 03:31:13 +00:00
parent b8736f6166
commit 00b55b709b

View File

@ -615,8 +615,8 @@ class BasePage(object):
with Html("table", class_ = table_class) as table:
section += table
for fhandle in family_list:
family = self.dbase_.get_family_from_handle(fhandle)
for family_handle in family_list:
family = self.dbase_.get_family_from_handle(family_handle)
if family:
self.display_spouse(family, table, ppl_handle_list, place_lat_long)
@ -3083,7 +3083,7 @@ class SurnamePage(BasePage):
self.XHTMLWriter(surnamepage, of)
class FamilyListPage(BasePage):
def __init__(self, report, title, ind_list):
def __init__(self, report, title, ind_list, db_family_handles):
self.dbase_ = report.database
BasePage.__init__(self, report, title)
@ -3142,16 +3142,16 @@ class FamilyListPage(BasePage):
letter =' '
# get person from sorted database list
for phandle in handle_list:
person = self.dbase_.get_person_from_handle(phandle)
for person_handle in handle_list:
person = self.dbase_.get_person_from_handle(person_handle)
if person:
family_handle_list = person.get_family_handle_list()
if family_handle_list:
first_family = True
for fhandle in family_handle_list:
for family_handle in family_handle_list:
family = self.dbase_.get_family_from_handle(fhandle)
family = self.dbase_.get_family_from_handle(family_handle)
if family:
trow = Html("tr")
@ -3175,7 +3175,7 @@ class FamilyListPage(BasePage):
if first_family:
trow.attr = 'class ="BeginFamily"'
tcell += self.family_link(fhandle, self.get_name(person),
tcell += self.family_link(family_handle, self.get_name(person),
family.get_gramps_id(), self.up)
first_family = False
@ -3192,7 +3192,7 @@ class FamilyListPage(BasePage):
if partner:
use_link = check_person_database(partner_handle, ind_list)
if use_link:
tcell += self.family_link(fhandle, self.get_name(partner),
tcell += self.family_link(family_handle, self.get_name(partner),
family.get_gramps_id(), self.up)
else:
tcell += self.get_name(partner)
@ -3226,6 +3226,7 @@ class FamilyListPage(BasePage):
tcell1 += ' '
tcell2 += ' '
first_family = False
db_family_handles.append(family_handle)
# add clearline for proper styling
# add footer section
@ -3332,7 +3333,7 @@ class FamilyPage(BasePage):
self.XHTMLWriter(familydetailpage, of)
class PlaceListPage(BasePage):
def __init__(self, report, title, place_handles):
def __init__(self, report, title, place_handles, db_place_handles):
self.dbase_ = report.database
BasePage.__init__(self, report, title)
@ -3385,8 +3386,8 @@ class PlaceListPage(BasePage):
tbody = Html("tbody")
table += tbody
for handle in handle_list:
place = self.dbase_.get_place_from_handle(handle)
for place_handle in handle_list:
place = self.dbase_.get_place_from_handle(place_handle)
if place:
place_title = place.get_title()
ml = place.get_main_location()
@ -3433,6 +3434,7 @@ class PlaceListPage(BasePage):
else:
tcell1 += ' '
tcell2 += ' '
db_place_handles.append(place_handles)
# add clearline for proper styling
# add footer section
@ -3576,7 +3578,7 @@ class PlacePage(BasePage):
self.XHTMLWriter(placepage, of)
class EventListPage(BasePage):
def __init__(self, report, title, event_types, event_handle_list, ppl_handle_list):
def __init__(self, report, title, event_types, event_handle_list, ppl_handle_list, db_event_handles):
"""
Will create the event list page
@ -3718,8 +3720,9 @@ class EventListPage(BasePage):
self.complete_people(tcell, first_person, handle_list,
ppl_handle_list, up =False)
_EVENT_DISPLAYED.append( gid )
_EVENT_DISPLAYED.append(gid)
first_event = False
db_event_handles.append(event_handle)
# add clearline for proper styling
# add footer section
@ -4427,11 +4430,11 @@ class SourceListPage(BasePage):
# and close the file
self.XHTMLWriter(sourcelistpage, of)
#################################################
"""
#
# Creates the individual source pages from SourceListPage
#
#################################################
"""
class SourcePage(BasePage):
def __init__(self, report, title, src_handle, src_list, ppl_handle_list, database_handles_list):
self.dbase_ = report.database
@ -4440,8 +4443,9 @@ class SourcePage(BasePage):
return
# for use in determining if a citation referent is in the report database?
(db_family_handles, db_event_handles, db_place_handles, db_source_handles,
db_media_handles) = database_handles_list
(db_people_handles, db_family_handles, db_event_handles, db_place_handles,
db_repository_handles, db_media_handles) = database_handles_list
db_source_handles = src_list
self.page_title = source.get_title()
BasePage.__init__(self, report, title, source.get_gramps_id())
@ -4566,6 +4570,10 @@ class SourcePage(BasePage):
# gets all citation referents no matter on the filters...
(people_list, family_list, event_list, place_list, source_list, media_list, repo_list) = refs
# remove people that are not in this report database...
people_list = [person_handle for person_handle in people_list if person_handle in db_people_handles]
# Sort the person list by the individual's surname...
people_list = sort_people(self.dbase_, people_list)
@ -4614,6 +4622,9 @@ class SourcePage(BasePage):
list2 += unordered3
unordered2 += list2
# remove family handles if they are not in this report database?
family_list = [family_handle for family_handle in family_list if family_handle in db_family_handles]
# Citation Referents have Family Objects...
if (self.inc_families and family_list):
@ -4628,7 +4639,7 @@ class SourcePage(BasePage):
for family_handle in family_list:
family = self.dbase_.get_family_from_handle(family_handle)
if (family and family_handle in db_family_handles):
if family:
unordered3.extend(
Html("li", self.get_family_string(family))
@ -4636,6 +4647,9 @@ class SourcePage(BasePage):
list2 += unordered3
unordered2 += list2
# remove event handles if they are not in this report database...
event_list = [event_handle for event_handle in event_list if event_handle in db_event_handles]
# Citation Referents have Event Objects...
if (self.inc_events and event_list):
@ -4668,7 +4682,7 @@ class SourcePage(BasePage):
for (sort_value, event_handle) in event_list:
event = self.dbase_.get_event_from_handle(event_handle)
if (event and event_handle in db_event_handles):
if event:
event_date = _dd.display(event.get_date_object())
list4 = Html("li")
@ -4721,6 +4735,9 @@ class SourcePage(BasePage):
list2 += unordered3
unordered2 += list2
# remove place handles if they are not in this report database...
place_list = [place_handle for place_handle in place_list if place_handle in db_place_handles]
# Citation Referents have Place Objects...
if place_list:
@ -4735,8 +4752,7 @@ class SourcePage(BasePage):
for place_handle in place_list:
place = self.dbase_.get_place_from_handle(place_handle)
if (place and place_handle in db_place_handles):
if place:
unordered3.extend(
Html("li", self.place_link(place_handle, place.get_title(), uplink = self.up),
inline = True)
@ -4744,6 +4760,9 @@ class SourcePage(BasePage):
list2 += unordered3
unordered2 += list2
# remove sources if they are not in this report database...
source_list = [source_handle for source_handle in source_list if source_handle in db_source_handles]
# Citation Referents have Source Objects...
if source_list:
@ -4758,13 +4777,16 @@ class SourcePage(BasePage):
for source_handle in source_list:
source = self.dbase_.get_source_from_handle(source_handle)
if (source and source_handle in db_source_handles):
if source:
unordered3.extend(
Html("li", self.source_link(source, uplink = self.up), inline = True)
)
list2 += unordered3
unordered2 += list2
# remove repositories if they are not in this report database...
repo_list = [repo_handle for repo_handle in repo_list if repo_handle in db_repository_handles]
# Citation Referents have Repository Objects...
if (inc_repositories and repo_list):
@ -4787,6 +4809,9 @@ class SourcePage(BasePage):
list2 += unordered3
unordered2 += list2
# remove media if they are not in this report database...
media_list = [media_handle for media_handle in media_list if media_handle in db_media_handles]
# Citation Referents has Media Objects...
if (self.create_media and media_list):
@ -4804,8 +4829,7 @@ class SourcePage(BasePage):
for media_handle in media_list:
media = self.dbase_.get_object_from_handle(media_handle)
if (media and media_handle in db_media_handles):
if media:
mime_type = media.get_mime_type()
if mime_type:
if mime_type.startswith("image/"):
@ -4821,6 +4845,7 @@ class SourcePage(BasePage):
Html("li", self.doc_link(media_handle, media.get_description(),
self.up, usedescr = False), inline = True)
)
list2 += unordered3
unordered2 += list2
@ -4837,7 +4862,7 @@ class SourcePage(BasePage):
self.XHTMLWriter(sourcepage, of)
class MediaListPage(BasePage):
def __init__(self, report, title):
def __init__(self, report, title, db_media_handles):
self.dbase_ = report.database
BasePage.__init__(self, report, title)
@ -4869,10 +4894,11 @@ class MediaListPage(BasePage):
trow.extend(
Html("th", trans, class_ =colclass, inline =True)
for trans, colclass in [
[" ", "ColumnRowLabel"],
[_("Media | Name"), "ColumnName"],
[_("Date"), "ColumnDate"],
[_("Mime Type"), "ColumnMime"] ]
(" ", "ColumnRowLabel"),
(_("Media | Name"), "ColumnName"),
(_("Date"), "ColumnDate"),
(_("Mime Type"), "ColumnMime")
]
)
# begin table body
@ -4883,8 +4909,8 @@ class MediaListPage(BasePage):
sort = Sort.Sort(self.dbase_)
mlist = sorted(self.report.photo_list, key = sort.by_media_title_key)
for handle in mlist:
media = self.dbase_.get_object_from_handle(handle)
for media_handle in mlist:
media = self.dbase_.get_object_from_handle(media_handle)
if media:
title = media.get_description() or "[untitled]"
@ -4893,7 +4919,7 @@ class MediaListPage(BasePage):
media_data_row = [
[index, "ColumnRowLabel"],
[self.media_ref_link(handle, title), "ColumnName"],
[self.media_ref_link(media_handle, title), "ColumnName"],
[_dd.display(media.get_date_object() ), "ColumnDate"],
[media.get_mime_type(), "ColumnMime"] ]
@ -4901,7 +4927,9 @@ class MediaListPage(BasePage):
Html("td", data, class_ = colclass)
for data, colclass in media_data_row
)
index += 1
db_media_handles.append(media_handle)
# add footer section
# add clearline for proper styling
@ -4938,14 +4966,14 @@ class ThumbnailPreviewPage(BasePage):
return
media_list = []
for phandle in self.photo_keys:
photo = self.dbase_.get_object_from_handle(phandle)
for person_handle in self.photo_keys:
photo = self.dbase_.get_object_from_handle(person_handle)
if photo:
if photo.get_mime_type().startswith("image"):
media_list.append((photo.get_description(), phandle, photo))
media_list.append((photo.get_description(), person_handle, photo))
if self.create_thumbs_only:
copy_thumbnail(self.report, phandle, photo)
copy_thumbnail(self.report, person_handle, photo)
if not media_list:
return
@ -4999,7 +5027,7 @@ class ThumbnailPreviewPage(BasePage):
cols = 0
while (cols < num_of_cols and indexpos < num_of_images):
ptitle = media_list[indexpos][0]
phandle = media_list[indexpos][1]
person_handle = media_list[indexpos][1]
photo = media_list[indexpos][2]
# begin table cell and attach to table row(trow)...
@ -5025,7 +5053,7 @@ class ThumbnailPreviewPage(BasePage):
unordered += list
# attach thumbnail to list...
list += self.thumb_hyper_image(newpath, "img", phandle, ptitle)
list += self.thumb_hyper_image(newpath, "img", person_handle, ptitle)
index += 1
indexpos += 1
@ -5049,7 +5077,7 @@ class ThumbnailPreviewPage(BasePage):
table += tbody
index = 1
for ptitle, phandle, photo in media_list:
for ptitle, person_handle, photo in media_list:
trow = Html("tr")
tbody += trow
@ -5813,7 +5841,7 @@ class IndividualPage(BasePage):
0, center, self.person.handle)
return tree
def draw_tree(self, gen_nr, maxgen, max_size, old_center, new_center, phandle):
def draw_tree(self, gen_nr, maxgen, max_size, old_center, new_center, person_handle):
"""
draws the Abcestor Tree
"""
@ -5821,14 +5849,14 @@ class IndividualPage(BasePage):
if gen_nr > maxgen:
return tree
gen_offset = int(max_size / pow(2, gen_nr+1))
person = self.dbase_.get_person_from_handle(phandle)
person = self.dbase_.get_person_from_handle(person_handle)
if not person:
return tree
if gen_nr == 1:
tree = self.draw_box(new_center, 0, person)
else:
tree = self.draw_connected_box(old_center, new_center, gen_nr-1, phandle)
tree = self.draw_connected_box(old_center, new_center, gen_nr-1, person_handle)
if gen_nr == maxgen:
return tree
@ -6476,7 +6504,7 @@ class IndividualPage(BasePage):
return trow
class RepositoryListPage(BasePage):
def __init__(self, report, title, repos_dict, keys):
def __init__(self, report, title, repos_dict, keys, db_repository_handles):
self.dbase_ = report.database
BasePage.__init__(self, report, title)
inc_repos = self.report.options["inc_repository"]
@ -6530,6 +6558,7 @@ class RepositoryListPage(BasePage):
repo.get_gramps_id(), self.up), class_ = "ColumnName")
else:
trow += Html("td", "[ untitled ]", class_ = "ColumnName")
db_repository_handles.append(handle)
# add clearline for proper styling
# add footer section
@ -6978,9 +7007,6 @@ class NavWebReport(Report):
place_list = {}
source_list = {}
database_handles_list = (self.database.get_family_handles(), self.database.get_event_handles(),
self.database.get_place_handles(), self.database.get_source_handles(), self.database.get_media_object_handles())
self.base_pages()
# build classes IndividualListPage and IndividualPage
@ -6990,42 +7016,46 @@ class NavWebReport(Report):
self.surname_pages(ind_list)
# build classes FamilyListPage and FamilyPage
db_family_handles = []
if self.inc_families:
self.family_pages(ind_list, place_list, place_lat_long, self.database.get_family_handles())
self.family_pages(ind_list, place_list, place_lat_long, db_family_handles)
# build classes EventListPage and EventPage
db_event_handles = []
if self.inc_events:
self.event_pages(ind_list)
self.event_pages(ind_list, db_event_handles)
# build classes PlaceListPage and PlacePage
self.place_pages(place_list, source_list)
# build classes SourceListPage and SourcePage
# has been moved so that all Sources can be found before processing...
self.source_pages(source_list, ind_list, database_handles_list)
db_place_handles = []
self.place_pages(place_list, source_list, db_place_handles)
# build classes RepositoryListPage and RepositoryPage
db_repository_handles = []
if self.inc_repository:
repolist = self.database.get_repository_handles()
if len(repolist):
self.repository_pages(repolist, source_list)
self.repository_pages(repolist, source_list, db_repository_handles)
# build classes MediaListPage and MediaPage
db_media_handles = []
if self.inc_gallery:
if not self.create_thumbs_only:
self.media_pages(source_list)
self.media_pages(source_list, db_media_handles)
# build Thumbnail Preview Page...
self.thumbnail_preview_page()
# Build classes source pages a second time to pick up sources referenced
# by galleries
self.source_pages(source_list, ind_list, database_handles_list)
# build classes ddressBookList and AddressBookPage
# build classes AddressBookListPage and AddressBookPage
if self.inc_addressbook:
self.addressbook_pages(ind_list)
database_handles_list = (ind_list, db_family_handles, db_event_handles, db_place_handles,
db_repository_handles, db_media_handles)
# build classes SourceListPage and SourcePage
# has been moved so that all Sources can be found before processing...
self.source_pages(source_list, ind_list, database_handles_list)
# if an archive is being used, close it?
if self.archive:
self.archive.close()
@ -7210,31 +7240,32 @@ class NavWebReport(Report):
"""
creates the FamiliesListPage and FamilyPages
"""
FamilyListPage(self, self.title, ppl_handle_list, db_family_handles)
self.user.begin_progress(_("Narrated Web Site Report"),
_("Creating family pages..."),
self.database.get_number_of_families())
FamilyListPage(self, self.title, ppl_handle_list)
len(db_family_handles))
for family_handle in db_family_handles:
FamilyPage(self, self.title, family_handle, place_list, ppl_handle_list, place_lat_long)
self.user.step_progress()
self.user.end_progress()
def place_pages(self, place_list, source_list):
def place_pages(self, place_list, source_list, db_place_handles):
"""
creates PlaceListPage and PlacePage
"""
self.user.begin_progress(_("Narrated Web Site Report"),
_("Creating place pages"), len(place_list))
PlaceListPage(self, self.title, place_list)
PlaceListPage(self, self.title, place_list, db_place_handles)
for place in place_list:
PlacePage(self, self.title, place, source_list, place_list)
self.user.step_progress()
self.user.end_progress()
def event_pages(self, ind_list):
def event_pages(self, ind_list, db_event_handles):
"""
a dump of all the events sorted by event type, date, and surname
for classes EventListPage and EventPage
@ -7245,7 +7276,7 @@ class NavWebReport(Report):
self.user.begin_progress(_("Narrated Web Site Report"),
_("Creating event pages"),
len(event_handle_list))
EventListPage(self, self.title, event_types, event_handle_list, ind_list)
EventListPage(self, self.title, event_types, event_handle_list, ind_list, db_event_handles)
for event_handle in event_handle_list:
EventPage(self, self.title, event_handle, ind_list)
@ -7253,7 +7284,7 @@ class NavWebReport(Report):
self.user.step_progress()
self.user.end_progress()
def media_pages(self, source_list):
def media_pages(self, source_list, db_media_handles):
"""
creates MediaListPage and MediaPage
"""
@ -7261,7 +7292,7 @@ class NavWebReport(Report):
_("Creating media pages"),
len(self.photo_list))
MediaListPage(self, self.title)
MediaListPage(self, self.title, db_media_handles)
prev = None
total = len(self.photo_list)
@ -7290,19 +7321,19 @@ class NavWebReport(Report):
ThumbnailPreviewPage(self, self.title, self.user.step_progress)
self.user.end_progress()
def repository_pages(self, repolist, source_list):
def repository_pages(self, repolist, source_list, db_repository_handles):
"""
will create RepositoryPage() and RepositoryListPage()
"""
repos_dict = {}
# Sort the repositories
for handle in repolist:
repository = self.database.get_repository_from_handle(handle)
for repository_handle in repolist:
repository = self.database.get_repository_from_handle(repository_handle)
key = repository.get_name() + str(repository.get_gramps_id())
repos_dict[key] = (repository, handle)
repos_dict[key] = (repository, repository_handle)
keys = sorted(repos_dict, key =locale.strxfrm)
keys = sorted(repos_dict, key = locale.strxfrm)
# set progress bar pass for Repositories
repository_size = len(repos_dict)
@ -7311,7 +7342,7 @@ class NavWebReport(Report):
_('Creating repository pages'),
repository_size)
# RepositoryListPage Class
RepositoryListPage(self, self.title, repos_dict, keys)
RepositoryListPage(self, self.title, repos_dict, keys, db_repository_handles)
for index, key in enumerate(keys):
(repo, handle) = repos_dict[key]
@ -8353,8 +8384,8 @@ def add_birthdate(dbase, ppl_handle_list):
"""
sortable_individuals = []
birth_date = False
for phandle in ppl_handle_list:
person = dbase.get_person_from_handle(phandle)
for person_handle in ppl_handle_list:
person = dbase.get_person_from_handle(person_handle)
if person:
# get birth date: if birth_date equals nothing, then generate a fake one?
@ -8364,7 +8395,7 @@ def add_birthdate(dbase, ppl_handle_list):
birth = dbase.get_event_from_handle(birth_ref.ref)
if birth:
birth_date = birth.get_date_object().get_sort_value()
sortable_individuals.append((birth_date, phandle))
sortable_individuals.append((birth_date, person_handle))
# return a list of handles with the individual's birthdate attached
return sortable_individuals
@ -8424,8 +8455,8 @@ def build_event_data_by_individuals(dbase, ppl_handle_list):
event_handle_list = []
event_types = []
for phandle in ppl_handle_list:
person = dbase.get_person_from_handle(phandle)
for person_handle in ppl_handle_list:
person = dbase.get_person_from_handle(person_handle)
if person:
evt_ref_list = person.get_event_ref_list()
@ -8439,8 +8470,8 @@ def build_event_data_by_individuals(dbase, ppl_handle_list):
person_family_handle_list = person.get_family_handle_list()
if person_family_handle_list:
for fhandle in person_family_handle_list:
family = dbase.get_family_from_handle(fhandle)
for family_handle in person_family_handle_list:
family = dbase.get_family_from_handle(family_handle)
if family:
family_evt_ref_list = family.get_event_ref_list()
@ -8469,10 +8500,10 @@ def build_event_data_by_events(dbase_, event_handles):
return event_handle_list, event_types
def check_person_database(phandle, ppl_handle_list):
def check_person_database(person_handle, ppl_handle_list):
"""
check to see if a person is in the report database
@param: person -- person object from the database presumably
"""
return any(person_handle == phandle for person_handle in ppl_handle_list)
return any(person_handle == person_handle for person_handle in ppl_handle_list)