From 6141ffb14b87dda89dd03f681127c74ecb37cde0 Mon Sep 17 00:00:00 2001 From: Alex Roitman Date: Sat, 8 Jan 2005 20:19:06 +0000 Subject: [PATCH] * src/Report.py (CommandLineReport.parse_option_str): Fix PluginMgr lists. * src/plugins/CustomBookText.py: Convert to new scheme. * src/plugins/FamilyGroup.py: Switch from handle to id for spouse. * src/plugins/SimpleBookTitle.py: Cleanups. svn: r3884 --- ChangeLog | 7 + src/Report.py | 13 +- src/plugins/CustomBookText.py | 356 +++++++++++++-------------------- src/plugins/FamilyGroup.py | 28 +-- src/plugins/SimpleBookTitle.py | 21 +- 5 files changed, 176 insertions(+), 249 deletions(-) diff --git a/ChangeLog b/ChangeLog index 083d492e1..ffc3771ec 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +2005-01-08 Alex Roitman + * src/Report.py (CommandLineReport.parse_option_str): + Fix PluginMgr lists. + * src/plugins/CustomBookText.py: Convert to new scheme. + * src/plugins/FamilyGroup.py: Switch from handle to id for spouse. + * src/plugins/SimpleBookTitle.py: Cleanups. + 2005-01-07 Don Allingham * src/gramps.glade: removal of more OptionMenus in favor of ComboBoxes diff --git a/src/Report.py b/src/Report.py index ee12899c7..c89eb33c1 100644 --- a/src/Report.py +++ b/src/Report.py @@ -50,6 +50,7 @@ import gnome.ui import const import Utils import Plugins +import PluginMgr import BaseDoc import StyleEditor import GrampsKeys @@ -1624,27 +1625,27 @@ class CommandLineReport: self.options_help['of'].append(os.path.expanduser("~/whatever_name")) if self.category == const.CATEGORY_TEXT: - for item in Plugins._textdoc: + for item in PluginMgr.textdoc_list: if item[7] == self.options_dict['off']: self.format = item[1] self.options_help['off'].append( - [ item[7] for item in Plugins._textdoc ] + [ item[7] for item in PluginMgr.textdoc_list ] ) self.options_help['off'].append(False) elif self.category == const.CATEGORY_DRAW: - for item in Plugins._drawdoc: + for item in PluginMgr.drawdoc_list: if item[6] == self.options_dict['off']: self.format = item[1] self.options_help['off'].append( - [ item[6] for item in Plugins._drawdoc ] + [ item[6] for item in PluginMgr.drawdoc_list ] ) self.options_help['off'].append(False) elif self.category == const.CATEGORY_BOOK: - for item in Plugins._bookdoc: + for item in PluginMgr.bookdoc_list: if item[6] == self.options_dict['off']: self.format = item[1] self.options_help['off'].append( - [ item[6] for item in Plugins._bookdoc ] + [ item[6] for item in PluginMgr.bookdoc_list ] ) self.options_help['off'].append(False) else: diff --git a/src/plugins/CustomBookText.py b/src/plugins/CustomBookText.py index fcb130465..442f52d7d 100644 --- a/src/plugins/CustomBookText.py +++ b/src/plugins/CustomBookText.py @@ -1,6 +1,6 @@ # Gramps - a GTK+/GNOME based genealogy program # -# Copyright (C) 2003 Donald N. Allingham +# Copyright (C) 2003-2005 Donald N. Allingham # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -17,10 +17,24 @@ # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # -# # Written by Alex Roitman, # largely based on the SimpleBookTitle.py by Don Allingham + +# $Id$ + +#------------------------------------------------------------------------ # +# python modules +# +#------------------------------------------------------------------------ +from gettext import gettext as _ + +#------------------------------------------------------------------------ +# +# gtk +# +#------------------------------------------------------------------------ +import gtk #------------------------------------------------------------------------ # @@ -29,11 +43,8 @@ #------------------------------------------------------------------------ import Report import BaseDoc -import Errors -from QuestionDialog import ErrorDialog -from gettext import gettext as _ - -import gtk +import const +import ReportOptions #------------------------------------------------------------------------ # @@ -42,32 +53,30 @@ import gtk #------------------------------------------------------------------------ class CustomText(Report.Report): - def __init__(self,database,person,top_text,middle_text,bottom_text,doc,output,newpage=0): - self.map = {} - self.database = database - self.start = person - self.top_text = top_text - self.middle_text = middle_text - self.bottom_text = bottom_text - self.doc = doc - self.newpage = newpage - if output: - self.standalone = 1 - self.doc.open(output) - self.doc.init() - else: - self.standalone = 0 - self.sref_map = {} - self.sref_index = 1 + def __init__(self,database,person,options_class): + """ + Creates CustomText object that produces the report. - def setup(self): - pass + The arguments are: + database - the GRAMPS database instance + person - currently selected person + options_class - instance of the Options class for this report + + This report needs the following parameters (class variables) + that come in the options class. + + top - Text on the top. + mid - Text in the middle. + bot - Text on the bottom. + """ + Report.Report.__init__(self,database,person,options_class) + + self.top_text = options_class.handler.options_dict['top'] + self.middle_text = options_class.handler.options_dict['mid'] + self.bottom_text = options_class.handler.options_dict['bot'] + def write_report(self): - - if self.newpage: - self.doc.page_break() - self.doc.start_paragraph('CBT-Initial') self.doc.write_text(self.top_text) self.doc.end_paragraph() @@ -80,216 +89,133 @@ class CustomText(Report.Report): self.doc.write_text(self.bottom_text) self.doc.end_paragraph() - if self.standalone: - self.doc.close() - - -def _make_default_style(default_style): - """Make the default output style for the Custom Text report.""" - font = BaseDoc.FontStyle() - font.set(face=BaseDoc.FONT_SANS_SERIF,size=12,bold=0,italic=0) - para = BaseDoc.ParagraphStyle() - para.set_font(font) - para.set_alignment(BaseDoc.PARA_ALIGN_CENTER) - para.set(pad=0.5) - para.set_description(_('The style used for the first portion of the custom text.')) - default_style.add_style("CBT-Initial",para) - - font = BaseDoc.FontStyle() - font.set(face=BaseDoc.FONT_SANS_SERIF,size=12,bold=0,italic=0) - para = BaseDoc.ParagraphStyle() - para.set_font(font) - para.set(pad=0.5) - para.set_alignment(BaseDoc.PARA_ALIGN_CENTER) - para.set_description(_('The style used for the middle portion of the custom text.')) - default_style.add_style("CBT-Middle",para) - - font = BaseDoc.FontStyle() - font.set(face=BaseDoc.FONT_SANS_SERIF,size=12,bold=0,italic=0) - para = BaseDoc.ParagraphStyle() - para.set_font(font) - para.set_alignment(BaseDoc.PARA_ALIGN_CENTER) - para.set(pad=0.5) - para.set_description(_('The style used for the last portion of the custom text.')) - default_style.add_style("CBT-Final",para) - #------------------------------------------------------------------------ # -# Set up sane defaults for the book_item +# # #------------------------------------------------------------------------ -_style_file = "custom_text.xml" -_style_name = "default" +class CustomTextOptions(ReportOptions.ReportOptions): -_person_handle = "" -_top_text = "" -_middle_text = "" -_bottom_text = "" + """ + Defines options and provides handling interface. + """ -_options = ( _person_handle, _top_text, _middle_text, _bottom_text ) + def __init__(self,name,person_id=None): + ReportOptions.ReportOptions.__init__(self,name,person_id) + def set_new_options(self): + # Options specific for this report + self.options_dict = { + 'top' : '', + 'mid' : '', + 'bot' : '', + } + self.options_help = { + 'top' : ("=str","Initial Text", + "Whatever String You Wish"), + 'mid' : ("=str","Middle Text", + "Whatever String You Wish"), + 'bot' : ("=str","Final Text", + "Whatever String You Wish"), + } -#------------------------------------------------------------------------ -# -# Book Item Options dialog -# -#------------------------------------------------------------------------ -class CustomTextDialog(Report.BareReportDialog): + def add_user_options(self,dialog): + dialog.setup_center_person = dialog.setup_paper_frame + dialog.notebook = gtk.Notebook() + dialog.notebook.set_border_width(6) + dialog.window.vbox.add(dialog.notebook) - def __init__(self,database,person,opt,stl): + top_sw = gtk.ScrolledWindow() + middle_sw = gtk.ScrolledWindow() + bottom_sw = gtk.ScrolledWindow() - self.options = opt - self.db = database - if self.options[0]: - self.person = self.db.get_person_from_handle(self.options[0]) - else: - self.person = person - self.style_name = stl - - Report.BareReportDialog.__init__(self,database,self.person) - - self.top_text = self.options[1] - self.middle_text = self.options[2] - self.bottom_text = self.options[3] - - self.top_text_view.get_buffer().set_text(self.top_text) - self.middle_text_view.get_buffer().set_text(self.middle_text) - self.bottom_text_view.get_buffer().set_text(self.bottom_text) - - self.notebook.set_size_request(450,300) - - self.new_person = None - - self.window.run() - - #------------------------------------------------------------------------ - # - # Customization hooks - # - #------------------------------------------------------------------------ - def make_default_style(self): - _make_default_style(self.default_style) - - def get_title(self): - """The window title for this dialog""" - return "%s - GRAMPS Book" % (_("Custom Text")) - - def get_header(self, name): - """The header line at the top of the dialog contents""" - return _("Custom Text for GRAMPS Book") - - def get_stylesheet_savefile(self): - """Where to save styles for this report.""" - return _style_file - - def setup_center_person(self): - pass - - def setup_report_options_frame(self): - self.notebook = gtk.Notebook() - self.notebook.set_border_width(6) - self.window.vbox.add(self.notebook) - - def add_user_options(self): - self.top_sw = gtk.ScrolledWindow() - self.middle_sw = gtk.ScrolledWindow() - self.bottom_sw = gtk.ScrolledWindow() - - self.top_sw.set_policy(gtk.POLICY_AUTOMATIC,gtk.POLICY_AUTOMATIC) - self.middle_sw.set_policy(gtk.POLICY_AUTOMATIC,gtk.POLICY_AUTOMATIC) - self.bottom_sw.set_policy(gtk.POLICY_AUTOMATIC,gtk.POLICY_AUTOMATIC) + top_sw.set_policy(gtk.POLICY_AUTOMATIC,gtk.POLICY_AUTOMATIC) + middle_sw.set_policy(gtk.POLICY_AUTOMATIC,gtk.POLICY_AUTOMATIC) + bottom_sw.set_policy(gtk.POLICY_AUTOMATIC,gtk.POLICY_AUTOMATIC) self.top_text_view = gtk.TextView() + self.top_text_view.get_buffer().set_text(self.options_dict['top']) self.middle_text_view = gtk.TextView() + self.middle_text_view.get_buffer().set_text(self.options_dict['mid']) self.bottom_text_view = gtk.TextView() + self.bottom_text_view.get_buffer().set_text(self.options_dict['bot']) - self.top_sw.add_with_viewport(self.top_text_view) - self.middle_sw.add_with_viewport(self.middle_text_view) - self.bottom_sw.add_with_viewport(self.bottom_text_view) - - self.add_frame_option(_('Initial Text'),"",self.top_sw) - self.add_frame_option(_('Middle Text'),"",self.middle_sw) - self.add_frame_option(_('Final Text'),"",self.bottom_sw) + top_sw.add_with_viewport(self.top_text_view) + middle_sw.add_with_viewport(self.middle_text_view) + bottom_sw.add_with_viewport(self.bottom_text_view) - def parse_report_options_frame(self): - """Parse the report options frame of the dialog. - Save the user selected choices for later use.""" + dialog.add_frame_option(_('Initial Text'),"",top_sw) + dialog.add_frame_option(_('Middle Text'),"",middle_sw) + dialog.add_frame_option(_('Final Text'),"",bottom_sw) - # call the parent task to handle normal options - Report.BareReportDialog.parse_report_options_frame(self) + def parse_user_options(self,dialog): + """ + Parses the custom options that we have added. + """ + self.options_dict['top'] = unicode( + self.top_text_view.get_buffer().get_text( + self.top_text_view.get_buffer().get_start_iter(), + self.top_text_view.get_buffer().get_end_iter(), + gtk.FALSE + ) + ).replace('\n',' ') - # get values from the widgets - self.top_text = self.top_text_view.get_buffer().get_text( - self.top_text_view.get_buffer().get_start_iter(), - self.top_text_view.get_buffer().get_end_iter(), - gtk.FALSE) - self.middle_text = self.middle_text_view.get_buffer().get_text( - self.middle_text_view.get_buffer().get_start_iter(), - self.middle_text_view.get_buffer().get_end_iter(), - gtk.FALSE) - self.bottom_text = self.bottom_text_view.get_buffer().get_text( - self.bottom_text_view.get_buffer().get_start_iter(), - self.bottom_text_view.get_buffer().get_end_iter(), - gtk.FALSE) + self.options_dict['mid'] = unicode( + self.middle_text_view.get_buffer().get_text( + self.middle_text_view.get_buffer().get_start_iter(), + self.middle_text_view.get_buffer().get_end_iter(), + gtk.FALSE + ) + ).replace('\n',' ') - def on_cancel(self, obj): - pass + self.options_dict['bot'] = unicode( + self.bottom_text_view.get_buffer().get_text( + self.bottom_text_view.get_buffer().get_start_iter(), + self.bottom_text_view.get_buffer().get_end_iter(), + gtk.FALSE + ) + ).replace('\n',' ') - def on_ok_clicked(self, obj): - """The user is satisfied with the dialog choices. Parse all options - and close the window.""" + def make_default_style(self,default_style): + """Make the default output style for the Custom Text report.""" + font = BaseDoc.FontStyle() + font.set(face=BaseDoc.FONT_SANS_SERIF,size=12,bold=0,italic=0) + para = BaseDoc.ParagraphStyle() + para.set_font(font) + para.set_alignment(BaseDoc.PARA_ALIGN_CENTER) + para.set(pad=0.5) + para.set_description(_('The style used for the first portion of the custom text.')) + default_style.add_style("CBT-Initial",para) - # Preparation - self.parse_style_frame() - self.parse_report_options_frame() - - if self.new_person: - self.person = self.new_person - self.options = ( self.person.get_handle(), - self.top_text, self.middle_text, self.bottom_text ) - self.style_name = self.selected_style.get_name() + font = BaseDoc.FontStyle() + font.set(face=BaseDoc.FONT_SANS_SERIF,size=12,bold=0,italic=0) + para = BaseDoc.ParagraphStyle() + para.set_font(font) + para.set(pad=0.5) + para.set_alignment(BaseDoc.PARA_ALIGN_CENTER) + para.set_description(_('The style used for the middle portion of the custom text.')) + default_style.add_style("CBT-Middle",para) -#------------------------------------------------------------------------ -# -# Function to write Book Item -# -#------------------------------------------------------------------------ -def write_book_item(database,person,doc,options,newpage=0): - """Write the Title Page using options set. - All user dialog has already been handled and the output file opened.""" - try: - if options[0]: - person = database.get_person_from_handle(options[0]) - top_text = options[1] - middle_text = options[2] - bottom_text = options[3] - return CustomText(database, person, - top_text, middle_text, bottom_text, doc, None, newpage ) - except Errors.ReportError, msg: - (m1,m2) = msg.messages() - ErrorDialog(m1,m2) - except Errors.FilterError, msg: - (m1,m2) = msg.messages() - ErrorDialog(m1,m2) - except: - import DisplayTrace - DisplayTrace.DisplayTrace() + font = BaseDoc.FontStyle() + font.set(face=BaseDoc.FONT_SANS_SERIF,size=12,bold=0,italic=0) + para = BaseDoc.ParagraphStyle() + para.set_font(font) + para.set_alignment(BaseDoc.PARA_ALIGN_CENTER) + para.set(pad=0.5) + para.set_description(_('The style used for the last portion of the custom text.')) + default_style.add_style("CBT-Final",para) #------------------------------------------------------------------------ # # # #------------------------------------------------------------------------ -from PluginMgr import register_book_item - -# (name,category,options_dialog,write_book_item,options,style_name,style_file,make_default_style) -register_book_item( - _("Custom Text"), - _("Text"), - CustomTextDialog, - write_book_item, - _options, - _style_name, - _style_file, - _make_default_style - ) +from PluginMgr import register_report +register_report( + name = 'custom_text', + category = const.CATEGORY_TEXT, + report_class = CustomText, + options_class = CustomTextOptions, + modes = Report.MODE_BKI, + translated_name = _("Custom Text"), + ) diff --git a/src/plugins/FamilyGroup.py b/src/plugins/FamilyGroup.py index 7b72c9ca1..b483bb469 100644 --- a/src/plugins/FamilyGroup.py +++ b/src/plugins/FamilyGroup.py @@ -1,7 +1,7 @@ # # Gramps - a GTK+/GNOME based genealogy program # -# Copyright (C) 2000-2004 Donald N. Allingham +# Copyright (C) 2000-2005 Donald N. Allingham # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -56,7 +56,6 @@ from DateHandler import displayer as _dd class FamilyGroup(Report.Report): def __init__(self,database,person,options_class): - #,family_handle,doc,output,newpage=0): """ Creates the DetAncestorReport object that produces the report. @@ -73,20 +72,22 @@ class FamilyGroup(Report.Report): """ Report.Report.__init__(self,database,person,options_class) + self.family = None + spouse_id = options_class.handler.options_dict['spouse_id'] if spouse_id: family_list = person.get_family_handle_list() for family_handle in family_list: family = database.get_family_from_handle(family_handle) if person.get_handle() == family.get_father_handle(): - this_spouse_id = family.get_mother_handle() + this_spouse_handle = family.get_mother_handle() else: - this_spouse_id = family.get_father_handle() + this_spouse_handle = family.get_father_handle() + this_spouse = database.get_person_from_handle(this_spouse_handle) + this_spouse_id = this_spouse.get_gramps_id() if spouse_id == this_spouse_id: self.family = family break - else: - self.family = None self.setup() @@ -161,15 +162,15 @@ class FamilyGroup(Report.Report): person = self.database.get_person_from_handle(person_handle) if person.get_gender() == RelLib.Person.male: - id = _("Husband") + the_id = _("Husband") else: - id = _("Wife") + the_id = _("Wife") self.doc.start_table(id,'FGR-ParentTable') self.doc.start_row() self.doc.start_cell('FGR-ParentHead',3) self.doc.start_paragraph('FGR-ParentName') - self.doc.write_text(id + ': ') + self.doc.write_text(the_id + ': ') self.doc.write_text(person.get_primary_name().get_regular_name()) self.doc.end_paragraph() self.doc.end_cell() @@ -448,12 +449,13 @@ class FamilyGroupOptions(ReportOptions.ReportOptions): for family_handle in family_list: family = database.get_family_from_handle(family_handle) if person.get_handle() == family.get_father_handle(): - spouse_id = family.get_mother_handle() + spouse_handle = family.get_mother_handle() else: - spouse_id = family.get_father_handle() - if spouse_id: - spouse = database.get_person_from_handle(spouse_id) + spouse_handle = family.get_father_handle() + if spouse_handle: + spouse = database.get_person_from_handle(spouse_handle) name = spouse.get_primary_name().get_name() + spouse_id = spouse.get_gramps_id() else: name = _("unknown") spouses.append((spouse_id,name)) diff --git a/src/plugins/SimpleBookTitle.py b/src/plugins/SimpleBookTitle.py index 96e555c26..9826b6ba7 100644 --- a/src/plugins/SimpleBookTitle.py +++ b/src/plugins/SimpleBookTitle.py @@ -161,7 +161,7 @@ class SimpleBookTitleOptions(ReportOptions.ReportOptions): footer_string = self.options_dict['footer'] if not footer_string: dateinfo = time.localtime(time.time()) - name = dialog.database.get_researcher().get_name() + name = dialog.db.get_researcher().get_name() footer_string = _('Copyright %d %s') % (dateinfo[0], name) self.footer_entry = gtk.Entry() self.footer_entry.set_text(footer_string) @@ -186,9 +186,9 @@ class SimpleBookTitleOptions(ReportOptions.ReportOptions): preview_table.attach(self.obj_title,0,1,0,1,gtk.SHRINK|gtk.FILL,gtk.SHRINK|gtk.FILL) select_obj_button = gtk.Button(_('From gallery...')) - select_obj_button.connect('clicked',self.select_obj,dialog.database) + select_obj_button.connect('clicked',self.select_obj,dialog.db) select_file_button = gtk.Button(_('From file...')) - select_file_button.connect('clicked',self.select_file,dialog.database) + select_file_button.connect('clicked',self.select_file,dialog.db) select_table = gtk.Table(1,3) select_table.set_col_spacings(10) select_table.attach(select_obj_button, @@ -210,9 +210,9 @@ class SimpleBookTitleOptions(ReportOptions.ReportOptions): dialog.add_frame_option(_('Image'),_('Size'),self.size) object_id = self.options_dict['imgid'] - if object_id and dialog.database.get_object_from_gramps_id(object_id): - the_object = dialog.database.get_object_from_gramps_id(object_id) - self.setup_object(dialog.database,the_object) + if object_id and dialog.db.get_object_from_gramps_id(object_id): + the_object = dialog.db.get_object_from_gramps_id(object_id) + self.setup_object(dialog.db,the_object) else: self.remove_obj_button.set_sensitive(False) self.size.set_sensitive(False) @@ -250,15 +250,6 @@ class SimpleBookTitleOptions(ReportOptions.ReportOptions): self.obj_title.set_text(the_object.get_description()) icon_image = database.get_thumbnail_image(the_object.get_handle()) self.preview.set_from_pixbuf(icon_image) -# the_type = Utils.get_mime_description(the_object.get_mime_type()) -# path = the_object.get_path() -# thumb_path = Utils.thumb_path(database.get_save_path(),the_object) -# pexists = os.path.exists(path) -# if pexists and os.path.exists(thumb_path): -# self.preview.set_from_pixbuf(gtk.gdk.pixbuf_new_from_file(thumb_path)) -# else: -# icon_image = gtk.gdk.pixbuf_new_from_file(Utils.find_icon(the_type)) -# self.preview.set_from_pixbuf(icon_image) self.remove_obj_button.set_sensitive(gtk.TRUE) self.size.set_sensitive(gtk.TRUE)