All if statements have been removed from holidays.xml. Labor Day, Inauguration Day, and Income Texes due have all been changed.

svn: r11933
This commit is contained in:
Rob G. Healey 2009-02-09 07:10:42 +00:00
parent d96eda6dfe
commit dff2d75e26
2 changed files with 139 additions and 28 deletions

View File

@ -382,10 +382,34 @@
<date name="Independence Day" value="*/7/4" type="national" /> <date name="Independence Day" value="*/7/4" type="national" />
<date name="Veterans Day" value="*/11/11" type="national" /> <date name="Veterans Day" value="*/11/11" type="national" />
<date name="Christmas" value="*/12/25" type="national" /> <date name="Christmas" value="*/12/25" type="national" />
<date name="Labor Day" value="*/1/mon/sep" if="y &lt;= 2008" type="national" /> <date name="Labor Day" value="1999/9/6" type="national" />
<date name="Labor Day" value="2009/1/tue/sep" type="national" /> <date name="Labor Day" value="2000/9/4" type="national" />
<date name="Labor Day" value="2001/9/3" type="national" />
<date name="Labor Day" value="2002/9/2" type="national" />
<date name="Labor Day" value="2003/9/1" type="national" />
<date name="Labor Day" value="2004/9/6" type="national" />
<date name="Labor Day" value="2005/9/5" type="national" />
<date name="Labor Day" value="2006/9/4" type="national" />
<date name="Labor Day" value="2007/9/3" type="national" />
<date name="Labor Day" value="2008/9/1" type="national" />
<date name="Labor Day" value="2009/9/1" type="national" />
<date name="Labor Day" value="2010/9/6" type="national" />
<date name="Labor Day" value="2011/9/5" type="national" />
<date name="Labor Day" value="2012/9/3" type="national" />
<date name="Labor Day" value="2013/9/2" type="national" />
<date name="Labor Day" value="2014/9/1" type="national" />
<date name="Labor Day" value="2015/9/7" type="national" />
<date name="Labor Day" value="2016/9/5" type="national" />
<date name="Labor Day" value="2017/9/4" type="national" />
<date name="Labor Day" value="2018/9/3" type="national" />
<date name="Labor Day" value="2019/9/2" type="national" />
<date name="Thanksgiving" value="*/4/thu/nov" type="national" /> <date name="Thanksgiving" value="*/4/thu/nov" type="national" />
<date name="Inauguration Day" value="*/1/20" if="(y - 1980) % 4 == 1" type="national" /> <date name="Inauguration Day" value="1997/1/20" type="national" />
<date name="Inauguration Day" value="2001/1/20" type="national" />
<date name="Inauguration Day" value="2005/1/20" type="national" />
<date name="Inauguration Day" value="2009/1/20" type="national" />
<date name="Inauguration Day" value="2013/1/20" type="national" />
<date name="Inauguration Day" value="2017/1/20" type="national" />
<date name="Groundhog Day" value="*/2/2" type="secular" /> <date name="Groundhog Day" value="*/2/2" type="secular" />
<date name="Lincoln's Birthday" value="*/2/12" type="secular" /> <date name="Lincoln's Birthday" value="*/2/12" type="secular" />
<date name="Valentine's Day" value="*/2/14" type="secular" /> <date name="Valentine's Day" value="*/2/14" type="secular" />
@ -429,12 +453,27 @@
<date name="Daylight Saving begins" value="2017/3/12" type="informational" /> <date name="Daylight Saving begins" value="2017/3/12" type="informational" />
<date name="Daylight Saving begins" value="2018/3/11" type="informational" /> <date name="Daylight Saving begins" value="2018/3/11" type="informational" />
<date name="Daylight Saving begins" value="2019/3/10" type="informational" /> <date name="Daylight Saving begins" value="2019/3/10" type="informational" />
<date name="Income Taxes due" value="*/4/15" type="national" <date name="Income Taxes due" value="1999/4/15" type="national" />
if="date.weekday().__cmp__(4)-1" /> <date name="Income Taxes due" value="2000/4/17" type="national" />
<date name="Income Taxes due" value="*/4/16" type="national" <date name="Income Taxes due" value="2001/4/16" type="national" />
if="date.weekday() == 0" /> <date name="Income Taxes due" value="2002/4/15" type="national" />
<date name="Income Taxes due" value="*/4/17" type="national" <date name="Income Taxes due" value="2003/4/15" type="national" />
if="date.weekday() == 0" /> <date name="Income Taxes due" value="2004/4/15" type="national" />
<date name="Income Taxes due" value="2005/4/15" type="national" />
<date name="Income Taxes due" value="2006/4/17" type="national" />
<date name="Income Taxes due" value="2007/4/16" type="national" />
<date name="Income Taxes due" value="2008/4/15" type="national" />
<date name="Income Taxes due" value="2009/4/15" type="national" />
<date name="Income Taxes due" value="2010/4/15" type="national" />
<date name="Income Taxes due" value="2011/4/15" type="national" />
<date name="Income Taxes due" value="2012/4/16" type="national" />
<date name="Income Taxes due" value="2013/4/15" type="national" />
<date name="Income Taxes due" value="2014/4/15" type="national" />
<date name="Income Taxes due" value="2015/4/15" type="national" />
<date name="Income Taxes due" value="2016/4/15" type="national" />
<date name="Income Taxes due" value="2017/4/17" type="national" />
<date name="Income Taxes due" value="2018/4/16" type="national" />
<date name="Income Taxes due" value="2019/4/15" type="national" />
<date name="Daylight Saving ends" value="1999/10/31" type="informational" /> <date name="Daylight Saving ends" value="1999/10/31" type="informational" />
<date name="Daylight Saving ends" value="2000/10/29" type="informational" /> <date name="Daylight Saving ends" value="2000/10/29" type="informational" />
<date name="Daylight Saving ends" value="2001/10/28" type="informational" /> <date name="Daylight Saving ends" value="2001/10/28" type="informational" />

