# # Gramps - a GTK+/GNOME based genealogy program # # Copyright (C) 2000-2007 Donald N. Allingham # Copyright (C) 2008 Brian G. Matherly # Copyright (C) 2010 Jakim Friant # Copyright (C) 2010 Nick Hall # # 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$ """Tools/Database Processing/Edit Database Owner Information""" #------------------------------------------------------------------------- # # gnome/gtk # #------------------------------------------------------------------------- import gtk #------------------------------------------------------------------------- # # gramps modules # #------------------------------------------------------------------------- import const import config from Utils import get_researcher import GrampsDisplay from gui.widgets import MonitoredEntry import ManagedWindow from gui.plug import tool from gen.ggettext import sgettext as _ from glade import Glade #------------------------------------------------------------------------- # # Constants # #------------------------------------------------------------------------- WIKI_HELP_PAGE = '%s_-_Tools' % const.URL_MANUAL_PAGE WIKI_HELP_SEC = _('manual|Edit_Database_Owner_Information...') #------------------------------------------------------------------------- # # constants # #------------------------------------------------------------------------- config_keys = ( 'researcher.researcher-name', 'researcher.researcher-addr', 'researcher.researcher-locality', 'researcher.researcher-city', 'researcher.researcher-state', 'researcher.researcher-country', 'researcher.researcher-postal', 'researcher.researcher-phone', 'researcher.researcher-email', ) #------------------------------------------------------------------------- # # OwnerEditor # #------------------------------------------------------------------------- class OwnerEditor(tool.Tool, ManagedWindow.ManagedWindow): """ Allow editing database owner information. Provides a possibility to direcly verify and edit the owner data of the current database. It also allows copying data from/to the preferences. """ def __init__(self, dbstate, uistate, options_class, name, callback=None): ManagedWindow.ManagedWindow.__init__(self, uistate, [], self.__class__) tool.Tool.__init__(self, dbstate, options_class, name) self.display() def display(self): # get the main window from glade topDialog = Glade() # set gramps style title for the window window = topDialog.toplevel self.set_window(window, topDialog.get_object("title"), _("Database Owner Editor")) # move help button to the left side action_area = topDialog.get_object("action_area") help_button = topDialog.get_object("help_button") action_area.set_child_secondary(help_button, True) # connect signals topDialog.connect_signals({ "on_ok_button_clicked": self.on_ok_button_clicked, "on_cancel_button_clicked": self.close, "on_help_button_clicked": self.on_help_button_clicked, "on_eventbox_button_press_event": self.on_button_press_event, "on_menu_activate": self.on_menu_activate, "on_delete_event" : self.close, }) # fetch the popup menu self.menu = topDialog.get_object("popup_menu") #topDialog.connect_signals({"on_menu_activate": self.on_menu_activate}) # get current db owner and attach it to the entries of the window self.owner = self.db.get_researcher() self.entries = [] entry = [ ("name", self.owner.set_name, self.owner.get_name), ("address", self.owner.set_address, self.owner.get_address), ("locality", self.owner.set_locality, self.owner.get_locality), ("city", self.owner.set_city, self.owner.get_city), ("state", self.owner.set_state, self.owner.get_state), ("country", self.owner.set_country, self.owner.get_country), ("zip", self.owner.set_postal_code, self.owner.get_postal_code), ("phone", self.owner.set_phone, self.owner.get_phone), ("email", self.owner.set_email, self.owner.get_email), ] for (name,set_fn,get_fn) in entry: self.entries.append(MonitoredEntry(topDialog.get_object(name), set_fn, get_fn, self.db.readonly)) # ok, let's see what we've done self.show() def on_ok_button_clicked(self, obj): """Update the current db's owner information from editor""" self.db.set_researcher(self.owner) self.close() def on_help_button_clicked(self, obj): """Display the relevant portion of GRAMPS manual""" GrampsDisplay.help(webpage=WIKI_HELP_PAGE, section=WIKI_HELP_SEC) def on_button_press_event(self, obj, event): """Shows popup-menu for db <-> preferences copying""" if event.button == 3 and event.type == gtk.gdk.BUTTON_PRESS: self.menu.popup(None,None,None,0,0) def build_menu_names(self, obj): return (_('Main window'), _("Edit database owner information")) def on_menu_activate(self, menuitem): """Copies the owner information from/to the preferences""" if menuitem.name == 'copy_from_preferences_to_db': self.owner.set_from(get_researcher()) for entry in self.entries: entry.update() elif menuitem.name == 'copy_from_db_to_preferences': for i in range(len(config_keys)): config.set(config_keys[i], self.owner.get()[i]) #------------------------------------------------------------------------- # # OwnerEditorOptions (None at the moment) # #------------------------------------------------------------------------- class OwnerEditorOptions(tool.ToolOptions): """Defines options and provides handling interface.""" def __init__(self, name,person_id=None): tool.ToolOptions.__init__(self, name,person_id)