# # Gramps - a GTK+/GNOME based genealogy program # # Copyright (C) 2007-2008 Donald N. Allingham # Copyright (C) 2008 Gary Burton # Copyright (C) 2008 Robert Cheramy # # 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 # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # """Provide the common export options for Exporters.""" #------------------------------------------------------------------------- # # python modules # #------------------------------------------------------------------------- import gtk from gen.ggettext import gettext as _ import gobject #------------------------------------------------------------------------- # # GRAMPS modules # #------------------------------------------------------------------------- import config from gen.display.name import displayer as name_displayer from Filters import GenericFilter, Rules #------------------------------------------------------------------------- # # WriterOptionBox # #------------------------------------------------------------------------- class WriterOptionBox(object): """ Create a VBox with the option widgets and define methods to retrieve the options. """ def __init__(self, person): self.person = person self.private = 0 self.restrict = 0 self.unlinked = 0 self.cfilter = None self.nfilter = None self.restrict_check = None self.private_check = None self.unlinked_check = None self.filter_obj = None self.filter_note = None # The following are special properties. Create them to force the # export wizard to not ask for a file, and to override the # confirmation message: #self.no_fileselect = True #self.confirm_text = "You made it, kid!" def get_option_box(self): """Build up a gtk.Table that contains the standard options.""" table = gtk.Table(5, 2) self.filter_obj = gtk.ComboBox() label = gtk.Label(_('_Person Filter')) label.set_use_underline(True) label.set_mnemonic_widget(self.filter_obj) # Objects for choosing a Note filter self.filter_note = gtk.ComboBox() label_note = gtk.Label(_('_Note Filter')) label_note.set_use_underline(True) label_note.set_mnemonic_widget(self.filter_note) self.private_check = gtk.CheckButton( _('_Do not include records marked private')) self.restrict_check = gtk.CheckButton( _('_Restrict data on living people')) self.unlinked_check = gtk.CheckButton( _('_Do not include unlinked records')) self.private_check.set_active(config.get('export.no-private')) self.restrict_check.set_active(config.get('export.restrict-living')) self.unlinked_check.set_active(config.get('export.no-unlinked')) table.set_border_width(12) table.set_row_spacings(6) table.set_col_spacings(6) table.attach(label, 0, 1, 0, 1, xoptions=0, yoptions=0) table.attach(self.filter_obj, 1, 2, 0, 1, yoptions=0) table.attach(label_note, 0, 1, 1, 2, xoptions =0, yoptions=0) table.attach(self.filter_note, 1, 2, 1, 2, yoptions=0) table.attach(self.private_check, 1, 2, 2, 3, yoptions=0) table.attach(self.restrict_check, 1, 2, 3, 4, yoptions=0) table.attach(self.unlinked_check, 1, 2, 4, 5, yoptions=0) # Populate the Person Filter entire_db = GenericFilter() entire_db.set_name(_("Entire Database")) the_filters = [entire_db] if self.person: the_filters += self.__define_person_filters() from Filters import CustomFilters the_filters.extend(CustomFilters.get_filters('Person')) model = gtk.ListStore(gobject.TYPE_STRING, object) for item in the_filters: model.append(row=[item.get_name(), item]) cell = gtk.CellRendererText() self.filter_obj.pack_start(cell, True) self.filter_obj.add_attribute(cell, 'text', 0) self.filter_obj.set_model(model) self.filter_obj.set_active(0) # Populate the Notes Filter notes_filters = [entire_db] notes_filters.extend(CustomFilters.get_filters('Note')) notes_model = gtk.ListStore(gobject.TYPE_STRING, object) for item in notes_filters: notes_model.append(row=[item.get_name(), item]) notes_cell = gtk.CellRendererText() self.filter_note.pack_start(notes_cell, True) self.filter_note.add_attribute(notes_cell, 'text', 0) self.filter_note.set_model(notes_model) self.filter_note.set_active(0) table.show() return table def __define_person_filters(self): """Add person filters if the active person is defined.""" name = name_displayer.display(self.person) gramps_id = self.person.get_gramps_id() des = GenericFilter() des.set_name(_("Descendants of %s") % name) des.add_rule(Rules.Person.IsDescendantOf([gramps_id, 1])) df = GenericFilter() df.set_name(_("Descendant Families of %s") % name) df.add_rule(Rules.Person.IsDescendantFamilyOf([gramps_id, 1])) ans = GenericFilter() ans.set_name(_("Ancestors of %s") % name) ans.add_rule(Rules.Person.IsAncestorOf([gramps_id, 1])) com = GenericFilter() com.set_name(_("People with common ancestor with %s") % name) com.add_rule(Rules.Person.HasCommonAncestorWith([gramps_id])) return [des, df, ans, com] def parse_options(self): """ Extract the common values from the GTK widgets. After this function is called, the following variables are defined: private = privacy requested restrict = restrict information on living peoplel cfitler = return the GenericFilter selected nfilter = return the NoteFilter selected unlinked = restrict unlinked records """ self.restrict = self.restrict_check.get_active() self.private = self.private_check.get_active() self.unlinked = self.unlinked_check.get_active() config.set('export.no-private', self.private) config.set('export.restrict-living', self.restrict) config.set('export.no-unlinked', self.unlinked) config.save() model = self.filter_obj.get_model() node = self.filter_obj.get_active_iter() self.cfilter = model[node][1] model = self.filter_note.get_model() node = self.filter_note.get_active_iter() self.nfilter = model[node][1]