Added calendar for report, and progress bar
svn: r10540
This commit is contained in:
parent
e410f04c7a
commit
7d9ef3710d
@ -47,6 +47,8 @@ import BaseDoc
|
|||||||
import Sort
|
import Sort
|
||||||
from QuestionDialog import ErrorDialog
|
from QuestionDialog import ErrorDialog
|
||||||
from BasicUtils import name_displayer
|
from BasicUtils import name_displayer
|
||||||
|
from Utils import probably_alive, ProgressMeter
|
||||||
|
import gen.lib
|
||||||
|
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -94,8 +96,10 @@ class TimeLine(Report):
|
|||||||
sort_func_num = menu.get_option_by_name('sortby').get_value()
|
sort_func_num = menu.get_option_by_name('sortby').get_value()
|
||||||
sort_functions = _get_sort_functions(Sort.Sort(database))
|
sort_functions = _get_sort_functions(Sort.Sort(database))
|
||||||
self.sort_func = sort_functions[sort_func_num][1]
|
self.sort_func = sort_functions[sort_func_num][1]
|
||||||
|
self.calendar = gen.lib.date.Date.ui_calendar_names[menu.get_option_by_name('calendar').get_value()]
|
||||||
|
|
||||||
def write_report(self):
|
def write_report(self):
|
||||||
|
self.progress = ProgressMeter(_('Timeline'))
|
||||||
|
|
||||||
(low, high) = self.find_year_range()
|
(low, high) = self.find_year_range()
|
||||||
|
|
||||||
@ -128,19 +132,22 @@ class TimeLine(Report):
|
|||||||
|
|
||||||
length = len(self.plist)
|
length = len(self.plist)
|
||||||
|
|
||||||
|
self.progress.set_pass(_('Sorting dates...'), 1)
|
||||||
self.plist.sort(self.sort_func)
|
self.plist.sort(self.sort_func)
|
||||||
|
self.progress.set_pass(_('Calculating timeline...'), len(self.plist))
|
||||||
|
|
||||||
for p_id in self.plist:
|
for p_id in self.plist:
|
||||||
|
self.progress.step()
|
||||||
p = self.database.get_person_from_handle(p_id)
|
p = self.database.get_person_from_handle(p_id)
|
||||||
birth = ReportUtils.get_birth_or_fallback(self.database, p)
|
birth = ReportUtils.get_birth_or_fallback(self.database, p)
|
||||||
if birth:
|
if birth:
|
||||||
b = birth.get_date_object().get_year()
|
b = birth.get_date_object().to_calendar(self.calendar).get_year()
|
||||||
else:
|
else:
|
||||||
b = None
|
b = None
|
||||||
|
|
||||||
death = ReportUtils.get_death_or_fallback(self.database, p)
|
death = ReportUtils.get_death_or_fallback(self.database, p)
|
||||||
if death:
|
if death:
|
||||||
d = death.get_date_object().get_year()
|
d = death.get_date_object().to_calendar(self.calendar).get_year()
|
||||||
else:
|
else:
|
||||||
d = None
|
d = None
|
||||||
|
|
||||||
@ -183,7 +190,7 @@ class TimeLine(Report):
|
|||||||
else:
|
else:
|
||||||
index += 1;
|
index += 1;
|
||||||
current += 1
|
current += 1
|
||||||
|
self.progress.close()
|
||||||
self.build_grid(low, high,start,stop)
|
self.build_grid(low, high,start,stop)
|
||||||
self.doc.end_page()
|
self.doc.end_page()
|
||||||
|
|
||||||
@ -232,13 +239,13 @@ class TimeLine(Report):
|
|||||||
p = self.database.get_person_from_handle(p_id)
|
p = self.database.get_person_from_handle(p_id)
|
||||||
birth = ReportUtils.get_birth_or_fallback(self.database, p)
|
birth = ReportUtils.get_birth_or_fallback(self.database, p)
|
||||||
if birth:
|
if birth:
|
||||||
b = birth.get_date_object().get_year()
|
b = birth.get_date_object().to_calendar(self.calendar).get_year()
|
||||||
else:
|
else:
|
||||||
b = None
|
b = None
|
||||||
|
|
||||||
death = ReportUtils.get_death_or_fallback(self.database, p)
|
death = ReportUtils.get_death_or_fallback(self.database, p)
|
||||||
if death:
|
if death:
|
||||||
d = death.get_date_object().get_year()
|
d = death.get_date_object().to_calendar(self.calendar).get_year()
|
||||||
else:
|
else:
|
||||||
d = None
|
d = None
|
||||||
|
|
||||||
@ -308,7 +315,7 @@ class TimeLineOptions(MenuReportOptions):
|
|||||||
self.__pid.set_help(_("The center person for the filter"))
|
self.__pid.set_help(_("The center person for the filter"))
|
||||||
menu.add_option(category_name, "pid", self.__pid)
|
menu.add_option(category_name, "pid", self.__pid)
|
||||||
self.__pid.connect('value-changed', self.__update_filters)
|
self.__pid.connect('value-changed', self.__update_filters)
|
||||||
|
|
||||||
self.__update_filters()
|
self.__update_filters()
|
||||||
|
|
||||||
sortby = EnumeratedListOption(_('Sort by'), 0 )
|
sortby = EnumeratedListOption(_('Sort by'), 0 )
|
||||||
@ -319,6 +326,14 @@ class TimeLineOptions(MenuReportOptions):
|
|||||||
sortby.set_help( _("Sorting method to use"))
|
sortby.set_help( _("Sorting method to use"))
|
||||||
menu.add_option(category_name,"sortby",sortby)
|
menu.add_option(category_name,"sortby",sortby)
|
||||||
|
|
||||||
|
self.__calendar = EnumeratedListOption(_("Calendar"), 0)
|
||||||
|
self.__calendar.set_help(_("The calendar which determines the year span"))
|
||||||
|
idx = 0
|
||||||
|
for calendar in gen.lib.date.Date.ui_calendar_names:
|
||||||
|
self.__calendar.add_item(idx, calendar)
|
||||||
|
idx += 1
|
||||||
|
menu.add_option(category_name, "calendar", self.__calendar)
|
||||||
|
|
||||||
def __update_filters(self):
|
def __update_filters(self):
|
||||||
"""
|
"""
|
||||||
Update the filter list based on the selected person
|
Update the filter list based on the selected person
|
||||||
|
Loading…
Reference in New Issue
Block a user