From 896cd4caef5ef57f3aaa1428a4a368ab9e617844 Mon Sep 17 00:00:00 2001 From: Don Allingham Date: Sun, 28 Oct 2001 23:28:38 +0000 Subject: [PATCH] Improved text, enhanced event comparison to load/save complex filters svn: r514 --- gramps/src/Filter.py | 45 +- gramps/src/OpenSpreadSheet.py | 3 +- gramps/src/TextDoc.py | 2 +- gramps/src/filters/After.py | 1 + gramps/src/filters/Before.py | 1 + gramps/src/gramps.glade | 6 +- gramps/src/gramps_main.py | 4 +- gramps/src/plugins/EventCmp.py | 695 +++++++++++++----------------- gramps/src/plugins/eventcmp.glade | 437 +++++++++++++------ gramps/src/plugins/merge.glade | 4 +- 10 files changed, 633 insertions(+), 565 deletions(-) diff --git a/gramps/src/Filter.py b/gramps/src/Filter.py index da8ab6a41..cc6dcc495 100644 --- a/gramps/src/Filter.py +++ b/gramps/src/Filter.py @@ -47,19 +47,15 @@ class Filter: self.text = text self.invert = 0 - #------------------------------------------------------------------------- - # - # compare - # - #------------------------------------------------------------------------- + def get_text(self): + return self.text + + def get_invert(self): + return self.invert + def set_invert(self,invert): self.invert = invert - #------------------------------------------------------------------------- - # - # compare - # - #------------------------------------------------------------------------- def compare(self,person): val = self.match(person) if self.invert: @@ -67,20 +63,9 @@ class Filter: else: return val - #------------------------------------------------------------------------- - # - # __repr__ - print representation - # - #------------------------------------------------------------------------- - def __repr__(self): + def get_name(self): return str(self.__class__) - #------------------------------------------------------------------------- - # - # match - returns true if a match is made. The base class matches - # everything. - # - #------------------------------------------------------------------------- def match(self,person): return 1 @@ -91,12 +76,28 @@ class Filter: #------------------------------------------------------------------------- _filter_list = [(Filter, _("All people"), 0)] +_filter2class = {} +_filter2descr = {} def register_filter(class_name, description=None, qualifier=0): + name = str(class_name) if description == None: description = _("No description") + _filter2class[name] = class_name + _filter2descr[name] = description _filter_list.append((class_name,description,qualifier)) +def get_filter_description(name): + if _filter2descr.has_key(name): + return _filter2descr[name] + else: + return "" + +def make_filter_from_name(name,qualifier,invert): + a = _filter2class[name](qualifier) + a.set_invert(invert) + return a + #------------------------------------------------------------------------- # # load_filters - loads all filters in the specfied directory. Assumes diff --git a/gramps/src/OpenSpreadSheet.py b/gramps/src/OpenSpreadSheet.py index 8c9c2b5a0..427f2e279 100644 --- a/gramps/src/OpenSpreadSheet.py +++ b/gramps/src/OpenSpreadSheet.py @@ -335,7 +335,8 @@ class OpenSpreadSheet(SpreadSheetDoc): self.f.write('99\n') self.f.write('\n') self.f.write('\n') - self.f.write(' \n') + self.f.write('\n') + self.f.write('\n') self.f.write('\n') self.f.close() diff --git a/gramps/src/TextDoc.py b/gramps/src/TextDoc.py index fd3e4501c..bf9779c19 100644 --- a/gramps/src/TextDoc.py +++ b/gramps/src/TextDoc.py @@ -174,7 +174,7 @@ class TableStyle: else: self.width = 0 self.columns = 0 - self.colwid = [ 0 ] * 10 + self.colwid = [ 0 ] * 100 def set_width(self,width): self.width = width diff --git a/gramps/src/filters/After.py b/gramps/src/filters/After.py index 18c44e419..575ecc492 100644 --- a/gramps/src/filters/After.py +++ b/gramps/src/filters/After.py @@ -37,6 +37,7 @@ class EventAfter(Filter.Filter): def __init__(self,text): self.date = Date.Date() self.date.set(text) + Filter.Filter.__init__(self,text) def match(self,p): for event in p.getEventList() + [p.getBirth(), p.getDeath()]: diff --git a/gramps/src/filters/Before.py b/gramps/src/filters/Before.py index d378e7fa3..2b83e8317 100644 --- a/gramps/src/filters/Before.py +++ b/gramps/src/filters/Before.py @@ -37,6 +37,7 @@ class EventBefore(Filter.Filter): def __init__(self,text): self.date = Date.Date() self.date.set(text) + Filter.Filter.__init__(text) def match(self,p): for event in p.getEventList() + [p.getBirth(), p.getDeath()]: diff --git a/gramps/src/gramps.glade b/gramps/src/gramps.glade index a47243fc6..b753c7b4b 100644 --- a/gramps/src/gramps.glade +++ b/gramps/src/gramps.glade @@ -414,7 +414,7 @@ help1_menu - GtkMenuItem + GtkPixmapMenuItem contents activate @@ -423,10 +423,11 @@ False + GNOME_STOCK_MENU_BOOK_RED - GtkMenuItem + GtkPixmapMenuItem writing_extensions activate @@ -435,6 +436,7 @@ False + GNOME_STOCK_MENU_BOOK_BLUE diff --git a/gramps/src/gramps_main.py b/gramps/src/gramps_main.py index b1d279da6..94ba78442 100755 --- a/gramps/src/gramps_main.py +++ b/gramps/src/gramps_main.py @@ -159,7 +159,7 @@ def on_merge_activate(obj): if page == 0: if len(person_list.selection) != 2: msg = _("Exactly two people must be selected to perform a merge") - GnomeErrorDialog() + GnomeErrorDialog(msg) else: import MergeData p1 = person_list.get_row_data(person_list.selection[0]) @@ -529,7 +529,7 @@ def on_delete_place_clicked(obj): if len(obj.selection) == 0: return elif len(obj.selection) > 1: - msg = _("Currently, you can only delete on place at a time") + msg = _("Currently, you can only delete one place at a time") topWindow.error(msg) return else: diff --git a/gramps/src/plugins/EventCmp.py b/gramps/src/plugins/EventCmp.py index 9fdc77bcf..8a6e35fd8 100644 --- a/gramps/src/plugins/EventCmp.py +++ b/gramps/src/plugins/EventCmp.py @@ -22,7 +22,7 @@ #------------------------------------------------------------------------ # -# +# Module imports # #------------------------------------------------------------------------ import os @@ -30,6 +30,14 @@ import re import sort import utils import string +from gtk import * +from gnome.ui import * +from libglade import * +import ListColors +import Filter +import const +from TextDoc import * +from OpenSpreadSheet import * import intl _ = intl.gettext @@ -39,30 +47,7 @@ _ = intl.gettext # # #------------------------------------------------------------------------ -from gtk import * -from gnome.ui import * -from libglade import * -#------------------------------------------------------------------------ -# -# -# -#------------------------------------------------------------------------ -import ListColors -import Filter -import const -from TextDoc import * -from OpenSpreadSheet import * - - -#------------------------------------------------------------------------ -# -# -# -#------------------------------------------------------------------------ - -OBJECT = "o" -INDEX = "i" FILTER = "filter" FUNCTION = "function" QUALIFIER= "qual" @@ -79,11 +64,6 @@ class TableReport: self.filename = filename self.doc = doc - #-------------------------------------------------------------------- - # - # - # - #-------------------------------------------------------------------- def initialize(self,cols): t = TableStyle() @@ -112,20 +92,10 @@ class TableReport: self.doc.open(self.filename) self.doc.start_page("Page 1","mytbl") - #-------------------------------------------------------------------- - # - # - # - #-------------------------------------------------------------------- def finalize(self): self.doc.end_page() self.doc.close() - #-------------------------------------------------------------------- - # - # - # - #-------------------------------------------------------------------- def write_table_data(self,data): length = len(data) @@ -136,19 +106,9 @@ class TableReport: self.doc.end_cell() self.doc.end_row() - #-------------------------------------------------------------------- - # - # - # - #-------------------------------------------------------------------- def set_row(self,val): self.row = val + 2 - #-------------------------------------------------------------------- - # - # - # - #-------------------------------------------------------------------- def write_table_head(self,data): length = len(data) self.prev = 3 @@ -167,25 +127,24 @@ class TableReport: #------------------------------------------------------------------------ class EventComparison: - #------------------------------------------------------------------------ - # - # - # - #------------------------------------------------------------------------ def __init__(self,database): self.db = database base = os.path.dirname(__file__) self.glade_file = base + os.sep + "eventcmp.glade" + self.qual = 0 + + xml = os.path.expanduser("~/.gramps/eventcmp.xml") + self.interface = ComplexFilterFile(xml) self.filterDialog = GladeXML(self.glade_file,"filters") self.filterDialog.signal_autoconnect({ - "on_add_clicked": on_add_clicked, - "on_delete_clicked":on_delete_clicked, - "on_select_row" : on_select_row, - "on_filter_save_clicked" : on_filter_save_clicked, - "on_apply_clicked":on_apply_clicked, - "destroy_passed_object" : utils.destroy_passed_object + "on_add_clicked" : self.on_add_clicked, + "on_delete_clicked" : self.on_delete_clicked, + "on_filter_save_clicked" : self.on_filter_save_clicked, + "on_filter_load_clicked" : self.on_filter_load_clicked, + "on_apply_clicked" : self.on_apply_clicked, + "destroy_passed_object" : utils.destroy_passed_object }) top =self.filterDialog.get_widget("filters") @@ -193,51 +152,290 @@ class EventComparison: self.filter_list_obj = self.filterDialog.get_widget("active_filters") qualifier = self.filterDialog.get_widget("qualifier") - self.filter_list_obj.set_data(INDEX,-1) - self.filter_list_obj.set_data(OBJECT,self) - self.filter_list = [] - myMenu = Filter.build_filter_menu(on_filter_name_changed,qualifier) + myMenu = Filter.build_filter_menu(self.on_filter_name_changed,qualifier) self.filter_menu.set_menu(myMenu) - top.set_data(OBJECT,self) top.show() - #------------------------------------------------------------------------ - # - # - # - #------------------------------------------------------------------------ - def display_results(self): + def on_apply_clicked(self,obj): my_list = [] for person in self.db.getPersonMap().values(): - match = 1 for filter in self.filter_list: if not filter.compare(person): - match = 0 - if match == 1: + break + else: my_list.append(person) if len(my_list) == 0: GnomeWarningDialog("No matches were found") - return + else: + DisplayChart(my_list) - self.topDialog = GladeXML(self.glade_file,"top") + def on_delete_clicked(self,obj): + if len(self.filter_list_obj.selection) != 1: + return + + row = self.filter_list_obj.selection[0] + self.filter_list_obj.remove(row) + self.filter_list_obj.unselect_all() + del self.filter_list[row] + + def on_add_clicked(self,obj): + + invert = self.filterDialog.get_widget("invert").get_active() + qwidget = self.filterDialog.get_widget("qualifier") + + if self.qual: + qualifier = qwidget.get_text() + else: + qualifier = "" + + menu = self.filter_menu.get_menu() + + function = menu.get_active().get_data(FUNCTION) + name = menu.get_active().get_data(NAME) + + myfilter = function(qualifier) + myfilter.set_invert(invert) + + self.filter_list.append(myfilter) + if invert: + invert_text = "yes" + else: + invert_text = "no" + + self.filter_list_obj.append([name,qualifier,invert_text]) + + def on_filter_save_clicked(self,obj): + self.load_dialog = GladeXML(self.glade_file,"filter_file") + self.filter_combo = self.load_dialog.get_widget("filter_combo") + self.load_dialog.get_widget("title").set_text("Save complex filter") + names = self.interface.get_filter_names() + if len(names) > 0: + self.filter_combo.set_popdown_strings(names) + self.load_dialog.signal_autoconnect({ + "destroy_passed_object" : utils.destroy_passed_object, + "combo_insert_text" : utils.combo_insert_text, + "on_load_filter" : self.on_save_filter, + }) + + def on_filter_load_clicked(self,obj): + self.load_dialog = GladeXML(self.glade_file,"filter_file") + self.filter_combo = self.load_dialog.get_widget("filter_combo") + self.load_dialog.get_widget("title").set_text("Load complex filter") + names = self.interface.get_filter_names() + if len(names) > 0: + self.filter_combo.set_popdown_strings(names) + self.load_dialog.signal_autoconnect({ + "destroy_passed_object" : utils.destroy_passed_object, + "combo_insert_text" : utils.combo_insert_text, + "on_load_filter" : self.on_load_filter, + }) + + def on_load_filter(self,obj): + name = self.load_dialog.get_widget("name").get_text() + self.filter_list = self.interface.get_filter(name) + self.filter_list_obj.freeze() + self.filter_list_obj.clear() + for f in self.filter_list: + if f.get_invert(): + invert = "yes" + else: + invert = "no" + name = str(f.__class__) + name = Filter.get_filter_description(name) + self.filter_list_obj.append([name,f.get_text(),invert]) + self.filter_list_obj.thaw() + utils.destroy_passed_object(obj) + + def on_save_filter(self,obj): + name = self.load_dialog.get_widget("name").get_text() + self.interface.save_filter(name,self.filter_list) + utils.destroy_passed_object(obj) + + def on_filter_name_changed(self,obj): + self.qual = obj.get_data(QUALIFIER) + obj.get_data(FILTER).set_sensitive(self.qual) + + +class ComplexFilterFile: + def __init__(self,name): + self.filters = {} + self.fname = name + f = open(self.fname) + parser = make_parser() + parser.setContentHandler(ComplexFilterParser(self)) + parser.parse(f) + f.close() + + def get_filter_names(self): + return self.filters.keys() + + def get_filter(self,name): + if self.filters.has_key(name): + return self.filters[name] + else: + return [] + + def save_filter(self,name,filter_list): + self.filters[name] = filter_list + + f = open(self.fname,"w") + f.write('\n') + f.write('\n') + for name in self.filters.keys(): + f.write(' \n' % name) + for filter in self.filters[name]: + val = (filter.get_name(),filter.get_text(),filter.get_invert()) + f.write(' \n' % val) + f.write(' \n') + f.write('\n') + f.close() + +class ComplexFilterParser(handler.ContentHandler): + def __init__(self,parent): + self.parent = parent + self.curfilter = [] + self.curname = "" + + def startElement(self,tag,attrs): + if tag == "complex_filter": + self.curname = attrs['name'] + self.curfilter = [] + elif tag == "filter": + name = attrs['name'] + qual = attrs['text'] + invert = int(attrs['invert']) + f = Filter.make_filter_from_name(name,qual,invert) + self.curfilter.append(f) + + def endElement(self,tag): + if tag == "complex_filter": + self.parent.filters[self.curname] = self.curfilter + +#------------------------------------------------------------------------ +# +# +# +#------------------------------------------------------------------------ +def runTool(database,person,callback): + EventComparison(database) + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +def by_value(first,second): + return cmp(second[0],first[0]) + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +def fix(line): + l = string.strip(line) + l = string.replace(l,'&','&') + l = string.replace(l,'>','>') + l = string.replace(l,'<','<') + return string.replace(l,'"','"') + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +class DisplayChart: + def __init__(self,people_list): + self.my_list = people_list + self.row_data = [] + + base = os.path.dirname(__file__) + self.glade_file = base + os.sep + "eventcmp.glade" + + self.topDialog = GladeXML(self.glade_file,"view") self.topDialog.signal_autoconnect({ - "on_write_table" : on_write_table, + "on_write_table" : self.on_write_table, "destroy_passed_object" : utils.destroy_passed_object }) - top = self.topDialog.get_widget("top") - top.set_data(OBJECT,self) - table = self.topDialog.get_widget("addarea") + self.top = self.topDialog.get_widget("view") + self.table = self.topDialog.get_widget("addarea") - my_list.sort(sort.by_last_name) + self.my_list.sort(sort.by_last_name) + self.event_titles = self.make_event_titles() + self.build_row_data() + self.draw_clist_display() + self.top.show() + + def draw_clist_display(self): + + eventlist = GtkCList(len(self.event_titles),self.event_titles) + self.table.add(eventlist) + eventlist.show() + color_clist = ListColors.ColorList(eventlist,2) + + for (top,bottom) in self.row_data: + color_clist.add(top) + color_clist.add(bottom) + + for index in range(0,len(self.event_titles)): + width = min(150,eventlist.optimal_column_width(index)) + eventlist.set_column_width(index,width) + + def build_row_data(self): + for individual in self.my_list: + name = individual.getPrimaryName().getName() + birth = individual.getBirth() + death = individual.getDeath() + map = {} + elist = individual.getEventList()[:] + for ievent in elist: + event_name = ievent.getName() + if map.has_key(event_name): + map[event_name].append(ievent) + else: + map[event_name] = [ievent] + + first = 1 + done = 0 + while done == 0: + added = 0 + if first: + tlist = [name,birth.getDate(),death.getDate()] + blist = ["",birth.getPlaceName(),death.getPlaceName()] + else: + tlist = ["","",""] + blist = ["","",""] + for ename in self.event_titles[3:]: + if map.has_key(ename) and len(map[ename]) > 0: + event = map[ename][0] + del map[ename][0] + tlist.append(event.getDate()) + blist.append(event.getPlaceName()) + added = 1 + else: + tlist.append("") + blist.append("") + + if first: + first = 0 + self.row_data.append((tlist,blist)) + elif added == 0: + done = 1 + else: + self.row_data.append((tlist,blist)) + + def make_event_titles(self): + """Creates the list of unique event types, along with the person's + name, birth, and death. This should be the column titles of the report""" map = {} - for individual in my_list: + for individual in self.my_list: elist = individual.getEventList() for event in elist: name = event.getName() @@ -257,334 +455,41 @@ class EventComparison: for item in unsort_list: sort_list.append(item[1]) - event_titles = ["Person","Birth","Death"] + sort_list + return [_("Person"),_("Birth"),_("Death")] + sort_list - eventlist = GtkCList(len(event_titles),event_titles) - eventlist.set_data(INDEX,-1) - - table.add(eventlist) - eventlist.show() - - color_clist = ListColors.ColorList(eventlist,2) - - for individual in my_list: - name = individual.getPrimaryName().getName() - birth = individual.getBirth() - death = individual.getDeath() - map = {} - elist = individual.getEventList()[:] - for ievent in elist: - event_name = ievent.getName() - if map.has_key(event_name): - map[event_name].append(ievent) - else: - map[event_name] = [ievent] + def on_write_table(self,obj): + self.form = GladeXML(self.glade_file,"dialog1") + self.form.signal_autoconnect({ + "on_save_clicked" : self.on_save_clicked, + "on_html_toggled" : self.on_html_toggled, + "destroy_passed_object" : utils.destroy_passed_object + }) + self.save_form = self.form.get_widget("dialog1") + self.save_form.show() - first = 1 - done = 0 - while done == 0: - added = 0 - if first: - tlist = [name,birth.getDate(),death.getDate()] - blist = ["",birth.getPlaceName(),death.getPlaceName()] - else: - tlist = ["","",""] - blist = ["","",""] - for ename in event_titles[3:]: - if map.has_key(ename) and len(map[ename]) > 0: - mylist = map[ename] - event = mylist[0] - del mylist[0] - tlist.append(event.getDate()) - blist.append(event.getPlaceName()) - added = 1 - else: - tlist.append("") - blist.append("") - - if first: - first = 0 - color_clist.add(tlist) - color_clist.add(blist) - elif added == 0: - done = 1 - else: - color_clist.add(tlist) - color_clist.add(blist) + def on_html_toggled(self,obj): + active = self.form.get_widget("html").get_active() + self.form.get_widget("htmltemplate").set_sensitive(active) - for index in range(0,len(event_titles)): - eventlist.set_column_width(index,eventlist.optimal_column_width(index)) - top.show() - - #------------------------------------------------------------------------ - # - # - # - #------------------------------------------------------------------------ - def save_data(self): + def on_save_clicked(self,obj): - my_list = [] - for person in self.db.getPersonMap().values(): - match = 1 - for filter in self.filter_list: - if not filter.compare(person): - match = 0 - if match == 1: - my_list.append(person) - - my_list.sort(sort.by_last_name) - - map = {} - for individual in my_list: - elist = individual.getEventList()[:] - for event in elist: - name = event.getName() - if not name: - break - if map.has_key(name): - map[name] = map[name] + 1 - else: - map[name] = 1 - - unsort_list = [] - for item in map.keys(): - unsort_list.append((map[item],item)) - unsort_list.sort(by_value) - - sort_list = [] - for item in unsort_list: - sort_list.append(item[1]) - - event_titles = ["Person","Birth","Death"] + sort_list - name = self.form.get_widget("filename").get_text() doc = OpenSpreadSheet(PaperStyle("junk",10,10),PAPER_PORTRAIT) spreadsheet = TableReport(name,doc) - spreadsheet.initialize(len(event_titles)) + spreadsheet.initialize(len(self.event_titles)) + spreadsheet.write_table_head(self.event_titles) - spreadsheet.write_table_head(event_titles) - index = 0 - for individual in my_list: + for (top,bottom) in self.row_data: spreadsheet.set_row(index%2) index = index + 1 - name = individual.getPrimaryName().getName() - birth = individual.getBirth() - death = individual.getDeath() - map = {} - elist = individual.getEventList()[:] - for ievent in elist: - event_name = ievent.getName() - if map.has_key(event_name): - map[event_name].append(ievent) - else: - map[event_name] = [ievent] - - first = 1 - done = 0 - while done == 0: - added = 0 - if first: - tlist = [name,birth.getDate(),death.getDate()] - blist = ["",birth.getPlaceName(),death.getPlaceName()] - else: - tlist = ["","",""] - blist = ["","",""] - for ename in event_titles[3:]: - if map.has_key(ename) and len(map[ename]) > 0: - mylist = map[ename] - event = mylist[0] - del mylist[0] - tlist.append(event.getDate()) - blist.append(event.getPlaceName()) - added = 1 - else: - tlist.append("") - blist.append("") - - if first: - first = 0 - spreadsheet.write_table_data(tlist) - spreadsheet.write_table_data(blist) - elif added == 0: - done = 1 - else: - spreadsheet.write_table_data(tlist) - spreadsheet.write_table_data(blist) + spreadsheet.write_table_data(top) + spreadsheet.write_table_data(bottom) spreadsheet.finalize() - - #------------------------------------------------------------------------ - # - # - # - #------------------------------------------------------------------------ - def display_save_form(self): - self.form = GladeXML(self.glade_file,"dialog1") - self.form.signal_autoconnect({ - "on_save_clicked": on_save_clicked, - "on_html_toggled": on_html_toggled, - "destroy_passed_object" : utils.destroy_passed_object - }) - self.save_form = self.form.get_widget("dialog1") - self.save_form.set_data(OBJECT,self) - self.save_form.show() - -#------------------------------------------------------------------------ -# -# -# -#------------------------------------------------------------------------ -def runTool(database,person,callback): - EventComparison(database) - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -def on_apply_clicked(obj): - myobj = obj.get_data(OBJECT) - myobj.display_results() - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -def on_write_table(obj): - myobj = obj.get_data(OBJECT) - myobj.display_save_form() - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -def on_save_clicked(obj): - myobj = obj.get_data(OBJECT) - myobj.save_data() - utils.destroy_passed_object(obj) - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -def on_html_toggled(obj): - myobj = obj.get_data(OBJECT) - if myobj.form.get_widget("html").get_active(): - myobj.form.get_widget("htmltemplate").set_sensitive(1) - else: - myobj.form.get_widget("htmltemplate").set_sensitive(0) - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -def on_double_click(obj,event): - import EditPerson - - row = obj.get_data(INDEX) - if event.button == 1 and event.type == GDK._2BUTTON_PRESS and row != -1: - EditPerson.EditPerson(obj.get_row_data(row)) - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -def on_select_row(obj,row,b,c): - obj.set_data(INDEX,row) - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -def on_delete_clicked(obj): - myobj = obj.get_data(OBJECT) - row = myobj.filter_list_obj.get_data(INDEX) - - if row == -1: - return - myobj.filter_list_obj.remove(row) - myobj.filter_list_obj.set_data(INDEX,row-1) - myobj.filter_list_obj.unselect_all() - del myobj.filter_list[row] - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -def on_add_clicked(obj): - - myobj = obj.get_data(OBJECT) - - invert = myobj.filterDialog.get_widget("invert").get_active() - qualifier = myobj.filterDialog.get_widget("qualifier").get_text() - menu = myobj.filter_menu.get_menu() - - function = menu.get_active().get_data(FUNCTION) - name = menu.get_active().get_data(NAME) - - myfilter = function(qualifier) - myfilter.set_invert(invert) - - myobj.filter_list.append(myfilter) - - row = myobj.filter_list_obj.get_data(INDEX) - - myobj.filter_list_obj.set_data(INDEX,row+1) - if invert: - invert_text = "yes" - else: - invert_text = "no" - - myobj.filter_list_obj.append([name,qualifier,invert_text]) - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -def on_filter_name_changed(obj): - obj.get_data(FILTER).set_sensitive(obj.get_data(QUALIFIER)) - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -def by_value(first,second): - return cmp(second[0],first[0]) - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -def on_filter_save_clicked(obj): - myobj = obj.get_data(OBJECT) - - for filter in myobj.filter_list: - print "%s(\"%s\"),%d" % (filter,filter.text,filter.invert) - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -def fix(line): - l = string.strip(line) - l = string.replace(l,'&','&') - l = string.replace(l,'>','>') - l = string.replace(l,'<','<') - return string.replace(l,'"','"') + utils.destroy_passed_object(obj) #------------------------------------------------------------------------- # diff --git a/gramps/src/plugins/eventcmp.glade b/gramps/src/plugins/eventcmp.glade index b890f1c97..db0b2fe2c 100644 --- a/gramps/src/plugins/eventcmp.glade +++ b/gramps/src/plugins/eventcmp.glade @@ -85,16 +85,7 @@ filters Tue, 06 Mar 2001 23:40:27 GMT - GNOME_STOCK_BUTTON_CANCEL - GTK_RELIEF_NORMAL - - - - GtkButton - button10 - True - True - GNOME_STOCK_BUTTON_HELP + GNOME_STOCK_BUTTON_CLOSE GTK_RELIEF_NORMAL @@ -371,6 +362,11 @@ button17 True True + + clicked + on_filter_load_clicked + Sun, 28 Oct 2001 21:28:30 GMT + GTK_RELIEF_NORMAL @@ -394,139 +390,10 @@ - - GtkWindow - top - Gramps - Event Comparison - GTK_WINDOW_TOPLEVEL - GTK_WIN_POS_NONE - False - False - True - False - - - GtkTable - temp - 3 - 1 - False - 0 - 0 - - - GtkHButtonBox - hbuttonbox4 - GTK_BUTTONBOX_END - 30 - 85 - 27 - 7 - 0 - - 0 - 1 - 2 - 3 - 0 - 0 - True - False - False - False - True - True - - - - GtkButton - button12 - True - True - - clicked - on_write_table - top - Thu, 15 Mar 2001 20:53:45 GMT - - - GTK_RELIEF_NORMAL - - - - GtkButton - button13 - True - True - - clicked - destroy_passed_object - top - Thu, 08 Mar 2001 16:10:16 GMT - - GNOME_STOCK_BUTTON_CLOSE - GTK_RELIEF_NORMAL - - - - - GtkLabel - label10 - - GTK_JUSTIFY_CENTER - False - 0.5 - 0.5 - 0 - 0 - - 0 - 1 - 0 - 1 - 0 - 0 - False - False - False - False - False - False - - - - - GtkScrolledWindow - addarea - GTK_POLICY_AUTOMATIC - GTK_POLICY_AUTOMATIC - GTK_UPDATE_CONTINUOUS - GTK_UPDATE_CONTINUOUS - - 0 - 1 - 1 - 2 - 0 - 0 - False - True - False - False - True - True - - - - Placeholder - - - - - GnomeDialog dialog1 + Gramps - Save as a Spreadsheet GTK_WINDOW_DIALOG GTK_WIN_POS_NONE False @@ -781,4 +648,294 @@ + + GnomeDialog + view + 350 + Gramps - Event Comparison + GTK_WINDOW_TOPLEVEL + GTK_WIN_POS_NONE + False + False + True + False + False + False + + + GtkVBox + GnomeDialog:vbox + dialog-vbox3 + False + 8 + + 4 + True + True + + + + GtkHButtonBox + GnomeDialog:action_area + dialog-action_area3 + GTK_BUTTONBOX_END + 8 + 85 + 27 + 7 + 0 + + 0 + False + True + GTK_PACK_END + + + + GtkButton + button19 + True + True + + clicked + on_write_table + view + Sun, 28 Oct 2001 15:21:19 GMT + + + GNOME_STOCK_PIXMAP_SAVE_AS + + + + GtkButton + button21 + True + True + + clicked + destroy_passed_object + view + Sun, 28 Oct 2001 15:19:04 GMT + + GNOME_STOCK_BUTTON_CLOSE + + + + + GtkTable + mytable + 2 + 1 + False + 0 + 0 + + 0 + True + True + + + + GtkLabel + label10 + 400 + + GTK_JUSTIFY_CENTER + False + 0.5 + 0.5 + 0 + 0 + + 0 + 1 + 0 + 1 + 0 + 10 + False + False + False + False + True + False + + + + + GtkScrolledWindow + addarea + GTK_POLICY_AUTOMATIC + GTK_POLICY_AUTOMATIC + GTK_UPDATE_CONTINUOUS + GTK_UPDATE_CONTINUOUS + + 0 + 1 + 1 + 2 + 0 + 0 + True + True + False + False + True + True + + + + Placeholder + + + + + + + + GnomeDialog + filter_file + Gramps - Complex Filter + GTK_WINDOW_TOPLEVEL + GTK_WIN_POS_NONE + False + False + True + False + False + False + + + GtkVBox + GnomeDialog:vbox + dialog-vbox4 + False + 8 + + 4 + True + True + + + + GtkHButtonBox + GnomeDialog:action_area + dialog-action_area4 + GTK_BUTTONBOX_END + 8 + 85 + 27 + 7 + 0 + + 0 + False + True + GTK_PACK_END + + + + GtkButton + button22 + True + True + + clicked + on_load_filter + filter_file + Sun, 28 Oct 2001 22:46:35 GMT + + GNOME_STOCK_BUTTON_OK + + + + GtkButton + button24 + True + True + + clicked + destroy_passed_object + filter_file + Sun, 28 Oct 2001 22:46:21 GMT + + GNOME_STOCK_BUTTON_CANCEL + + + + + GtkVBox + vbox6 + False + 0 + + 0 + True + True + + + + GtkLabel + title + + GTK_JUSTIFY_CENTER + False + 0.5 + 0.5 + 0 + 0 + + 5 + False + False + + + + + GtkHSeparator + hseparator2 + + 5 + True + True + + + + + GtkCombo + filter_combo + 350 + False + True + False + True + False + + + 15 + False + False + + + + GtkEntry + GtkCombo:entry + name + True + + insert_text + combo_insert_text + filter_combo + Sun, 28 Oct 2001 21:27:05 GMT + + True + True + 0 + + + + + + + diff --git a/gramps/src/plugins/merge.glade b/gramps/src/plugins/merge.glade index f08e071e4..0761a46f8 100644 --- a/gramps/src/plugins/merge.glade +++ b/gramps/src/plugins/merge.glade @@ -265,7 +265,7 @@ GtkLabel CList:title label57 - + GTK_JUSTIFY_CENTER False 0.5 @@ -278,7 +278,7 @@ GtkLabel CList:title label58 - + GTK_JUSTIFY_CENTER False 0.5