diff --git a/gramps/src/HtmlDoc.py b/gramps/src/HtmlDoc.py
index c8cf0adf2..01d93de2d 100644
--- a/gramps/src/HtmlDoc.py
+++ b/gramps/src/HtmlDoc.py
@@ -194,9 +194,9 @@ class HtmlDoc(TextDoc):
font_size = font.get_size()
font_color = '#%02x%02x%02x' % font.get_color()
align = style.get_alignment_text()
- text_indent = fl2txt("%.2f",style.get_first_indent())
- right_margin = fl2txt("%.2f",style.get_right_margin())
- left_margin = fl2txt("%.2f",style.get_left_margin())
+ text_indent = "%.2f" % style.get_first_indent()
+ right_margin = "%.2f" % style.get_right_margin()
+ left_margin = "%.2f" % style.get_left_margin()
top = bottom = left = right = 'none'
if style.get_top_border():
diff --git a/gramps/src/Report.py b/gramps/src/Report.py
index d7bdf0e11..1b68bdbba 100644
--- a/gramps/src/Report.py
+++ b/gramps/src/Report.py
@@ -140,12 +140,9 @@ class ReportDialog:
frame_pad = 5
border_pad = 5
- def __init__(self,database,person,filename="basicreport.glade"):
+ def __init__(self,database,person):
"""Initialize a dialog to request that the user select options
- for a basic report. The glade filename is optional. If
- provided it must reference a glade file that is either be a
- superset of the basic dialog, or the subclass must override
- most of the setup_xxx and parse_xxx functions."""
+ for a basic report."""
# Save info about who the report is about.
self.db = database
@@ -169,10 +166,10 @@ class ReportDialog:
# Set up and run the dialog. These calls are not in top down
# order when looking at the dialog box as there is some
# interaction between the various frames.
+ self.add_user_options()
self.setup_title()
self.setup_header()
self.setup_target_frame()
- self.setup_format_frame()
self.setup_style_frame()
self.setup_output_notebook()
self.setup_paper_frame()
@@ -180,6 +177,11 @@ class ReportDialog:
self.setup_report_options_frame()
self.setup_other_frames()
self.window.show_all()
+ self.setup_format_frame()
+
+ def add_user_options(self):
+ pass
+
#------------------------------------------------------------------------
#
# Customization hooks for subclasses
@@ -395,6 +397,9 @@ class ReportDialog:
# Save Frame
frame = GtkFrame(_("Save As"))
frame.set_border_width(ReportDialog.frame_pad)
+ hid = self.get_stylesheet_savefile()
+ if hid[-4:]==".xml":
+ hid = hid[0:-4]
self.target_fileentry = GnomeFileEntry(hid,_("Save As"))
hbox = GtkHBox()
@@ -406,10 +411,6 @@ class ReportDialog:
else:
label = GtkLabel(_("Filename"))
hbox.pack_start(label,0,0,5)
-
- hid = self.get_stylesheet_savefile()
- if hid[-4:]==".xml":
- hid = hid[0:-4]
hbox.add(self.target_fileentry)
frame.add(hbox)
@@ -419,7 +420,6 @@ class ReportDialog:
if (self.get_target_is_directory()):
import _gnomeui
_gnomeui.gnome_file_entry_set_directory(self.target_fileentry._o, 1)
- self.topDialog.get_widget("saveas").set_text(_("Directory"))
target_filename = self.target_fileentry.children()[0].entry
target_filename.set_text(self.get_default_directory())
@@ -812,11 +812,11 @@ class ReportDialog:
#
#------------------------------------------------------------------------
class TextReportDialog(ReportDialog):
- def __init__(self,database,person,filename="basicreport.glade"):
+ def __init__(self,database,person):
"""Initialize a dialog to request that the user select options
for a basic text report. See the ReportDialog class for more
information."""
- ReportDialog.__init__(self,database,person,filename)
+ ReportDialog.__init__(self,database,person)
#------------------------------------------------------------------------
#
diff --git a/gramps/src/plugins/Merge.py b/gramps/src/plugins/Merge.py
index 848751d9a..2153775c5 100644
--- a/gramps/src/plugins/Merge.py
+++ b/gramps/src/plugins/Merge.py
@@ -66,11 +66,6 @@ def ancestors_of(p1,list):
#-------------------------------------------------------------------------
class Merge:
- #---------------------------------------------------------------------
- #
- #
- #
- #---------------------------------------------------------------------
def __init__(self,database,callback):
self.db = database
self.map = {}
@@ -113,31 +108,18 @@ class Merge:
})
def on_merge_ok_clicked(self,obj):
-
active = self.menu.get_menu().get_active().get_data("v")
self.use_soundex = self.soundex_obj.get_active()
utils.destroy_passed_object(obj)
self.find_potentials(active)
self.show()
-
- #---------------------------------------------------------------------
- #
- #
- #
- #---------------------------------------------------------------------
def progress_update(self,val):
self.progress.set_value(val)
while events_pending():
mainiteration()
- #---------------------------------------------------------------------
- #
- #
- #
- #---------------------------------------------------------------------
def find_potentials(self,thresh):
-
top = GladeXML(self.glade_file,"message")
self.topWin = top.get_widget("message")
self.progress = top.get_widget("progressbar1")
@@ -199,11 +181,6 @@ class Merge:
self.topWin.destroy()
self.dellist = {}
- #---------------------------------------------------------------------
- #
- #
- #
- #---------------------------------------------------------------------
def show(self):
top = GladeXML(self.glade_file,"mergelist")
self.window = top.get_widget("mergelist")
@@ -266,11 +243,6 @@ class Merge:
self.update(1)
utils.destroy_passed_object(obj)
- #---------------------------------------------------------------------
- #
- #
- #
- #---------------------------------------------------------------------
def list_reduce(self,list1,list2):
value = 0
for name in list1:
@@ -292,33 +264,18 @@ class Merge:
else:
return min(value,1)
- #-----------------------------------------------------------------
- #
- #
- #
- #-----------------------------------------------------------------
def gen_key(self,val):
if self.use_soundex:
return soundex.soundex(val)
else:
return val
- #-----------------------------------------------------------------
- #
- #
- #
- #-----------------------------------------------------------------
def name_compare(self,s1,s2):
if self.use_soundex:
return soundex.compare(s1,s2)
else:
return s1 == s2
- #-----------------------------------------------------------------
- #
- #
- #
- #-----------------------------------------------------------------
def date_match(self,date1,date2):
if date1.getDate() == "" or date2.getDate() == "":
return 0
@@ -341,11 +298,6 @@ class Merge:
else:
return -1
- #-----------------------------------------------------------------
- #
- #
- #
- #-----------------------------------------------------------------
def range_compare(self,date1,date2):
if date1.isRange() and date2.isRange():
if date1.get_start_date() >= date2.get_start_date() and \
@@ -372,11 +324,6 @@ class Merge:
else:
return -1
- #-----------------------------------------------------------------
- #
- #
- #
- #-----------------------------------------------------------------
def name_match(self,name,name1):
if not name1 or not name:
@@ -404,11 +351,6 @@ class Merge:
else:
return self.list_reduce(list2,list1)
- #---------------------------------------------------------------------
- #
- #
- #
- #---------------------------------------------------------------------
def place_match(self,p1,p2):
if p1 == p2:
return 1
@@ -445,11 +387,6 @@ class Merge:
else:
return min(value,1)
- #---------------------------------------------------------------------
- #
- #
- #
- #---------------------------------------------------------------------
def compare_people(self,p1,p2):
name1 = p1.getPrimaryName()
diff --git a/gramps/src/plugins/WebPage.py b/gramps/src/plugins/WebPage.py
index 1d5dc2d93..414ed044f 100644
--- a/gramps/src/plugins/WebPage.py
+++ b/gramps/src/plugins/WebPage.py
@@ -1,4 +1,4 @@
-#
+
# Gramps - a GTK+/GNOME based genealogy program
#
# Copyright (C) 2000 Donald N. Allingham
@@ -777,8 +777,28 @@ class WebReport(Report):
#------------------------------------------------------------------------
class WebReportDialog(ReportDialog):
def __init__(self,database,person):
- ReportDialog.__init__(self,database,person,"webpage.glade")
+ ReportDialog.__init__(self,database,person)
+ def add_user_options(self):
+
+ self.use_link = GtkCheckButton(_("Include a link to the index page"))
+ self.use_link.set_active(1)
+ self.no_private = GtkCheckButton(_("Do not include records marked private"))
+ self.no_private.set_active(1)
+ self.restrict_living = GtkCheckButton(_("Restrict information on living people"))
+ self.no_images = GtkCheckButton(_("Do not use images"))
+ self.no_living_images = GtkCheckButton(_("Do not use images for living people"))
+ self.no_comments = GtkCheckButton(_("Do not include comments and text in source information"))
+
+ self.add_option('',self.use_link)
+ self.add_option('',self.no_private)
+ self.add_option('',self.restrict_living)
+ self.add_option('',self.no_images)
+ self.add_option('',self.no_living_images)
+ self.add_option('',self.no_comments)
+
+ self.no_images.connect('toggled',self.on_nophotos_toggled)
+
#------------------------------------------------------------------------
#
# Customization hooks
@@ -936,21 +956,6 @@ class WebReportDialog(ReportDialog):
page."""
self.output_notebook.set_page(1)
- def setup_other_frames(self):
- """Set up the privacy frame of the dialog. This sole purpose of
- this function is to grab a pointer for later use in a callback
- routine."""
- self.restrict_photos_check = self.topDialog.get_widget("restrict_photos")
-
- def connect_signals(self):
- """Connect the signal handlers for this dialog. This routine
- uses the parent routine to connect the common handlers, and
- the connects its own unique handler."""
- ReportDialog.connect_signals(self)
- self.topDialog.signal_autoconnect({
- "on_nophotos_toggled" : self.on_nophotos_toggled,
- })
-
#------------------------------------------------------------------------
#
# Functions related to retrieving data from the dialog window
@@ -965,17 +970,17 @@ class WebReportDialog(ReportDialog):
"""Parse the report options frame of the dialog. Save the
user selected choices for later use."""
ReportDialog.parse_report_options_frame(self)
- self.include_link = self.topDialog.get_widget("include_link").get_active()
+ self.include_link = self.use_link.get_active()
def parse_other_frames(self):
"""Parse the privacy options frame of the dialog. Save the
user selected choices for later use."""
- self.restrict = self.topDialog.get_widget("restrict").get_active()
- self.private = self.topDialog.get_widget("private").get_active()
- self.srccomments = self.topDialog.get_widget("srccomments").get_active()
- if (self.topDialog.get_widget("nophotos").get_active() == 1):
+ self.restrict = self.restrict_living.get_active()
+ self.private = self.no_private.get_active()
+ self.srccomments = self.no_comments.get_active()
+ if self.no_images.get_active() == 1:
self.photos = 0
- elif (self.restrict_photos_check.get_active() == 1):
+ elif self.no_living_images.get_active() == 1:
self.photos = 1
else:
self.photos = 2
@@ -991,9 +996,9 @@ class WebReportDialog(ReportDialog):
no sense to worry about restricting which photos are included,
now does it?"""
if obj.get_active():
- self.restrict_photos_check.set_sensitive(0)
+ self.no_living_images.set_sensitive(0)
else:
- self.restrict_photos_check.set_sensitive(1)
+ self.no_living_images.set_sensitive(1)
#------------------------------------------------------------------------
#