From 4a69d45fe607b5a16c2921829f10283db3e067cc Mon Sep 17 00:00:00 2001 From: Tim G L Lyons Date: Tue, 15 Nov 2011 12:08:43 +0000 Subject: [PATCH] Upgraded Source and Citation reference Quick Views to work with citations (actually, for citationtreeview, this is a source_or_citation reference, to avoid having to change the way listview calls the pop up menu items). Also minimal changes to SimpleAccess and SimpleTable to support these references views. svn: r18447 --- src/QuickReports.py | 20 +++++++++++++++++--- src/Simple/_SimpleAccess.py | 16 ++++++++++++++++ src/Simple/_SimpleTable.py | 4 ++++ src/gen/plug/__init__.py | 2 ++ src/gen/plug/_pluginreg.py | 4 ++++ src/plugins/gramplet/QuickViewGramplet.py | 7 ++++++- src/plugins/quickview/References.py | 5 +++++ src/plugins/quickview/quickview.gpr.py | 3 +++ src/plugins/view/citationlistview.py | 4 ++-- src/plugins/view/citationtreeview.py | 4 ++-- 10 files changed, 61 insertions(+), 8 deletions(-) diff --git a/src/QuickReports.py b/src/QuickReports.py index 20ce14dea..622396f26 100644 --- a/src/QuickReports.py +++ b/src/QuickReports.py @@ -57,7 +57,8 @@ from gui.pluginmanager import GuiPluginManager from gen.plug import (CATEGORY_QR_PERSON, CATEGORY_QR_FAMILY, CATEGORY_QR_MEDIA, CATEGORY_QR_EVENT, CATEGORY_QR_SOURCE, CATEGORY_QR_MISC, CATEGORY_QR_PLACE, CATEGORY_QR_REPOSITORY, - CATEGORY_QR_NOTE) + CATEGORY_QR_NOTE, CATEGORY_QR_CITATION, + CATEGORY_QR_SOURCE_OR_CITATION) def flatten(L): """ @@ -119,7 +120,8 @@ def create_quickreport_menu(category,dbstate,uistate, handle) : It collects the reports of the requested category, which must be one of CATEGORY_QR_PERSON, CATEGORY_QR_FAMILY, CATEGORY_QR_EVENT, CATEGORY_QR_SOURCE, CATEGORY_QR_MEDIA, - CATEGORY_QR_PLACE, CATEGORY_QR_REPOSITORY + CATEGORY_QR_PLACE, CATEGORY_QR_REPOSITORY, + CATEGORY_QR_CITATION, CATEGORY_QR_SOURCE_OR_CITATION It constructs the ui string of the quick report menu, and it's actions The action callback function is constructed, using the dbstate and the handle as input method. @@ -166,7 +168,8 @@ def get_quick_report_list(qv_category=None): Returns a list of PluginData of quick views of category qv_category CATEGORY_QR_PERSON, CATEGORY_QR_FAMILY, CATEGORY_QR_EVENT, CATEGORY_QR_SOURCE, CATEGORY_QR_MISC, CATEGORY_QR_PLACE, - CATEGORY_QR_REPOSITORY, CATEGORY_QR_MEDIA or None for all + CATEGORY_QR_REPOSITORY, CATEGORY_QR_MEDIA, + CATEGORY_QR_CITATION, CATEGORY_QR_SOURCE_OR_CITATION or None for all """ names = [] pmgr = GuiPluginManager.get_instance() @@ -254,6 +257,17 @@ def run_report(dbstate, uistate, category, handle, pdata, container=None, obj = dbstate.db.get_event_from_handle(handle) elif category == CATEGORY_QR_SOURCE : obj = dbstate.db.get_source_from_handle(handle) + elif category == CATEGORY_QR_CITATION : + obj = dbstate.db.get_citation_from_handle(handle) + elif category == CATEGORY_QR_SOURCE_OR_CITATION : + source = dbstate.db.get_source_from_handle(handle) + citation = dbstate.db.get_citation_from_handle(handle) + if (not source and not citation) or (source and citation): + raise ValueError("selection must be either source or citation") + if citation: + obj = citation + else: + obj = source elif category == CATEGORY_QR_PLACE : obj = dbstate.db.get_place_from_handle(handle) elif category == CATEGORY_QR_MEDIA : diff --git a/src/Simple/_SimpleAccess.py b/src/Simple/_SimpleAccess.py index 07a866b60..9fccc8fed 100644 --- a/src/Simple/_SimpleAccess.py +++ b/src/Simple/_SimpleAccess.py @@ -849,6 +849,20 @@ class SimpleAccess(object): return source.get_title() return u'' + def page(self, citation): + """ + Return the page of the citation. + + @param citation: Source object + @type citation: L{gen.lib.Citation} + @return: title of the citation + @rtype: unicode + """ + assert(isinstance(citation, (gen.lib.Citation, NoneType))) + if citation: + return citation.get_page() + return u'' + def author(self, source): """ Return the author of the source. @@ -952,6 +966,8 @@ class SimpleAccess(object): return obj.desc elif isinstance(obj, gen.lib.Source): return self.title(obj) + elif isinstance(obj, gen.lib.Citation): + return self.page(obj) elif isinstance(obj, gen.lib.Place): return place_name(self.dbase, obj.handle) elif isinstance(obj, gen.lib.Repository): diff --git a/src/Simple/_SimpleTable.py b/src/Simple/_SimpleTable.py index 68a96fc3d..aeb744223 100644 --- a/src/Simple/_SimpleTable.py +++ b/src/Simple/_SimpleTable.py @@ -352,6 +352,10 @@ class SimpleTable(object): retval.append(self.access.describe(item)) if (self.__link_col == col or link is None): link = ('Source', item.handle) + elif isinstance(item, gen.lib.Citation): + retval.append(self.access.describe(item)) + if (self.__link_col == col or link is None): + link = ('Citation', item.handle) elif isinstance(item, gen.lib.Event): retval.append(self.access.describe(item)) if (self.__link_col == col or link is None): diff --git a/src/gen/plug/__init__.py b/src/gen/plug/__init__.py index 4fcce9acb..785dc4c3e 100644 --- a/src/gen/plug/__init__.py +++ b/src/gen/plug/__init__.py @@ -33,6 +33,7 @@ from _pluginreg import (PluginData, PluginRegister, REPORT, TOOL, CATEGORY_QR_FAMILY, CATEGORY_QR_EVENT, CATEGORY_QR_SOURCE, CATEGORY_QR_PLACE, CATEGORY_QR_REPOSITORY, CATEGORY_QR_NOTE, CATEGORY_QR_DATE, PTYPE_STR, CATEGORY_QR_MEDIA, + CATEGORY_QR_CITATION, CATEGORY_QR_SOURCE_OR_CITATION, START, END, make_environment, ) from _manager import BasePluginManager @@ -54,4 +55,5 @@ __all__ = [ "docbackend", "docgen", "menu", Plugin, PluginData, CATEGORY_QR_FAMILY, CATEGORY_QR_EVENT, CATEGORY_QR_SOURCE, CATEGORY_QR_PLACE, CATEGORY_QR_REPOSITORY, CATEGORY_QR_NOTE, CATEGORY_QR_DATE, PTYPE_STR, CATEGORY_QR_MEDIA, + CATEGORY_QR_CITATION, CATEGORY_QR_SOURCE_OR_CITATION, START, END, make_environment] diff --git a/src/gen/plug/_pluginreg.py b/src/gen/plug/_pluginreg.py index 9f6472a9f..a53de80ee 100644 --- a/src/gen/plug/_pluginreg.py +++ b/src/gen/plug/_pluginreg.py @@ -116,6 +116,8 @@ CATEGORY_QR_REPOSITORY = 5 CATEGORY_QR_NOTE = 6 CATEGORY_QR_DATE = 7 CATEGORY_QR_MEDIA = 8 +CATEGORY_QR_CITATION = 9 +CATEGORY_QR_SOURCE_OR_CITATION = 10 # Modes for generating reports REPORT_MODE_GUI = 1 # Standalone report using GUI @@ -1009,6 +1011,8 @@ def make_environment(**kwargs): 'CATEGORY_QR_FAMILY': CATEGORY_QR_FAMILY, 'CATEGORY_QR_EVENT': CATEGORY_QR_EVENT, 'CATEGORY_QR_SOURCE': CATEGORY_QR_SOURCE, + 'CATEGORY_QR_CITATION': CATEGORY_QR_CITATION, + 'CATEGORY_QR_SOURCE_OR_CITATION': CATEGORY_QR_SOURCE_OR_CITATION, 'CATEGORY_QR_PLACE': CATEGORY_QR_PLACE, 'CATEGORY_QR_MEDIA': CATEGORY_QR_MEDIA, 'CATEGORY_QR_REPOSITORY': CATEGORY_QR_REPOSITORY, diff --git a/src/plugins/gramplet/QuickViewGramplet.py b/src/plugins/gramplet/QuickViewGramplet.py index a4ea56522..6187d771b 100644 --- a/src/plugins/gramplet/QuickViewGramplet.py +++ b/src/plugins/gramplet/QuickViewGramplet.py @@ -36,7 +36,8 @@ from QuickReports import run_quick_report_by_name, get_quick_report_list from gen.plug import (CATEGORY_QR_PERSON, CATEGORY_QR_FAMILY, CATEGORY_QR_EVENT, CATEGORY_QR_SOURCE, CATEGORY_QR_NOTE, CATEGORY_QR_MISC, CATEGORY_QR_PLACE, CATEGORY_QR_MEDIA, - CATEGORY_QR_REPOSITORY) + CATEGORY_QR_REPOSITORY, CATEGORY_QR_CITATION, + CATEGORY_QR_SOURCE_OR_CITATION) #------------------------------------------------------------------------ # @@ -52,6 +53,7 @@ class QuickViewGramplet(Gramplet): self.connect_signal('Event', self._active_changed) self.connect_signal('Place', self._active_changed) self.connect_signal('Source', self._active_changed) + self.connect_signal('Citation', self._active_changed) self.connect_signal('Repository', self._active_changed) self.connect_signal('Media', self._active_changed) self.connect_signal('Note', self._active_changed) @@ -108,6 +110,7 @@ class QuickViewGramplet(Gramplet): ("Place", _("Place")), ("Repository", _("Repository")), ("Source", _("Source")), + ("Citation", _("Citation")), ]: type_list.add_item(item[0], item[1]) # Add particular lists: @@ -129,6 +132,8 @@ class QuickViewGramplet(Gramplet): "Family": CATEGORY_QR_FAMILY, "Event": CATEGORY_QR_EVENT, "Source": CATEGORY_QR_SOURCE, + "Citation": CATEGORY_QR_CITATION, + "Source or Citation": CATEGORY_QR_SOURCE_OR_CITATION, "Place": CATEGORY_QR_PLACE, "Media": CATEGORY_QR_MEDIA, "Note": CATEGORY_QR_NOTE, diff --git a/src/plugins/quickview/References.py b/src/plugins/quickview/References.py index fbdf6d362..33fce1287 100644 --- a/src/plugins/quickview/References.py +++ b/src/plugins/quickview/References.py @@ -41,6 +41,8 @@ def get_ref(db, objclass, handle): ref = db.get_event_from_handle(handle) elif objclass == 'Source': ref = db.get_source_from_handle(handle) + elif objclass == 'Citation': + ref = db.get_citation_from_handle(handle) elif objclass == 'Place': ref = db.get_place_from_handle(handle) elif objclass == 'Note': @@ -83,6 +85,9 @@ run_person = lambda db, doc, obj: run(db, doc, obj, 'person', _("Person")) run_family = lambda db, doc, obj: run(db, doc, obj, 'family', _("Family")) run_event = lambda db, doc, obj: run(db, doc, obj, 'event', _("Event")) run_source = lambda db, doc, obj: run(db, doc, obj, 'source', _("Source")) +run_citation = lambda db, doc, obj: run(db, doc, obj, 'citation', _("Citation")) +run_source_or_citation = lambda db, doc, obj: run(db, doc, obj, + 'source or citation', _("Source or Citation")) run_place = lambda db, doc, obj: run(db, doc, obj, 'place', _("Place")) run_media = lambda db, doc, obj: run(db, doc, obj, 'media', _("Media")) run_note = lambda db, doc, obj: run(db, doc, obj, 'note', _("Note")) diff --git a/src/plugins/quickview/quickview.gpr.py b/src/plugins/quickview/quickview.gpr.py index c29355f67..c5bdbfe52 100644 --- a/src/plugins/quickview/quickview.gpr.py +++ b/src/plugins/quickview/quickview.gpr.py @@ -202,6 +202,9 @@ refitems = [(CATEGORY_QR_PERSON, 'person', _("Person")), (CATEGORY_QR_PLACE, 'place', _("Place")), (CATEGORY_QR_MEDIA, 'media', _("Media")), (CATEGORY_QR_NOTE, 'note', _("Note")), + (CATEGORY_QR_CITATION, 'citation', _("Citation")), + (CATEGORY_QR_SOURCE_OR_CITATION, 'source or citation', + _("Source or Citation")) ] for (category, item, trans) in refitems: diff --git a/src/plugins/view/citationlistview.py b/src/plugins/view/citationlistview.py index bf4e9b95c..ce4ddbc60 100644 --- a/src/plugins/view/citationlistview.py +++ b/src/plugins/view/citationlistview.py @@ -46,7 +46,7 @@ import gtk # #------------------------------------------------------------------------- from gui.views.treemodels.citationlistmodel import CitationListModel -from gen.plug import CATEGORY_QR_SOURCE +from gen.plug import CATEGORY_QR_CITATION import gen.lib from gui.views.listview import ListView import Utils @@ -120,7 +120,7 @@ class CitationListView(ListView): DEL_MSG = _("Delete the selected citation") MERGE_MSG = _("Merge the selected citations") FILTER_TYPE = "Citation" - QR_CATEGORY = CATEGORY_QR_SOURCE + QR_CATEGORY = CATEGORY_QR_CITATION def __init__(self, pdata, dbstate, uistate, nav_group=0): diff --git a/src/plugins/view/citationtreeview.py b/src/plugins/view/citationtreeview.py index 3160a002d..d5203e82b 100644 --- a/src/plugins/view/citationtreeview.py +++ b/src/plugins/view/citationtreeview.py @@ -47,7 +47,7 @@ import gtk #------------------------------------------------------------------------- from gui.views.listview import LISTTREE from gui.views.treemodels.citationtreemodel import CitationTreeModel -from gen.plug import CATEGORY_QR_SOURCE +from gen.plug import CATEGORY_QR_SOURCE_OR_CITATION import gen.lib from gui.views.listview import ListView import Utils @@ -112,7 +112,7 @@ class CitationTreeView(ListView): DEL_MSG = _("Delete the selected citation or source") MERGE_MSG = _("Merge the selected citations or selected sources") FILTER_TYPE = "Citation" - QR_CATEGORY = CATEGORY_QR_SOURCE + QR_CATEGORY = CATEGORY_QR_SOURCE_OR_CITATION def __init__(self, pdata, dbstate, uistate, nav_group=0):