Re-did Internet Address Book. it is now Address Book. Current styles for my work on Address Book in stylesheet.
svn: r13529
This commit is contained in:
parent
19522ec975
commit
232bb80d6c
@ -383,7 +383,7 @@ table.infolist tr td a {
|
||||
color: #000;
|
||||
}
|
||||
table.infolist tr.BeginLetter td, table.infolist tr.BeginSurname td {
|
||||
border-top:solid 1px #228A22;
|
||||
border-top:solid 1px #5D835F;
|
||||
}
|
||||
table.infolist tr td.ColumnLetter {
|
||||
width:3%;
|
||||
@ -891,32 +891,48 @@ div#RepositoryList table.repolist tbody tr td.ColumnName {
|
||||
background-color: #FFF;
|
||||
}
|
||||
|
||||
/* Internet Address Book
|
||||
/* Address Book
|
||||
------------------------------------------------------ */
|
||||
div#InternetAddressBook {
|
||||
div#AddressBookList, AddressBookDetail {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
div#InternetAddressBook table.addressbook {
|
||||
div#AddressBookList table.addressbook {
|
||||
margin: .3em 0 .3em 0;
|
||||
}
|
||||
div#InternetAddressBook table.addressbook tbody tr.BeginName {
|
||||
border-top: solid 1px #000;
|
||||
div#AddressBookList table.addressbook tbody tr.Totals {
|
||||
border: solid 1px #5D835F;
|
||||
}
|
||||
div#InternetAddressBook table.addressbook tbody tr td {
|
||||
background-color: #FFF;
|
||||
border-bottom: dashed 1px #000;
|
||||
}
|
||||
div#InternetAddressBook table.addressbook tbody tr td.ColumnType {
|
||||
div#AddressBookList tble.addressbook tbody tr.Totals td {
|
||||
text-align: left;
|
||||
background-color: #D8F3D6;
|
||||
width: 15%;
|
||||
}
|
||||
div#InternetAddressBook table.addressbook tbody tr td.ColumnName {
|
||||
width: 30%;
|
||||
div#AddressBookList table.addressbook tbody tr td {
|
||||
background-color: #D8F3D6;
|
||||
text-align: center;
|
||||
border: solid 1px #5D835F;
|
||||
}
|
||||
div#InternetAddressBook table.addressbook tbody tr td.ColumnLink {
|
||||
div#AddressBookList table.addressbook tbody tr td.ColumnRowLabel {
|
||||
width: 4%;
|
||||
}
|
||||
div#AddressBookList table.addressbook tbody tr td.ColumnName {
|
||||
background-color: #FFF;
|
||||
text-align: left;
|
||||
width: 70%;
|
||||
}
|
||||
div#AddressBookList table.addressbook tbody tr td.ColumnName a {
|
||||
display: block;
|
||||
padding: 6px 0px 6px 0px;
|
||||
}
|
||||
div#AddressBookList table.addressbook tbody tr td.ColumnAddress {
|
||||
width: 8%;
|
||||
}
|
||||
div#AddressBookList table.adressbook tbody tr td.ColumnResidence {
|
||||
width: 8%;
|
||||
}
|
||||
div#AddressBookList table.addressbook tbody tr td.ColumnWebLinks {
|
||||
width: 8%;
|
||||
}
|
||||
|
||||
/* Subsections
|
||||
----------------------------------------------------- */
|
||||
@ -997,15 +1013,13 @@ table.infolist tbody tr td.ColumnValue p {
|
||||
|
||||
/* Subsections : Attributes
|
||||
----------------------------------------------------- */
|
||||
div#attributes { }
|
||||
|
||||
div#attributes {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
table.attrlist {
|
||||
width: 100%;
|
||||
}
|
||||
table.attrlist thead tr th {
|
||||
font-weight: bold;
|
||||
text-transform: uppercase;
|
||||
}
|
||||
table.attrlist tbody tr {
|
||||
border: solid 1px #5D835F;
|
||||
}
|
||||
@ -1015,6 +1029,9 @@ table.attrlist tbody tr td {
|
||||
table.attrlist tbody tr td.ColumnType {
|
||||
width: 200px;
|
||||
}
|
||||
table.attrlist tbody tr td.ColumnAttribute {
|
||||
width: 10%;
|
||||
}
|
||||
table.attrlist tbody tr td.ColumnValue {
|
||||
width: 250px;
|
||||
}
|
||||
@ -1106,40 +1123,39 @@ table.ldsordlist tbody tr td.ColumnLDSSources {
|
||||
/* Subsections : Addresses
|
||||
----------------------------------------------------- */
|
||||
div#Addresses {
|
||||
padding-bottom:0;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
div#Addresses table.infolist {
|
||||
font-size:.35cm;
|
||||
background-color: #FFF;
|
||||
font-size: 12px;
|
||||
background- color: #D8F3D6;
|
||||
}
|
||||
div#Addresses table.infolist tbody tr td {
|
||||
border-bottom:solid 1px #000;
|
||||
padding-top:.4em;
|
||||
padding-bottom:.4em;
|
||||
border-bottom: solid 1px #5D835F;
|
||||
}
|
||||
div#Addresses table.infolist tbody tr td.ColumnDate {
|
||||
width:15%;
|
||||
width: 15%;
|
||||
}
|
||||
div#Addresses table.infolist tbody tr td.ColumnStreetAddress {
|
||||
width:30%;
|
||||
width: 30%;
|
||||
}
|
||||
div#Addresses table.infolist tbody tr td.ColumnCity {
|
||||
width:8%;
|
||||
width: 8%;
|
||||
}
|
||||
div#Addresses table.infolist tbody tr td.ColumnCounty {
|
||||
with:8%;
|
||||
with: 8%;
|
||||
}
|
||||
div#Addresses table.infolist tbody tr td.ColumnState {
|
||||
width:12%;
|
||||
width: 12%;
|
||||
}
|
||||
div#Addresses table.infolist tbody tr td.ColumnCntry {
|
||||
width:5%;
|
||||
width: 5%;
|
||||
}
|
||||
div#Addresses table.infolist tbody tr td.ColumnPostalcode {
|
||||
width:10%;
|
||||
width: 10%;
|
||||
}
|
||||
div#Addresses table.infolist tbody tr td.ColumnPhone {
|
||||
width:15%;
|
||||
width: 15%;
|
||||
}
|
||||
|
||||
/* Subsections : Gallery
|
||||
|
@ -99,7 +99,6 @@ from gui.utils import ProgressMeter
|
||||
import ThumbNails
|
||||
import ImgManip
|
||||
import Mime
|
||||
from Utils import probably_alive, xml_lang
|
||||
from QuestionDialog import ErrorDialog, WarningDialog
|
||||
from BasicUtils import name_displayer as _nd
|
||||
from DateHandler import displayer as _dd
|
||||
@ -275,11 +274,13 @@ class BasePage(object):
|
||||
|
||||
def __init__(self, report, title, gid = None):
|
||||
"""
|
||||
report - instance of NavWebReport
|
||||
title - text for the <title> tag
|
||||
gid - Gramps ID
|
||||
"""
|
||||
Holds all of the things that each class needs to have...
|
||||
|
||||
@param: report - instance of NavWebReport
|
||||
@param: title - text for the title
|
||||
@param: gid - Gramps ID
|
||||
"""
|
||||
self.up = False
|
||||
# class to do conversion of styled notes to html markup
|
||||
self._backend = HtmlBackend()
|
||||
|
||||
@ -293,7 +294,6 @@ class BasePage(object):
|
||||
self.author = Utils.get_researcher().get_name()
|
||||
if self.author:
|
||||
self.author = self.author.replace(',,,', '')
|
||||
self.up = False
|
||||
|
||||
# TODO. All of these attributes are not necessary, because we have
|
||||
# also the options in self.options. Besides, we need to check which
|
||||
@ -697,14 +697,36 @@ class BasePage(object):
|
||||
# return hyperlink to its callers
|
||||
return hyper
|
||||
|
||||
def dump_addresses(self, addrobj, showsrc = True):
|
||||
def display_addr_list(self, addrlist, showsrc):
|
||||
"""
|
||||
display a person's addresses ...
|
||||
|
||||
@param: addrlist -- a list of address handles
|
||||
@param: showsrc -- whether to show sources or not?
|
||||
"""
|
||||
|
||||
if not addrlist:
|
||||
return None
|
||||
|
||||
# begin addresses division and title
|
||||
with Html("div", class_ = "subsection", id = "Addresses") as section:
|
||||
section += Html("h4", _("Addresses"), inline = True)
|
||||
|
||||
# write out addresses()
|
||||
section += self.dump_addresses(addrlist, showsrc)
|
||||
|
||||
# return address division to its caller
|
||||
return section
|
||||
|
||||
def dump_addresses(self, addrlist, showsrc):
|
||||
"""
|
||||
will display an object's addresses, url list, note list,
|
||||
and source references.
|
||||
|
||||
@param: addrobj = either person or repository address object
|
||||
@param: addrlist = either person or repository address list
|
||||
@param: showsrc = True -- person
|
||||
False -- repository
|
||||
None -- do not show sources
|
||||
"""
|
||||
|
||||
def write_address_header(showsrc):
|
||||
@ -723,7 +745,7 @@ class BasePage(object):
|
||||
|
||||
# if showsrc = True -- an individual's address else repository
|
||||
if showsrc:
|
||||
addr_header.append([SHEAD, 'Sources'])
|
||||
addr_header.append([SHEAD, "Sources"])
|
||||
|
||||
for (label, colclass) in addr_header:
|
||||
trow += Html("th", label, class_ = "Column%s" % colclass, inline = True)
|
||||
@ -738,9 +760,13 @@ class BasePage(object):
|
||||
with Html("table") as table:
|
||||
summaryarea += table
|
||||
|
||||
# get table class based on either person or repository
|
||||
table.attr = 'class = "infolist addrlist"' if showsrc \
|
||||
else 'class = "infolist repolist"'
|
||||
# get table class based on showsrc
|
||||
if showsrc == True:
|
||||
table.attr = 'class = "infolist addrlist"'
|
||||
elif showsrc == False:
|
||||
table.attr = 'class = "infolist repolist"'
|
||||
else:
|
||||
table.attr = 'class = "infolist addressbook"'
|
||||
|
||||
# begin table head
|
||||
thead = Html("thead")
|
||||
@ -754,7 +780,7 @@ class BasePage(object):
|
||||
table += tbody
|
||||
|
||||
# get address list from an object; either repository or person
|
||||
for address in addrobj.get_address_list():
|
||||
for address in addrlist:
|
||||
|
||||
trow = Html("tr")
|
||||
tbody += trow
|
||||
@ -780,6 +806,7 @@ class BasePage(object):
|
||||
trow += Html("td", value, class_ = "Column%s" % colclass, inline = True)
|
||||
|
||||
# address: notelist
|
||||
if showsrc is not None:
|
||||
notelist = self.display_note_list(address.get_note_list())
|
||||
if notelist is not None:
|
||||
summaryarea += notelist
|
||||
@ -787,6 +814,19 @@ class BasePage(object):
|
||||
# return summaryarea division to its callers
|
||||
return summaryarea
|
||||
|
||||
def addressbook_link(self, handle, up = False):
|
||||
""" createsa hyperlink for an address book link based on person's handle """
|
||||
db = self.report.database
|
||||
|
||||
url = self.report.build_url_fname_html(handle, "addr", up)
|
||||
person = db.get_person_from_handle(handle)
|
||||
person_name = self.get_name(person)
|
||||
|
||||
addr_hyper = Html("a", person_name, href = url, title = html_escape(person_name))
|
||||
|
||||
# return addressbook hyperlink to its caller
|
||||
return addr_hyper
|
||||
|
||||
def get_copyright_license(self, copyright, up = False):
|
||||
"""
|
||||
will return either the text or image of the copyright license
|
||||
@ -954,7 +994,7 @@ class BasePage(object):
|
||||
db = self.report.database
|
||||
|
||||
# Header constants
|
||||
xmllang = xml_lang()
|
||||
xmllang = Utils.xml_lang()
|
||||
_META1 = 'name="generator" content="%s %s %s"' % (
|
||||
const.PROGRAM_NAME, const.VERSION, const.URL_HOMEPAGE
|
||||
)
|
||||
@ -991,7 +1031,7 @@ class BasePage(object):
|
||||
|
||||
# Link to GRAMPS favicon
|
||||
fname = "/".join(['images', 'favicon.ico'])
|
||||
url5 = self.report.build_url_image('favicon.ico', 'images', self.up)
|
||||
url5 = self.report.build_url_image("favicon.ico", "images", self.up)
|
||||
|
||||
# create stylesheet and favicon links
|
||||
links = [Html("link", href = url5, type = "image/x-icon", rel = "shortcut icon"),
|
||||
@ -1052,7 +1092,7 @@ class BasePage(object):
|
||||
('contact', _("Contact"), self.report.use_contact),
|
||||
('sources', SHEAD, True),
|
||||
('repositories', _("Repositories"), inc_repos),
|
||||
("Internet_Address_Book", _("Internet Address Book"), self.report.add_book)
|
||||
("addressbook", _("Address Book"), self.report.addressbook)
|
||||
]
|
||||
|
||||
navigation = Html("div", id = 'navigation')
|
||||
@ -1095,11 +1135,11 @@ class BasePage(object):
|
||||
elif nav_text == _("Media"):
|
||||
if "img" in self.report.cur_fname:
|
||||
cs = True
|
||||
elif nav_text == _("Internet Address Book"):
|
||||
if "iab" in self.report.cur_fname:
|
||||
elif nav_text == _("Address Book"):
|
||||
if "addr" in self.report.cur_fname:
|
||||
cs = True
|
||||
|
||||
cs = cs and 'class="CurrentSection"' or ''
|
||||
cs = 'class = "CurrentSection"' if cs else ""
|
||||
ul += (Html("li", attr = cs, inline = True) +
|
||||
Html("a", nav_text, href = url)
|
||||
)
|
||||
@ -1270,11 +1310,6 @@ class BasePage(object):
|
||||
descr = uri
|
||||
_type = url.get_type()
|
||||
|
||||
uri = url.get_path()
|
||||
descr = url.get_description()
|
||||
if not descr:
|
||||
descr = uri
|
||||
|
||||
list = Html("li")
|
||||
ordered += list
|
||||
|
||||
@ -1306,22 +1341,23 @@ class BasePage(object):
|
||||
# return web links to its caller
|
||||
return section
|
||||
|
||||
# Only used in IndividualPage.display_ind_sources
|
||||
# and MediaPage.display_media_sources
|
||||
def display_source_refs(self, bibli):
|
||||
if bibli.get_citation_count() == 0:
|
||||
return None
|
||||
db = self.report.database
|
||||
|
||||
# begin Source References division and title
|
||||
with Html("div", id = "sourcerefs", class_ = "subsection") as section:
|
||||
section += Html("h4", _("Source References"), inline = True)
|
||||
|
||||
# begin ordered list
|
||||
ordered1 = Html("ol")
|
||||
section += ordered1
|
||||
ordered = Html("ol")
|
||||
|
||||
cindex = 0
|
||||
for citation in bibli.get_citation_list():
|
||||
cindex += 1
|
||||
|
||||
cindex += 1
|
||||
# Add this source to the global list of sources to be displayed
|
||||
# on each source page.
|
||||
lnk = (self.report.cur_fname, self.page_title, self.gid)
|
||||
@ -1335,21 +1371,24 @@ class BasePage(object):
|
||||
# Add this source and its references to the page
|
||||
source = db.get_source_from_handle(shandle)
|
||||
title = source.get_title()
|
||||
list1 = Html("li")
|
||||
ordered1 += list1
|
||||
hyper = self.source_link(source.handle, "sref%d" % cindex, title, source.gramps_id, True)
|
||||
list1 += hyper
|
||||
|
||||
ordered2 = Html("ol")
|
||||
list1 += ordered2
|
||||
list = Html("li", inline = True)
|
||||
|
||||
hyper = (Html("a", name = "sref%d" % cindex) +
|
||||
self.source_link(source.handle, title, source.gramps_id, True)
|
||||
)
|
||||
list += hyper
|
||||
|
||||
ordered1 = Html("ol")
|
||||
list += ordered1
|
||||
|
||||
for key, sref in citation.get_ref_list():
|
||||
|
||||
tmp = []
|
||||
confidence = Utils.confidence.get(sref.confidence, _("Unknown"))
|
||||
if confidence == _("Normal"):
|
||||
confidence = Utils.confidence.get(sref.confidence, _('Unknown'))
|
||||
if confidence == _('Normal'):
|
||||
confidence = None
|
||||
for (label, data) in [(DHEAD, format_date(sref.date)),
|
||||
for (label, data) in [(_("Date"), format_date(sref.date)),
|
||||
(_("Page"), sref.page),
|
||||
(_("Confidence"), confidence)]:
|
||||
if data:
|
||||
@ -1358,12 +1397,14 @@ class BasePage(object):
|
||||
for notehandle in notelist:
|
||||
note = db.get_note_from_handle(notehandle)
|
||||
note_text = self.get_note_format(note)
|
||||
tmp.append("%s: %s" % (_("Text"), note_text))
|
||||
tmp.append("%s: %s" % (_('Text'), note_text))
|
||||
if len(tmp) > 0:
|
||||
list2 = (Html("li") +
|
||||
Html("a", '; '.join(tmp), name = "sref%d%s" % (cindex, key), inline = True)
|
||||
)
|
||||
ordered2 += list2
|
||||
|
||||
list1 = Html("li")
|
||||
ordered1 += list1
|
||||
|
||||
hyper1 = Html("a", '; '.join(tmp), name = "sref%d%s" % (cindex, key))
|
||||
list1 += hyper1
|
||||
|
||||
# return section to its callers
|
||||
return section
|
||||
@ -1498,6 +1539,75 @@ class BasePage(object):
|
||||
# return hyperlink to its callers
|
||||
return hyper
|
||||
|
||||
def dump_place(self, place, table, gid):
|
||||
""" dump a place from the database """
|
||||
|
||||
if not self.noid and gid:
|
||||
trow = Html("tr") + (
|
||||
Html("td", GRAMPSID, class_ = "ColumnAttribute", inline = True),
|
||||
Html("td", gid, class_ = "ColumnValue", inline = True)
|
||||
)
|
||||
table += trow
|
||||
|
||||
if place.main_loc:
|
||||
ml = place.get_main_location()
|
||||
if ml and not ml.is_empty():
|
||||
for val in [
|
||||
(LATITUDE, place.lat),
|
||||
(LONGITUDE, place.long),
|
||||
(STREET, ml.street),
|
||||
(CITY, ml.city),
|
||||
(PARISH, ml.parish),
|
||||
(COUNTY, ml.county),
|
||||
(STATE, ml.state),
|
||||
(POSTAL, ml.postal),
|
||||
(COUNTRY, ml.country),
|
||||
(LOCATIONS, place.get_alternate_locations() ) ]:
|
||||
|
||||
if val[1]:
|
||||
trow = Html("tr") + (
|
||||
Html("td", val[0], class_ = "ColumnAttribute", inline = True),
|
||||
Html("td", val[1], class_ = "ColumnValue", inline = True)
|
||||
)
|
||||
table += trow
|
||||
|
||||
# return place table to its callers
|
||||
return table
|
||||
|
||||
def dump_residence(self, has_res):
|
||||
""" creates a residence from the daTABASE """
|
||||
|
||||
if not has_res:
|
||||
return None
|
||||
db = self.report.database
|
||||
|
||||
# begin residence division
|
||||
with Html("div", id = "Residence", class_ = "content") as residence:
|
||||
residence += Html("h4", _("Residence"), inline = True)
|
||||
|
||||
with Html("table", class_ = "infolist place") as table:
|
||||
residence += table
|
||||
|
||||
place_handle = has_res.get_place_handle()
|
||||
if place_handle:
|
||||
place = db.get_place_from_handle(place_handle)
|
||||
if place:
|
||||
self.dump_place(place, table, place.gramps_id)
|
||||
|
||||
descr = has_res.get_description()
|
||||
if descr:
|
||||
with Html("table", class_ = "infolist") as table:
|
||||
residence += table
|
||||
|
||||
trow = Html("tr") + (
|
||||
Html("td", DESCRHEAD, class_ = "ColumnAttribute", inline = True),
|
||||
Html("td", descr, class_ = "ColumnValue")
|
||||
)
|
||||
table += trow
|
||||
|
||||
# return information to its callers
|
||||
return residence
|
||||
|
||||
# ---------------------------------------------------------------------------------------
|
||||
# # Web Page Fortmatter and writer
|
||||
# ---------------------------------------------------------------------------------------
|
||||
@ -1951,6 +2061,7 @@ class PlaceListPage(BasePage):
|
||||
class PlacePage(BasePage):
|
||||
|
||||
def __init__(self, report, title, place_handle, src_list, place_list):
|
||||
""" creates the individual place pages """
|
||||
db = report.database
|
||||
|
||||
place = db.get_place_from_handle(place_handle)
|
||||
@ -1981,33 +2092,8 @@ class PlacePage(BasePage):
|
||||
with Html("table", class_ = "infolist place") as table:
|
||||
summaryarea += table
|
||||
|
||||
if not self.noid:
|
||||
trow = Html("tr") + (
|
||||
Html("td", GRAMPSID, class_ = "ColumnAttribute", inline = True),
|
||||
Html("td", place.gramps_id, class_ = "ColumnValue", inline = True)
|
||||
)
|
||||
table += trow
|
||||
|
||||
if place.main_loc:
|
||||
ml = place.main_loc
|
||||
for val in [
|
||||
(LATITUDE, place.lat),
|
||||
(LONGITUDE, place.long),
|
||||
(STREET, ml.street),
|
||||
(CITY, ml.city),
|
||||
(PARISH, ml.parish),
|
||||
(COUNTY, ml.county),
|
||||
(STATE, ml.state),
|
||||
(POSTAL, ml.postal),
|
||||
(COUNTRY, ml.country),
|
||||
(LOCATIONS, place.get_alternate_locations() ) ]:
|
||||
|
||||
if val[1]:
|
||||
trow = Html("tr") + (
|
||||
Html("td", val[0], class_ = "ColumnAttribute", inline = True),
|
||||
Html("td", val[1], class_ = "ColumnValue", inline = True)
|
||||
)
|
||||
table += trow
|
||||
# list the place
|
||||
self.dump_place(place, table, place.gramps_id)
|
||||
|
||||
# place gallery
|
||||
if self.create_media:
|
||||
@ -3314,8 +3400,8 @@ class IndividualPage(BasePage):
|
||||
if sect5 is not None:
|
||||
individualdetail += sect5
|
||||
|
||||
# display address(es)
|
||||
sect6 = self.display_addresses()
|
||||
# display address(es) and show sources if any
|
||||
sect6 = self.display_addr_list(self.person.get_address_list(), True)
|
||||
if sect6 is not None:
|
||||
individualdetail += sect6
|
||||
|
||||
@ -3751,7 +3837,7 @@ class IndividualPage(BasePage):
|
||||
birth_date = birth.get_date_object()
|
||||
|
||||
if birth_date is not None and birth_date != Date.EMPTY:
|
||||
alive = probably_alive(self.person, db, date.Today() )
|
||||
alive = Utils.probably_alive(self.person, db, date.Today() )
|
||||
|
||||
death_date = None
|
||||
death_ref = self.person.get_death_ref()
|
||||
@ -3845,25 +3931,6 @@ class IndividualPage(BasePage):
|
||||
# return section to its caller
|
||||
return section
|
||||
|
||||
def display_addresses(self):
|
||||
"""
|
||||
display a person's addresses ...
|
||||
"""
|
||||
|
||||
alist = self.person.get_address_list()
|
||||
if not alist:
|
||||
return None
|
||||
|
||||
# begin addresses division and title
|
||||
with Html("div", class_ = "subsection", id = "Addresses") as section:
|
||||
section += Html("h4", _("Addresses"), inline = True)
|
||||
|
||||
# write out addresses()
|
||||
section += self.dump_addresses(self.person)
|
||||
|
||||
# return address division to its caller
|
||||
return section
|
||||
|
||||
def display_lds_ordinance(self, person):
|
||||
"""
|
||||
display LDS information for a person or family
|
||||
@ -4533,7 +4600,7 @@ class RepositoryPage(BasePage):
|
||||
table += trow
|
||||
|
||||
# repository: address(es)
|
||||
addresses = self.dump_addresses(repo, False)
|
||||
addresses = self.dump_addresses(repo.get_address_list(), False)
|
||||
if addresses is not None:
|
||||
repositorydetail += addresses
|
||||
|
||||
@ -4556,115 +4623,172 @@ class RepositoryPage(BasePage):
|
||||
# and close the file
|
||||
self.XHTMLWriter(repositorypage, of)
|
||||
|
||||
class InternetAddressBook(BasePage):
|
||||
"""
|
||||
Will Create an Internet Address Book of people's web sites and email addresses
|
||||
"""
|
||||
class AddressBookListPage(BasePage):
|
||||
|
||||
def __init__(self, report, title, ind_list, iab_progress):
|
||||
def __init__(self, report, title, has_url_address):
|
||||
"""
|
||||
Create a list of individual's that have either internet addresses or
|
||||
address/ Residence events
|
||||
|
||||
@param: has_url_address -- a list of (sort_name, person_handle, has_add, has_rtes, and has_url
|
||||
|
||||
"""
|
||||
BasePage.__init__(self, report, title)
|
||||
db = report.database
|
||||
|
||||
# Name the file, and create it
|
||||
of = self.report.create_file("Internet_Address_Book")
|
||||
of = self.report.create_file("addressbook")
|
||||
|
||||
# Add xml, doctype, meta and stylesheets
|
||||
iabpage, body = self.write_header(_("Internet Address Book"))
|
||||
addressbooklistpage, body = self.write_header("%s - %s" % (title, _("Address Book List")))
|
||||
|
||||
# begin page division
|
||||
with Html("div", class_ = "content", id = "InternetAddressBook") as addbook:
|
||||
body += addbook
|
||||
# begin AddressBookList division
|
||||
with Html("div", class_ = "content", id = "AddressBookList") as addressbooklist:
|
||||
body += addressbooklist
|
||||
|
||||
# Internet Address Book Page message
|
||||
msg = _("This page contains an index of all the individuals in the "
|
||||
"database, sorted by their GRAMPS ID. Selecting the person’s "
|
||||
"name will take you to that person’s individual page. "
|
||||
"Selecting a link will take you to their website or e-mail address.")
|
||||
addbook += Html("p", msg, id = "description")
|
||||
"database, sorted by their surname. Selecting the person’s "
|
||||
"name will take you to their Address Book’s individual page.")
|
||||
addressbooklist += Html("p", msg, id = "description")
|
||||
|
||||
# begin Address Book table
|
||||
with Html("table", class_ = "infolist addressbook") as table:
|
||||
addbook += table
|
||||
addressbooklist += table
|
||||
|
||||
thead = Html("thead")
|
||||
table += thead
|
||||
|
||||
trow = Html("tr") + (
|
||||
Html("th", THEAD, class_ = "ColumnType", inline = True),
|
||||
Html("th", _("Name"), class_ = "ColumnName", inline = True),
|
||||
Html("th", _("Link"), class_ = "ColumnLink", inline = True)
|
||||
)
|
||||
trow = Html("tr")
|
||||
thead += trow
|
||||
|
||||
for (label, colclass) in [
|
||||
[" ", "RowLabel"],
|
||||
[_("Name"), "Name"],
|
||||
[_("Address"), "Address"],
|
||||
[_("Residence"), "Residence"],
|
||||
[_("Web Links"), "WebLinks"] ]:
|
||||
trow += Html("th", label, class_ = "Column%s" % colclass, inline = True)
|
||||
|
||||
tbody = Html("tbody")
|
||||
table += tbody
|
||||
|
||||
for person_handle in ind_list:
|
||||
iab_progress.step()
|
||||
# local counters for total line
|
||||
index, countadd, countres, counturl = 0, 0, 0, 0
|
||||
|
||||
for (sort_name, person_handle, has_add, has_res, has_url) in has_url_address:
|
||||
person = db.get_person_from_handle(person_handle)
|
||||
urllist = person.get_url_list()
|
||||
index += 1
|
||||
|
||||
first = True
|
||||
for url in urllist:
|
||||
address = None
|
||||
residence = None
|
||||
weblinks = None
|
||||
|
||||
# has address but no residence event
|
||||
if has_add and not has_res:
|
||||
address = "X"
|
||||
countadd += 1
|
||||
|
||||
# has residence, but no addresses
|
||||
elif has_res and not has_add:
|
||||
residence = "X"
|
||||
countres += 1
|
||||
|
||||
# has residence and addresses too
|
||||
elif has_add and has_res:
|
||||
address = "X"
|
||||
residence = "X"
|
||||
countadd += 1
|
||||
countres += 1
|
||||
|
||||
# has Web Links
|
||||
if has_url:
|
||||
weblinks = "X"
|
||||
counturl += 1
|
||||
|
||||
trow = Html("tr")
|
||||
tbody += trow
|
||||
|
||||
# Internet link type
|
||||
_type = url.get_type()
|
||||
trow += Html("td", str(_type), class_ = "ColumnType", inline = True)
|
||||
for (colclass, data) in [
|
||||
["RowLabel", index],
|
||||
["Name", self.addressbook_link(person_handle)],
|
||||
["Address", address],
|
||||
["Residence", residence],
|
||||
["WebLinks", weblinks] ]:
|
||||
data = data or " "
|
||||
|
||||
if first:
|
||||
trow.attr = 'class = "BeginName"'
|
||||
trow += Html("td", data, class_ = "Column%s" % colclass, inline = True)
|
||||
|
||||
person_url = self.report.build_url_fname_html(person.handle, "ppl", False)
|
||||
person_hyper = self.person_link(person_url, person, True, gid = person.gramps_id)
|
||||
else:
|
||||
person_hyper = " "
|
||||
first = False
|
||||
|
||||
trow += Html("td", person_hyper, class_ = "ColumnName")
|
||||
|
||||
uri = url.get_path()
|
||||
descr = url.get_description()
|
||||
if not descr:
|
||||
descr = uri
|
||||
|
||||
tcell = Html("td", class_ = "ColumnLink")
|
||||
trow += tcell
|
||||
|
||||
# Email address
|
||||
if _type == UrlType.EMAIL:
|
||||
if not uri.startswith("mailto:"):
|
||||
tcell += Html("a",descr, href = 'mailto: %s' % uri)
|
||||
else:
|
||||
tcell += Html("a", descr, href = "%s" % uri)
|
||||
|
||||
# Web Site address
|
||||
elif _type == UrlType.WEB_HOME:
|
||||
if not uri.startswith("http://"):
|
||||
tcell += Html("a", descr, href = 'http://%s' % uri)
|
||||
else:
|
||||
tcell += Html("a", href = "%s" % uri)
|
||||
|
||||
# FTP server address
|
||||
elif _type == UrlType.WEB_FTP:
|
||||
if not uri.startswith("ftp://"):
|
||||
tcell += Html("a", descr, href = 'ftp://%s' % uri)
|
||||
else:
|
||||
tcell += Html("a", drscr, href = "%s" % uri)
|
||||
|
||||
# custom type
|
||||
else:
|
||||
tcell += Html("a", descr, href = uri)
|
||||
# create totals row for table
|
||||
trow = Html("tr", class_ = "Totals") + (
|
||||
Html("td", _("Total"), classs_ = "ColumnRowlabel", inline = True),
|
||||
Html("td", index, class_ = "ColumnName", inline = True),
|
||||
Html("td", countadd, class_ = "ColumnAddress", inline = True),
|
||||
Html("td", countres, class_ = "ColumnResidence", inline = True),
|
||||
Html("td", counturl, class_ = "ColumnWebLinks", inline = True)
|
||||
)
|
||||
tbody += trow
|
||||
|
||||
# Add footer and clearline
|
||||
footer = self.write_footer()
|
||||
body += (fullclear, footer)
|
||||
|
||||
# write the file and close it
|
||||
self.XHTMLWriter(iabpage, of)
|
||||
# send the page out for processing
|
||||
# and close the file
|
||||
self.XHTMLWriter(addressbooklistpage, of)
|
||||
|
||||
class AddressBookPage(BasePage):
|
||||
|
||||
def __init__(self, report, title, person_handle, has_add, has_res, has_url):
|
||||
"""
|
||||
Creates the individual address book pages
|
||||
|
||||
@parm: title = title for this report
|
||||
@param: has_add -- a list of address handles or None
|
||||
@param: has_res -- a residence event or None
|
||||
@param: has_url -- list of url handles or None
|
||||
"""
|
||||
db = report.database
|
||||
|
||||
person = db.get_person_from_handle(person_handle)
|
||||
BasePage.__init__(self, report, title, person.gramps_id)
|
||||
self.up = True
|
||||
|
||||
# set the file name and open file
|
||||
of = self.report.create_file(person_handle, "addr")
|
||||
addressbookpage, body = self.write_header("%s - %s" % (title, _("Address Book")))
|
||||
|
||||
# begin address book page division and section title
|
||||
with Html("div", class_ = "content", id = "AddressBookDetail") as addressbookdetail:
|
||||
body += addressbookdetail
|
||||
|
||||
addressbookdetail += Html("h3", self.get_name(person), inline = True)
|
||||
|
||||
# individual has a url
|
||||
if has_url:
|
||||
addressbookdetail += self.display_url_list(has_url)
|
||||
|
||||
# individual has an address, and not a residence event
|
||||
if has_add and not has_res:
|
||||
addressbookdetail += self.display_addr_list(has_add, None)
|
||||
|
||||
# individual has a residence event and no addresses
|
||||
elif has_res and not has_add:
|
||||
addressbookdetail += self.dump_residence(has_res)
|
||||
|
||||
# individual has both
|
||||
elif has_add and has_res:
|
||||
addressbookdetail += self.display_addr_list(has_add, None)
|
||||
addressbookdetail += self.dump_residence(has_res)
|
||||
|
||||
# add fullclear for proper styling
|
||||
# and footer section to page
|
||||
footer = self.write_footer()
|
||||
body += (fullclear, footer)
|
||||
|
||||
# send page out for processing
|
||||
# and close the file
|
||||
self.XHTMLWriter(addressbookpage, of)
|
||||
|
||||
class NavWebReport(Report):
|
||||
|
||||
@ -4753,7 +4877,7 @@ class NavWebReport(Report):
|
||||
self.birthorder = self.options['birthorder']
|
||||
|
||||
# get option for Internet Address Book
|
||||
self.add_book = self.options["add_book"]
|
||||
self.addressbook = self.options["addressbook"]
|
||||
|
||||
if self.use_home:
|
||||
self.index_fname = "index"
|
||||
@ -4878,7 +5002,7 @@ class NavWebReport(Report):
|
||||
|
||||
|
||||
# build class InternetAddressBook
|
||||
if self.add_book:
|
||||
if self.addressbook:
|
||||
self.address_book_page(ind_list)
|
||||
|
||||
# if an archive is being used, close it?
|
||||
@ -5231,11 +5355,55 @@ class NavWebReport(Report):
|
||||
self.progress.step()
|
||||
|
||||
def address_book_page(self, ind_list):
|
||||
"""
|
||||
Creates classes AddressBookListPage and AddressBookPage
|
||||
"""
|
||||
|
||||
# set progress pass
|
||||
self.progress.set_pass(_("Creating internet address book page ..."), len(ind_list))
|
||||
db = self.database
|
||||
has_url_address = []
|
||||
|
||||
InternetAddressBook(self, self.title, ind_list, self.progress)
|
||||
for person_handle in ind_list:
|
||||
|
||||
person = db.get_person_from_handle(person_handle)
|
||||
addrlist = person.get_address_list()
|
||||
evt_ref_list = person.get_event_ref_list()
|
||||
urllist = person.get_url_list()
|
||||
|
||||
has_add = None
|
||||
has_url = None
|
||||
if addrlist:
|
||||
has_add = addrlist
|
||||
if urllist:
|
||||
has_url = urllist
|
||||
|
||||
has_res = None
|
||||
for event_ref in evt_ref_list:
|
||||
event = db.get_event_from_handle(event_ref.ref)
|
||||
|
||||
# get event type
|
||||
evt_type = str(event.get_type() )
|
||||
if evt_type == "Residence":
|
||||
has_res = event
|
||||
break
|
||||
|
||||
if has_add or has_res or has_url:
|
||||
primary_name = person.get_primary_name()
|
||||
sort_name = ''.join([primary_name.get_surname(), ", ", primary_name.get_first_name()])
|
||||
|
||||
data = (sort_name, person_handle, has_add, has_res, has_url)
|
||||
has_url_address.append(data)
|
||||
|
||||
# Determine if we build Address Book
|
||||
if has_url_address:
|
||||
has_url_address.sort()
|
||||
AddressBookListPage(self, self.title, has_url_address)
|
||||
|
||||
self.progress.set_pass(_("Creating address book pages ..."), len(has_url_address))
|
||||
|
||||
for (sort_name, person_handle, has_add, has_res, has_url) in has_url_address:
|
||||
self.progress.step()
|
||||
|
||||
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]
|
||||
@ -5727,9 +5895,10 @@ class NavWebOptions(MenuReportOptions):
|
||||
inc_gendex.set_help(_('Whether to include a GENDEX file or not'))
|
||||
menu.add_option(category_name, 'inc_gendex', inc_gendex)
|
||||
|
||||
add_book = BooleanOption(_("Include an Internet Address Book Page"), True)
|
||||
add_book.set_help(_("Whether to add an Internet Address Book or not?"))
|
||||
menu.add_option(category_name, "add_book", add_book)
|
||||
addressbook = BooleanOption(_("Include address book pages"), False)
|
||||
addressbook.set_help(_("Whether to add Address Book pages or not which can include"
|
||||
" e-mail and website addresses and personal address/ residence events?"))
|
||||
menu.add_option(category_name, "addressbook", addressbook)
|
||||
|
||||
def __archive_changed(self):
|
||||
"""
|
||||
|
Loading…
x
Reference in New Issue
Block a user