Generate the report dialog progress window
svn: r691
This commit is contained in:
parent
316319f1ed
commit
9878aa0d34
@ -97,23 +97,26 @@ class Report:
|
|||||||
i.e. the maximum number of times this routine will be
|
i.e. the maximum number of times this routine will be
|
||||||
called."""
|
called."""
|
||||||
|
|
||||||
# Load the glade file
|
|
||||||
base = os.path.dirname(__file__)
|
|
||||||
self.glade_file = os.path.join(base, "plugins", "basicreport.glade")
|
|
||||||
self.pxml = libglade.GladeXML(self.glade_file,"progress_dialog")
|
|
||||||
|
|
||||||
# Customize the dialog for this report
|
# Customize the dialog for this report
|
||||||
(title, header) = self.get_progressbar_data()
|
(title, header) = self.get_progressbar_data()
|
||||||
self.ptop = self.pxml.get_widget("progress_dialog")
|
self.ptop = GnomeDialog()
|
||||||
self.ptop.set_title(title)
|
self.ptop.set_title(title)
|
||||||
self.pxml.get_widget("header_label").set_text(header)
|
self.ptop.vbox.add(GtkLabel(header))
|
||||||
|
self.ptop.vbox.add(GtkHSeparator())
|
||||||
# Setup the progress bar limits
|
self.ptop.vbox.set_spacing(10)
|
||||||
self.pbar = self.pxml.get_widget("progressbar")
|
self.pbar = GtkProgressBar()
|
||||||
|
self.pbar.set_format_string(_("%v of %u (%P%%)"))
|
||||||
self.pbar.configure(0.0,0.0,total)
|
self.pbar.configure(0.0,0.0,total)
|
||||||
|
self.pbar.set_show_text(1)
|
||||||
|
self.pbar.set_usize(350,20)
|
||||||
self.pbar_max = total
|
self.pbar_max = total
|
||||||
self.pbar_index = 0.0
|
self.pbar_index = 0.0
|
||||||
|
|
||||||
|
self.ptop.vbox.add(self.pbar)
|
||||||
|
self.ptop.show_all()
|
||||||
|
|
||||||
|
# Setup the progress bar limits
|
||||||
|
|
||||||
def progress_bar_step(self):
|
def progress_bar_step(self):
|
||||||
"""Click the progress bar over to the next value. Be paranoid
|
"""Click the progress bar over to the next value. Be paranoid
|
||||||
and insure that it doesn't go over 100%."""
|
and insure that it doesn't go over 100%."""
|
||||||
@ -159,16 +162,20 @@ class ReportDialog:
|
|||||||
self.frame_names = []
|
self.frame_names = []
|
||||||
self.frames = {}
|
self.frames = {}
|
||||||
|
|
||||||
self.window = GnomeDialog('My Window',STOCK_BUTTON_OK,STOCK_BUTTON_CANCEL)
|
self.window = GnomeDialog('Gramps',STOCK_BUTTON_OK,STOCK_BUTTON_CANCEL)
|
||||||
self.window.set_default(0)
|
self.window.set_default(0)
|
||||||
self.window.button_connect(0,self.on_ok_clicked)
|
self.window.button_connect(0,self.on_ok_clicked)
|
||||||
self.window.button_connect(1,self.on_cancel)
|
self.window.button_connect(1,self.on_cancel)
|
||||||
self.window.set_resize_mode(0)
|
self.window.set_resize_mode(0)
|
||||||
|
|
||||||
|
# Build the list of widgets that are used to extend the Options
|
||||||
|
# frame and to create other frames
|
||||||
|
|
||||||
|
self.add_user_options()
|
||||||
|
|
||||||
# Set up and run the dialog. These calls are not in top down
|
# Set up and run the dialog. These calls are not in top down
|
||||||
# order when looking at the dialog box as there is some
|
# order when looking at the dialog box as there is some
|
||||||
# interaction between the various frames.
|
# interaction between the various frames.
|
||||||
self.add_user_options()
|
|
||||||
self.setup_title()
|
self.setup_title()
|
||||||
self.setup_header()
|
self.setup_header()
|
||||||
self.setup_target_frame()
|
self.setup_target_frame()
|
||||||
@ -179,10 +186,11 @@ class ReportDialog:
|
|||||||
self.setup_report_options_frame()
|
self.setup_report_options_frame()
|
||||||
self.setup_other_frames()
|
self.setup_other_frames()
|
||||||
self.window.show_all()
|
self.window.show_all()
|
||||||
self.setup_format_frame()
|
|
||||||
|
|
||||||
def add_user_options(self):
|
# Allow for post processing of the format frame, since the
|
||||||
pass
|
# show_all task calls events that may reset values
|
||||||
|
|
||||||
|
self.setup_format_frame()
|
||||||
|
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -291,10 +299,33 @@ class ReportDialog:
|
|||||||
# Functions related to extending the options
|
# Functions related to extending the options
|
||||||
#
|
#
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
|
def add_user_options(self):
|
||||||
|
"""Called to allow subclasses add widgets to the dialog form.
|
||||||
|
It is called immediately before the window is displayed. All
|
||||||
|
calls to add_option or add_frame_option should be called in
|
||||||
|
this task."""
|
||||||
|
pass
|
||||||
|
|
||||||
def add_option(self,label_text,widget):
|
def add_option(self,label_text,widget):
|
||||||
|
"""Takes a text string and a Gtk Widget, and stores them to be
|
||||||
|
appended to the Options section of the dialog. The text string
|
||||||
|
is used to create a label for the passed widget. This allows the
|
||||||
|
subclass to extend the Options section with its own widgets. The
|
||||||
|
subclass is reponsible for all managing of the widgets, including
|
||||||
|
extracting the final value before the report executes. This task
|
||||||
|
should only be called in the add_user_options task."""
|
||||||
self.widgets.append((label_text,widget))
|
self.widgets.append((label_text,widget))
|
||||||
|
|
||||||
def add_frame_option(self,frame_name,label_text,widget):
|
def add_frame_option(self,frame_name,label_text,widget):
|
||||||
|
"""Similar to add_option this method takes a frame_name, a
|
||||||
|
text string and a Gtk Widget. When the interface is built,
|
||||||
|
all widgets with the same frame_name are grouped into a
|
||||||
|
GtkFrame. This allows the subclass to create its own sections,
|
||||||
|
filling them with its own widgets. The subclass is reponsible for
|
||||||
|
all managing of the widgets, including extracting the final value
|
||||||
|
before the report executes. This task should only be called in
|
||||||
|
the add_user_options task."""
|
||||||
|
|
||||||
if self.frames.has_key(frame_name):
|
if self.frames.has_key(frame_name):
|
||||||
self.frames[frame_name].append((label_text,widget))
|
self.frames[frame_name].append((label_text,widget))
|
||||||
else:
|
else:
|
||||||
@ -546,7 +577,8 @@ class ReportDialog:
|
|||||||
html frame function."""
|
html frame function."""
|
||||||
|
|
||||||
hbox = GtkHBox()
|
hbox = GtkHBox()
|
||||||
hbox.pack_start(GtkLabel("Template"))
|
hbox.set_border_width(ReportDialog.border_pad)
|
||||||
|
hbox.pack_start(GtkLabel("Template"),0,0,5)
|
||||||
self.html_fileentry = GnomeFileEntry(_("HTML Template"),_("Choose File"))
|
self.html_fileentry = GnomeFileEntry(_("HTML Template"),_("Choose File"))
|
||||||
hbox.add(self.html_fileentry)
|
hbox.add(self.html_fileentry)
|
||||||
self.html_frame.add(hbox)
|
self.html_frame.add(hbox)
|
||||||
@ -886,8 +918,6 @@ class TextReportDialog(ReportDialog):
|
|||||||
title = "Basic Report for %s" % self.name
|
title = "Basic Report for %s" % self.name
|
||||||
self.doc.write_text(title)
|
self.doc.write_text(title)
|
||||||
self.doc.end_paragraph()
|
self.doc.end_paragraph()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -896,11 +926,11 @@ class TextReportDialog(ReportDialog):
|
|||||||
#
|
#
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
class DrawReportDialog(ReportDialog):
|
class DrawReportDialog(ReportDialog):
|
||||||
def __init__(self,database,person,filename="basicreport.glade"):
|
def __init__(self,database,person):
|
||||||
"""Initialize a dialog to request that the user select options
|
"""Initialize a dialog to request that the user select options
|
||||||
for a basic drawing report. See the ReportDialog class for
|
for a basic drawing report. See the ReportDialog class for
|
||||||
more information."""
|
more information."""
|
||||||
ReportDialog.__init__(self,database,person,filename)
|
ReportDialog.__init__(self,database,person)
|
||||||
|
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
|
@ -780,22 +780,29 @@ class WebReportDialog(ReportDialog):
|
|||||||
ReportDialog.__init__(self,database,person)
|
ReportDialog.__init__(self,database,person)
|
||||||
|
|
||||||
def add_user_options(self):
|
def add_user_options(self):
|
||||||
|
lnk_msg = _("Include a link to the index page")
|
||||||
|
priv_msg = _("Do not include records marked private")
|
||||||
|
restrict_msg = _("Restrict information on living people")
|
||||||
|
no_img_msg = _("Do not use images")
|
||||||
|
no_limg_msg = _("Do not use images for living people")
|
||||||
|
no_com_msg = _("Do not include comments and text in source information")
|
||||||
|
|
||||||
self.use_link = GtkCheckButton(_("Include a link to the index page"))
|
self.use_link = GtkCheckButton(lnk_msg)
|
||||||
self.use_link.set_active(1)
|
self.use_link.set_active(1)
|
||||||
self.no_private = GtkCheckButton(_("Do not include records marked private"))
|
self.no_private = GtkCheckButton(priv_msg)
|
||||||
self.no_private.set_active(1)
|
self.no_private.set_active(1)
|
||||||
self.restrict_living = GtkCheckButton(_("Restrict information on living people"))
|
self.restrict_living = GtkCheckButton(restrict_msg)
|
||||||
self.no_images = GtkCheckButton(_("Do not use images"))
|
self.no_images = GtkCheckButton(no_img_msg)
|
||||||
self.no_living_images = GtkCheckButton(_("Do not use images for living people"))
|
self.no_living_images = GtkCheckButton(no_limg_msg)
|
||||||
self.no_comments = GtkCheckButton(_("Do not include comments and text in source information"))
|
self.no_comments = GtkCheckButton(no_com_msg)
|
||||||
|
|
||||||
self.add_option('',self.use_link)
|
self.add_option('',self.use_link)
|
||||||
self.add_option('',self.no_private)
|
title = _("Privacy Options")
|
||||||
self.add_option('',self.restrict_living)
|
self.add_frame_option(title,None,self.no_private)
|
||||||
self.add_option('',self.no_images)
|
self.add_frame_option(title,None,self.restrict_living)
|
||||||
self.add_option('',self.no_living_images)
|
self.add_frame_option(title,None,self.no_images)
|
||||||
self.add_option('',self.no_comments)
|
self.add_frame_option(title,None,self.no_living_images)
|
||||||
|
self.add_frame_option(title,None,self.no_comments)
|
||||||
|
|
||||||
self.no_images.connect('toggled',self.on_nophotos_toggled)
|
self.no_images.connect('toggled',self.on_nophotos_toggled)
|
||||||
|
|
||||||
@ -1019,11 +1026,8 @@ class WebReportDialog(ReportDialog):
|
|||||||
#
|
#
|
||||||
#
|
#
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
|
|
||||||
def report(database,person):
|
def report(database,person):
|
||||||
WebReportDialog(database,person)
|
WebReportDialog(database,person)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
|
Loading…
Reference in New Issue
Block a user