View File

@ -102,6 +102,8 @@ from gen.lib.eventroletype import EventRoleType
# constants # constants
# #
#------------------------------------------------------------------------ #------------------------------------------------------------------------
_PERSON = 0
_PLACE = 1
_INCLUDE_LIVING_VALUE = 99 # Arbitrary number _INCLUDE_LIVING_VALUE = 99 # Arbitrary number
_NAME_COL = 3 _NAME_COL = 3
@ -275,6 +277,45 @@ class BasePage:
self.linkhome = options['linkhome'] self.linkhome = options['linkhome']
self.use_gallery = options['gallery'] self.use_gallery = options['gallery']
def alphabet_navigation(self, of, db, handle_list, key):
"""
Will create the alphabetical navigation bar...
"""
first_letter_dict = get_first_letter_dict(db, handle_list, key)
sorted_set = {}
for ltr in first_letter_dict:
try: sorted_set[ltr] += 1
except KeyError: sorted_set[ltr] = 1
sorted_first_letter = sorted_set.keys()
sorted_first_letter.sort(locale.strcoll)
num_ltrs = len(sorted_first_letter)
if num_ltrs <= 25:
of.write('\t<div id="navigation">\n')
of.write('\t\t<ul>\n')
for ltr in sorted_first_letter:
of.write('\t\t\t<li><a href="#%s">%s</a> </li>' % (ltr, ltr))
of.write('\t\t</ul>\n')
of.write('\t</div>\n')
else:
nrows = (num_ltrs / 25)
index = 0
for rows in range(0, nrows):
of.write('\t<div id="navigation">\n')
of.write('\t\t<ul>\n')
cols = 0
while (cols <= 24 and index <= num_ltrs):
of.write('\t\t\t<li><a href="#%s">%s</a></li>\n'
% (sorted_first_letter[index], sorted_first_letter[index]))
cols += 1
index += 1
of.write('\t\t<ul>\n')
of.write('\t</div>\n')
return of
def write_footer(self, of): def write_footer(self, of):
of.write('</div>\n') # Terminate div_content of.write('</div>\n') # Terminate div_content
@ -733,6 +774,9 @@ class IndividualListPage(BasePage):
of = self.report.create_file("individuals") of = self.report.create_file("individuals")
self.write_header(of, _('Individuals')) self.write_header(of, _('Individuals'))
# begin alphabetic navigation
self.alphabet_navigation(of, db, person_handle_list, _PERSON)
of.write('<div id="Individuals" class="content">\n') of.write('<div id="Individuals" class="content">\n')
msg = _("This page contains an index of all the individuals in the " msg = _("This page contains an index of all the individuals in the "
@ -778,8 +822,8 @@ class IndividualListPage(BasePage):
if first: if first:
of.write('\t\t<tr class="BeginSurname">\n') of.write('\t\t<tr class="BeginSurname">\n')
if surname: if surname:
of.write('\t\t\t<td class="ColumnSurname"><a name="%s">%s</a>\n' of.write('\t\t\t<td class="ColumnSurname"><a name="%s">%s</a></td>\n'
% (name_to_md5(surname), surname)) % (surname[0], surname))
else: else:
of.write('\t\t\t<td class="ColumnSurname">&nbsp;\n') of.write('\t\t\t<td class="ColumnSurname">&nbsp;\n')
else: else:
@ -1012,6 +1056,9 @@ class PlaceListPage(BasePage):
of = self.report.create_file("places") of = self.report.create_file("places")
self.write_header(of, _('Places')) self.write_header(of, _('Places'))
# begin alphabetic navigation
self.alphabet_navigation(of, db, place_handles, _PLACE)
of.write('<div id="Places" class="content">\n') of.write('<div id="Places" class="content">\n')
msg = _("This page contains an index of all the places in the " msg = _("This page contains an index of all the places in the "
@ -1036,23 +1083,24 @@ class PlaceListPage(BasePage):
for handle in handle_list: for handle in handle_list:
place = db.get_place_from_handle(handle) place = db.get_place_from_handle(handle)
n = ReportUtils.place_name(db, handle) place_title = ReportUtils.place_name(db, handle)
if not n: if not place_title:
continue continue
letter = normalize('NFKC', n)[0].upper() letter = normalize('NFKC', place_title)[0].upper()
if letter != last_letter: if letter != last_letter:
last_letter = letter last_letter = letter
of.write('\t\t<tr class="BeginLetter">\n') of.write('\t\t<tr class="BeginLetter">\n')
of.write('\t\t\t<td class="ColumnLetter">%s</td>\n' % last_letter) of.write('\t\t\t<td class="ColumnLetter"><a name="%s">%s</a></td>\n'
% (last_letter, last_letter))
else: else:
of.write('\t\t<tr>\n') of.write('\t\t<tr>\n')
of.write('\t\t\t<td class="ColumnLetter">&nbsp;</td>\n') of.write('\t\t\t<td class="ColumnLetter">&nbsp;</td>\n')
of.write('\t\t\t<td class="ColumnName">') of.write('\t\t\t<td class="ColumnName">')
self.place_link(of, place.handle, n, place.gramps_id) self.place_link(of, place.handle, place_title, place.gramps_id)
of.write('</td>\n') of.write('</td>\n')
of.write('\t\t</tr>\n') of.write('\t\t</tr>\n')
@ -1430,10 +1478,13 @@ class SurnameListPage(BasePage):
if order_by == self.ORDER_BY_NAME: if order_by == self.ORDER_BY_NAME:
of = self.report.create_file(filename) of = self.report.create_file(filename)
self.write_header(of, _('Surnames')) self.write_header(of, _('Surnames'))
of.write('<div id="Surnames" class="content">\n')
else: else:
of = self.report.create_file("surnames_count") of = self.report.create_file("surnames_count")
self.write_header(of, _('Surnames by person count')) self.write_header(of, _('Surnames by person count'))
# begin alphabetic navigation
self.alphabet_navigation(of, db, person_handle_list, _PERSON)
of.write('<div id="Surnames" class="content">\n') of.write('<div id="Surnames" class="content">\n')
of.write('\t<p id="description">%s</p>\n' % _( of.write('\t<p id="description">%s</p>\n' % _(
@ -1486,7 +1537,8 @@ class SurnameListPage(BasePage):
if letter is not last_letter: if letter is not last_letter:
last_letter = letter last_letter = letter
of.write('\t\t<tr class="BeginLetter">\n') of.write('\t\t<tr class="BeginLetter">\n')
of.write('\t\t\t<td class="ColumnLetter">%s</td?\n' % last_letter) of.write('\t\t\t<td class="ColumnLetter"><a name="%s">%s</a></td>\n'
% (last_letter, last_letter))
of.write('\t\t\t<td class="ColumnSurname">') of.write('\t\t\t<td class="ColumnSurname">')
self.surname_link(of, name_to_md5(surname), surname) self.surname_link(of, name_to_md5(surname), surname)
of.write('</td>\n') of.write('</td>\n')
@ -3543,18 +3595,38 @@ def _get_prefix_suffix_name(sex, name):
first = first + ", " + suffix first = first + ", " + suffix
return first return first
def get_people(db): def get_person_keyname(db, handle):
for handle in db.get_handles(): """ .... """
yield db.get_person_from_handle(handle) person = db.get_person_from_handle(handle)
return person.get_primary_name().surname
def get_place(db, handle): def get_place_keyname(db, handle):
""" ... """ """ ... """
place = db.get_place_from_handle(handle)
return place
# ***************************************** return ReportUtils.place_name(db, handle)
def get_first_letter_dict(db, handle_list, key):
""" key is _PLACE or _PERSON ...."""
namedict = []
for handle in handle_list:
if key == _PERSON:
keyname = get_person_keyname(db, handle)
else:
keyname = get_place_keyname(db, handle)
if keyname:
firstletter = normalize('NFC', keyname)[0].upper()
namedict.append(firstletter)
return namedict
# ------------------------------------------
#
# Register Plugin # Register Plugin
# ***************************************** #
# -------------------------------------------
pmgr = PluginManager.get_instance() pmgr = PluginManager.get_instance()
pmgr.register_report( pmgr.register_report(
name = 'navwebpage', name = 'navwebpage',