gramps/src/Editors/_EditEventRef.py

284 lines
9.5 KiB
Python
Raw Normal View History

2006-02-22 01:27:49 +00:00
#
# Gramps - a GTK+/GNOME based genealogy program
#
# Copyright (C) 2000-2006 Donald N. Allingham
#
# 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$
#-------------------------------------------------------------------------
#
# Python modules
#
#-------------------------------------------------------------------------
from TransUtils import sgettext as _
2006-02-22 01:27:49 +00:00
try:
set()
except:
from sets import Set as set
#-------------------------------------------------------------------------
#
# GTK/Gnome modules
#
#-------------------------------------------------------------------------
import gtk
import gtk.glade
#-------------------------------------------------------------------------
#
# gramps modules
#
#-------------------------------------------------------------------------
import const
import Utils
import RelLib
import DisplayState
from DisplayTabs import *
from GrampsWidgets import *
2006-03-04 22:53:46 +00:00
from _EditReference import EditReference
2006-02-22 01:27:49 +00:00
#-------------------------------------------------------------------------
#
# Constants
#
#-------------------------------------------------------------------------
total_events = dict(Utils.personal_events)
for event_type in Utils.family_events.keys():
if not total_events.has_key(event_type):
total_events[event_type] = Utils.family_events[event_type]
#-------------------------------------------------------------------------
#
# EditEventRef class
#
#-------------------------------------------------------------------------
2006-03-04 22:53:46 +00:00
class EditEventRef(EditReference):
def __init__(self, state, uistate, track, event, event_ref, update):
2006-03-04 22:53:46 +00:00
EditReference.__init__(self, state, uistate, track, event, event_ref,
update)
self._init_event()
2006-02-22 01:27:49 +00:00
2006-03-04 22:53:46 +00:00
def _local_init(self):
2006-02-22 01:27:49 +00:00
self.top = gtk.glade.XML(const.gladeFile, "event_eref_edit","gramps")
2006-03-04 22:53:46 +00:00
self.define_top_level(self.top.get_widget('event_eref_edit'),
self.top.get_widget('eer_title'),
_('Event Reference Editor'))
self.define_warn_box(self.top.get_widget("eer_warning"))
self.define_expander(self.top.get_widget("eer_expander"))
def _init_event(self):
self.commit_event = self.db.commit_personal_event
self.add_event = self.db.add_person_event
def get_roles(self):
return Utils.event_roles
def get_event_types(self):
return Utils.personal_events
def get_custom_events(self):
return [ (RelLib.Event.CUSTOM,val) for val in self.dbstate.db.get_person_event_types()]
2006-02-22 01:27:49 +00:00
2006-03-04 22:53:46 +00:00
def _connect_signals(self):
self.define_ok_button(self.top.get_widget('ok'),self.ok_clicked)
self.define_cancel_button(self.top.get_widget('cancel'))
2006-02-22 01:27:49 +00:00
2006-03-04 22:53:46 +00:00
def _setup_fields(self):
self.cause_monitor = MonitoredEntry(
self.top.get_widget("eer_cause"),
2006-03-04 22:53:46 +00:00
self.source.set_cause,
self.source.get_cause,
self.db.readonly)
self.ref_privacy = PrivacyButton(
self.top.get_widget('eer_ref_priv'),
2006-03-04 22:53:46 +00:00
self.source_ref)
self.descr_field = MonitoredEntry(
self.top.get_widget("eer_description"),
2006-03-04 22:53:46 +00:00
self.source.set_description,
self.source.get_description,
self.db.readonly)
self.place_field = PlaceEntry(
self.top.get_widget("eer_place"),
2006-03-04 22:53:46 +00:00
self.source.get_place_handle(),
self.dbstate.get_place_completion(),
self.db.readonly)
self.ev_privacy = PrivacyButton(
self.top.get_widget("eer_ev_priv"),
2006-03-04 22:53:46 +00:00
self.source)
self.role_selector = MonitoredType(
self.top.get_widget('eer_role_combo'),
2006-03-04 22:53:46 +00:00
self.source_ref.set_role,
self.source_ref.get_role,
self.get_roles(),
RelLib.EventRef.CUSTOM)
self.event_menu = MonitoredType(
self.top.get_widget("eer_type_combo"),
2006-03-04 22:53:46 +00:00
self.source.set_type,
self.source.get_type,
self.get_event_types(),
RelLib.Event.CUSTOM,
custom_values=self.get_custom_events())
* src/AddrEdit.py: remove already_exist check in favor of exception * src/AttrEdit.py: remove already_exist check in favor of exception * src/DisplayState.py: remove already_exist variable * src/DisplayTabs.py: handle exception * src/EditEventRef.py: remove already_exist check in favor of exception * src/EditFamily.py: update to derive from EditPrimary * src/EditMedia.py: update to derive from EditPrimary * src/EditMediaRef.py: remove already_exist check in favor of exception * src/EditPerson.py: update to derive from EditPrimary * src/EditPlace.py: update to derive from EditPrimary * src/EditRepository.py:update to derive from EditPrimary * src/EditSource.py: update to derive from EditPrimary * src/EditSourceRef.py: remove already_exist check in favor of exception * src/Errors.py: new exception * src/EventEdit.py: update to derive from EditPrimary * src/EventView.py: catch exception of window already exists * src/FamilyList.py: catch exception of window already exists * src/FamilyView.py: catch exception of window already exists * src/GrampsWidgets.py: typos * src/NameEdit.py: remove already_exist check in favor of exception * src/PedView.py: catch exception of window already exists * src/PersonView.py: catch exception of window already exists * src/PlaceView.py: catch exception of window already exists * src/Plugins.py: catch exception of window already exists * src/UrlEdit.py: remove already_exist check in favor of exception * src/const.py.in: dynamically determine path * src/gramps.glade: name changes * src/gramps.py: set path svn: r6014
2006-03-01 05:08:11 +00:00
self.date_check = MonitoredDate(
self.top.get_widget("eer_date"),
self.top.get_widget("eer_date_stat"),
2006-03-04 22:53:46 +00:00
self.source.get_date_object(),
* src/AddrEdit.py: remove already_exist check in favor of exception * src/AttrEdit.py: remove already_exist check in favor of exception * src/DisplayState.py: remove already_exist variable * src/DisplayTabs.py: handle exception * src/EditEventRef.py: remove already_exist check in favor of exception * src/EditFamily.py: update to derive from EditPrimary * src/EditMedia.py: update to derive from EditPrimary * src/EditMediaRef.py: remove already_exist check in favor of exception * src/EditPerson.py: update to derive from EditPrimary * src/EditPlace.py: update to derive from EditPrimary * src/EditRepository.py:update to derive from EditPrimary * src/EditSource.py: update to derive from EditPrimary * src/EditSourceRef.py: remove already_exist check in favor of exception * src/Errors.py: new exception * src/EventEdit.py: update to derive from EditPrimary * src/EventView.py: catch exception of window already exists * src/FamilyList.py: catch exception of window already exists * src/FamilyView.py: catch exception of window already exists * src/GrampsWidgets.py: typos * src/NameEdit.py: remove already_exist check in favor of exception * src/PedView.py: catch exception of window already exists * src/PersonView.py: catch exception of window already exists * src/PlaceView.py: catch exception of window already exists * src/Plugins.py: catch exception of window already exists * src/UrlEdit.py: remove already_exist check in favor of exception * src/const.py.in: dynamically determine path * src/gramps.glade: name changes * src/gramps.py: set path svn: r6014
2006-03-01 05:08:11 +00:00
self.window,
self.db.readonly)
2006-02-22 01:27:49 +00:00
def _create_tabbed_pages(self):
"""
Creates the notebook tabs and inserts them into the main
window.
"""
2006-03-04 22:53:46 +00:00
notebook = self.top.get_widget('notebook')
notebook_ref = self.top.get_widget('notebook_ref')
self.srcref_list = self._add_tab(
notebook,
SourceEmbedList(self.dbstate,self.uistate, self.track,
self.source.source_list))
self.note_tab = self._add_tab(
notebook,
NoteTab(self.dbstate, self.uistate, self.track,
self.source.get_note_object()))
self.note_ref_tab = self._add_tab(
notebook_ref,
NoteTab(self.dbstate, self.uistate, self.track,
self.source_ref.get_note_object()))
self.gallery_tab = self._add_tab(
notebook,
GalleryTab(self.dbstate, self.uistate, self.track,
self.source.get_media_list()))
self.backref_tab = self._add_tab(
notebook,
EventBackRefList(self.dbstate, self.uistate, self.track,
self.db.find_backlink_handles(self.source.handle)))
2006-02-22 01:27:49 +00:00
def build_menu_names(self,eventref):
2006-03-04 22:53:46 +00:00
if self.source:
if self.source.get_type()[0] == RelLib.Event.CUSTOM:
event_name = self.source.get_type()[1]
2006-02-22 01:27:49 +00:00
else:
try:
2006-03-04 22:53:46 +00:00
event_name = Utils.personal_events[self.source.get_type()[0]]
2006-02-22 01:27:49 +00:00
except:
2006-03-04 22:53:46 +00:00
event_name = Utils.family_events[self.source.get_type()[0]]
2006-02-22 01:27:49 +00:00
submenu_label = _('Event: %s') % event_name
else:
submenu_label = _('New Event')
return (_('Event Reference Editor'),submenu_label)
def ok_clicked(self,obj):
(need_new, handle) = self.place_field.get_place_info()
if need_new:
place_obj = RelLib.Place()
2006-03-10 02:46:19 +00:00
place_obj.set_handle(Utils.create_id())
place_obj.set_title(handle)
2006-03-04 22:53:46 +00:00
self.source.set_place_handle(place_obj.get_handle())
else:
2006-03-04 22:53:46 +00:00
self.source.set_place_handle(handle)
2006-02-22 01:27:49 +00:00
trans = self.db.transaction_begin()
2006-03-04 22:53:46 +00:00
if self.source.handle:
if need_new:
self.db.add_place(place_obj,trans)
self.commit_event(self.source,trans)
2006-03-04 22:53:46 +00:00
self.db.transaction_commit(trans,_("Modify Event"))
2006-02-22 01:27:49 +00:00
else:
if need_new:
self.db.add_place(place_obj,trans)
self.add_event(self.source,trans)
2006-03-04 22:53:46 +00:00
self.db.transaction_commit(trans,_("Add Event"))
self.source_ref.ref = self.source.handle
2006-02-22 01:27:49 +00:00
if self.update:
2006-03-04 22:53:46 +00:00
self.update(self.source_ref,self.source)
self.close_window(None)
2006-02-22 01:27:49 +00:00
class EditFamilyEventRef(EditEventRef):
def __init__(self, state, uistate, track, event, event_ref, update):
EditEventRef.__init__(self, state, uistate, track, event,
event_ref, update)
def _init_event(self):
self.commit_event = self.db.commit_family_event
self.add_event = self.db.add_family_event
def get_roles(self):
return Utils.event_roles
def get_event_types(self):
return Utils.family_events
def get_custom_events(self):
return [ (RelLib.Event.CUSTOM,val) for val in self.dbstate.db.get_family_event_types()]
2006-02-22 01:27:49 +00:00
#-------------------------------------------------------------------------
#
# Delete Query class
#
#-------------------------------------------------------------------------
class DelEventQuery:
def __init__(self,event,db,person_list,family_list):
self.event = event
self.db = db
self.person_list = person_list
self.family_list = family_list
def query_response(self):
trans = self.db.transaction_begin()
self.db.disable_signals()
ev_handle_list = [self.event.get_handle()]
for handle in self.person_list:
person = self.db.get_person_from_handle(handle)
person.remove_handle_references('Event',ev_handle_list)
self.db.commit_person(person,trans)
for handle in self.family_list:
family = self.db.get_family_from_handle(handle)
family.remove_handle_references('Event',ev_handle_list)
self.db.commit_family(family,trans)
self.db.enable_signals()
self.db.remove_event(self.event.get_handle(),trans)
self.db.transaction_commit(
trans,_("Delete Event (%s)") % self.event.get_gramps_id())