diff --git a/gramps2/src/Plugins.py b/gramps2/src/Plugins.py
index 1038cbb6e..b3ef8da5b 100644
--- a/gramps2/src/Plugins.py
+++ b/gramps2/src/Plugins.py
@@ -116,21 +116,26 @@ class PluginDialog:
"""Displays the dialog box that allows the user to select the
report that is desired."""
- def __init__(self,db,active,list,msg,label=None,button_label=None,tool_tip=None):
+ def __init__(self,parent,db,active,list,msg,label=None,button_label=None,tool_tip=None):
"""Display the dialog box, and build up the list of available
reports. This is used to build the selection tree on the left
hand side of the dailog box."""
+ self.parent = parent
+ if self.parent.child_windows.has_key(msg):
+ self.parent.child_windows[msg].present(None)
+ return
self.db = db
self.active = active
self.update = None
self.imap = {}
+ self.msg = msg
self.dialog = gtk.glade.XML(const.pluginsFile,"report","gramps")
self.dialog.signal_autoconnect({
"on_report_apply_clicked" : self.on_apply_clicked,
- "on_report_ok_clicked" : self.on_ok_clicked,
- "destroy_passed_object" : Utils.destroy_passed_object
+ "destroy_passed_object" : self.close,
+ "on_delete_event" : self.on_delete_event,
})
self.tree = self.dialog.get_widget("tree")
@@ -174,6 +179,29 @@ class PluginDialog:
self.run_tool = None
self.build_tree(list)
+ self.add_itself_to_menu()
+ self.top.show()
+
+ def on_delete_event(self,obj,b):
+ self.remove_itself_from_menu()
+
+ def close(self,ok=0):
+ self.remove_itself_from_menu()
+ self.top.destroy()
+
+ def add_itself_to_menu(self):
+ self.parent.child_windows[self.msg] = self
+ self.win_menu_item = gtk.MenuItem(self.msg)
+ self.win_menu_item.connect("activate",self.present)
+ self.win_menu_item.show()
+ self.parent.winsmenu.append(self.win_menu_item)
+
+ def remove_itself_from_menu(self):
+ del self.parent.child_windows[self.msg]
+ self.win_menu_item.destroy()
+
+ def present(self,obj):
+ self.top.present()
def on_apply_clicked(self,obj):
"""Execute the selected report"""
@@ -184,12 +212,6 @@ class PluginDialog:
else:
self.run_tool(self.db,self.active)
- def on_ok_clicked(self,obj):
- """Execute the selected report and close the dialog window"""
-
- Utils.destroy_passed_object(obj)
- self.on_apply_clicked(obj)
-
def on_node_selected(self,obj):
"""Updates the informational display on the right hand side of
the dialog box with the description of the selected report"""
@@ -271,11 +293,11 @@ class ReportPlugins(PluginDialog):
"""Displays the dialog box that allows the user to select the
report that is desired."""
- def __init__(self,db,active):
+ def __init__(self,parent,db,active):
"""Display the dialog box, and build up the list of available
reports. This is used to build the selection tree on the left
hand side of the dailog box."""
- PluginDialog.__init__(self,db,active,_reports,_("Report Selection"),
+ PluginDialog.__init__(self,parent,db,active,_reports,_("Report Selection"),
_("Select a report from those available on the left."),
_("_Generate"), _("Generate selected report"))
@@ -288,12 +310,12 @@ class ToolPlugins(PluginDialog):
"""Displays the dialog box that allows the user to select the tool
that is desired."""
- def __init__(self,db,active,update):
+ def __init__(self,parent,db,active,update):
"""Display the dialog box, and build up the list of available
reports. This is used to build the selection tree on the left
hand side of the dailog box."""
- PluginDialog.__init__(self,db,active,_tools,_("Tool Selection"),
+ PluginDialog.__init__(self,parent,db,active,_tools,_("Tool Selection"),
_("Select a tool from those available on the left."),
_("_Run"), _("Run selected tool"))
self.update = update
diff --git a/gramps2/src/gramps_main.py b/gramps2/src/gramps_main.py
index ee4d65c9c..16e567b53 100755
--- a/gramps2/src/gramps_main.py
+++ b/gramps2/src/gramps_main.py
@@ -961,12 +961,12 @@ class Gramps:
def on_tools_clicked(self,obj):
if self.active_person:
- Plugins.ToolPlugins(self.db,self.active_person,
+ Plugins.ToolPlugins(self,self.db,self.active_person,
self.tool_callback)
def on_reports_clicked(self,obj):
if self.active_person:
- Plugins.ReportPlugins(self.db,self.active_person)
+ Plugins.ReportPlugins(self,self.db,self.active_person)
def on_ok_button1_clicked(self,obj):
diff --git a/gramps2/src/plugins.glade b/gramps2/src/plugins.glade
index 2515bc5f1..48144d79b 100644
--- a/gramps2/src/plugins.glade
+++ b/gramps2/src/plugins.glade
@@ -97,6 +97,7 @@
True
False
gramps.png
+