Completed bug# 2698. Please test it out completely. Report issues to bug#2698.
svn: r13715
This commit is contained in:
parent
46dd4e6c1a
commit
b886d022bb
@ -446,7 +446,7 @@ class BasePage(object):
|
|||||||
# return unordered note list to its callers
|
# return unordered note list to its callers
|
||||||
return ul
|
return ul
|
||||||
|
|
||||||
def display_event_row(self, evt, evt_ref, showplc, showdescr, showsrc, shownote, subdirs, hyp):
|
def display_event_row(self, evt, evt_ref, showplc, showdescr, showsrc, subdirs, hyp):
|
||||||
"""
|
"""
|
||||||
display the event row for IndividualPage
|
display the event row for IndividualPage
|
||||||
"""
|
"""
|
||||||
@ -1095,6 +1095,73 @@ class BasePage(object):
|
|||||||
# return navigation menu bar to its caller
|
# return navigation menu bar to its caller
|
||||||
return navigation
|
return navigation
|
||||||
|
|
||||||
|
def add_image(self, option_name, height = 0):
|
||||||
|
db = self.report.database
|
||||||
|
|
||||||
|
pic_id = self.report.options[option_name]
|
||||||
|
if pic_id:
|
||||||
|
obj = db.get_object_from_gramps_id(pic_id)
|
||||||
|
obj_handle = obj.handle
|
||||||
|
mime_type = obj.get_mime_type()
|
||||||
|
if mime_type and mime_type.startswith("image"):
|
||||||
|
try:
|
||||||
|
|
||||||
|
newpath, thumb_path = self.report.prepare_copy_media(obj)
|
||||||
|
self.report.copy_file(Utils.media_path_full(db, obj.get_path()), newpath)
|
||||||
|
|
||||||
|
# get media rectangles
|
||||||
|
_region_items = self.media_rectangles(obj_handle, obj)
|
||||||
|
if len(_region_items):
|
||||||
|
with Html("div") as mediadisplay:
|
||||||
|
|
||||||
|
# Feature #2634; display the mouse-selectable regions.
|
||||||
|
# See the large block at the top of this function where
|
||||||
|
# the various regions are stored in _region_items
|
||||||
|
ordered = Html("ol", class_ = "RegionBox")
|
||||||
|
mediadisplay += ordered
|
||||||
|
while len(_region_items):
|
||||||
|
(name, x, y, w, h, linkurl) = _region_items.pop()
|
||||||
|
ordered += Html("li", style = "left:%d%%; top:%d%%; width:%d%%; height:%d%%;"
|
||||||
|
% (x, y, w, h)) +(
|
||||||
|
Html("a", name, href = linkurl)
|
||||||
|
)
|
||||||
|
|
||||||
|
# begin image
|
||||||
|
image = Html("img")
|
||||||
|
mediadisplay += image
|
||||||
|
img_attr = ''
|
||||||
|
if height:
|
||||||
|
img_attr += 'height = "%d"' % height
|
||||||
|
img_attr += ' src = "%s" alt = "%s"' % (newpath, obj.get_description())
|
||||||
|
|
||||||
|
# add image attributes to image
|
||||||
|
image.attr = img_attr
|
||||||
|
|
||||||
|
# return image with media behaviours styling
|
||||||
|
return mediadisplay
|
||||||
|
|
||||||
|
# media has no media references
|
||||||
|
else:
|
||||||
|
|
||||||
|
# begin image
|
||||||
|
image = Html("img")
|
||||||
|
img_attr = ''
|
||||||
|
if height:
|
||||||
|
img_attr += 'height = "%d"' % height
|
||||||
|
img_attr += ' src = "%s" alt = "%s"' % (newpath, obj.get_description())
|
||||||
|
|
||||||
|
# add image attributes to image
|
||||||
|
image.attr = img_attr
|
||||||
|
|
||||||
|
# return an image
|
||||||
|
return image
|
||||||
|
|
||||||
|
except (IOError, OSError), msg:
|
||||||
|
WarningDialog(_("Could not add photo to page"), str(msg))
|
||||||
|
|
||||||
|
# no image to return
|
||||||
|
return None
|
||||||
|
|
||||||
def media_rectangles(self, handle, media):
|
def media_rectangles(self, handle, media):
|
||||||
|
|
||||||
"""
|
"""
|
||||||
@ -1200,6 +1267,25 @@ class BasePage(object):
|
|||||||
|
|
||||||
if mime_type:
|
if mime_type:
|
||||||
try:
|
try:
|
||||||
|
|
||||||
|
# get media rectangles
|
||||||
|
_region_items = self.media_rectangles(photo_handle, photo)
|
||||||
|
if len(_region_items):
|
||||||
|
with Html("div") as mediadisplay:
|
||||||
|
snapshot += mediadisplay
|
||||||
|
|
||||||
|
# Feature #2634; display the mouse-selectable regions.
|
||||||
|
# See the large block at the top of this function where
|
||||||
|
# the various regions are stored in _region_items
|
||||||
|
ordered = Html("ol", class_ = "RegionBox")
|
||||||
|
mediadisplay += ordered
|
||||||
|
while len(_region_items):
|
||||||
|
(name, x, y, w, h, linkurl) = _region_items.pop()
|
||||||
|
ordered += Html("li", style = "left:%d%%; top:%d%%; width:%d%%; height:%d%%;"
|
||||||
|
% (x, y, w, h)) +(
|
||||||
|
Html("a", name, href = linkurl)
|
||||||
|
)
|
||||||
|
|
||||||
lnkref = (self.report.cur_fname, self.page_title, self.gid)
|
lnkref = (self.report.cur_fname, self.page_title, self.gid)
|
||||||
self.report.add_lnkref_to_photo(photo, lnkref)
|
self.report.add_lnkref_to_photo(photo, lnkref)
|
||||||
real_path, newpath = self.report.prepare_copy_media(photo)
|
real_path, newpath = self.report.prepare_copy_media(photo)
|
||||||
@ -1250,6 +1336,7 @@ class BasePage(object):
|
|||||||
|
|
||||||
photo_handle = mediaref.get_reference_handle()
|
photo_handle = mediaref.get_reference_handle()
|
||||||
photo = db.get_object_from_handle(photo_handle)
|
photo = db.get_object_from_handle(photo_handle)
|
||||||
|
|
||||||
if photo_handle in displayed:
|
if photo_handle in displayed:
|
||||||
continue
|
continue
|
||||||
mime_type = photo.get_mime_type()
|
mime_type = photo.get_mime_type()
|
||||||
@ -1259,6 +1346,25 @@ class BasePage(object):
|
|||||||
|
|
||||||
if mime_type:
|
if mime_type:
|
||||||
try:
|
try:
|
||||||
|
|
||||||
|
# get media rectangles
|
||||||
|
_region_items = self.media_rectangles(photo_handle, photo)
|
||||||
|
if len(_region_items):
|
||||||
|
with Html("div") as mediadisplay:
|
||||||
|
section += mediadisplay
|
||||||
|
|
||||||
|
# Feature #2634; display the mouse-selectable regions.
|
||||||
|
# See the large block at the top of this function where
|
||||||
|
# the various regions are stored in _region_items
|
||||||
|
ordered = Html("ol", class_ = "RegionBox")
|
||||||
|
mediadisplay += ordered
|
||||||
|
while len(_region_items):
|
||||||
|
(name, x, y, w, h, linkurl) = _region_items.pop()
|
||||||
|
ordered += Html("li", style = "left:%d%%; top:%d%%; width:%d%%; height:%d%%;"
|
||||||
|
% (x, y, w, h)) +(
|
||||||
|
Html("a", name, href = linkurl)
|
||||||
|
)
|
||||||
|
|
||||||
lnkref = (self.report.cur_fname, self.page_title, self.gid)
|
lnkref = (self.report.cur_fname, self.page_title, self.gid)
|
||||||
self.report.add_lnkref_to_photo(photo, lnkref)
|
self.report.add_lnkref_to_photo(photo, lnkref)
|
||||||
real_path, newpath = self.report.prepare_copy_media(photo)
|
real_path, newpath = self.report.prepare_copy_media(photo)
|
||||||
@ -2669,7 +2775,7 @@ class MediaPage(BasePage):
|
|||||||
|
|
||||||
# media date
|
# media date
|
||||||
date = media.get_date_object()
|
date = media.get_date_object()
|
||||||
if date:
|
if date and date is not Date.EMPTY:
|
||||||
trow = Html("tr") + (
|
trow = Html("tr") + (
|
||||||
Html("td", DHEAD, class_ = "ColumnAttribute", inline = True),
|
Html("td", DHEAD, class_ = "ColumnAttribute", inline = True),
|
||||||
Html("td", _dd.display(date), class_ = "ColumnValue", inline = True)
|
Html("td", _dd.display(date), class_ = "ColumnValue", inline = True)
|
||||||
@ -2941,7 +3047,7 @@ class IntroductionPage(BasePage):
|
|||||||
with Html("div", class_ = "content", id = "Introduction") as section:
|
with Html("div", class_ = "content", id = "Introduction") as section:
|
||||||
body += section
|
body += section
|
||||||
|
|
||||||
introimg = report.add_image('introimg')
|
introimg = self.add_image('introimg')
|
||||||
if introimg is not None:
|
if introimg is not None:
|
||||||
section += introimg
|
section += introimg
|
||||||
|
|
||||||
@ -2978,7 +3084,7 @@ class HomePage(BasePage):
|
|||||||
with Html("div", class_ = "content", id = "Home") as section:
|
with Html("div", class_ = "content", id = "Home") as section:
|
||||||
body += section
|
body += section
|
||||||
|
|
||||||
homeimg = report.add_image('homeimg')
|
homeimg = self.add_image('homeimg')
|
||||||
if homeimg is not None:
|
if homeimg is not None:
|
||||||
section += homeimg
|
section += homeimg
|
||||||
|
|
||||||
@ -3373,7 +3479,7 @@ class ContactPage(BasePage):
|
|||||||
with Html("div", id = 'summaryarea') as summaryarea:
|
with Html("div", id = 'summaryarea') as summaryarea:
|
||||||
section += summaryarea
|
section += summaryarea
|
||||||
|
|
||||||
contactimg = report.add_image('contactimg', 200)
|
contactimg = self.add_image('contactimg', 200)
|
||||||
if contactimg is not None:
|
if contactimg is not None:
|
||||||
summaryarea += contactimg
|
summaryarea += contactimg
|
||||||
|
|
||||||
@ -3951,9 +4057,8 @@ class IndividualPage(BasePage):
|
|||||||
@param: show place
|
@param: show place
|
||||||
@param: show description
|
@param: show description
|
||||||
@param: show source references
|
@param: show source references
|
||||||
@param: show note
|
|
||||||
"""
|
"""
|
||||||
thead += self.display_event_header(True, True, True, False)
|
thead += self.display_event_header(True, True, True)
|
||||||
|
|
||||||
tbody = Html("tbody")
|
tbody = Html("tbody")
|
||||||
table += tbody
|
table += tbody
|
||||||
@ -3968,11 +4073,10 @@ class IndividualPage(BasePage):
|
|||||||
@param: show place or not?
|
@param: show place or not?
|
||||||
@param: show description or not?
|
@param: show description or not?
|
||||||
@param: show source references or not?
|
@param: show source references or not?
|
||||||
@param: shownote = show notes or not?
|
|
||||||
@param: subdirs = True or False
|
@param: subdirs = True or False
|
||||||
@param: hyp = show hyperlinked evt type or not?
|
@param: hyp = show hyperlinked evt type or not?
|
||||||
"""
|
"""
|
||||||
tbody += self.display_event_row(event, evt_ref, True, True, True, False, True, True)
|
tbody += self.display_event_row(event, evt_ref, True, True, True, True, True)
|
||||||
|
|
||||||
# return section to its caller
|
# return section to its caller
|
||||||
return section
|
return section
|
||||||
@ -4445,7 +4549,7 @@ class IndividualPage(BasePage):
|
|||||||
)
|
)
|
||||||
return ped
|
return ped
|
||||||
|
|
||||||
def display_event_header(self, showplc, showdescr, showsrc, shownote):
|
def display_event_header(self, showplc, showdescr, showsrc):
|
||||||
"""
|
"""
|
||||||
will print the event header row for display_event_row() and
|
will print the event header row for display_event_row() and
|
||||||
format_event()
|
format_event()
|
||||||
@ -4453,7 +4557,6 @@ class IndividualPage(BasePage):
|
|||||||
@param: showplc = show place
|
@param: showplc = show place
|
||||||
@param: showdescr = show description
|
@param: showdescr = show description
|
||||||
@param: showsrc = show source references
|
@param: showsrc = show source references
|
||||||
@param: shownote = show notes or not?
|
|
||||||
"""
|
"""
|
||||||
# position 0 = translatable label, position 1 = column class, and
|
# position 0 = translatable label, position 1 = column class, and
|
||||||
# position 2 = data
|
# position 2 = data
|
||||||
@ -4470,9 +4573,6 @@ class IndividualPage(BasePage):
|
|||||||
if showsrc:
|
if showsrc:
|
||||||
event_header_row.append((SHEAD, "Sources"))
|
event_header_row.append((SHEAD, "Sources"))
|
||||||
|
|
||||||
if shownote:
|
|
||||||
event_header_row.append((NHEAD, "Notes"))
|
|
||||||
|
|
||||||
trow = Html("tr")
|
trow = Html("tr")
|
||||||
trow.extend(
|
trow.extend(
|
||||||
Html("th", label, class_ = "Column" + colclass, inline = True)
|
Html("th", label, class_ = "Column" + colclass, inline = True)
|
||||||
@ -4497,9 +4597,8 @@ class IndividualPage(BasePage):
|
|||||||
@param: show place
|
@param: show place
|
||||||
@param: show description
|
@param: show description
|
||||||
@param: show source references
|
@param: show source references
|
||||||
@param: show note
|
|
||||||
"""
|
"""
|
||||||
thead += self.display_event_header(True, True, True, False)
|
thead += self.display_event_header(True, True, True)
|
||||||
|
|
||||||
# begin table body
|
# begin table body
|
||||||
tbody = Html("tbody")
|
tbody = Html("tbody")
|
||||||
@ -4515,11 +4614,10 @@ class IndividualPage(BasePage):
|
|||||||
@param: show place or not?
|
@param: show place or not?
|
||||||
@param: show description or not?
|
@param: show description or not?
|
||||||
@param: show source references or not?
|
@param: show source references or not?
|
||||||
@param: shownote = show notes or not?
|
|
||||||
@param: up = True or False: attach subdirs or not?
|
@param: up = True or False: attach subdirs or not?
|
||||||
@param: hyp = show hyperlinked evt type or not?
|
@param: hyp = show hyperlinked evt type or not?
|
||||||
"""
|
"""
|
||||||
tbody += self.display_event_row(event, event_ref, True, True, True, False, True, True)
|
tbody += self.display_event_row(event, event_ref, True, True, True, True, True)
|
||||||
|
|
||||||
# return table to its callers
|
# return table to its callers
|
||||||
return table
|
return table
|
||||||
@ -5339,7 +5437,8 @@ class NavWebReport(Report):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
# set up progress bar for event pages; using ind list because it was taking too long at the end
|
# set up progress bar for event pages; using ind list because it was taking too long at the end
|
||||||
self.progress.set_pass(_("Creating event pages"), len(ind_list))
|
event_handles = self.database.get_event_handles()
|
||||||
|
self.progress.set_pass(_("Creating event pages"), len(event_handles))
|
||||||
|
|
||||||
# send all data to the events list page
|
# send all data to the events list page
|
||||||
EventListPage(self, self.title, event_types, event_handle_list, ind_list)
|
EventListPage(self, self.title, event_types, event_handle_list, ind_list)
|
||||||
@ -5471,36 +5570,6 @@ class NavWebReport(Report):
|
|||||||
|
|
||||||
AddressBookPage(self, self.title, person_handle, has_add, has_res, has_url)
|
AddressBookPage(self, self.title, person_handle, has_add, has_res, has_url)
|
||||||
|
|
||||||
def add_image(self, option_name, height=0):
|
|
||||||
pic_id = self.options[option_name]
|
|
||||||
if pic_id:
|
|
||||||
obj = self.database.get_object_from_gramps_id(pic_id)
|
|
||||||
mime_type = obj.get_mime_type()
|
|
||||||
if mime_type and mime_type.startswith("image"):
|
|
||||||
try:
|
|
||||||
newpath, thumb_path = self.prepare_copy_media(obj)
|
|
||||||
self.copy_file(Utils.media_path_full(self.database, obj.get_path()),
|
|
||||||
newpath)
|
|
||||||
|
|
||||||
# begin image
|
|
||||||
image = Html("img")
|
|
||||||
img_attr = ''
|
|
||||||
if height:
|
|
||||||
img_attr += 'height = "%d"' % height
|
|
||||||
img_attr += ' src = "%s" alt = "%s"' % (newpath, obj.get_description())
|
|
||||||
|
|
||||||
# add image attributes to image
|
|
||||||
image.attr = img_attr
|
|
||||||
|
|
||||||
# return an image
|
|
||||||
return image
|
|
||||||
|
|
||||||
except (IOError, OSError), msg:
|
|
||||||
WarningDialog(_("Could not add photo to page"), str(msg))
|
|
||||||
|
|
||||||
# no image to return
|
|
||||||
return None
|
|
||||||
|
|
||||||
def build_subdirs(self, subdir, fname, up = False):
|
def build_subdirs(self, subdir, fname, up = False):
|
||||||
"""
|
"""
|
||||||
If subdir is given, then two extra levels of subdirectory are inserted
|
If subdir is given, then two extra levels of subdirectory are inserted
|
||||||
|
Loading…
x
Reference in New Issue
Block a user