More work on converting the two of these.

svn: r12700
This commit is contained in:
Rob G. Healey 2009-06-23 22:34:14 +00:00
parent ae28b8538b
commit d5ccd93043
2 changed files with 74 additions and 105 deletions

View File

@ -150,17 +150,18 @@ h5, h6 {
margin:1.3em 0 .5em 1em; margin:1.3em 0 .5em 1em;
} }
#description:first-letter {
color:#FF0000;
font:20px;
}
p#description { p#description {
text-indent:20px;
color:#000; color:#000;
max-width:800px; max-width:800px;
margin:0; margin:0;
padding:1em 20px; padding:1em 20px;
background-color:#FFF; background-color:#FFF;
} }
p#description:first-letter {
color:#FF0000;
font:20px;
}
p a { p a {
color:#FFF; color:#FFF;
text-decoration:underline; text-decoration:underline;

View File

@ -507,7 +507,7 @@ class BasePage(object):
(self.report.surname_fname, _('Surnames'), True), (self.report.surname_fname, _('Surnames'), True),
('individuals', _('Individuals'), True), ('individuals', _('Individuals'), True),
('places', _('Places'), True), ('places', _('Places'), True),
('gallery', _('Gallery'), self.use_gallery), ('gallery', _('Media'), self.use_gallery),
('download', _('Download'), self.report.inc_download), ('download', _('Download'), self.report.inc_download),
('contact', _('Contact'), self.report.use_contact), ('contact', _('Contact'), self.report.use_contact),
('sources', _('Sources'), True), ('sources', _('Sources'), True),
@ -1566,35 +1566,37 @@ class MediaPage(BasePage):
self.copy_thumbnail(handle, photo) self.copy_thumbnail(handle, photo)
self.page_title = photo.get_description() self.page_title = photo.get_description()
mediapage, body = self.write_header("%s - %s" % (_('Gallery'), self.page_title)) mediapage, body = self.write_header("%s - %s" % (_('Media'), self.page_title))
# begin GalleryDetail division # begin GalleryDetail division
gallerydetail = Html('div', class_='content', id='GalleryDetail') mediadetail = Html('div', class_='content', id='GalleryDetail')
body += mediadetail
# gallery navigation # gallery navigation
gallerynav = Html('div', id='GalleryNav') gallerynav = Html('div', id='GalleryNav')
mediadetail += gallerynav
if prev: if prev:
hyper = self.gallery_nav_link(prev, _('Previous'), True) gallerynav += self.gallery_nav_link(prev, _('Previous'), True)
gallerynav += hyper
data = _('<strong id="GalleryCurrent">%(page_number)d</strong> of ' data = _('<strong id="GalleryCurrent">%(page_number)d</strong> of '
'<strong id="GalleryTotal">%(total_pages)d</strong>' ) % { '<strong id="GalleryTotal">%(total_pages)d</strong>' ) % {
'page_number' : page_number, 'total_pages' : total_pages } 'page_number' : page_number, 'total_pages' : total_pages }
mediacounter = Html('span', data, id='GalleryPages') gallerynav += Html('span', data, id='GalleryPages')
gallerynav += mediacounter
if next: if next:
hyper = self.gallery_nav_link(next, _('Next'), True) gallerynav += self.gallery_nav_link(next, _('Next'), True)
gallerynav += hyper
gallerydetail += gallerynav # missing media error msg
errormsg = _('The file has been moved or deleted.')
missingimage = Html('span', errormsg, class_='MissingImage')
# begin summaryarea division # begin summaryarea division
summaryarea = Html('div', id='summaryarea') summaryarea = Html('div', id='summaryarea')
mediadetail += summaryarea
if mime_type: if mime_type:
if mime_type.startswith("image/"): if mime_type.startswith("image/"):
if not target_exists: if not target_exists:
gallerydisplay = Html('div', id='GalleryDisplay') mediadisplay = Html('div', id='GalleryDisplay') + \
errormsg = _('The file has been moved or deleted.') missingimage
missingimage = Html('span', errormsg, class_='MissingImage') summaryarea += mediadisplay
gallerydisplay += missingimage
else: else:
# Check how big the image is relative to the requested 'initial' # Check how big the image is relative to the requested 'initial'
# image size. If it's significantly bigger, scale it down to # image size. If it's significantly bigger, scale it down to
@ -1631,41 +1633,38 @@ class MediaPage(BasePage):
# TODO. Convert disk path to URL. # TODO. Convert disk path to URL.
url = self.report.build_url_fname(initial_image_path, None, self.up) url = self.report.build_url_fname(initial_image_path, None, self.up)
if initial_image_path != newpath: if initial_image_path != newpath:
msg = _('Click on the image to see the full- sized version') scalemsg = Html('p', '(%d x %d).' % (width, height), inline=True)
scalemsg = Html('p', '%s (%d x %d).' % (msg, width, height), inline=True)
summaryarea += scalemsg summaryarea += scalemsg
gallerydisplay = Html('div', style='width:%dpx; height:%dpx;' % (new_width, new_height)) mediadisplay = Html('div', style='width:%dpx; height:%dpx;' % (new_width, new_height))
summaryarea += mediadisplay
# Feature #2634; display the mouse-selectable regions. # Feature #2634; display the mouse-selectable regions.
# See the large block at the top of this function where # See the large block at the top of this function where
# the various regions are stored in _region_items # the various regions are stored in _region_items
if len(_region_items): if len(_region_items):
ordered = Html('ol', class_='RegionBox') ordered = Html('ol', class_='RegionBox')
mediadisplay += ordered
while len(_region_items) > 0: while len(_region_items) > 0:
(name, x, y, w, h, linkurl) = _region_items.pop() (name, x, y, w, h, linkurl) = _region_items.pop()
ordered += Html('li', style='left:%d%%; top:%d%%; width:%d%%; height:%d%%;' ordered += Html('li', style='left:%d%%; top:%d%%; width:%d%%; height:%d%%;'
% (x, y, w, h)) +( % (x, y, w, h)) +(
Html('a', name, href=linkurl) Html('a', name, href=linkurl)
) )
gallerydisplay += ordered
# display the image # display the image
if initial_image_path != newpath: if initial_image_path != newpath:
url = self.report.build_url_fname(newpath, None, self.up) url = self.report.build_url_fname(newpath, None, self.up)
hyper = Html('a', href=url) + ( mediadisplay += Html('a', href=url) + (
Html('img', width=new_width, height=new_height, src=url, Html('img', width=new_width, height=new_height, src=url,
alt=html_escape(self.page_title), type=media_type) alt=html_escape(self.page_title), type=media_type)
) )
gallerydisplay += hyper
summaryarea += gallerydisplay
else: else:
dirname = tempfile.mkdtemp() dirname = tempfile.mkdtemp()
thmb_path = os.path.join(dirname, "temp.png") thmb_path = os.path.join(dirname, "temp.png")
if ThumbNails.run_thumbnailer(mime_type, if ThumbNails.run_thumbnailer(mime_type,
Utils.media_path_full(db, Utils.media_path_full(db,
photo.get_path()), photo.get_path()),
thmb_path, 320): thmb_path, 320):
try: try:
path = self.report.build_path('preview', photo.handle) path = self.report.build_path('preview', photo.handle)
npath = os.path.join(path, photo.handle) + '.png' npath = os.path.join(path, photo.handle) + '.png'
@ -1678,7 +1677,8 @@ class MediaPage(BasePage):
path = os.path.join('images', 'document.png') path = os.path.join('images', 'document.png')
os.rmdir(dirname) os.rmdir(dirname)
gallerydisplay = Html('div', id='GalleryDisplay') mediadisplay = Html('div', id='GalleryDisplay')
summaryarea += mediadisplay
if target_exists: if target_exists:
# TODO. Convert disk path to URL # TODO. Convert disk path to URL
url = self.report.build_url_fname(newpath, None, self.up) url = self.report.build_url_fname(newpath, None, self.up)
@ -1688,18 +1688,14 @@ class MediaPage(BasePage):
url = self.report.build_url_fname(path, None, self.up) url = self.report.build_url_fname(path, None, self.up)
hyper += Html('img', src=url, alt=html_escape(self.page_title), type=media_type) hyper += Html('img', src=url, alt=html_escape(self.page_title), type=media_type)
if target_exists: if target_exists:
gallerydisplay += hyper mediadisplay += hyper
else: else:
errormsg = _('The file has been moved or deleted.') mediadisplay += missingimage
missingimage = Html('span', errormsg, class_='MissingImage')
gallerydisplay += missingimage
summaryarea += gallerydisplay
else: else:
gallerydisplay = Html('div', id='GalleryDisplay') mediadisplay = Html('div', id='GalleryDisplay')
summaryarea += mediadisplay
url = self.report.build_url_image('document.png', 'images', self.up) url = self.report.build_url_image('document.png', 'images', self.up)
image = Html('img', src=url, alt=html_escape(self.page_title), type=media_type) mediadisplay += Html('img', src=url, alt=html_escape(self.page_title), type=media_type)
gallerydisplay += image
summaryarea += gallerydisplay
# media title # media title
title = Html('h3', html_escape(self.page_title.strip()), inline=True) title = Html('h3', html_escape(self.page_title.strip()), inline=True)
@ -1707,9 +1703,11 @@ class MediaPage(BasePage):
# begin media table # begin media table
with Html('table', class_='infolist gallery') as table: with Html('table', class_='infolist gallery') as table:
summaryarea += table
if not self.noid: if not self.noid:
with Html('tr') as trow: with Html('tr') as trow:
table += trow
trow += Html('td', _('GRAMPS ID'), class_='ColumnAttribute', inline=True) trow += Html('td', _('GRAMPS ID'), class_='ColumnAttribute', inline=True)
trow += Html('td', photo.gramps_id, class_='ColumnValue', inline=True) trow += Html('td', photo.gramps_id, class_='ColumnValue', inline=True)
@ -1726,39 +1724,30 @@ class MediaPage(BasePage):
trow += Html('td', _('Date'), class_='ColumnAttribute', inline=True) trow += Html('td', _('Date'), class_='ColumnAttribute', inline=True)
trow += Html('td', date, class_='ColumnValue', inline=True) trow += Html('td', date, class_='ColumnValue', inline=True)
# close the table
summaryarea += table
# close summaryarea division
gallerydetail += summaryarea
# get media notes # get media notes
notes = self.display_note_list(photo.get_note_list()) notes = self.display_note_list(photo.get_note_list())
if notes is not None: if notes is not None:
gallerydetail += notes mediadetail += notes
# get media attributes # get media attributes
attrib = self.display_attr_list(photo.get_attribute_list()) attrib = self.display_attr_list(photo.get_attribute_list())
if attrib is not None: if attrib is not None:
gallerydetail += attrib mediadetail += attrib
# get media sources # get media sources
sources = self.display_media_sources(photo) sources = self.display_media_sources(photo)
if sources is not None: if sources is not None:
gallerydetail += sources mediadetail += sources
# get media references # get media references
references = self.display_references(my_media_list) references = self.display_references(my_media_list)
if references is not None: if references is not None:
gallerydetail += references mediadetail += references
# close gallerydetail division and
# add clearline for proper styling # add clearline for proper styling
body += (gallerydetail, fullclear)
# add footer section # add footer section
footer = self.write_footer(counter=0) footer = self.write_footer(counter=0)
body += footer body += (fullclear, footer)
# send page out for processing # send page out for processing
self.mywriter(mediapage, of) self.mywriter(mediapage, of)
@ -1880,8 +1869,7 @@ class SurnameListPage(BasePage):
'surnames in the database. Selecting a link ' 'surnames in the database. Selecting a link '
'will lead to a list of individuals in the ' 'will lead to a list of individuals in the '
'database with this same surname.') 'database with this same surname.')
descr = Html('p', msg, class_='description') section += Html('p', msg, id='description')
section += descr
# add alphabet navigation after page msg # add alphabet navigation after page msg
# only if surname list not surname count # only if surname list not surname count
@ -2228,7 +2216,11 @@ class MediaListPage(BasePage):
msg = _("This page contains an index of all the media objects " msg = _("This page contains an index of all the media objects "
"in the database, sorted by their title. Clicking on " "in the database, sorted by their title. Clicking on "
"the title will take you to that media object&#8217;s page.") "the title will take you to that media object&#8217;s page.\n\n")
section += Html('p', msg, id='description')
msg = _("if you see media dimensions, Click on the image to see the "
"full- sized version.\n")
section += Html('p', msg, id='description') section += Html('p', msg, id='description')
# begin gallery table and table head # begin gallery table and table head
@ -4683,66 +4675,42 @@ def alphabet_navigation(db, handle_list, key):
sorted_set[ltr] = 1 sorted_set[ltr] = 1
# remove the number of each occurance of each letter # remove the number of each occurance of each letter
sorted_first_letter = sorted((l for l in sorted_set if l != ','), sorted_alphabet_index = sorted((l for l in sorted_set if l != ','),
key=locale.strxfrm) key=locale.strxfrm)
# if no letters, do not show? # if no letters, do not show?
if not sorted_first_letter: if not sorted_alphabet_index:
return None return None
# begin alphabet division # begin alphabet division
with Html('div', id='alphabet') as section: with Html('div', id='alphabet') as section:
# begin alphabet table num_ltrs = len(sorted_alphabet_index)
with Html('table', class_='alphabet infolist') as table:
section += table
num_ltrs = len(sorted_first_letter) # +1 because we are starting at 0 instead of 1
if num_ltrs <= 26: nrows = (num_ltrs / 30) + 1
trow = Html('tr') index = 0
table += trow for rows in range(0, nrows):
trow = Html('tr', class_='infolist alphabet')
section += trow
unordered = Html('ul') unordered = Html('ul')
trow += unordered trow += unordered
for ltr in sorted_first_letter:
title_str = _('Surnames') if key == 0 else _('Places')
if lang_country == "sv_SE" and ltr == u'V':
title_str += _(' starting with %s') % "V,W"
unordered += Html('li', class_='letters', inline=True) + (
Html('a', '%s' % ("V,W"), href='#%s' % ("V,W"), title=title_str)
)
else:
title_str += _(' starting with %s') % ltr
unordered += Html('li', class_='letters', inline=True) + (
Html('a', ltr, href='#%s' % ltr, title=title_str)
)
else: cols = 0
nrows = (num_ltrs / 28) + 1 while (cols <= 30 and index < num_ltrs):
index = 0 ltr = sorted_alphabet_index[index]
for rows in range(0, nrows): title_str = _('Surnames') if key == 0 else _('Places')
trow = Html('tr') if lang_country == "sv_SE" and letter == u'V':
table += trow title_str += _(' starting with %s') % "V,W"
unordered += Html('li', class_='letters', inline=True) + \
unordered = Html('ul') Html('a', "V,W", href="#V,W", title=title_str)
trow += unordered else:
cols = 0 title_str += _(' starting with %s') % ltr
while (cols <= 28 and index < num_ltrs): unordered += Html('li', class_='letters', inline=True) + \
ltr = sorted_first_letter[index] Html('a', ltr, href="%s" % ltr, title=title_str)
title_str = _('Surnames') if key == 0 else _('Places') cols += 1
if lang_country == "sv_SE" and letter == u'V': index += 1
title_str += _(' starting with %s') % "V,W"
unordered += (Html('li', class_='letters', inline=True) +
Html('a', "V,W", href="#V,W", title=title_str)
)
else:
title_str += _(' starting with %s') % ltr
unordered += Html('li', class_='letters', inline=True) + (
Html('a', ltr, href='#%s' % ltr, title=title_str)
)
cols += 1
index += 1
# return alphabet navigation to its callers # return alphabet navigation to its callers
return section return section