# Gramps - a GTK+/GNOME based genealogy program # # Copyright (C) 2001-2007 Donald N. Allingham # Copyright (C) 2008 Gary Burton # # 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 # # $Id$ """ Provide the event view. """ #------------------------------------------------------------------------- # # Standard python modules # #------------------------------------------------------------------------- from gettext import gettext as _ import logging _LOG = logging.getLogger(".plugins.eventview") #------------------------------------------------------------------------- # # GTK/Gnome modules # #------------------------------------------------------------------------- import gtk #------------------------------------------------------------------------- # # gramps modules # #------------------------------------------------------------------------- import gen.lib from gui.views.navigationview import NAVIGATION_EVENT from gui.views.listview import ListView from gui.views.treemodels import EventModel import Utils import Errors import Bookmarks import config from DdTargets import DdTargets from gui.editors import EditEvent, DeleteEventQuery from Filters.SideBar import EventSidebarFilter from gen.plug import CATEGORY_QR_EVENT #------------------------------------------------------------------------- # # EventView # #------------------------------------------------------------------------- class EventView(ListView): """ EventView class, derived from the ListView """ COLUMN_NAMES = [ _('Description'), _('ID'), _('Type'), _('Date'), _('Place'), _('Last Changed'), _('Main Participants'), ] ADD_MSG = _("Add a new event") EDIT_MSG = _("Edit the selected event") DEL_MSG = _("Delete the selected event") FILTER_TYPE = "Event" QR_CATEGORY = CATEGORY_QR_EVENT def __init__(self, dbstate, uistate): """ Create the Event View """ signal_map = { 'event-add' : self.row_add, 'event-update' : self.row_update, 'event-delete' : self.row_delete, 'event-rebuild' : self.object_build, } ListView.__init__( self, _('Events'), dbstate, uistate, EventView.COLUMN_NAMES, len(EventView.COLUMN_NAMES), EventModel, signal_map, dbstate.db.get_event_bookmarks(), Bookmarks.EventBookmarks, multiple=True, filter_class=EventSidebarFilter) self.func_list = { 'J' : self.jump, 'BackSpace' : self.key_delete, } config.connect("interface.filter", self.filter_toggle) def navigation_type(self): return NAVIGATION_EVENT def column_ord_setfunc(self, clist): self.dbstate.db.set_event_column_order(clist) def get_bookmarks(self): """ Return the bookmark object """ return self.dbstate.db.get_event_bookmarks() def drag_info(self): """ Indicate that the drag type is an EVENT """ return DdTargets.EVENT def column_order(self): """ returns a tuple indicating the column order """ return self.dbstate.db.get_event_column_order() def get_stock(self): """ Use the gramps-event stock icon """ return 'gramps-event' def ui_definition(self): """ Defines the UI string for UIManager """ return ''' ''' def define_actions(self): ListView.define_actions(self) self._add_action('FilterEdit', None, _('Event Filter Editor'), callback=self.filter_editor,) self._add_action('ColumnEdit', gtk.STOCK_PROPERTIES, _('_Column Editor'), callback=self._column_editor,) self._add_action('QuickReport', None, _("Quick View"), None, None, None) self._add_action('Dummy', None, ' ', None, None, self.dummy_report) def get_handle_from_gramps_id(self, gid): obj = self.dbstate.db.get_event_from_gramps_id(gid) if obj: return obj.get_handle() else: return None def _column_editor(self, obj): """ returns a tuple indicating the column order """ import ColumnOrder ColumnOrder.ColumnOrder( _('Select Event Columns'), self.uistate, self.dbstate.db.get_event_column_order(), EventView.COLUMN_NAMES, self.set_column_order) def add(self, obj): try: EditEvent(self.dbstate, self.uistate, [], gen.lib.Event()) except Errors.WindowActiveError: pass def remove(self, obj): self.remove_selected_objects() def remove_object_from_handle(self, handle): person_list = [ item[1] for item in self.dbstate.db.find_backlink_handles(handle,['Person']) ] family_list = [ item[1] for item in self.dbstate.db.find_backlink_handles(handle,['Family']) ] object = self.dbstate.db.get_event_from_handle(handle) query = DeleteEventQuery(self.dbstate, self.uistate, object, person_list, family_list) is_used = len(person_list) + len(family_list) > 0 return (query, is_used, object) def edit(self, obj): for handle in self.selected_handles(): event = self.dbstate.db.get_event_from_handle(handle) try: EditEvent(self.dbstate, self.uistate, [], event) except Errors.WindowActiveError: pass def dummy_report(self, obj): """ For the xml UI definition of popup to work, the submenu Quick Report must have an entry in the xml As this submenu will be dynamically built, we offer a dummy action """ pass