EditName call in EditPerson

svn: r6289
This commit is contained in:
Don Allingham 2006-04-07 20:28:41 +00:00
parent 706ed650c9
commit 1439dcf535
2 changed files with 249 additions and 180 deletions

View File

@ -1,3 +1,6 @@
2006-04-07 Don Allingham <don@gramps-project.org>
* src/EditPerson.py: Fix call to EditName, pylint fixes
2006-04-06 Don Allingham <don@gramps-project.org>
* src/glade/gramps.glade: restored addr_edit
* src/DataViews/_FamilyView.py: add select parents function

View File

@ -20,15 +20,21 @@
# $Id$
"""
EditPerson Dialog. Provides the interface to allow the GRAMPS program
to edit information about a particular Person.
"""
__author__ = "Don Allingham"
__revision__ = "$Revision$"
#-------------------------------------------------------------------------
#
# Standard python modules
#
#-------------------------------------------------------------------------
import os
import locale
from gettext import gettext as _
from cgi import escape
#-------------------------------------------------------------------------
#
@ -39,6 +45,11 @@ import gtk
import gtk.glade
import gtk.gdk
try:
set()
except NameError:
from sets import Set as set
#-------------------------------------------------------------------------
#
# gramps modules
@ -46,25 +57,13 @@ import gtk.gdk
#-------------------------------------------------------------------------
import const
import Utils
import Config
import Mime
import RelLib
import DateHandler
import NameDisplay
import DisplayState
import GrampsDisplay
import GrampsWidgets
import AutoComp
from _EditPrimary import EditPrimary
from DisplayTabs import *
from QuestionDialog import WarningDialog, ErrorDialog, QuestionDialog2
from DdTargets import DdTargets
try:
set()
except:
from sets import Set as set
from DisplayTabs import NoteTab, GalleryTab, WebEmbedList, LdsEmbedList
#-------------------------------------------------------------------------
#
@ -72,28 +71,43 @@ except:
#
#-------------------------------------------------------------------------
_select_gender = ((True,False,False),(False,True,False),(False,False,True))
_use_patronymic = set(["ru","RU","ru_RU","koi8r","ru_koi8r","russian","Russian"])
_select_gender = ((True, False, False),
(False, True, False),
(False, False, True))
_use_patronymic = set(
["ru", "RU", "ru_RU", "koi8r", "ru_koi8r", "russian", "Russian"]
)
#-------------------------------------------------------------------------
#
# EditPerson class
#
#-------------------------------------------------------------------------
class EditPerson(EditPrimary):
"""
The EditPerson dialog is derived from the EditPrimary class. It
allos for the editing of the primary object type of Person.
"""
use_patronymic = locale.getlocale(locale.LC_TIME)[0] in _use_patronymic
def __init__(self, state, uistate, track, person, callback=None):
"""Creates an edit window. Associates a person with the window."""
"""
Creates an EditPerson window. Associates a person with the window.
"""
EditPrimary.__init__(self, state, uistate, track, person,
state.db.get_person_from_handle, callback)
def empty_object(self):
"""
Returns an empty Person object for comparison for changes. This
is used by the base class (EditPrimary)
"""
return RelLib.Person()
def _local_init(self):
"""
Local initialization function. Performs basic initialization,
including setting up widgets and the glade interface. This is called
by the base class of EditPrimary, and overridden here.
"""
self.pname = self.obj.get_primary_name()
self.should_guess_gender = (not self.obj.get_gramps_id() and
self.obj.get_gender () ==
@ -108,20 +122,37 @@ class EditPerson(EditPrimary):
self.eventbox = self.top.get_widget("eventbox1")
def _post_init(self):
"""
Post initalization function. Handles any initialization that
needs to be done after the interface is brought up. This called
by _EditPrimary's init routine, and overridden in the derived
class (this class)
"""
self.load_person_image()
self.surname_field.grab_focus()
def _connect_signals(self):
"""
Connects any signals that need to be connected. Called by the
init routine of the base class (_EditPrimary).
"""
self.define_cancel_button(self.top.get_widget("button15"))
self.define_ok_button(self.top.get_widget("ok"), self.save)
self.define_help_button(self.top.get_widget("button134"), 'adv-pers')
self.given.connect("focus_out_event",self.given_focus_out_event)
self.top.get_widget("button177").connect("clicked", self.edit_name_clicked)
self.given.connect("focus_out_event", self._given_focus_out_event)
self.top.get_widget("button177").connect("clicked",
self._edit_name_clicked)
self.eventbox.connect('button-press-event',self.image_button_press)
self.eventbox.connect('button-press-event',
self._image_button_press)
def _setup_fields(self):
"""
Connects the GrampsWidget objects to field in the interface. This
allows the widgets to keep the data in the attached Person object
up to date at all times, eliminating a lot of need in 'save' routine.
"""
self.private = GrampsWidgets.PrivacyButton(
self.top.get_widget('private'),
@ -259,26 +290,29 @@ class EditPerson(EditPrimary):
self.top.get_widget('vbox').pack_start(notebook, True)
def build_menu_names(self, person):
"""
Provides the information need by the base class to define the
window management menu entries.
"""
win_menu_label = self.nd.display(person)
if not win_menu_label.strip():
win_menu_label = _("New Person")
return (_('Edit Person'), win_menu_label)
# def set_list_dnd(self,obj, get, begin, receive):
# obj.drag_dest_set(gtk.DEST_DEFAULT_ALL, [DdTargets.NAME.target()],
# gtk.gdk.ACTION_COPY)
# obj.drag_source_set(gtk.gdk.BUTTON1_MASK,[DdTargets.NAME.target()],
# gtk.gdk.ACTION_COPY)
# obj.connect('drag_data_get', get)
# obj.connect('drag_begin', begin)
# if not self.db.readonly:
# obj.connect('drag_data_received', receive)
def image_callback(self,ref):
def _image_callback(self, ref):
"""
Called when a media reference had been edited. This allows fot
the updating image on the main form which has just been modified.
"""
obj = self.db.get_object_from_handle(ref.get_reference_handle())
self.load_photo(obj)
def image_button_press(self,obj,event):
def _image_button_press(self, obj, event):
"""
Button press event that is caught when a button has been
pressed while on the image on the main form. This does not apply
to the images in galleries, just the image on the main form.
"""
if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1:
media_list = self.obj.get_media_list()
@ -290,16 +324,18 @@ class EditPerson(EditPrimary):
media_obj = self.db.get_object_from_handle(object_handle)
EditMediaRef(self.dbstate, self.uistate, self.track,
media_obj, media_ref, self.image_callback)
media_obj, media_ref, self._image_callback)
elif event.type == gtk.gdk.BUTTON_PRESS and event.button == 3:
media_list = self.obj.get_media_list()
if media_list:
ph = media_list[0]
self.show_popup(ph,event)
photo = media_list[0]
self._show_popup(photo, event)
def show_popup(self, photo, event):
"""Look for right-clicks on a picture and create a popup
menu of the available actions."""
def _show_popup(self, photo, event):
"""
Look for right-clicks on a picture and create a popup
menu of the available actions.
"""
menu = gtk.Menu()
menu.set_title(_("Media Object"))
@ -309,20 +345,25 @@ class EditPerson(EditPrimary):
if progname and len(progname) > 1:
Utils.add_menuitem(menu, _("Open in %s") % progname[1],
photo,self.popup_view_photo)
photo, self._popup_view_photo)
Utils.add_menuitem(menu, _("Edit Object Properties"), photo,
self.popup_change_description)
self._popup_change_description)
menu.popup(None, None, None, event.button, event.time)
def popup_view_photo(self, obj):
"""Open this picture in a picture viewer"""
def _popup_view_photo(self, obj):
"""
Open this picture in the default picture viewer
"""
media_list = self.obj.get_media_list()
if media_list:
ph = media_list[0]
object_handle = ph.get_reference_handle()
photo = media_list[0]
object_handle = photo.get_reference_handle()
Utils.view_photo(self.db.get_object_from_handle(object_handle))
def popup_change_description(self,obj):
def _popup_change_description(self, obj):
"""
Brings up the EditMediaRef dialog for the image on the main form.
"""
media_list = self.obj.get_media_list()
if media_list:
from Editors import EditMediaRef
@ -331,13 +372,19 @@ class EditPerson(EditPrimary):
object_handle = media_ref.get_reference_handle()
media_obj = self.db.get_object_from_handle(object_handle)
EditMediaRef(self.dbstate, self.uistate, self.track,
media_obj, media_ref, self.image_callback)
media_obj, media_ref, self._image_callback)
def given_focus_out_event (self, entry, event):
def _given_focus_out_event (self, entry, event):
"""
Callback that occurs when the user leaves the given name field,
allowing us to attempt to guess the gender of the person if
so requested.
"""
if not self.should_guess_gender:
return False
try:
self.gender.force(self.db.genderStats.guess_gender(entry.get_text()))
gender_type = self.db.genderStats.guess_gender(entry.get_text())
self.gender.force(gender_type)
except:
return False
return False
@ -381,12 +428,13 @@ class EditPerson(EditPrimary):
idval = self.obj.get_gramps_id()
person = self.db.get_person_from_gramps_id(idval)
if person:
n = self.nd.display(person)
name = self.nd.display(person)
msg1 = _("GRAMPS ID value was not changed.")
msg2 = _("You have attempted to change the GRAMPS ID to a value "
"of %(grampsid)s. This value is already used by %(person)s.") % {
msg2 = _("You have attempted to change the GRAMPS ID "
"to a value of %(grampsid)s. This value is "
"already used by %(person)s.") % {
'grampsid' : idval,
'person' : n }
'person' : name }
WarningDialog(msg1, msg2)
def _update_family_ids(self, trans):
@ -395,11 +443,13 @@ class EditPerson(EditPrimary):
family = self.obj.get_main_parents_family_handle()
if (family):
f = self.db.find_family_from_handle(family, trans)
new_order = self.reorder_child_list(self.obj,f.get_child_handle_list())
new_order = self.reorder_child_list(self.obj,
f.get_child_handle_list())
f.set_child_handle_list(new_order)
for (family, rel1, rel2) in self.obj.get_parent_family_handle_list():
f = self.db.find_family_from_handle(family, trans)
new_order = self.reorder_child_list(self.obj,f.get_child_handle_list())
new_order = self.reorder_child_list(self.obj,
f.get_child_handle_list())
f.set_child_handle_list(new_order)
error = False
@ -408,8 +458,8 @@ class EditPerson(EditPrimary):
if original:
(female, male, unknown) = _select_gender[self.obj.get_gender()]
if male and original.get_gender() != RelLib.Person.MALE:
for temp_family_handle in self.obj.get_family_handle_list():
temp_family = self.db.get_family_from_handle(temp_family_handle)
for tmp_handle in self.obj.get_family_handle_list():
temp_family = self.db.get_family_from_handle(tmp_handle)
if self.obj == temp_family.get_mother_handle():
if temp_family.get_father_handle() != None:
error = True
@ -417,8 +467,8 @@ class EditPerson(EditPrimary):
temp_family.set_mother_handle(None)
temp_family.set_father_handle(self.obj)
elif female and original != RelLib.Person.FEMALE:
for temp_family_handle in self.obj.get_family_handle_list():
temp_family = self.db.get_family_from_handle(temp_family_handle)
for tmp_handle in self.obj.get_family_handle_list():
temp_family = self.db.get_family_from_handle(tmp_handle)
if self.obj == temp_family.get_father_handle():
if temp_family.get_mother_handle() != None:
error = True
@ -426,8 +476,8 @@ class EditPerson(EditPrimary):
temp_family.set_father_handle(None)
temp_family.set_mother_handle(self.obj)
elif unknown and original.get_gender() != RelLib.Person.UNKNOWN:
for temp_family_handle in self.obj.get_family_handle_list():
temp_family = self.db.get_family_from_handle(temp_family_handle)
for tmp_handle in self.obj.get_family_handle_list():
temp_family = self.db.get_family_from_handle(tmp_handle)
if self.obj == temp_family.get_father_handle():
if temp_family.get_mother_handle() != None:
error = True
@ -446,7 +496,7 @@ class EditPerson(EditPrimary):
msg = _("Changing the gender caused problems "
"with marriage information.\nPlease check "
"the person's marriages.")
ErrorDialog(msg)
ErrorDialog(msg2, msg)
def save(self, *obj):
"""
@ -462,10 +512,10 @@ class EditPerson(EditPrimary):
if self._check_for_unknown_gender():
return
(br, dr, el) = self.event_list.return_info()
self.obj.set_birth_ref(br)
self.obj.set_death_ref(dr)
self.obj.set_event_ref_list(el)
(birth_ref, death_ref, event_list) = self.event_list.return_info()
self.obj.set_birth_ref(birth_ref)
self.obj.set_death_ref(death_ref)
self.obj.set_event_ref_list(event_list)
self.window.hide()
@ -481,25 +531,40 @@ class EditPerson(EditPrimary):
self.obj.set_gramps_id(self.db.find_next_person_gramps_id())
self.db.commit_person(self.obj, trans)
self.db.transaction_commit(trans,_("Edit Person (%s)") % self.nd.display(self.obj))
msg = _("Edit Person (%s)") % self.nd.display(self.obj)
self.db.transaction_commit(trans, msg)
self.close()
if self.callback:
self.callback(self.obj)
def edit_name_clicked(self,obj):
NameEdit.NameEditor(self.dbstate, self.uistate, self.track,
self.pname, self.update_name)
def _edit_name_clicked(self, obj):
"""
Called when the edit name button is clicked for the primary name
on the main form (not in the names tab). Brings up the EditName
dialog for this name.
"""
from Editors import EditName
EditName(self.dbstate, self.uistate, self.track,
self.pname, self._update_name)
def update_name(self,name):
def _update_name(self, name):
"""
Called when the primary name has been changed by the EditName
dialog. This allows us to update the main form in response to
any changes.
"""
for obj in (self.suffix, self.prefix, self.given, self.title,
self.ntype_field, self.surname_field):
obj.update()
def load_person_image(self):
"""
Loads the primary image into the main form if it exists.
"""
media_list = self.obj.get_media_list()
if media_list:
ph = media_list[0]
object_handle = ph.get_reference_handle()
photo = media_list[0]
object_handle = photo.get_reference_handle()
obj = self.db.get_object_from_handle(object_handle)
if self.load_obj != obj.get_path():
mime_type = obj.get_mime_type()
@ -510,16 +575,17 @@ class EditPerson(EditPrimary):
else:
self.load_photo(None)
def birth_dates_in_order(self,list):
def birth_dates_in_order(self, child_list):
"""Check any *valid* birthdates in the list to insure that they are in
numerically increasing order."""
inorder = True
prev_date = 0
for i in range(len(list)):
child_handle = list[i]
for i in range(len(child_list)):
child_handle = child_list[i]
child = self.db.get_person_from_handle(child_handle)
if child.get_birth_ref():
event = self.db.get_event_from_handle(child.get_birth_ref().ref)
event_handle = child.get_birth_ref().ref
event = self.db.get_event_from_handle(event_handle)
child_date = event.get_date_object().get_sort_value()
else:
continue
@ -529,13 +595,13 @@ class EditPerson(EditPrimary):
inorder = False
return inorder
def reorder_child_list(self, person, list):
def reorder_child_list(self, person, child_list):
"""Reorder the child list to put the specified person in his/her
correct birth order. Only check *valid* birthdates. Move the person
as short a distance as possible."""
if (self.birth_dates_in_order(list)):
return(list)
if self.birth_dates_in_order(child_list):
return(child_list)
# Build the person's date string once
event_ref = person.get_birth_ref()
@ -547,10 +613,10 @@ class EditPerson(EditPrimary):
# First, see if the person needs to be moved forward in the list
index = list.index(person.get_handle())
index = child_list.index(person.get_handle())
target = index
for i in range(index-1, -1, -1):
other = self.db.get_person_from_handle(list[i])
other = self.db.get_person_from_handle(child_list[i])
event_ref = other.get_birth_ref()
if event_ref:
event = self.db.get_event_from_handle(event_ref.ref)
@ -564,8 +630,8 @@ class EditPerson(EditPrimary):
# Now try moving to a later position in the list
if (target == index):
for i in range(index, len(list)):
other = self.db.get_person_from_handle(list[i])
for i in range(index, len(child_list)):
other = self.db.get_person_from_handle(child_list[i])
event_ref = other.get_birth_ref()
if event_ref:
event = self.db.get_event_from_handle(event_ref.ref)
@ -579,7 +645,7 @@ class EditPerson(EditPrimary):
# Actually need to move? Do it now.
if (target != index):
list.remove(person.get_handle())
list.insert(target,person.get_handle())
return list
child_list.remove(person.get_handle())
child_list.insert(target, person.get_handle())
return child_list