gramps/gramps2/src/Editors/_EditEventRef.py

255 lines
8.6 KiB
Python
Raw Normal View History

2006-02-22 06:57:49 +05:30
#
# 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 gettext import gettext as _
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-05 04:23:46 +05:30
from _EditReference import EditReference
2006-02-22 06:57:49 +05:30
#-------------------------------------------------------------------------
#
# 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-05 04:23:46 +05:30
class EditEventRef(EditReference):
def __init__(self, state, uistate, track, event, event_ref, referent, update):
2006-02-22 06:57:49 +05:30
self.referent = referent
2006-03-05 04:23:46 +05:30
EditReference.__init__(self, state, uistate, track, event, event_ref,
update)
2006-02-22 06:57:49 +05:30
2006-03-05 04:23:46 +05:30
def _local_init(self):
2006-02-22 06:57:49 +05:30
self.top = gtk.glade.XML(const.gladeFile, "event_eref_edit","gramps")
2006-03-05 04:23:46 +05:30
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"))
2006-02-22 06:57:49 +05:30
if self.referent.__class__.__name__ == 'Person':
2006-03-05 04:23:46 +05:30
self.role_dict = Utils.event_roles
2006-02-22 06:57:49 +05:30
elif self.referent.__class__.__name__ == 'Family':
2006-03-05 04:23:46 +05:30
self.role_dict = Utils.family_event_roles
2006-02-22 06:57:49 +05:30
2006-03-05 04:23:46 +05:30
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 06:57:49 +05:30
2006-03-05 04:23:46 +05:30
def _setup_fields(self):
self.cause_monitor = MonitoredEntry(
self.top.get_widget("eer_cause"),
2006-03-05 04:23:46 +05:30
self.source.set_cause,
self.source.get_cause,
self.db.readonly)
self.ref_privacy = PrivacyButton(
self.top.get_widget('eer_ref_priv'),
2006-03-05 04:23:46 +05:30
self.source_ref)
self.descr_field = MonitoredEntry(
self.top.get_widget("eer_description"),
2006-03-05 04:23:46 +05:30
self.source.set_description,
self.source.get_description,
self.db.readonly)
self.place_field = PlaceEntry(
self.top.get_widget("eer_place"),
2006-03-05 04:23:46 +05:30
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-05 04:23:46 +05:30
self.source)
self.role_selector = MonitoredType(
self.top.get_widget('eer_role_combo'),
2006-03-05 04:23:46 +05:30
self.source_ref.set_role,
self.source_ref.get_role,
self.role_dict,
RelLib.EventRef.CUSTOM)
self.event_menu = MonitoredType(
self.top.get_widget("eer_type_combo"),
2006-03-05 04:23:46 +05:30
self.source.set_type,
self.source.get_type,
dict(total_events),
RelLib.Event.CUSTOM)
* 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 10:38:11 +05:30
self.date_check = MonitoredDate(
self.top.get_widget("eer_date"),
self.top.get_widget("eer_date_stat"),
2006-03-05 04:23:46 +05:30
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 10:38:11 +05:30
self.window,
self.db.readonly)
2006-02-22 06:57:49 +05:30
def _create_tabbed_pages(self):
"""
Creates the notebook tabs and inserts them into the main
window.
"""
2006-03-05 04:23:46 +05:30
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 06:57:49 +05:30
def build_menu_names(self,eventref):
2006-03-05 04:23:46 +05:30
if self.source:
if self.source.get_type()[0] == RelLib.Event.CUSTOM:
event_name = self.source.get_type()[1]
2006-02-22 06:57:49 +05:30
else:
try:
2006-03-05 04:23:46 +05:30
event_name = Utils.personal_events[self.source.get_type()[0]]
2006-02-22 06:57:49 +05:30
except:
2006-03-05 04:23:46 +05:30
event_name = Utils.family_events[self.source.get_type()[0]]
2006-02-22 06:57:49 +05:30
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()
place_obj.set_title(handle)
2006-03-05 04:23:46 +05:30
self.source.set_place_handle(place_obj.get_handle())
else:
2006-03-05 04:23:46 +05:30
self.source.set_place_handle(handle)
2006-02-22 06:57:49 +05:30
trans = self.db.transaction_begin()
2006-03-05 04:23:46 +05:30
if self.source.handle:
if need_new:
self.db.add_place(place_obj,trans)
2006-03-06 11:13:47 +05:30
self.db.commit_event(self.source,trans)
2006-03-05 04:23:46 +05:30
self.db.transaction_commit(trans,_("Modify Event"))
2006-02-22 06:57:49 +05:30
else:
if need_new:
self.db.add_place(place_obj,trans)
2006-03-06 11:13:47 +05:30
self.db.add_event(self.source,trans)
2006-03-05 04:23:46 +05:30
self.db.transaction_commit(trans,_("Add Event"))
self.source_ref.ref = self.source.handle
2006-02-22 06:57:49 +05:30
if self.update:
2006-03-05 04:23:46 +05:30
self.update(self.source_ref,self.source)
self.close_window(None)
2006-02-22 06:57:49 +05:30
#-------------------------------------------------------------------------
#
# 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())