2002-10-20 14:25:16 +00:00
|
|
|
#
|
|
|
|
# Gramps - a GTK+/GNOME based genealogy program
|
|
|
|
#
|
2004-02-06 20:57:01 +00:00
|
|
|
# Copyright (C) 2000-2004 Donald N. Allingham
|
2002-10-20 14:25:16 +00:00
|
|
|
#
|
|
|
|
# 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
|
|
|
|
#
|
|
|
|
|
2003-10-20 02:47:03 +00:00
|
|
|
# $Id$
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Standard python modules
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
import pickle
|
2004-10-09 01:35:58 +00:00
|
|
|
import os
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# GTK/Gnome modules
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
import gtk
|
|
|
|
import gtk.glade
|
2004-05-02 04:10:33 +00:00
|
|
|
import gobject
|
2003-03-03 04:32:53 +00:00
|
|
|
import gnome
|
2004-12-01 04:15:08 +00:00
|
|
|
import locale
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2002-11-15 03:49:39 +00:00
|
|
|
from gtk.gdk import ACTION_COPY, BUTTON1_MASK, INTERP_BILINEAR, pixbuf_new_from_file
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# gramps modules
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
import const
|
|
|
|
import Utils
|
2004-09-25 05:12:15 +00:00
|
|
|
import GrampsGconfKeys
|
2002-10-20 14:25:16 +00:00
|
|
|
import GrampsCfg
|
2004-11-29 03:24:02 +00:00
|
|
|
import GrampsMime
|
2002-10-20 14:25:16 +00:00
|
|
|
import ImageSelect
|
|
|
|
import AutoComp
|
2002-11-21 04:41:40 +00:00
|
|
|
import ListModel
|
2003-01-10 05:21:32 +00:00
|
|
|
import RelLib
|
2003-10-29 05:04:43 +00:00
|
|
|
import Sources
|
2003-10-30 04:17:05 +00:00
|
|
|
import DateEdit
|
2004-09-19 15:17:57 +00:00
|
|
|
import Date
|
2004-09-17 03:30:04 +00:00
|
|
|
import DateHandler
|
2004-06-23 04:54:33 +00:00
|
|
|
import TransTable
|
2004-11-29 03:24:02 +00:00
|
|
|
import ImageSelect
|
2003-10-30 04:17:05 +00:00
|
|
|
|
2004-10-09 01:35:58 +00:00
|
|
|
from QuestionDialog import WarningDialog, ErrorDialog, SaveDialog
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-08-17 02:14:33 +00:00
|
|
|
from gettext import gettext as _
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-08-13 04:34:07 +00:00
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Constants
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
|
|
|
|
_PICTURE_WIDTH = 200.0
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
_temple_names = const.lds_temple_codes.keys()
|
|
|
|
_temple_names.sort()
|
|
|
|
_temple_names = [""] + _temple_names
|
|
|
|
|
|
|
|
pycode_tgts = [('url', 0, 0),
|
|
|
|
('pevent', 0, 1),
|
|
|
|
('pattr', 0, 2),
|
|
|
|
('paddr', 0, 3)]
|
|
|
|
|
2004-10-09 01:35:58 +00:00
|
|
|
|
|
|
|
_use_patronymic = [
|
|
|
|
"ru","RU","ru_RU","koi8r","ru_koi8r","russian","Russian",
|
|
|
|
]
|
|
|
|
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# EditPerson class
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
class EditPerson:
|
|
|
|
|
2004-12-01 04:15:08 +00:00
|
|
|
use_patronymic = locale.getlocale(locale.LC_TIME)[0] in _use_patronymic
|
2004-10-09 01:35:58 +00:00
|
|
|
|
2004-02-19 13:40:09 +00:00
|
|
|
def __init__(self,parent,person,db,callback=None):
|
2002-10-20 14:25:16 +00:00
|
|
|
"""Creates an edit window. Associates a person with the window."""
|
2004-02-14 05:40:30 +00:00
|
|
|
|
2004-09-17 03:30:04 +00:00
|
|
|
self.dp = DateHandler.create_parser()
|
|
|
|
self.dd = DateHandler.create_display()
|
2002-10-20 14:25:16 +00:00
|
|
|
self.person = person
|
2004-10-17 23:17:30 +00:00
|
|
|
self.orig_surname = person.get_primary_name().get_group_name()
|
2004-02-19 13:40:09 +00:00
|
|
|
self.parent = parent
|
2004-08-24 04:51:11 +00:00
|
|
|
self.orig_handle = self.person.get_handle()
|
|
|
|
if self.parent.child_windows.has_key(self.orig_handle):
|
2004-07-28 02:29:07 +00:00
|
|
|
self.parent.child_windows[self.person.get_handle()].present(None)
|
2004-02-20 00:52:24 +00:00
|
|
|
return
|
2002-10-20 14:25:16 +00:00
|
|
|
self.db = db
|
|
|
|
self.callback = callback
|
* src/AddrEdit.py, src/AttrEdit.py, src/EditPerson.py,
src/EditSource.py, src/EventEdit.py, src/ImageSelect.py,
src/Marriage.py, src/NameEdit.py, src/NoteEdit.py,
src/Sources.py, src/UrlEdit.py, src/Witness.py:
Register windows opened for existing objects. Prevent editing
same object twice.
svn: r2905
2004-02-24 05:37:06 +00:00
|
|
|
self.child_windows = {}
|
2004-02-14 05:40:30 +00:00
|
|
|
self.path = db.get_save_path()
|
2004-09-20 03:12:51 +00:00
|
|
|
self.not_loaded = True
|
|
|
|
self.lds_not_loaded = True
|
|
|
|
self.lists_changed = False
|
|
|
|
self.update_birth = False
|
|
|
|
self.update_death = False
|
2003-06-13 15:08:07 +00:00
|
|
|
self.pdmap = {}
|
2002-10-20 14:25:16 +00:00
|
|
|
self.add_places = []
|
2004-08-24 04:51:11 +00:00
|
|
|
self.should_guess_gender = (person.get_gramps_id() == '' and
|
2004-02-14 05:40:30 +00:00
|
|
|
person.get_gender () ==
|
2003-07-01 19:04:47 +00:00
|
|
|
RelLib.Person.unknown)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-08-13 04:34:07 +00:00
|
|
|
for key in db.get_place_handles():
|
|
|
|
p = db.get_place_from_handle(key).get_display_info()
|
2003-06-13 15:08:07 +00:00
|
|
|
self.pdmap[p[0]] = key
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
self.load_obj = None
|
2003-08-17 02:14:33 +00:00
|
|
|
self.top = gtk.glade.XML(const.editPersonFile, "editPerson","gramps")
|
* src/SourceView.py (button_press,on_add_clicked,on_delete_clicked,
on_edit_clicked): Pass parent window to the child dialog.
* src/Sources.py (add_src_clicked): Likewise.
* src/EditSource.py (__init__): Add optional parent_window argument.
Make dialog modal and transient for its parent.
* src/gramps.glade (sourceEditor dialog): Delete unneeded handlers
for buttons.
* src/QuestionDialog.py (SaveDialog,QuestionDialog,OptionDialog,
ErrorDialog,WarningDialog,MissingMediaDialog): Set transient status
if parent is given.
* src/EventEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/Witness.py: Make WittnessEditor dialog modal and transient for
its parent. Call SelectPerson with itself as a parent.
* src/SelectPerson.py (__init__): Make dialog transient for its parent.
* src/imagesel.glade: Define proper responses and delete unneeded handlers
for buttons. Make gtkFileEntry modal.
* src/dialog.glade (all dialogs): Define proper responses for buttons.
* src/EditPerson.py (on_add_aka_clicked, on_aka_update_clicked):
Call NameEdit with itself as a parent; (on_add_attr_clicked,
on_update_attr_clicked): Call AttributeEditor with itself as a parent;
(on_add_addr_clicked,on_update_addr_clicked): Call AddressEditor with
itself as a parent; (on_add_url_clicked,on_update_url_clicked): Call
UrlEditor with itself as a parent; (on_name_note_clicked,
on_ldsbap_note_clicked,on_ldsendow_note_clicked,
on_ldsseal_note_clicked): Call NoteEditor with itself as a parent.
* src/NameEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/AttrEdit.py (__init__): Likewise.
* src/AddrEdit.py (__init__): Likewise.
* src/UrlEdit.py (__init__): Likewise.
* src/NoteEdit.py (__init__): Likewise.
svn: r2131
2003-09-15 04:11:30 +00:00
|
|
|
self.window = self.get_widget("editPerson")
|
|
|
|
self.window.set_title("%s - GRAMPS" % _('Edit Person'))
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
self.icon_list = self.top.get_widget("iconlist")
|
2004-08-07 05:16:57 +00:00
|
|
|
self.gallery = ImageSelect.Gallery(person, self.db.commit_person,
|
|
|
|
self.path, self.icon_list,
|
|
|
|
self.db, self, self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-12-03 03:49:39 +00:00
|
|
|
self.complete = self.get_widget('complete')
|
2002-10-20 14:25:16 +00:00
|
|
|
self.name_delete_btn = self.top.get_widget('aka_delete')
|
2003-02-28 04:49:18 +00:00
|
|
|
self.name_edit_btn = self.top.get_widget('aka_edit')
|
2002-10-20 14:25:16 +00:00
|
|
|
self.web_delete_btn = self.top.get_widget('delete_url')
|
2003-03-03 04:32:53 +00:00
|
|
|
self.web_edit_btn = self.top.get_widget('edit_url')
|
2002-10-20 14:25:16 +00:00
|
|
|
self.event_delete_btn = self.top.get_widget('event_delete_btn')
|
2003-03-03 04:32:53 +00:00
|
|
|
self.event_edit_btn = self.top.get_widget('event_edit_btn')
|
2002-10-20 14:25:16 +00:00
|
|
|
self.attr_delete_btn = self.top.get_widget('attr_delete_btn')
|
2003-03-03 04:32:53 +00:00
|
|
|
self.attr_edit_btn = self.top.get_widget('attr_edit_btn')
|
2002-10-20 14:25:16 +00:00
|
|
|
self.addr_delete_btn = self.top.get_widget('addr_delete_btn')
|
2003-03-03 04:32:53 +00:00
|
|
|
self.addr_edit_btn = self.top.get_widget('addr_edit_btn')
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
self.notes_field = self.get_widget("personNotes")
|
2003-12-10 14:21:48 +00:00
|
|
|
self.flowed = self.get_widget("flowed")
|
|
|
|
self.preform = self.get_widget("preform")
|
2002-10-20 14:25:16 +00:00
|
|
|
self.event_name_field = self.get_widget("eventName")
|
|
|
|
self.event_place_field = self.get_widget("eventPlace")
|
|
|
|
self.event_cause_field = self.get_widget("eventCause")
|
|
|
|
self.event_date_field = self.get_widget("eventDate")
|
|
|
|
self.event_descr_field = self.get_widget("eventDescription")
|
|
|
|
self.event_src_field = self.get_widget("event_srcinfo")
|
|
|
|
self.event_conf_field = self.get_widget("event_conf")
|
|
|
|
self.attr_conf_field = self.get_widget("attr_conf")
|
2002-11-15 03:49:39 +00:00
|
|
|
self.addr_conf_field = self.get_widget("addr_conf")
|
2002-10-20 14:25:16 +00:00
|
|
|
self.name_conf_field = self.get_widget("name_conf")
|
|
|
|
self.attr_src_field = self.get_widget("attr_srcinfo")
|
|
|
|
self.name_src_field = self.get_widget("name_srcinfo")
|
|
|
|
self.addr_src_field = self.get_widget("addr_srcinfo")
|
|
|
|
self.attr_list = self.get_widget("attr_list")
|
|
|
|
self.attr_type = self.get_widget("attr_type")
|
|
|
|
self.attr_value = self.get_widget("attr_value")
|
|
|
|
self.web_list = self.get_widget("web_list")
|
|
|
|
self.web_url = self.get_widget("web_url")
|
|
|
|
self.web_go = self.get_widget("web_go")
|
|
|
|
self.web_description = self.get_widget("url_des")
|
|
|
|
self.addr_list = self.get_widget("address_list")
|
|
|
|
self.addr_start = self.get_widget("address_start")
|
|
|
|
self.addr_street = self.get_widget("street")
|
|
|
|
self.addr_city = self.get_widget("city")
|
|
|
|
self.addr_state = self.get_widget("state")
|
|
|
|
self.addr_country = self.get_widget("country")
|
|
|
|
self.addr_postal = self.get_widget("postal")
|
2003-12-09 06:02:36 +00:00
|
|
|
self.addr_phone = self.get_widget("phone")
|
2002-10-20 14:25:16 +00:00
|
|
|
self.event_list = self.get_widget("eventList")
|
|
|
|
self.edit_person = self.get_widget("editPerson")
|
|
|
|
self.name_list = self.get_widget("nameList")
|
|
|
|
self.alt_given_field = self.get_widget("alt_given")
|
|
|
|
self.alt_last_field = self.get_widget("alt_last")
|
|
|
|
self.alt_title_field = self.get_widget("alt_title")
|
|
|
|
self.alt_suffix_field = self.get_widget("alt_suffix")
|
2002-12-04 04:58:07 +00:00
|
|
|
self.alt_prefix_field = self.get_widget("alt_prefix")
|
2002-10-20 14:25:16 +00:00
|
|
|
self.name_type_field = self.get_widget("name_type")
|
|
|
|
self.ntype_field = self.get_widget("ntype")
|
|
|
|
self.suffix = self.get_widget("suffix")
|
2002-12-04 04:58:07 +00:00
|
|
|
self.prefix = self.get_widget("prefix")
|
2002-10-20 14:25:16 +00:00
|
|
|
self.given = self.get_widget("givenName")
|
|
|
|
self.nick = self.get_widget("nickname")
|
|
|
|
self.title = self.get_widget("title")
|
|
|
|
self.bdate = self.get_widget("birthDate")
|
2004-05-02 04:10:33 +00:00
|
|
|
self.bplace = self.get_widget("birth_place")
|
|
|
|
self.surname = self.get_widget("surname")
|
2002-10-20 14:25:16 +00:00
|
|
|
self.ddate = self.get_widget("deathDate")
|
2004-05-02 04:10:33 +00:00
|
|
|
self.dplace = self.get_widget("death_place")
|
2002-10-20 14:25:16 +00:00
|
|
|
self.is_male = self.get_widget("genderMale")
|
|
|
|
self.is_female = self.get_widget("genderFemale")
|
|
|
|
self.is_unknown = self.get_widget("genderUnknown")
|
|
|
|
self.addr_note = self.get_widget("addr_note")
|
|
|
|
self.addr_source = self.get_widget("addr_source")
|
|
|
|
self.attr_note = self.get_widget("attr_note")
|
|
|
|
self.attr_source = self.get_widget("attr_source")
|
|
|
|
self.name_note = self.get_widget("name_note")
|
|
|
|
self.name_source = self.get_widget("name_source")
|
|
|
|
self.gid = self.get_widget("gid")
|
2003-10-29 05:04:43 +00:00
|
|
|
self.slist = self.get_widget("slist")
|
2003-11-11 00:32:28 +00:00
|
|
|
self.general_label = self.get_widget("general_label")
|
|
|
|
self.names_label = self.get_widget("names_label")
|
|
|
|
self.events_label = self.get_widget("events_label")
|
|
|
|
self.attr_label = self.get_widget("attr_label")
|
|
|
|
self.addr_label = self.get_widget("addr_label")
|
|
|
|
self.notes_label = self.get_widget("notes_label")
|
|
|
|
self.sources_label = self.get_widget("sources_label")
|
|
|
|
self.inet_label = self.get_widget("inet_label")
|
|
|
|
self.gallery_label = self.get_widget("gallery_label")
|
|
|
|
self.lds_tab = self.get_widget("lds_tab")
|
2004-11-29 03:24:02 +00:00
|
|
|
self.person_photo = self.get_widget("personPix")
|
|
|
|
self.eventbox = self.get_widget("eventbox1")
|
|
|
|
|
2004-08-24 03:48:15 +00:00
|
|
|
self.get_widget("changed").set_text(person.get_change_display())
|
2003-11-11 00:32:28 +00:00
|
|
|
|
2004-10-09 01:35:58 +00:00
|
|
|
self.prefix_label = self.get_widget('prefix_label')
|
|
|
|
|
|
|
|
if self.use_patronymic:
|
|
|
|
self.prefix_label.set_text(_('Patronymic:'))
|
|
|
|
self.prefix_label.set_use_underline(True)
|
|
|
|
|
* src/AddSpouse.py, src/ChooseParents.py, src/EditPerson.py,
src/EditPlace.py, src/EditSource.py, src/EventEdit.py,
src/FamilyView.py, src/GenericFilter.py,
src/Marriage.py, src/PedView.py, src/PeopleModel.py,
src/PlaceView.py, src/RelLib.py, src/SelectChild.py,
src/Sort.py, src/SourceView.py, src/SubstKeywords.py,
src/WriteGedcom.py, src/WriteXML.py, src/plugins/AncestorReport.py,
src/plugins/Ancestors.py, src/plugins/ChangeTypes.py,
src/plugins/DescendReport.py, src/plugins/DetDescendantReport.py,
src/plugins/EventCmp.py, src/plugins/FamilyGroup.py,
src/plugins/FanChart.py, src/plugins/FtmStyleAncestors.py,
src/plugins/FtmStyleDescendants.py, src/plugins/GraphViz.py,
src/plugins/IndivComplete.py, src/plugins/IndivSummary.py,
src/plugins/Merge.py, src/plugins/RelCalc.py, src/plugins/RelGraph.py,
src/plugins/Summary.py, src/plugins/TimeLine.py, src/plugins/Verify.py,
src/plugins/WebPage.py, src/plugins/WriteCD.py,
src/plugins/WritePkg.py, src/plugins/DetAncestralReport.py:
Use get_event_from_handle (not find_ ).
svn: r3462
2004-08-21 18:56:01 +00:00
|
|
|
self.orig_birth = self.db.get_event_from_handle(person.get_birth_handle())
|
|
|
|
self.orig_death = self.db.get_event_from_handle(person.get_death_handle())
|
2004-02-19 05:07:46 +00:00
|
|
|
self.death = RelLib.Event(self.orig_death)
|
|
|
|
self.birth = RelLib.Event(self.orig_birth)
|
2004-02-14 05:40:30 +00:00
|
|
|
self.pname = RelLib.Name(person.get_primary_name())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
self.elist = person.get_event_list()[:]
|
|
|
|
self.nlist = person.get_alternate_names()[:]
|
|
|
|
self.alist = person.get_attribute_list()[:]
|
|
|
|
self.ulist = person.get_url_list()[:]
|
|
|
|
self.plist = person.get_address_list()[:]
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-10-29 05:04:43 +00:00
|
|
|
if person:
|
2004-02-14 05:40:30 +00:00
|
|
|
self.srcreflist = person.get_source_references()
|
2003-10-29 05:04:43 +00:00
|
|
|
else:
|
|
|
|
self.srcreflist = []
|
|
|
|
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.general_label)
|
2003-11-11 00:32:28 +00:00
|
|
|
if self.srcreflist:
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.sources_label)
|
2003-11-11 00:32:28 +00:00
|
|
|
if self.elist:
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.events_label)
|
2003-11-11 00:32:28 +00:00
|
|
|
if self.nlist:
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.names_label)
|
2003-11-11 00:32:28 +00:00
|
|
|
if self.alist:
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.attr_label)
|
2003-11-11 00:32:28 +00:00
|
|
|
if self.ulist:
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.inet_label)
|
2003-11-11 00:32:28 +00:00
|
|
|
if self.plist:
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.addr_label)
|
2004-02-21 06:11:59 +00:00
|
|
|
if self.person.get_media_list():
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.gallery_label)
|
2003-11-11 00:32:28 +00:00
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
# event display
|
2004-06-23 04:54:33 +00:00
|
|
|
|
|
|
|
event_default = [ 'Event', 'Description', 'Date', 'Place' ]
|
|
|
|
self.event_trans = TransTable.TransTable(event_default)
|
|
|
|
evalues = {
|
|
|
|
'Event' : (_('Event'),-1,150),
|
|
|
|
'Description' : (_('Description'),-1,150),
|
|
|
|
'Date' : (_('Date'),-1,100),
|
|
|
|
'Place' : (_('Place'),-1,100)
|
|
|
|
}
|
|
|
|
|
|
|
|
values = self.db.metadata.get('event_order')
|
|
|
|
if not values:
|
|
|
|
values = event_default
|
|
|
|
|
|
|
|
etitles = []
|
|
|
|
for val in values:
|
|
|
|
etitles.append(evalues[val])
|
|
|
|
|
2002-11-21 04:41:40 +00:00
|
|
|
self.etree = ListModel.ListModel(self.event_list,etitles,
|
|
|
|
self.on_event_select_row,
|
|
|
|
self.on_event_update_clicked)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
# attribute display
|
2003-01-06 05:14:49 +00:00
|
|
|
atitles = [(_('Attribute'),-1,150),(_('Value'),-1,150)]
|
2002-11-21 04:41:40 +00:00
|
|
|
self.atree = ListModel.ListModel(self.attr_list,atitles,
|
|
|
|
self.on_attr_select_row,
|
|
|
|
self.on_update_attr_clicked)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
# address display
|
2003-01-06 05:14:49 +00:00
|
|
|
ptitles = [(_('Date'),-1,150),(_('Address'),-1,150)]
|
2002-11-21 04:41:40 +00:00
|
|
|
self.ptree = ListModel.ListModel(self.addr_list, ptitles,
|
|
|
|
self.on_addr_select_row,
|
|
|
|
self.on_update_addr_clicked)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
# name display
|
2003-01-06 05:14:49 +00:00
|
|
|
ntitles = [(_('Name'),-1,250),(_('Type'),-1,100)]
|
2002-11-21 04:41:40 +00:00
|
|
|
self.ntree = ListModel.ListModel(self.name_list,ntitles,
|
|
|
|
self.on_name_select_row)
|
|
|
|
self.ntree.tree.connect('event',self.aka_double_click)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
# web display
|
2003-01-06 05:14:49 +00:00
|
|
|
wtitles = [(_('Path'),-1,250),(_('Description'),-1,100)]
|
2002-11-21 04:41:40 +00:00
|
|
|
self.wtree = ListModel.ListModel(self.web_list,wtitles,
|
|
|
|
self.on_web_select_row,
|
|
|
|
self.on_update_url_clicked)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-05-02 04:10:33 +00:00
|
|
|
self.place_list = self.pdmap.keys()
|
|
|
|
self.place_list.sort()
|
|
|
|
|
|
|
|
build_dropdown(self.bplace,self.place_list)
|
|
|
|
build_dropdown(self.dplace,self.place_list)
|
2004-08-13 04:34:07 +00:00
|
|
|
build_dropdown(self.surname,self.db.get_surname_list())
|
2004-08-19 03:44:10 +00:00
|
|
|
|
|
|
|
gid = person.get_gramps_id()
|
|
|
|
if gid:
|
|
|
|
self.gid.set_text(gid)
|
2004-07-09 04:31:43 +00:00
|
|
|
self.gid.set_editable(1)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_baptism = RelLib.LdsOrd(self.person.get_lds_baptism())
|
|
|
|
self.lds_endowment = RelLib.LdsOrd(self.person.get_lds_endowment())
|
|
|
|
self.lds_sealing = RelLib.LdsOrd(self.person.get_lds_sealing())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-09-25 05:12:15 +00:00
|
|
|
if GrampsGconfKeys.get_uselds() \
|
2004-02-14 05:40:30 +00:00
|
|
|
or (not self.lds_baptism.is_empty()) \
|
|
|
|
or (not self.lds_endowment.is_empty()) \
|
|
|
|
or (not self.lds_sealing.is_empty()):
|
2002-10-20 14:25:16 +00:00
|
|
|
self.get_widget("lds_tab").show()
|
|
|
|
self.get_widget("lds_page").show()
|
2004-02-14 05:40:30 +00:00
|
|
|
if (not self.lds_baptism.is_empty()) \
|
|
|
|
or (not self.lds_endowment.is_empty()) \
|
|
|
|
or (not self.lds_sealing.is_empty()):
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.lds_tab)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-01-20 23:30:15 +00:00
|
|
|
types = const.NameTypesMap.get_values()
|
2002-10-20 14:25:16 +00:00
|
|
|
types.sort()
|
2004-08-04 04:53:29 +00:00
|
|
|
AutoComp.fill_combo(self.ntype_field,types)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.write_primary_name()
|
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if person.get_gender() == RelLib.Person.male:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.is_male.set_active(1)
|
2004-02-14 05:40:30 +00:00
|
|
|
elif person.get_gender() == RelLib.Person.female:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.is_female.set_active(1)
|
|
|
|
else:
|
|
|
|
self.is_unknown.set_active(1)
|
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
self.nick.set_text(person.get_nick_name())
|
2002-10-20 14:25:16 +00:00
|
|
|
self.load_person_image()
|
|
|
|
|
|
|
|
# set notes data
|
|
|
|
self.notes_buffer = self.notes_field.get_buffer()
|
2004-02-14 05:40:30 +00:00
|
|
|
if person.get_note():
|
|
|
|
self.notes_buffer.set_text(person.get_note())
|
|
|
|
if person.get_note_object().get_format() == 1:
|
2003-12-10 14:21:48 +00:00
|
|
|
self.preform.set_active(1)
|
|
|
|
else:
|
|
|
|
self.flowed.set_active(1)
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.notes_label)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-06-23 04:54:33 +00:00
|
|
|
self.event_list.drag_dest_set(gtk.DEST_DEFAULT_ALL, pycode_tgts,
|
|
|
|
ACTION_COPY)
|
2002-11-15 03:49:39 +00:00
|
|
|
self.event_list.drag_source_set(BUTTON1_MASK, pycode_tgts, ACTION_COPY)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.event_list.connect('drag_data_get', self.ev_drag_data_get)
|
2003-01-06 05:14:49 +00:00
|
|
|
self.event_list.connect('drag_begin', self.ev_drag_begin)
|
2004-06-23 04:54:33 +00:00
|
|
|
self.event_list.connect('drag_data_received',
|
|
|
|
self.ev_drag_data_received)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-06-23 04:54:33 +00:00
|
|
|
self.web_list.drag_dest_set(gtk.DEST_DEFAULT_ALL,pycode_tgts,
|
|
|
|
ACTION_COPY)
|
2002-11-15 03:49:39 +00:00
|
|
|
self.web_list.drag_source_set(BUTTON1_MASK, pycode_tgts, ACTION_COPY)
|
|
|
|
self.web_list.connect('drag_data_get', self.url_drag_data_get)
|
2003-01-08 05:41:35 +00:00
|
|
|
self.web_list.connect('drag_begin', self.url_drag_begin)
|
2003-01-10 05:21:32 +00:00
|
|
|
self.web_list.connect('drag_data_received',self.url_drag_data_received)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-01-10 05:21:32 +00:00
|
|
|
self.attr_list.drag_dest_set(gtk.DEST_DEFAULT_ALL,pycode_tgts,ACTION_COPY)
|
|
|
|
self.attr_list.drag_source_set(BUTTON1_MASK, pycode_tgts, ACTION_COPY)
|
2002-11-15 03:49:39 +00:00
|
|
|
self.attr_list.connect('drag_data_get', self.at_drag_data_get)
|
2003-01-10 05:21:32 +00:00
|
|
|
self.attr_list.connect('drag_data_received',self.at_drag_data_received)
|
2003-01-08 05:41:35 +00:00
|
|
|
self.attr_list.connect('drag_begin', self.at_drag_begin)
|
2002-11-15 03:49:39 +00:00
|
|
|
|
2003-01-10 05:21:32 +00:00
|
|
|
self.addr_list.drag_dest_set(gtk.DEST_DEFAULT_ALL,pycode_tgts,ACTION_COPY)
|
|
|
|
self.addr_list.drag_source_set(BUTTON1_MASK, pycode_tgts,ACTION_COPY)
|
2002-11-15 03:49:39 +00:00
|
|
|
self.addr_list.connect('drag_data_get', self.ad_drag_data_get)
|
2003-01-10 05:21:32 +00:00
|
|
|
self.addr_list.connect('drag_data_received',self.ad_drag_data_received)
|
2003-01-13 03:59:10 +00:00
|
|
|
self.addr_list.connect('drag_begin', self.ad_drag_begin)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-09-19 15:17:57 +00:00
|
|
|
self.birth_date_object = self.birth.get_date_object()
|
|
|
|
self.death_date_object = self.death.get_date_object()
|
|
|
|
self.update_birth_death()
|
|
|
|
|
|
|
|
self.bdate_check = DateEdit.DateEdit(self.birth_date_object,
|
|
|
|
self.bdate,
|
|
|
|
self.get_widget("birth_stat"),
|
|
|
|
self.window)
|
2003-01-02 04:31:52 +00:00
|
|
|
|
2004-09-19 15:17:57 +00:00
|
|
|
self.ddate_check = DateEdit.DateEdit(self.death_date_object,
|
|
|
|
self.ddate,
|
|
|
|
self.get_widget("death_stat"),
|
|
|
|
self.window)
|
2003-01-02 04:31:52 +00:00
|
|
|
|
|
|
|
self.top.signal_autoconnect({
|
|
|
|
"destroy_passed_object" : self.on_cancel_edit,
|
|
|
|
"on_up_clicked" : self.on_up_clicked,
|
|
|
|
"on_down_clicked" : self.on_down_clicked,
|
|
|
|
"on_add_address_clicked" : self.on_add_addr_clicked,
|
|
|
|
"on_add_aka_clicked" : self.on_add_aka_clicked,
|
|
|
|
"on_add_attr_clicked" : self.on_add_attr_clicked,
|
|
|
|
"on_add_url_clicked" : self.on_add_url_clicked,
|
2004-02-23 02:45:36 +00:00
|
|
|
"on_addphoto_clicked" : self.gallery.on_add_media_clicked,
|
|
|
|
"on_selectphoto_clicked" : self.gallery.on_select_media_clicked,
|
2003-01-02 04:31:52 +00:00
|
|
|
"on_aka_delete_clicked" : self.on_aka_delete_clicked,
|
|
|
|
"on_aka_update_clicked" : self.on_aka_update_clicked,
|
|
|
|
"on_apply_person_clicked" : self.on_apply_person_clicked,
|
|
|
|
"on_edit_birth_clicked" : self.on_edit_birth_clicked,
|
|
|
|
"on_edit_death_clicked" : self.on_edit_death_clicked,
|
|
|
|
"on_delete_address_clicked" : self.on_delete_addr_clicked,
|
|
|
|
"on_delete_attr_clicked" : self.on_delete_attr_clicked,
|
|
|
|
"on_delete_event" : self.on_delete_event,
|
|
|
|
"on_delete_url_clicked" : self.on_delete_url_clicked,
|
2004-02-23 02:45:36 +00:00
|
|
|
"on_deletephoto_clicked" : self.gallery.on_delete_media_clicked,
|
2003-01-02 04:31:52 +00:00
|
|
|
"on_edit_properties_clicked": self.gallery.popup_change_description,
|
2004-02-23 02:45:36 +00:00
|
|
|
"on_editphoto_clicked" : self.gallery.on_edit_media_clicked,
|
2003-01-02 04:31:52 +00:00
|
|
|
"on_editperson_switch_page" : self.on_switch_page,
|
|
|
|
"on_event_add_clicked" : self.on_event_add_clicked,
|
|
|
|
"on_event_delete_clicked" : self.on_event_delete_clicked,
|
|
|
|
"on_event_update_clicked" : self.on_event_update_clicked,
|
2004-09-29 02:06:46 +00:00
|
|
|
"on_edit_name_clicked" : self.on_edit_name_clicked,
|
2003-01-02 04:31:52 +00:00
|
|
|
"on_ldsbap_note_clicked" : self.on_ldsbap_note_clicked,
|
|
|
|
"on_ldsendow_note_clicked" : self.on_ldsendow_note_clicked,
|
|
|
|
"on_ldsseal_note_clicked" : self.on_ldsseal_note_clicked,
|
|
|
|
"on_ldsbap_src_clicked" : self.on_ldsbap_source_clicked,
|
|
|
|
"on_ldsendow_src_clicked" : self.on_ldsendow_source_clicked,
|
|
|
|
"on_ldsseal_src_clicked" : self.on_ldsseal_source_clicked,
|
|
|
|
"on_update_address_clicked" : self.on_update_addr_clicked,
|
|
|
|
"on_update_attr_clicked" : self.on_update_attr_clicked,
|
|
|
|
"on_update_url_clicked" : self.on_update_url_clicked,
|
|
|
|
"on_web_go_clicked" : self.on_web_go_clicked,
|
2003-06-24 14:16:47 +00:00
|
|
|
"on_gender_activate" : self.on_gender_activate,
|
2004-09-30 18:32:56 +00:00
|
|
|
"on_given_focus_out" : self.on_given_focus_out_event,
|
2003-11-18 04:26:06 +00:00
|
|
|
"on_help_person_clicked" : self.on_help_clicked,
|
2003-01-02 04:31:52 +00:00
|
|
|
})
|
|
|
|
|
2003-10-29 05:04:43 +00:00
|
|
|
self.sourcetab = Sources.SourceTab(self.srcreflist,self,
|
|
|
|
self.top,self.window,self.slist,
|
|
|
|
self.top.get_widget('add_src'),
|
|
|
|
self.top.get_widget('edit_src'),
|
|
|
|
self.top.get_widget('del_src'))
|
|
|
|
|
2004-08-13 04:34:07 +00:00
|
|
|
if self.person.get_complete_flag():
|
2003-12-03 03:49:39 +00:00
|
|
|
self.complete.set_active(1)
|
|
|
|
|
2004-11-29 03:24:02 +00:00
|
|
|
self.eventbox.connect('button-press-event',self.image_button_press)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
self.redraw_event_list()
|
|
|
|
self.redraw_attr_list()
|
|
|
|
self.redraw_addr_list()
|
|
|
|
self.redraw_name_list()
|
|
|
|
self.redraw_url_list()
|
2003-03-26 04:32:14 +00:00
|
|
|
self.get_widget("notebook").set_current_page(0)
|
2003-03-14 05:46:02 +00:00
|
|
|
self.given.grab_focus()
|
2004-02-19 13:40:09 +00:00
|
|
|
self.add_itself_to_winsmenu()
|
2003-03-21 04:25:55 +00:00
|
|
|
self.window.show()
|
2003-03-14 05:46:02 +00:00
|
|
|
|
2004-11-29 03:24:02 +00:00
|
|
|
def image_button_press(self,obj,event):
|
|
|
|
if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1:
|
|
|
|
|
|
|
|
media_list = self.person.get_media_list()
|
|
|
|
if media_list:
|
|
|
|
ph = media_list[0]
|
|
|
|
object_handle = ph.get_reference_handle()
|
|
|
|
obj = self.db.get_object_from_handle(object_handle)
|
|
|
|
ImageSelect.LocalMediaProperties(ph,obj.get_path(),self,self.window)
|
|
|
|
elif event.type == gtk.gdk.BUTTON_PRESS and event.button == 3:
|
|
|
|
media_list = self.person.get_media_list()
|
|
|
|
if media_list:
|
|
|
|
ph = media_list[0]
|
|
|
|
self.show_popup(ph,event)
|
|
|
|
|
|
|
|
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"))
|
|
|
|
obj = self.db.get_object_from_handle(photo.get_reference_handle())
|
|
|
|
mtype = obj.get_mime_type()
|
|
|
|
progname = GrampsMime.get_application(mtype)
|
|
|
|
|
|
|
|
if progname and len(progname) > 1:
|
|
|
|
Utils.add_menuitem(menu,_("Open in %s") % progname[1],
|
|
|
|
photo,self.popup_view_photo)
|
|
|
|
if mtype[0:5] == "image":
|
|
|
|
Utils.add_menuitem(menu,_("Edit with the GIMP"),
|
|
|
|
photo,self.popup_edit_photo)
|
|
|
|
Utils.add_menuitem(menu,_("Edit Object Properties"),photo,
|
|
|
|
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"""
|
|
|
|
media_list = self.person.get_media_list()
|
|
|
|
if media_list:
|
|
|
|
ph = media_list[0]
|
|
|
|
object_handle = ph.get_reference_handle()
|
|
|
|
Utils.view_photo(self.db.get_object_from_handle(object_handle))
|
|
|
|
|
|
|
|
def popup_edit_photo(self, obj):
|
|
|
|
"""Open this picture in a picture editor"""
|
|
|
|
media_list = self.person.get_media_list()
|
|
|
|
if media_list:
|
|
|
|
ph = media_list[0]
|
|
|
|
object_handle = ph.get_reference_handle()
|
|
|
|
if os.fork() == 0:
|
|
|
|
obj = self.db.get_object_from_handle(object_handle)
|
|
|
|
os.execvp(const.editor,[const.editor, obj.get_path()])
|
|
|
|
|
|
|
|
def popup_change_description(self,obj):
|
|
|
|
media_list = self.person.get_media_list()
|
|
|
|
if media_list:
|
|
|
|
ph = media_list[0]
|
|
|
|
object_handle = ph.get_reference_handle()
|
|
|
|
obj = self.db.get_object_from_handle(object_handle)
|
|
|
|
ImageSelect.LocalMediaProperties(ph,obj.get_path(),self,self.window)
|
|
|
|
|
2004-02-19 19:15:27 +00:00
|
|
|
def close_child_windows(self):
|
* src/AddrEdit.py, src/AttrEdit.py, src/EditPerson.py,
src/EditSource.py, src/EventEdit.py, src/ImageSelect.py,
src/Marriage.py, src/NameEdit.py, src/NoteEdit.py,
src/Sources.py, src/UrlEdit.py, src/Witness.py:
Register windows opened for existing objects. Prevent editing
same object twice.
svn: r2905
2004-02-24 05:37:06 +00:00
|
|
|
for child_window in self.child_windows.values():
|
2004-02-20 00:52:24 +00:00
|
|
|
child_window.close(None)
|
* src/AddrEdit.py, src/AttrEdit.py, src/EditPerson.py,
src/EditSource.py, src/EventEdit.py, src/ImageSelect.py,
src/Marriage.py, src/NameEdit.py, src/NoteEdit.py,
src/Sources.py, src/UrlEdit.py, src/Witness.py:
Register windows opened for existing objects. Prevent editing
same object twice.
svn: r2905
2004-02-24 05:37:06 +00:00
|
|
|
self.child_windows = {}
|
2004-02-19 19:15:27 +00:00
|
|
|
|
2004-08-04 04:53:29 +00:00
|
|
|
def close(self):
|
2004-06-23 04:54:33 +00:00
|
|
|
event_list = []
|
|
|
|
for col in self.event_list.get_columns():
|
|
|
|
event_list.append(self.event_trans.find_key(col.get_title()))
|
|
|
|
self.db.metadata['event_order'] = event_list
|
|
|
|
|
2004-08-04 04:53:29 +00:00
|
|
|
self.gallery.close()
|
2004-02-20 00:52:24 +00:00
|
|
|
self.close_child_windows()
|
|
|
|
self.remove_itself_from_winsmenu()
|
|
|
|
self.window.destroy()
|
2004-02-19 19:15:27 +00:00
|
|
|
|
2004-02-19 13:40:09 +00:00
|
|
|
def add_itself_to_winsmenu(self):
|
2004-08-24 03:48:15 +00:00
|
|
|
self.parent.child_windows[self.orig_handle] = self
|
2004-07-15 02:54:04 +00:00
|
|
|
win_menu_label = GrampsCfg.get_nameof()(self.person)
|
2004-02-19 19:15:27 +00:00
|
|
|
if not win_menu_label.strip():
|
2004-02-19 20:34:58 +00:00
|
|
|
win_menu_label = _("New Person")
|
2004-02-19 19:15:27 +00:00
|
|
|
self.win_menu_item = gtk.MenuItem(win_menu_label)
|
2004-02-20 00:52:24 +00:00
|
|
|
self.win_menu_item.set_submenu(gtk.Menu())
|
2004-02-19 19:15:27 +00:00
|
|
|
self.win_menu_item.show()
|
|
|
|
self.parent.winsmenu.append(self.win_menu_item)
|
2004-02-25 03:20:53 +00:00
|
|
|
self.winsmenu = self.win_menu_item.get_submenu()
|
2004-02-20 00:52:24 +00:00
|
|
|
self.menu_item = gtk.MenuItem(_('Edit Person'))
|
2004-02-19 13:40:09 +00:00
|
|
|
self.menu_item.connect("activate",self.present)
|
|
|
|
self.menu_item.show()
|
2004-02-25 03:20:53 +00:00
|
|
|
self.winsmenu.append(self.menu_item)
|
2004-02-19 13:40:09 +00:00
|
|
|
|
|
|
|
def remove_itself_from_winsmenu(self):
|
2004-08-24 03:48:15 +00:00
|
|
|
del self.parent.child_windows[self.orig_handle]
|
2004-02-19 13:40:09 +00:00
|
|
|
self.menu_item.destroy()
|
2004-02-25 03:20:53 +00:00
|
|
|
self.winsmenu.destroy()
|
2004-02-20 00:52:24 +00:00
|
|
|
self.win_menu_item.destroy()
|
2004-02-19 13:40:09 +00:00
|
|
|
|
|
|
|
def present(self,obj):
|
|
|
|
self.window.present()
|
|
|
|
|
2003-11-18 04:26:06 +00:00
|
|
|
def on_help_clicked(self,obj):
|
|
|
|
"""Display the relevant portion of GRAMPS manual"""
|
2003-12-02 04:27:23 +00:00
|
|
|
gnome.help_display('gramps-manual','gramps-edit-complete')
|
2003-11-18 04:26:06 +00:00
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
def build_columns(self,tree,list):
|
|
|
|
cnum = 0
|
|
|
|
for name in list:
|
|
|
|
renderer = gtk.CellRendererText()
|
|
|
|
column = gtk.TreeViewColumn(name[0],renderer,text=cnum)
|
|
|
|
column.set_min_width(name[1])
|
|
|
|
cnum = cnum + 1
|
|
|
|
tree.append_column(column)
|
|
|
|
|
2004-08-11 03:42:38 +00:00
|
|
|
def lds_field(self,lds_ord,combo,date,place):
|
2004-08-04 04:53:29 +00:00
|
|
|
AutoComp.fill_combo(combo,_temple_names)
|
2004-08-11 03:42:38 +00:00
|
|
|
if not lds_ord.is_empty():
|
|
|
|
stat = lds_ord.get_status()
|
|
|
|
date.set_text(lds_ord.get_date())
|
|
|
|
if lds_ord.get_temple() != "":
|
|
|
|
name = const.lds_temple_to_abrev[lds_ord.get_temple()]
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
name = ""
|
2004-08-04 04:53:29 +00:00
|
|
|
combo.child.set_text(name)
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
stat = 0
|
2004-08-04 04:53:29 +00:00
|
|
|
combo.child.set_text("")
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-05-02 04:10:33 +00:00
|
|
|
build_dropdown(place,self.place_list)
|
2004-08-11 03:42:38 +00:00
|
|
|
if lds_ord and lds_ord.get_place_handle():
|
|
|
|
lds_ord_place = self.db.get_place_from_handle(lds_ord.get_place_handle())
|
|
|
|
place.set_text(lds_ord_place.get_title())
|
2002-10-20 14:25:16 +00:00
|
|
|
return stat
|
|
|
|
|
|
|
|
def draw_lds(self):
|
|
|
|
"""Draws the LDS window. This window is not always drawn, and in
|
|
|
|
may cases is hidden."""
|
|
|
|
|
|
|
|
self.ldsbap_date = self.get_widget("ldsbapdate")
|
|
|
|
self.ldsbap_temple = self.get_widget("ldsbaptemple")
|
|
|
|
self.ldsend_date = self.get_widget("endowdate")
|
|
|
|
self.ldsend_temple = self.get_widget("endowtemple")
|
|
|
|
self.ldsseal_date = self.get_widget("sealdate")
|
|
|
|
self.ldsseal_temple = self.get_widget("sealtemple")
|
|
|
|
self.ldsseal_fam = self.get_widget("sealparents")
|
|
|
|
self.ldsbapstat = self.get_widget("ldsbapstat")
|
|
|
|
self.ldssealstat = self.get_widget("sealstat")
|
|
|
|
self.ldsendowstat = self.get_widget("endowstat")
|
|
|
|
self.ldsbapplace = self.get_widget("lds_bap_place")
|
|
|
|
self.ldssealplace = self.get_widget("lds_seal_place")
|
|
|
|
self.ldsendowplace = self.get_widget("lds_end_place")
|
|
|
|
|
|
|
|
self.bstat = self.lds_field(self.lds_baptism,
|
|
|
|
self.ldsbap_temple,
|
|
|
|
self.ldsbap_date,
|
|
|
|
self.ldsbapplace)
|
|
|
|
|
|
|
|
self.estat = self.lds_field(self.lds_endowment,
|
|
|
|
self.ldsend_temple,
|
|
|
|
self.ldsend_date,
|
|
|
|
self.ldsendowplace)
|
|
|
|
|
|
|
|
self.seal_stat = self.lds_field(self.lds_sealing,
|
|
|
|
self.ldsseal_temple,
|
|
|
|
self.ldsseal_date,
|
|
|
|
self.ldssealplace)
|
|
|
|
if self.lds_sealing:
|
2004-07-28 02:29:07 +00:00
|
|
|
self.ldsfam = self.lds_sealing.get_family_handle()
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
self.ldsfam = None
|
|
|
|
|
|
|
|
myMenu = gtk.Menu()
|
|
|
|
item = gtk.MenuItem(_("None"))
|
|
|
|
item.set_data("f",None)
|
|
|
|
item.connect("activate",self.menu_changed)
|
|
|
|
item.show()
|
|
|
|
myMenu.append(item)
|
|
|
|
|
|
|
|
index = 0
|
|
|
|
hist = 0
|
2004-07-28 02:29:07 +00:00
|
|
|
flist = [self.person.get_main_parents_family_handle()]
|
|
|
|
for (fam,mrel,frel) in self.person.get_parent_family_handle_list():
|
2004-03-22 23:59:37 +00:00
|
|
|
if fam not in flist:
|
|
|
|
flist.append(fam)
|
2004-02-21 06:40:44 +00:00
|
|
|
for fam_id in flist:
|
2004-08-19 21:35:16 +00:00
|
|
|
fam = self.db.get_family_from_handle(fam_id)
|
2002-10-20 14:25:16 +00:00
|
|
|
if fam == None:
|
|
|
|
continue
|
2004-07-28 02:29:07 +00:00
|
|
|
f_id = fam.get_father_handle()
|
|
|
|
m_id = fam.get_mother_handle()
|
2004-08-07 05:16:57 +00:00
|
|
|
f = self.db.get_person_from_handle(f_id)
|
|
|
|
m = self.db.get_person_from_handle(m_id)
|
2002-10-20 14:25:16 +00:00
|
|
|
if f and m:
|
|
|
|
name = _("%(father)s and %(mother)s") % {
|
2004-07-15 02:54:04 +00:00
|
|
|
'father' : GrampsCfg.get_nameof()(f),
|
|
|
|
'mother' : GrampsCfg.get_nameof()(m) }
|
2002-10-20 14:25:16 +00:00
|
|
|
elif f:
|
2004-07-15 02:54:04 +00:00
|
|
|
name = GrampsCfg.get_nameof()(f)
|
2002-10-20 14:25:16 +00:00
|
|
|
elif m:
|
2004-07-15 02:54:04 +00:00
|
|
|
name = GrampsCfg.get_nameof()(m)
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
name = _("unknown")
|
|
|
|
item = gtk.MenuItem(name)
|
|
|
|
item.set_data("f",fam)
|
|
|
|
item.connect("activate",self.menu_changed)
|
|
|
|
item.show()
|
|
|
|
myMenu.append(item)
|
|
|
|
index = index + 1
|
|
|
|
if fam == self.ldsfam:
|
|
|
|
hist = index
|
|
|
|
self.ldsseal_fam.set_menu(myMenu)
|
|
|
|
self.ldsseal_fam.set_history(hist)
|
|
|
|
|
|
|
|
self.build_bap_menu()
|
|
|
|
self.build_seal_menu()
|
|
|
|
self.build_endow_menu()
|
|
|
|
|
2003-06-24 14:16:47 +00:00
|
|
|
def on_gender_activate (self, button):
|
2004-09-20 03:12:51 +00:00
|
|
|
self.should_guess_gender = False
|
2003-06-24 14:16:47 +00:00
|
|
|
|
2004-09-30 18:32:56 +00:00
|
|
|
def on_given_focus_out_event (self, entry, event):
|
2003-06-24 14:16:47 +00:00
|
|
|
if not self.should_guess_gender:
|
|
|
|
return
|
|
|
|
|
2003-12-17 05:23:16 +00:00
|
|
|
gender = self.db.genderStats.guess_gender(unicode(entry.get_text ()))
|
2003-06-24 14:16:47 +00:00
|
|
|
if gender == RelLib.Person.unknown:
|
2004-09-20 03:12:51 +00:00
|
|
|
self.is_unknown.set_active(True)
|
2003-06-24 14:16:47 +00:00
|
|
|
elif gender == RelLib.Person.male:
|
2004-09-20 03:12:51 +00:00
|
|
|
self.is_male.set_active(True)
|
2003-06-24 14:16:47 +00:00
|
|
|
else:
|
2004-09-20 03:12:51 +00:00
|
|
|
self.is_female.set_active(True)
|
2003-06-24 14:16:47 +00:00
|
|
|
|
2003-11-17 00:41:32 +00:00
|
|
|
def build_menu(self,list,task,opt_menu,type):
|
2002-10-20 14:25:16 +00:00
|
|
|
menu = gtk.Menu()
|
|
|
|
index = 0
|
|
|
|
for val in list:
|
|
|
|
menuitem = gtk.MenuItem(val)
|
|
|
|
menuitem.set_data("val",index)
|
|
|
|
menuitem.connect('activate',task)
|
|
|
|
menuitem.show()
|
|
|
|
menu.append(menuitem)
|
|
|
|
index = index + 1
|
|
|
|
opt_menu.set_menu(menu)
|
2003-11-17 00:41:32 +00:00
|
|
|
opt_menu.set_history(type)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def build_bap_menu(self):
|
2003-11-17 00:41:32 +00:00
|
|
|
self.build_menu(const.lds_baptism,self.set_lds_bap,self.ldsbapstat,
|
|
|
|
self.bstat)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def build_endow_menu(self):
|
2003-11-17 00:41:32 +00:00
|
|
|
self.build_menu(const.lds_baptism,self.set_lds_endow,self.ldsendowstat,
|
|
|
|
self.estat)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def build_seal_menu(self):
|
2003-11-17 00:41:32 +00:00
|
|
|
self.build_menu(const.lds_csealing,self.set_lds_seal,self.ldssealstat,
|
|
|
|
self.seal_stat)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def set_lds_bap(self,obj):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_baptism.set_status(obj.get_data("val"))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def set_lds_endow(self,obj):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_endowment.set_status(obj.get_data("val"))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def set_lds_seal(self,obj):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_sealing.set_status(obj.get_data("val"))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def ev_drag_data_received(self,widget,context,x,y,sel_data,info,time):
|
2003-01-06 05:14:49 +00:00
|
|
|
row = self.etree.get_row_at(x,y)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
if sel_data and sel_data.data:
|
|
|
|
exec 'data = %s' % sel_data.data
|
|
|
|
exec 'mytype = "%s"' % data[0]
|
|
|
|
exec 'person = "%s"' % data[1]
|
2003-01-06 05:14:49 +00:00
|
|
|
if mytype != 'pevent':
|
2002-10-20 14:25:16 +00:00
|
|
|
return
|
2004-07-28 02:29:07 +00:00
|
|
|
elif person == self.person.get_handle():
|
2003-01-06 05:14:49 +00:00
|
|
|
self.move_element(self.elist,self.etree.get_selected_row(),row)
|
|
|
|
else:
|
|
|
|
foo = pickle.loads(data[2]);
|
2004-02-14 05:40:30 +00:00
|
|
|
for src in foo.get_source_references():
|
2004-07-28 02:29:07 +00:00
|
|
|
base_handle = src.get_base_handle()
|
2004-08-07 05:16:57 +00:00
|
|
|
newbase = self.db.get_source_from_handle(base_handle)
|
2004-07-28 02:29:07 +00:00
|
|
|
src.set_base_handle(newbase)
|
|
|
|
place = foo.get_place_handle()
|
2003-01-06 05:14:49 +00:00
|
|
|
if place:
|
2004-07-28 02:29:07 +00:00
|
|
|
foo.set_place_handle(place.get_handle())
|
2003-01-06 05:14:49 +00:00
|
|
|
self.elist.insert(row,foo)
|
|
|
|
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
self.redraw_event_list()
|
|
|
|
|
2003-01-06 05:14:49 +00:00
|
|
|
def move_element(self,list,src,dest):
|
|
|
|
if src == -1:
|
|
|
|
return
|
|
|
|
obj = list[src]
|
|
|
|
list.remove(obj)
|
|
|
|
list.insert(dest,obj)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
def ev_drag_data_get(self,widget, context, sel_data, info, time):
|
2003-01-06 05:14:49 +00:00
|
|
|
ev = self.etree.get_selected_objects()
|
2003-01-02 04:31:52 +00:00
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
bits_per = 8; # we're going to pass a string
|
2003-01-06 05:14:49 +00:00
|
|
|
pickled = pickle.dumps(ev[0]);
|
2004-07-28 02:29:07 +00:00
|
|
|
data = str(('pevent',self.person.get_handle(),pickled));
|
2002-10-20 14:25:16 +00:00
|
|
|
sel_data.set(sel_data.target, bits_per, data)
|
|
|
|
|
2003-01-06 05:14:49 +00:00
|
|
|
def ev_drag_begin(self, context, a):
|
|
|
|
return
|
|
|
|
icon = self.etree.get_icon()
|
|
|
|
t = self.etree.tree
|
|
|
|
(x,y) = icon.get_size()
|
|
|
|
mask = gtk.gdk.Pixmap(self.window.window,x,y,1)
|
|
|
|
mask.draw_rectangle(t.get_style().white_gc, gtk.TRUE, 0,0,x,y)
|
|
|
|
t.drag_source_set_icon(t.get_colormap(),icon,mask)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
def url_drag_data_received(self,widget,context,x,y,sel_data,info,time):
|
2003-01-06 05:14:49 +00:00
|
|
|
row = self.wtree.get_row_at(x,y)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
if sel_data and sel_data.data:
|
|
|
|
exec 'data = %s' % sel_data.data
|
|
|
|
exec 'mytype = "%s"' % data[0]
|
|
|
|
exec 'person = "%s"' % data[1]
|
2003-01-06 05:14:49 +00:00
|
|
|
if mytype != "url":
|
2002-10-20 14:25:16 +00:00
|
|
|
return
|
2004-07-28 02:29:07 +00:00
|
|
|
elif person == self.person.get_handle():
|
2003-01-06 05:14:49 +00:00
|
|
|
self.move_element(self.ulist,self.wtree.get_selected_row(),row)
|
|
|
|
else:
|
|
|
|
foo = pickle.loads(data[2]);
|
|
|
|
self.ulist.append(foo)
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
self.redraw_url_list()
|
|
|
|
|
2003-01-08 05:41:35 +00:00
|
|
|
def url_drag_begin(self, context, a):
|
|
|
|
return
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
def url_drag_data_get(self,widget, context, sel_data, info, time):
|
2003-01-06 05:14:49 +00:00
|
|
|
ev = self.wtree.get_selected_objects()
|
2003-03-14 05:46:02 +00:00
|
|
|
|
|
|
|
if len(ev):
|
|
|
|
bits_per = 8; # we're going to pass a string
|
|
|
|
pickled = pickle.dumps(ev[0]);
|
2004-07-28 02:29:07 +00:00
|
|
|
data = str(('url',self.person.get_handle(),pickled));
|
2003-03-14 05:46:02 +00:00
|
|
|
sel_data.set(sel_data.target, bits_per, data)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def at_drag_data_received(self,widget,context,x,y,sel_data,info,time):
|
2003-01-06 05:14:49 +00:00
|
|
|
row = self.atree.get_row_at(x,y)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
if sel_data and sel_data.data:
|
|
|
|
exec 'data = %s' % sel_data.data
|
|
|
|
exec 'mytype = "%s"' % data[0]
|
|
|
|
exec 'person = "%s"' % data[1]
|
2003-01-06 05:14:49 +00:00
|
|
|
if mytype != 'pattr':
|
2002-10-20 14:25:16 +00:00
|
|
|
return
|
2004-07-28 02:29:07 +00:00
|
|
|
elif person == self.person.get_handle():
|
2003-01-06 05:14:49 +00:00
|
|
|
self.move_element(self.alist,self.atree.get_selected_row(),row)
|
|
|
|
else:
|
|
|
|
foo = pickle.loads(data[2]);
|
2004-02-14 05:40:30 +00:00
|
|
|
for src in foo.get_source_references():
|
2004-07-28 02:29:07 +00:00
|
|
|
base_handle = src.get_base_handle()
|
2004-08-07 05:16:57 +00:00
|
|
|
newbase = self.db.get_source_from_handle(base_handle)
|
2004-07-28 02:29:07 +00:00
|
|
|
src.set_base_handle(newbase)
|
2003-01-06 05:14:49 +00:00
|
|
|
self.alist.append(foo)
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
self.redraw_attr_list()
|
|
|
|
|
2003-01-08 05:41:35 +00:00
|
|
|
def at_drag_begin(self, context, a):
|
|
|
|
return
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
def at_drag_data_get(self,widget, context, sel_data, info, time):
|
2003-01-06 05:14:49 +00:00
|
|
|
ev = self.atree.get_selected_objects()
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-03-14 05:46:02 +00:00
|
|
|
if len(ev):
|
|
|
|
bits_per = 8; # we're going to pass a string
|
|
|
|
pickled = pickle.dumps(ev[0]);
|
2004-07-28 02:29:07 +00:00
|
|
|
data = str(('pattr',self.person.get_handle(),pickled));
|
2003-03-14 05:46:02 +00:00
|
|
|
sel_data.set(sel_data.target, bits_per, data)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
def ad_drag_data_received(self,widget,context,x,y,sel_data,info,time):
|
2003-01-06 05:14:49 +00:00
|
|
|
row = self.ptree.get_row_at(x,y)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
if sel_data and sel_data.data:
|
|
|
|
exec 'data = %s' % sel_data.data
|
|
|
|
exec 'mytype = "%s"' % data[0]
|
|
|
|
exec 'person = "%s"' % data[1]
|
2003-01-06 05:14:49 +00:00
|
|
|
if mytype != 'paddr':
|
2002-10-20 14:25:16 +00:00
|
|
|
return
|
2004-07-28 02:29:07 +00:00
|
|
|
elif person == self.person.get_handle():
|
2003-01-06 05:14:49 +00:00
|
|
|
self.move_element(self.plist,self.ptree.get_selected_row(),row)
|
|
|
|
else:
|
|
|
|
foo = pickle.loads(data[2]);
|
2004-02-14 05:40:30 +00:00
|
|
|
for src in foo.get_source_references():
|
2004-07-28 02:29:07 +00:00
|
|
|
base_handle = src.get_base_handle()
|
2004-08-07 05:16:57 +00:00
|
|
|
newbase = self.db.get_source_from_handle(base_handle)
|
2004-07-28 02:29:07 +00:00
|
|
|
src.set_base_handle(newbase)
|
2003-01-08 05:41:35 +00:00
|
|
|
self.plist.insert(row,foo)
|
|
|
|
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
self.redraw_addr_list()
|
|
|
|
|
|
|
|
def ad_drag_data_get(self,widget, context, sel_data, info, time):
|
2003-01-06 05:14:49 +00:00
|
|
|
ev = self.ptree.get_selected_objects()
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-03-14 05:46:02 +00:00
|
|
|
if len(ev):
|
|
|
|
bits_per = 8; # we're going to pass a string
|
|
|
|
pickled = pickle.dumps(ev[0]);
|
2004-07-28 02:29:07 +00:00
|
|
|
data = str(('paddr',self.person.get_handle(),pickled));
|
2003-03-14 05:46:02 +00:00
|
|
|
sel_data.set(sel_data.target, bits_per, data)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-01-08 05:41:35 +00:00
|
|
|
def ad_drag_begin(self, context, a):
|
|
|
|
return
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
def menu_changed(self,obj):
|
|
|
|
self.ldsfam = obj.get_data("f")
|
|
|
|
|
|
|
|
def get_widget(self,str):
|
|
|
|
"""returns the widget related to the passed string"""
|
|
|
|
return self.top.get_widget(str)
|
|
|
|
|
|
|
|
def redraw_name_list(self):
|
|
|
|
"""redraws the name list"""
|
2002-11-21 04:41:40 +00:00
|
|
|
self.ntree.clear()
|
2003-06-11 03:26:02 +00:00
|
|
|
self.nmap = {}
|
2002-11-21 04:41:40 +00:00
|
|
|
for name in self.nlist:
|
2004-08-11 03:42:38 +00:00
|
|
|
node = self.ntree.add([name.get_name(),_(name.get_type())],name)
|
|
|
|
self.nmap[str(name)] = node
|
2003-11-11 00:38:24 +00:00
|
|
|
if self.nlist:
|
2002-12-14 05:07:09 +00:00
|
|
|
self.ntree.select_row(0)
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.names_label)
|
2003-11-11 00:32:28 +00:00
|
|
|
else:
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.unbold_label(self.names_label)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def redraw_url_list(self):
|
|
|
|
"""redraws the url list, disabling the go button if no url
|
|
|
|
is selected"""
|
2002-11-21 04:41:40 +00:00
|
|
|
self.wtree.clear()
|
2003-06-11 03:26:02 +00:00
|
|
|
self.wmap = {}
|
2002-11-21 04:41:40 +00:00
|
|
|
for url in self.ulist:
|
2004-08-11 03:42:38 +00:00
|
|
|
node = self.wtree.add([url.get_path(),url.get_description()],url)
|
|
|
|
self.wmap[str(url)] = node
|
2003-06-11 03:26:02 +00:00
|
|
|
|
2002-11-21 04:41:40 +00:00
|
|
|
if len(self.ulist) > 0:
|
2004-09-20 03:12:51 +00:00
|
|
|
self.web_go.set_sensitive(False)
|
2002-12-14 05:07:09 +00:00
|
|
|
self.wtree.select_row(0)
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.inet_label)
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-09-20 03:12:51 +00:00
|
|
|
self.web_go.set_sensitive(False)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.web_url.set_text("")
|
|
|
|
self.web_description.set_text("")
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.unbold_label(self.inet_label)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def redraw_addr_list(self):
|
2002-11-21 04:41:40 +00:00
|
|
|
"""Redraws the address list"""
|
|
|
|
self.ptree.clear()
|
2003-06-11 03:26:02 +00:00
|
|
|
self.pmap = {}
|
2002-11-21 04:41:40 +00:00
|
|
|
for addr in self.plist:
|
2004-02-14 05:40:30 +00:00
|
|
|
location = "%s %s %s %s" % (addr.get_street(),addr.get_city(),
|
|
|
|
addr.get_state(),addr.get_country())
|
2004-08-11 03:42:38 +00:00
|
|
|
node = self.ptree.add([addr.get_date(),location],addr)
|
|
|
|
self.pmap[str(addr)] = node
|
2002-12-14 05:07:09 +00:00
|
|
|
if self.plist:
|
|
|
|
self.ptree.select_row(0)
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.addr_label)
|
2003-11-11 00:32:28 +00:00
|
|
|
else:
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.unbold_label(self.addr_label)
|
2002-11-21 04:41:40 +00:00
|
|
|
|
|
|
|
def redraw_attr_list(self):
|
|
|
|
"""redraws the attribute list for the person"""
|
|
|
|
self.atree.clear()
|
2003-06-11 02:54:57 +00:00
|
|
|
self.amap = {}
|
2002-11-21 04:41:40 +00:00
|
|
|
for attr in self.alist:
|
2004-08-11 03:42:38 +00:00
|
|
|
node = self.atree.add([const.display_pattr(attr.get_type()),attr.get_value()],attr)
|
|
|
|
self.amap[str(attr)] = node
|
2002-12-14 05:07:09 +00:00
|
|
|
if self.alist:
|
|
|
|
self.atree.select_row(0)
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.attr_label)
|
2003-11-11 00:32:28 +00:00
|
|
|
else:
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.unbold_label(self.attr_label)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-06-11 03:26:02 +00:00
|
|
|
def name_edit_callback(self,name):
|
|
|
|
self.redraw_name_list()
|
|
|
|
self.ntree.select_iter(self.nmap[str(name)])
|
|
|
|
|
|
|
|
def addr_edit_callback(self,addr):
|
|
|
|
self.redraw_addr_list()
|
|
|
|
self.ptree.select_iter(self.pmap[str(addr)])
|
|
|
|
|
|
|
|
def url_edit_callback(self,url):
|
|
|
|
self.redraw_url_list()
|
|
|
|
self.wtree.select_iter(self.wmap[str(url)])
|
|
|
|
|
2003-06-11 02:54:57 +00:00
|
|
|
def event_edit_callback(self,event):
|
|
|
|
"""Birth and death events may not be in the map"""
|
|
|
|
self.redraw_event_list()
|
|
|
|
try:
|
|
|
|
self.etree.select_iter(self.emap[str(event)])
|
|
|
|
except:
|
|
|
|
pass
|
|
|
|
|
|
|
|
def attr_edit_callback(self,attr):
|
|
|
|
self.redraw_attr_list()
|
|
|
|
self.atree.select_iter(self.amap[str(attr)])
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
def redraw_event_list(self):
|
|
|
|
"""redraw_event_list - Update both the birth and death place combo
|
|
|
|
boxes for any changes that occurred in the 'Event Edit' window.
|
|
|
|
Make sure not to allow the editing of a birth event to change
|
|
|
|
any values in the death event, and vice versa. Since updating a
|
|
|
|
combo list resets its present value, this code will have to save
|
|
|
|
and restore the value for the event *not* being edited."""
|
2002-11-21 04:41:40 +00:00
|
|
|
|
|
|
|
self.etree.clear()
|
2003-06-11 02:54:57 +00:00
|
|
|
self.emap = {}
|
2004-07-28 02:29:07 +00:00
|
|
|
for event_handle in self.elist:
|
* src/AddSpouse.py, src/ChooseParents.py, src/EditPerson.py,
src/EditPlace.py, src/EditSource.py, src/EventEdit.py,
src/FamilyView.py, src/GenericFilter.py,
src/Marriage.py, src/PedView.py, src/PeopleModel.py,
src/PlaceView.py, src/RelLib.py, src/SelectChild.py,
src/Sort.py, src/SourceView.py, src/SubstKeywords.py,
src/WriteGedcom.py, src/WriteXML.py, src/plugins/AncestorReport.py,
src/plugins/Ancestors.py, src/plugins/ChangeTypes.py,
src/plugins/DescendReport.py, src/plugins/DetDescendantReport.py,
src/plugins/EventCmp.py, src/plugins/FamilyGroup.py,
src/plugins/FanChart.py, src/plugins/FtmStyleAncestors.py,
src/plugins/FtmStyleDescendants.py, src/plugins/GraphViz.py,
src/plugins/IndivComplete.py, src/plugins/IndivSummary.py,
src/plugins/Merge.py, src/plugins/RelCalc.py, src/plugins/RelGraph.py,
src/plugins/Summary.py, src/plugins/TimeLine.py, src/plugins/Verify.py,
src/plugins/WebPage.py, src/plugins/WriteCD.py,
src/plugins/WritePkg.py, src/plugins/DetAncestralReport.py:
Use get_event_from_handle (not find_ ).
svn: r3462
2004-08-21 18:56:01 +00:00
|
|
|
event = self.db.get_event_from_handle(event_handle)
|
2004-02-14 05:40:30 +00:00
|
|
|
pname = place_title(self.db,event)
|
2004-10-16 17:26:04 +00:00
|
|
|
node = self.etree.add([const.display_pevent(event.get_name()),
|
|
|
|
event.get_description(),
|
|
|
|
event.get_quote_date(),pname],event)
|
2004-08-11 03:42:38 +00:00
|
|
|
self.emap[str(event)] = node
|
2002-12-14 05:07:09 +00:00
|
|
|
if self.elist:
|
|
|
|
self.etree.select_row(0)
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.events_label)
|
2003-11-11 00:32:28 +00:00
|
|
|
else:
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.unbold_label(self.events_label)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
# Remember old combo list input
|
2003-04-04 05:48:25 +00:00
|
|
|
|
2003-12-17 05:23:16 +00:00
|
|
|
bplace_text = unicode(self.bplace.get_text())
|
|
|
|
dplace_text = unicode(self.dplace.get_text())
|
2003-04-04 05:48:25 +00:00
|
|
|
|
|
|
|
prev_btext = Utils.strip_id(bplace_text)
|
|
|
|
prev_dtext = Utils.strip_id(dplace_text)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
# Update birth with new values, make sure death values don't change
|
|
|
|
if self.update_birth:
|
2004-09-20 03:12:51 +00:00
|
|
|
self.update_birth = False
|
2002-10-20 14:25:16 +00:00
|
|
|
self.update_birth_info()
|
|
|
|
self.dplace.set_text(prev_dtext)
|
|
|
|
|
|
|
|
# Update death with new values, make sure birth values don't change
|
|
|
|
if self.update_death:
|
2004-09-20 03:12:51 +00:00
|
|
|
self.update_death = False
|
2002-10-20 14:25:16 +00:00
|
|
|
self.update_death_info()
|
|
|
|
self.bplace.set_text(prev_btext)
|
|
|
|
|
|
|
|
def on_add_addr_clicked(self,obj):
|
|
|
|
"""Invokes the address editor to add a new address"""
|
|
|
|
import AddrEdit
|
* src/SourceView.py (button_press,on_add_clicked,on_delete_clicked,
on_edit_clicked): Pass parent window to the child dialog.
* src/Sources.py (add_src_clicked): Likewise.
* src/EditSource.py (__init__): Add optional parent_window argument.
Make dialog modal and transient for its parent.
* src/gramps.glade (sourceEditor dialog): Delete unneeded handlers
for buttons.
* src/QuestionDialog.py (SaveDialog,QuestionDialog,OptionDialog,
ErrorDialog,WarningDialog,MissingMediaDialog): Set transient status
if parent is given.
* src/EventEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/Witness.py: Make WittnessEditor dialog modal and transient for
its parent. Call SelectPerson with itself as a parent.
* src/SelectPerson.py (__init__): Make dialog transient for its parent.
* src/imagesel.glade: Define proper responses and delete unneeded handlers
for buttons. Make gtkFileEntry modal.
* src/dialog.glade (all dialogs): Define proper responses for buttons.
* src/EditPerson.py (on_add_aka_clicked, on_aka_update_clicked):
Call NameEdit with itself as a parent; (on_add_attr_clicked,
on_update_attr_clicked): Call AttributeEditor with itself as a parent;
(on_add_addr_clicked,on_update_addr_clicked): Call AddressEditor with
itself as a parent; (on_add_url_clicked,on_update_url_clicked): Call
UrlEditor with itself as a parent; (on_name_note_clicked,
on_ldsbap_note_clicked,on_ldsendow_note_clicked,
on_ldsseal_note_clicked): Call NoteEditor with itself as a parent.
* src/NameEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/AttrEdit.py (__init__): Likewise.
* src/AddrEdit.py (__init__): Likewise.
* src/UrlEdit.py (__init__): Likewise.
* src/NoteEdit.py (__init__): Likewise.
svn: r2131
2003-09-15 04:11:30 +00:00
|
|
|
AddrEdit.AddressEditor(self,None,self.addr_edit_callback,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_add_aka_clicked(self,obj):
|
|
|
|
"""Invokes the name editor to add a new name"""
|
|
|
|
import NameEdit
|
2004-09-30 01:33:15 +00:00
|
|
|
NameEdit.NameEditor(self,None,self.name_edit_callback,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_add_url_clicked(self,obj):
|
|
|
|
"""Invokes the url editor to add a new name"""
|
|
|
|
import UrlEdit
|
2004-02-14 05:40:30 +00:00
|
|
|
pname = self.person.get_primary_name().get_name()
|
* src/SourceView.py (button_press,on_add_clicked,on_delete_clicked,
on_edit_clicked): Pass parent window to the child dialog.
* src/Sources.py (add_src_clicked): Likewise.
* src/EditSource.py (__init__): Add optional parent_window argument.
Make dialog modal and transient for its parent.
* src/gramps.glade (sourceEditor dialog): Delete unneeded handlers
for buttons.
* src/QuestionDialog.py (SaveDialog,QuestionDialog,OptionDialog,
ErrorDialog,WarningDialog,MissingMediaDialog): Set transient status
if parent is given.
* src/EventEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/Witness.py: Make WittnessEditor dialog modal and transient for
its parent. Call SelectPerson with itself as a parent.
* src/SelectPerson.py (__init__): Make dialog transient for its parent.
* src/imagesel.glade: Define proper responses and delete unneeded handlers
for buttons. Make gtkFileEntry modal.
* src/dialog.glade (all dialogs): Define proper responses for buttons.
* src/EditPerson.py (on_add_aka_clicked, on_aka_update_clicked):
Call NameEdit with itself as a parent; (on_add_attr_clicked,
on_update_attr_clicked): Call AttributeEditor with itself as a parent;
(on_add_addr_clicked,on_update_addr_clicked): Call AddressEditor with
itself as a parent; (on_add_url_clicked,on_update_url_clicked): Call
UrlEditor with itself as a parent; (on_name_note_clicked,
on_ldsbap_note_clicked,on_ldsendow_note_clicked,
on_ldsseal_note_clicked): Call NoteEditor with itself as a parent.
* src/NameEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/AttrEdit.py (__init__): Likewise.
* src/AddrEdit.py (__init__): Likewise.
* src/UrlEdit.py (__init__): Likewise.
* src/NoteEdit.py (__init__): Likewise.
svn: r2131
2003-09-15 04:11:30 +00:00
|
|
|
UrlEdit.UrlEditor(self,pname,None,self.url_edit_callback,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_add_attr_clicked(self,obj):
|
|
|
|
"""Brings up the AttributeEditor for a new attribute"""
|
|
|
|
import AttrEdit
|
2004-02-14 05:40:30 +00:00
|
|
|
pname = self.person.get_primary_name().get_name()
|
2003-06-11 02:54:57 +00:00
|
|
|
AttrEdit.AttributeEditor(self,None,pname,const.personalAttributes,
|
* src/SourceView.py (button_press,on_add_clicked,on_delete_clicked,
on_edit_clicked): Pass parent window to the child dialog.
* src/Sources.py (add_src_clicked): Likewise.
* src/EditSource.py (__init__): Add optional parent_window argument.
Make dialog modal and transient for its parent.
* src/gramps.glade (sourceEditor dialog): Delete unneeded handlers
for buttons.
* src/QuestionDialog.py (SaveDialog,QuestionDialog,OptionDialog,
ErrorDialog,WarningDialog,MissingMediaDialog): Set transient status
if parent is given.
* src/EventEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/Witness.py: Make WittnessEditor dialog modal and transient for
its parent. Call SelectPerson with itself as a parent.
* src/SelectPerson.py (__init__): Make dialog transient for its parent.
* src/imagesel.glade: Define proper responses and delete unneeded handlers
for buttons. Make gtkFileEntry modal.
* src/dialog.glade (all dialogs): Define proper responses for buttons.
* src/EditPerson.py (on_add_aka_clicked, on_aka_update_clicked):
Call NameEdit with itself as a parent; (on_add_attr_clicked,
on_update_attr_clicked): Call AttributeEditor with itself as a parent;
(on_add_addr_clicked,on_update_addr_clicked): Call AddressEditor with
itself as a parent; (on_add_url_clicked,on_update_url_clicked): Call
UrlEditor with itself as a parent; (on_name_note_clicked,
on_ldsbap_note_clicked,on_ldsendow_note_clicked,
on_ldsseal_note_clicked): Call NoteEditor with itself as a parent.
* src/NameEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/AttrEdit.py (__init__): Likewise.
* src/AddrEdit.py (__init__): Likewise.
* src/UrlEdit.py (__init__): Likewise.
* src/NoteEdit.py (__init__): Likewise.
svn: r2131
2003-09-15 04:11:30 +00:00
|
|
|
self.attr_edit_callback,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_up_clicked(self,obj):
|
|
|
|
sel = obj.get_selection()
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = sel.get_selected()
|
|
|
|
if node:
|
|
|
|
row = store.get_path(node)
|
2002-10-20 14:25:16 +00:00
|
|
|
sel.select_path((row[0]-1))
|
|
|
|
|
|
|
|
def on_down_clicked(self,obj):
|
|
|
|
sel = obj.get_selection()
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = sel.get_selected()
|
|
|
|
if node:
|
|
|
|
row = store.get_path(node)
|
2002-10-20 14:25:16 +00:00
|
|
|
sel.select_path((row[0]+1))
|
|
|
|
|
|
|
|
def on_event_add_clicked(self,obj):
|
|
|
|
"""Brings up the EventEditor for a new event"""
|
|
|
|
import EventEdit
|
2004-02-14 05:40:30 +00:00
|
|
|
pname = self.person.get_primary_name().get_name()
|
2002-10-20 14:25:16 +00:00
|
|
|
EventEdit.EventEditor(self,pname,const.personalEvents,
|
2004-08-20 21:26:51 +00:00
|
|
|
const.personal_events,None,None,0,self.event_edit_callback)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_edit_birth_clicked(self,obj):
|
|
|
|
"""Brings up the EventEditor for the birth record, event
|
|
|
|
name cannot be changed"""
|
|
|
|
|
|
|
|
import EventEdit
|
2004-09-20 03:12:51 +00:00
|
|
|
self.update_birth = True
|
2004-02-14 05:40:30 +00:00
|
|
|
pname = self.person.get_primary_name().get_name()
|
2002-10-20 14:25:16 +00:00
|
|
|
event = self.birth
|
2004-09-19 15:17:57 +00:00
|
|
|
event.set_date_object(Date.Date(self.birth_date_object))
|
2003-12-17 05:23:16 +00:00
|
|
|
def_placename = unicode(self.bplace.get_text())
|
2003-04-04 05:48:25 +00:00
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
p = self.get_place(self.bplace)
|
|
|
|
if p:
|
2004-07-28 02:29:07 +00:00
|
|
|
event.set_place_handle(p)
|
2002-10-20 14:25:16 +00:00
|
|
|
EventEdit.EventEditor(self,pname,const.personalEvents,
|
2004-08-20 21:26:51 +00:00
|
|
|
const.personal_events,event,def_placename,1,
|
2003-06-11 02:54:57 +00:00
|
|
|
self.event_edit_callback)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_edit_death_clicked(self,obj):
|
|
|
|
"""Brings up the EventEditor for the death record, event
|
|
|
|
name cannot be changed"""
|
|
|
|
|
|
|
|
import EventEdit
|
2004-09-20 03:12:51 +00:00
|
|
|
self.update_death = True
|
2004-02-14 05:40:30 +00:00
|
|
|
pname = self.person.get_primary_name().get_name()
|
2002-10-20 14:25:16 +00:00
|
|
|
event = self.death
|
2004-09-19 15:17:57 +00:00
|
|
|
event.set_date_object(Date.Date(self.death_date_object))
|
2003-12-17 05:23:16 +00:00
|
|
|
def_placename = unicode(self.dplace.get_text())
|
2003-04-04 05:48:25 +00:00
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
p = self.get_place(self.dplace)
|
|
|
|
if p:
|
2004-07-28 02:29:07 +00:00
|
|
|
event.set_place_handle(p)
|
2002-10-20 14:25:16 +00:00
|
|
|
EventEdit.EventEditor(self,pname,const.personalEvents,
|
2004-08-20 21:26:51 +00:00
|
|
|
const.personal_events,event,def_placename,1,
|
2003-06-11 02:54:57 +00:00
|
|
|
self.event_edit_callback)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_aka_delete_clicked(self,obj):
|
|
|
|
"""Deletes the selected name from the name list"""
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.ntree.get_selected()
|
|
|
|
if node:
|
|
|
|
self.nlist.remove(self.ntree.get_object(node))
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
self.redraw_name_list()
|
|
|
|
|
|
|
|
def on_delete_url_clicked(self,obj):
|
|
|
|
"""Deletes the selected URL from the URL list"""
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.wtree.get_selected()
|
|
|
|
if node:
|
|
|
|
self.ulist.remove(self.wtree.get_object(node))
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
self.redraw_url_list()
|
|
|
|
|
|
|
|
def on_delete_attr_clicked(self,obj):
|
|
|
|
"""Deletes the selected attribute from the attribute list"""
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.atree.get_selected()
|
|
|
|
if node:
|
|
|
|
self.alist.remove(self.atree.get_object(node))
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
self.redraw_attr_list()
|
|
|
|
|
|
|
|
def on_delete_addr_clicked(self,obj):
|
|
|
|
"""Deletes the selected address from the address list"""
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.ptree.get_selected()
|
|
|
|
if node:
|
|
|
|
self.plist.remove(self.ptree.get_object(node))
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
self.redraw_addr_list()
|
|
|
|
|
|
|
|
def on_web_go_clicked(self,obj):
|
|
|
|
"""Attempts to display the selected URL in a web browser"""
|
|
|
|
text = obj.get()
|
|
|
|
if text:
|
2003-03-03 04:32:53 +00:00
|
|
|
gnome.url_show(text)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_cancel_edit(self,obj):
|
|
|
|
"""If the data has changed, give the user a chance to cancel
|
|
|
|
the close window"""
|
2004-11-11 04:28:40 +00:00
|
|
|
|
|
|
|
if self.did_data_change() and not GrampsGconfKeys.get_dont_ask():
|
2004-02-14 05:40:30 +00:00
|
|
|
n = "<i>%s</i>" % self.person.get_primary_name().get_regular_name()
|
2003-05-24 03:40:58 +00:00
|
|
|
SaveDialog(_('Save changes to %s?') % n,
|
2003-02-24 04:51:57 +00:00
|
|
|
_('If you close without saving, the changes you '
|
|
|
|
'have made will be lost'),
|
|
|
|
self.cancel_callback,
|
|
|
|
self.save)
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-08-04 04:53:29 +00:00
|
|
|
self.close()
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-02-24 04:51:57 +00:00
|
|
|
def save(self):
|
|
|
|
self.on_apply_person_clicked(None)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
def on_delete_event(self,obj,b):
|
|
|
|
"""If the data has changed, give the user a chance to cancel
|
|
|
|
the close window"""
|
2004-11-11 04:28:40 +00:00
|
|
|
if self.did_data_change() and not GrampsGconfKeys.get_dont_ask():
|
2004-02-14 05:40:30 +00:00
|
|
|
n = "<i>%s</i>" % self.person.get_primary_name().get_regular_name()
|
2003-05-24 03:40:58 +00:00
|
|
|
SaveDialog(_('Save Changes to %s?') % n,
|
2003-02-24 04:51:57 +00:00
|
|
|
_('If you close without saving, the changes you '
|
|
|
|
'have made will be lost'),
|
|
|
|
self.cancel_callback,
|
|
|
|
self.save)
|
2004-09-20 03:12:51 +00:00
|
|
|
return True
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-08-04 04:53:29 +00:00
|
|
|
self.close()
|
2004-09-20 03:12:51 +00:00
|
|
|
return False
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def cancel_callback(self):
|
|
|
|
"""If the user answered yes to abandoning changes, close the window"""
|
2004-08-04 04:53:29 +00:00
|
|
|
self.close()
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def did_data_change(self):
|
|
|
|
"""Check to see if any of the data has changed from the
|
2004-03-09 05:12:14 +00:00
|
|
|
orig record"""
|
2003-09-20 19:56:27 +00:00
|
|
|
|
2004-05-02 04:10:33 +00:00
|
|
|
surname = unicode(self.surname.get_text())
|
2004-09-19 15:17:57 +00:00
|
|
|
self.birth.set_date_object(self.birth_date_object)
|
|
|
|
self.death.set_date_object(self.death_date_object)
|
2003-12-17 05:23:16 +00:00
|
|
|
|
2004-08-04 04:53:29 +00:00
|
|
|
ntype = unicode(self.ntype_field.child.get_text())
|
2003-12-17 05:23:16 +00:00
|
|
|
suffix = unicode(self.suffix.get_text())
|
|
|
|
prefix = unicode(self.prefix.get_text())
|
|
|
|
given = unicode(self.given.get_text())
|
|
|
|
nick = unicode(self.nick.get_text())
|
|
|
|
title = unicode(self.title.get_text())
|
2002-10-20 14:25:16 +00:00
|
|
|
male = self.is_male.get_active()
|
|
|
|
female = self.is_female.get_active()
|
|
|
|
unknown = self.is_unknown.get_active()
|
2003-12-17 16:06:36 +00:00
|
|
|
text = unicode(self.notes_buffer.get_text(self.notes_buffer.get_start_iter(),
|
|
|
|
self.notes_buffer.get_end_iter(),gtk.FALSE))
|
2003-12-16 00:37:47 +00:00
|
|
|
format = self.preform.get_active()
|
2003-12-17 05:23:16 +00:00
|
|
|
idval = unicode(self.gid.get_text())
|
2004-08-26 21:54:14 +00:00
|
|
|
if idval == "":
|
|
|
|
idval = None
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = False
|
2004-02-14 05:40:30 +00:00
|
|
|
name = self.person.get_primary_name()
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-08-13 04:34:07 +00:00
|
|
|
if self.complete.get_active() != self.person.get_complete_flag():
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2003-12-03 03:49:39 +00:00
|
|
|
|
2004-06-27 03:10:06 +00:00
|
|
|
if self.person.get_gramps_id() != idval:
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-02-14 05:40:30 +00:00
|
|
|
if suffix != name.get_suffix():
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-10-09 01:35:58 +00:00
|
|
|
if self.use_patronymic:
|
|
|
|
if prefix != name.get_patronymic():
|
|
|
|
changed = True
|
|
|
|
elif prefix != name.get_surname_prefix():
|
|
|
|
changed = True
|
2004-02-14 05:40:30 +00:00
|
|
|
if surname.upper() != name.get_surname().upper():
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-02-14 05:40:30 +00:00
|
|
|
if ntype != const.NameTypesMap.find_value(name.get_type()):
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-02-14 05:40:30 +00:00
|
|
|
if given != name.get_first_name():
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-02-14 05:40:30 +00:00
|
|
|
if nick != self.person.get_nick_name():
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-02-14 05:40:30 +00:00
|
|
|
if title != name.get_title():
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-02-14 05:40:30 +00:00
|
|
|
if self.pname.get_note() != name.get_note():
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-10-03 21:04:54 +00:00
|
|
|
if not self.lds_not_loaded and self.check_lds():
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-08-24 03:48:15 +00:00
|
|
|
bplace = unicode(self.bplace.get_text().strip())
|
|
|
|
dplace = unicode(self.dplace.get_text().strip())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-06-13 15:08:07 +00:00
|
|
|
if self.pdmap.has_key(bplace):
|
2004-07-28 02:29:07 +00:00
|
|
|
self.birth.set_place_handle(self.pdmap[bplace])
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
if bplace != "":
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-07-28 02:29:07 +00:00
|
|
|
self.birth.set_place_handle('')
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-06-13 15:08:07 +00:00
|
|
|
if self.pdmap.has_key(dplace):
|
2004-07-28 02:29:07 +00:00
|
|
|
self.death.set_place_handle(self.pdmap[dplace])
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
if dplace != "":
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-07-28 02:29:07 +00:00
|
|
|
self.death.set_place_handle('')
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-19 05:07:46 +00:00
|
|
|
if not self.birth.are_equal(self.orig_birth):
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-02-19 05:07:46 +00:00
|
|
|
if not self.death.are_equal(self.orig_death):
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-02-14 05:40:30 +00:00
|
|
|
if male and self.person.get_gender() != RelLib.Person.male:
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-02-14 05:40:30 +00:00
|
|
|
elif female and self.person.get_gender() != RelLib.Person.female:
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2004-02-14 05:40:30 +00:00
|
|
|
elif unknown and self.person.get_gender() != RelLib.Person.unknown:
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
|
|
|
if text != self.person.get_note():
|
|
|
|
changed = True
|
2004-02-14 05:40:30 +00:00
|
|
|
if format != self.person.get_note_format():
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-10-03 21:04:54 +00:00
|
|
|
if not self.lds_not_loaded:
|
2004-02-14 05:40:30 +00:00
|
|
|
if not self.lds_baptism.are_equal(self.person.get_lds_baptism()):
|
2004-09-20 03:12:51 +00:00
|
|
|
changed= True
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if not self.lds_endowment.are_equal(self.person.get_lds_endowment()):
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if not self.lds_sealing.are_equal(self.person.get_lds_sealing()):
|
2004-09-20 03:12:51 +00:00
|
|
|
changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
return changed
|
|
|
|
|
|
|
|
def check_lds(self):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_baptism.set_date(unicode(self.ldsbap_date.get_text()))
|
2004-08-04 04:53:29 +00:00
|
|
|
temple = unicode(self.ldsbap_temple.child.get_text())
|
2002-10-20 14:25:16 +00:00
|
|
|
if const.lds_temple_codes.has_key(temple):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_baptism.set_temple(const.lds_temple_codes[temple])
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_baptism.set_temple("")
|
2004-07-28 02:29:07 +00:00
|
|
|
self.lds_baptism.set_place_handle(self.get_place(self.ldsbapplace,1))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_endowment.set_date(unicode(self.ldsend_date.get_text()))
|
2004-08-04 04:53:29 +00:00
|
|
|
temple = unicode(self.ldsend_temple.child.get_text())
|
2002-10-20 14:25:16 +00:00
|
|
|
if const.lds_temple_codes.has_key(temple):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_endowment.set_temple(const.lds_temple_codes[temple])
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_endowment.set_temple("")
|
2004-07-28 02:29:07 +00:00
|
|
|
self.lds_endowment.set_place_handle(self.get_place(self.ldsendowplace,1))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_sealing.set_date(unicode(self.ldsseal_date.get_text()))
|
2004-08-04 04:53:29 +00:00
|
|
|
temple = unicode(self.ldsseal_temple.child.get_text())
|
2002-10-20 14:25:16 +00:00
|
|
|
if const.lds_temple_codes.has_key(temple):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_sealing.set_temple(const.lds_temple_codes[temple])
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_sealing.set_temple("")
|
2004-07-28 02:29:07 +00:00
|
|
|
self.lds_sealing.set_family_handle(self.ldsfam)
|
|
|
|
self.lds_sealing.set_place_handle(self.get_place(self.ldssealplace,1))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_event_delete_clicked(self,obj):
|
|
|
|
"""Delete the selected event"""
|
|
|
|
if Utils.delete_selected(obj,self.elist):
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
self.redraw_event_list()
|
|
|
|
|
|
|
|
def update_birth_death(self):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.bplace.set_text(place_title(self.db,self.birth))
|
|
|
|
self.dplace.set_text(place_title(self.db,self.death))
|
|
|
|
|
2004-09-19 15:17:57 +00:00
|
|
|
self.bdate.set_text(self.dd.display(self.birth_date_object))
|
|
|
|
self.ddate.set_text(self.dd.display(self.death_date_object))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_update_attr_clicked(self,obj):
|
|
|
|
import AttrEdit
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.atree.get_selected()
|
|
|
|
if node:
|
|
|
|
attr = self.atree.get_object(node)
|
2004-02-14 05:40:30 +00:00
|
|
|
pname = self.person.get_primary_name().get_name()
|
2003-06-11 02:54:57 +00:00
|
|
|
AttrEdit.AttributeEditor(self,attr,pname,const.personalAttributes,
|
* src/SourceView.py (button_press,on_add_clicked,on_delete_clicked,
on_edit_clicked): Pass parent window to the child dialog.
* src/Sources.py (add_src_clicked): Likewise.
* src/EditSource.py (__init__): Add optional parent_window argument.
Make dialog modal and transient for its parent.
* src/gramps.glade (sourceEditor dialog): Delete unneeded handlers
for buttons.
* src/QuestionDialog.py (SaveDialog,QuestionDialog,OptionDialog,
ErrorDialog,WarningDialog,MissingMediaDialog): Set transient status
if parent is given.
* src/EventEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/Witness.py: Make WittnessEditor dialog modal and transient for
its parent. Call SelectPerson with itself as a parent.
* src/SelectPerson.py (__init__): Make dialog transient for its parent.
* src/imagesel.glade: Define proper responses and delete unneeded handlers
for buttons. Make gtkFileEntry modal.
* src/dialog.glade (all dialogs): Define proper responses for buttons.
* src/EditPerson.py (on_add_aka_clicked, on_aka_update_clicked):
Call NameEdit with itself as a parent; (on_add_attr_clicked,
on_update_attr_clicked): Call AttributeEditor with itself as a parent;
(on_add_addr_clicked,on_update_addr_clicked): Call AddressEditor with
itself as a parent; (on_add_url_clicked,on_update_url_clicked): Call
UrlEditor with itself as a parent; (on_name_note_clicked,
on_ldsbap_note_clicked,on_ldsendow_note_clicked,
on_ldsseal_note_clicked): Call NoteEditor with itself as a parent.
* src/NameEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/AttrEdit.py (__init__): Likewise.
* src/AddrEdit.py (__init__): Likewise.
* src/UrlEdit.py (__init__): Likewise.
* src/NoteEdit.py (__init__): Likewise.
svn: r2131
2003-09-15 04:11:30 +00:00
|
|
|
self.attr_edit_callback,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_update_addr_clicked(self,obj):
|
|
|
|
import AddrEdit
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.ptree.get_selected()
|
|
|
|
if node:
|
|
|
|
AddrEdit.AddressEditor(self,self.ptree.get_object(node),
|
* src/SourceView.py (button_press,on_add_clicked,on_delete_clicked,
on_edit_clicked): Pass parent window to the child dialog.
* src/Sources.py (add_src_clicked): Likewise.
* src/EditSource.py (__init__): Add optional parent_window argument.
Make dialog modal and transient for its parent.
* src/gramps.glade (sourceEditor dialog): Delete unneeded handlers
for buttons.
* src/QuestionDialog.py (SaveDialog,QuestionDialog,OptionDialog,
ErrorDialog,WarningDialog,MissingMediaDialog): Set transient status
if parent is given.
* src/EventEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/Witness.py: Make WittnessEditor dialog modal and transient for
its parent. Call SelectPerson with itself as a parent.
* src/SelectPerson.py (__init__): Make dialog transient for its parent.
* src/imagesel.glade: Define proper responses and delete unneeded handlers
for buttons. Make gtkFileEntry modal.
* src/dialog.glade (all dialogs): Define proper responses for buttons.
* src/EditPerson.py (on_add_aka_clicked, on_aka_update_clicked):
Call NameEdit with itself as a parent; (on_add_attr_clicked,
on_update_attr_clicked): Call AttributeEditor with itself as a parent;
(on_add_addr_clicked,on_update_addr_clicked): Call AddressEditor with
itself as a parent; (on_add_url_clicked,on_update_url_clicked): Call
UrlEditor with itself as a parent; (on_name_note_clicked,
on_ldsbap_note_clicked,on_ldsendow_note_clicked,
on_ldsseal_note_clicked): Call NoteEditor with itself as a parent.
* src/NameEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/AttrEdit.py (__init__): Likewise.
* src/AddrEdit.py (__init__): Likewise.
* src/UrlEdit.py (__init__): Likewise.
* src/NoteEdit.py (__init__): Likewise.
svn: r2131
2003-09-15 04:11:30 +00:00
|
|
|
self.addr_edit_callback,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_update_url_clicked(self,obj):
|
|
|
|
import UrlEdit
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.wtree.get_selected()
|
|
|
|
if node:
|
2004-02-14 05:40:30 +00:00
|
|
|
pname = self.person.get_primary_name().get_name()
|
2004-08-11 03:42:38 +00:00
|
|
|
url = self.wtree.get_object(node)
|
* src/SourceView.py (button_press,on_add_clicked,on_delete_clicked,
on_edit_clicked): Pass parent window to the child dialog.
* src/Sources.py (add_src_clicked): Likewise.
* src/EditSource.py (__init__): Add optional parent_window argument.
Make dialog modal and transient for its parent.
* src/gramps.glade (sourceEditor dialog): Delete unneeded handlers
for buttons.
* src/QuestionDialog.py (SaveDialog,QuestionDialog,OptionDialog,
ErrorDialog,WarningDialog,MissingMediaDialog): Set transient status
if parent is given.
* src/EventEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/Witness.py: Make WittnessEditor dialog modal and transient for
its parent. Call SelectPerson with itself as a parent.
* src/SelectPerson.py (__init__): Make dialog transient for its parent.
* src/imagesel.glade: Define proper responses and delete unneeded handlers
for buttons. Make gtkFileEntry modal.
* src/dialog.glade (all dialogs): Define proper responses for buttons.
* src/EditPerson.py (on_add_aka_clicked, on_aka_update_clicked):
Call NameEdit with itself as a parent; (on_add_attr_clicked,
on_update_attr_clicked): Call AttributeEditor with itself as a parent;
(on_add_addr_clicked,on_update_addr_clicked): Call AddressEditor with
itself as a parent; (on_add_url_clicked,on_update_url_clicked): Call
UrlEditor with itself as a parent; (on_name_note_clicked,
on_ldsbap_note_clicked,on_ldsendow_note_clicked,
on_ldsseal_note_clicked): Call NoteEditor with itself as a parent.
* src/NameEdit.py (__init__): Make dialog modal and transient for
its parent.
* src/AttrEdit.py (__init__): Likewise.
* src/AddrEdit.py (__init__): Likewise.
* src/UrlEdit.py (__init__): Likewise.
* src/NoteEdit.py (__init__): Likewise.
svn: r2131
2003-09-15 04:11:30 +00:00
|
|
|
UrlEdit.UrlEditor(self,pname,url,self.url_edit_callback,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_event_update_clicked(self,obj):
|
|
|
|
import EventEdit
|
2002-11-21 04:41:40 +00:00
|
|
|
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.etree.get_selected()
|
|
|
|
if not node:
|
2002-11-21 04:41:40 +00:00
|
|
|
return
|
2004-02-14 05:40:30 +00:00
|
|
|
pname = self.person.get_primary_name().get_name()
|
2004-08-11 03:42:38 +00:00
|
|
|
event = self.etree.get_object(node)
|
2002-11-21 04:41:40 +00:00
|
|
|
EventEdit.EventEditor(self,pname,const.personalEvents,
|
2004-08-20 21:26:51 +00:00
|
|
|
const.personal_events,event,None,0,
|
2003-06-11 02:54:57 +00:00
|
|
|
self.event_edit_callback)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_event_select_row(self,obj):
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = obj.get_selected()
|
|
|
|
if node:
|
|
|
|
row = store.get_path(node)
|
* src/AddSpouse.py, src/ChooseParents.py, src/EditPerson.py,
src/EditPlace.py, src/EditSource.py, src/EventEdit.py,
src/FamilyView.py, src/GenericFilter.py,
src/Marriage.py, src/PedView.py, src/PeopleModel.py,
src/PlaceView.py, src/RelLib.py, src/SelectChild.py,
src/Sort.py, src/SourceView.py, src/SubstKeywords.py,
src/WriteGedcom.py, src/WriteXML.py, src/plugins/AncestorReport.py,
src/plugins/Ancestors.py, src/plugins/ChangeTypes.py,
src/plugins/DescendReport.py, src/plugins/DetDescendantReport.py,
src/plugins/EventCmp.py, src/plugins/FamilyGroup.py,
src/plugins/FanChart.py, src/plugins/FtmStyleAncestors.py,
src/plugins/FtmStyleDescendants.py, src/plugins/GraphViz.py,
src/plugins/IndivComplete.py, src/plugins/IndivSummary.py,
src/plugins/Merge.py, src/plugins/RelCalc.py, src/plugins/RelGraph.py,
src/plugins/Summary.py, src/plugins/TimeLine.py, src/plugins/Verify.py,
src/plugins/WebPage.py, src/plugins/WriteCD.py,
src/plugins/WritePkg.py, src/plugins/DetAncestralReport.py:
Use get_event_from_handle (not find_ ).
svn: r3462
2004-08-21 18:56:01 +00:00
|
|
|
event = self.db.get_event_from_handle(self.elist[row[0]])
|
2004-02-14 05:40:30 +00:00
|
|
|
self.event_date_field.set_text(event.get_date())
|
|
|
|
self.event_place_field.set_text(place_title(self.db,event))
|
|
|
|
self.event_name_field.set_text(const.display_pevent(event.get_name()))
|
|
|
|
self.event_cause_field.set_text(event.get_cause())
|
|
|
|
self.event_descr_field.set_text(short(event.get_description()))
|
|
|
|
if len(event.get_source_references()) > 0:
|
2004-02-21 06:40:44 +00:00
|
|
|
psrc_ref = event.get_source_references()[0]
|
2004-07-28 02:29:07 +00:00
|
|
|
psrc_id = psrc_ref.get_base_handle()
|
2004-08-07 05:16:57 +00:00
|
|
|
psrc = self.db.get_source_from_handle(psrc_id)
|
2004-02-21 06:40:44 +00:00
|
|
|
self.event_src_field.set_text(short(psrc.get_title()))
|
|
|
|
self.event_conf_field.set_text(const.confidence[psrc_ref.get_confidence_level()])
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
self.event_src_field.set_text('')
|
|
|
|
self.event_conf_field.set_text('')
|
|
|
|
self.event_delete_btn.set_sensitive(1)
|
2003-03-03 04:32:53 +00:00
|
|
|
self.event_edit_btn.set_sensitive(1)
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
self.event_date_field.set_text('')
|
|
|
|
self.event_place_field.set_text('')
|
2003-03-03 04:32:53 +00:00
|
|
|
self.event_name_field.set_text('')
|
2002-10-20 14:25:16 +00:00
|
|
|
self.event_cause_field.set_text('')
|
|
|
|
self.event_descr_field.set_text('')
|
|
|
|
self.event_src_field.set_text('')
|
|
|
|
self.event_conf_field.set_text('')
|
|
|
|
self.event_delete_btn.set_sensitive(0)
|
2003-03-03 04:32:53 +00:00
|
|
|
self.event_edit_btn.set_sensitive(0)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_addr_select_row(self,obj):
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.ptree.get_selected()
|
|
|
|
if node:
|
|
|
|
addr = self.ptree.get_object(node)
|
2004-02-14 05:40:30 +00:00
|
|
|
self.addr_start.set_text(addr.get_date())
|
|
|
|
self.addr_street.set_text(addr.get_street())
|
|
|
|
self.addr_city.set_text(addr.get_city())
|
|
|
|
self.addr_state.set_text(addr.get_state())
|
|
|
|
self.addr_country.set_text(addr.get_country())
|
|
|
|
self.addr_postal.set_text(addr.get_postal_code())
|
|
|
|
self.addr_phone.set_text(addr.get_phone())
|
|
|
|
if len(addr.get_source_references()) > 0:
|
2004-02-21 06:40:44 +00:00
|
|
|
psrc_ref = addr.get_source_references()[0]
|
2004-07-28 02:29:07 +00:00
|
|
|
psrc_id = psrc_ref.get_base_handle()
|
2004-08-07 05:16:57 +00:00
|
|
|
psrc = self.db.get_source_from_handle(psrc_id)
|
2004-02-21 06:40:44 +00:00
|
|
|
self.addr_conf_field.set_text(const.confidence[psrc_ref.get_confidence_level()])
|
|
|
|
self.addr_src_field.set_text(short(psrc.get_title()))
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
self.addr_src_field.set_text('')
|
|
|
|
self.addr_conf_field.set_text('')
|
|
|
|
self.addr_delete_btn.set_sensitive(1)
|
2003-03-03 04:32:53 +00:00
|
|
|
self.addr_edit_btn.set_sensitive(1)
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
self.addr_start.set_text('')
|
|
|
|
self.addr_street.set_text('')
|
|
|
|
self.addr_city.set_text('')
|
|
|
|
self.addr_state.set_text('')
|
|
|
|
self.addr_country.set_text('')
|
|
|
|
self.addr_postal.set_text('')
|
2003-12-09 06:02:36 +00:00
|
|
|
self.addr_phone.set_text('')
|
2002-10-20 14:25:16 +00:00
|
|
|
self.addr_conf_field.set_text('')
|
|
|
|
self.addr_src_field.set_text('')
|
|
|
|
self.addr_delete_btn.set_sensitive(0)
|
2003-03-03 04:32:53 +00:00
|
|
|
self.addr_edit_btn.set_sensitive(0)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_name_select_row(self,obj):
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.ntree.get_selected()
|
|
|
|
if node:
|
|
|
|
name = self.ntree.get_object(node)
|
2004-02-14 05:40:30 +00:00
|
|
|
self.alt_given_field.set_text(name.get_first_name())
|
|
|
|
self.alt_title_field.set_text(name.get_title())
|
|
|
|
self.alt_last_field.set_text(name.get_surname())
|
|
|
|
self.alt_suffix_field.set_text(name.get_suffix())
|
|
|
|
self.alt_prefix_field.set_text(name.get_surname_prefix())
|
|
|
|
self.name_type_field.set_text(const.NameTypesMap.find_value(name.get_type()))
|
|
|
|
if len(name.get_source_references()) > 0:
|
2004-02-20 02:38:31 +00:00
|
|
|
psrc_ref = name.get_source_references()[0]
|
2004-07-28 02:29:07 +00:00
|
|
|
psrc_id = psrc_ref.get_base_handle()
|
2004-08-07 05:16:57 +00:00
|
|
|
psrc = self.db.get_source_from_handle(psrc_id)
|
2004-02-20 02:38:31 +00:00
|
|
|
self.name_src_field.set_text(short(psrc.get_title()))
|
|
|
|
self.name_conf_field.set_text(const.confidence[psrc_ref.get_confidence_level()])
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
self.name_src_field.set_text('')
|
|
|
|
self.name_conf_field.set_text('')
|
|
|
|
self.name_delete_btn.set_sensitive(1)
|
2003-02-28 04:49:18 +00:00
|
|
|
self.name_edit_btn.set_sensitive(1)
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
self.alt_given_field.set_text('')
|
|
|
|
self.alt_title_field.set_text('')
|
|
|
|
self.alt_last_field.set_text('')
|
|
|
|
self.alt_suffix_field.set_text('')
|
2002-12-04 04:58:07 +00:00
|
|
|
self.alt_prefix_field.set_text('')
|
2002-10-20 14:25:16 +00:00
|
|
|
self.name_type_field.set_text('')
|
|
|
|
self.name_src_field.set_text('')
|
|
|
|
self.name_conf_field.set_text('')
|
|
|
|
self.name_delete_btn.set_sensitive(0)
|
2003-02-28 04:49:18 +00:00
|
|
|
self.name_edit_btn.set_sensitive(0)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_web_select_row(self,obj):
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.wtree.get_selected()
|
|
|
|
if node:
|
|
|
|
url = self.wtree.get_object(node)
|
2002-10-20 14:25:16 +00:00
|
|
|
path = url.get_path()
|
|
|
|
self.web_url.set_text(path)
|
|
|
|
self.web_description.set_text(url.get_description())
|
|
|
|
self.web_go.set_sensitive(0)
|
2003-03-03 04:32:53 +00:00
|
|
|
self.web_go.set_sensitive(1)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.web_delete_btn.set_sensitive(1)
|
2003-03-03 04:32:53 +00:00
|
|
|
self.web_edit_btn.set_sensitive(1)
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
self.web_url.set_text('')
|
|
|
|
self.web_description.set_text('')
|
|
|
|
self.web_go.set_sensitive(0)
|
|
|
|
self.web_delete_btn.set_sensitive(0)
|
2003-03-03 04:32:53 +00:00
|
|
|
self.web_edit_btn.set_sensitive(0)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_attr_select_row(self,obj):
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.atree.get_selected()
|
|
|
|
if node:
|
|
|
|
attr = self.atree.get_object(node)
|
2004-02-14 05:40:30 +00:00
|
|
|
self.attr_type.set_text(const.display_pattr(attr.get_type()))
|
|
|
|
self.attr_value.set_text(short(attr.get_value()))
|
|
|
|
if len(attr.get_source_references()) > 0:
|
2004-02-21 06:40:44 +00:00
|
|
|
psrc_ref = attr.get_source_references()[0]
|
2004-07-28 02:29:07 +00:00
|
|
|
psrc_id = psrc_ref.get_base_handle()
|
2004-08-07 05:16:57 +00:00
|
|
|
psrc = self.db.get_source_from_handle(psrc_id)
|
2004-02-21 06:40:44 +00:00
|
|
|
self.attr_src_field.set_text(short(psrc.get_title()))
|
|
|
|
self.attr_conf_field.set_text(const.confidence[psrc_ref.get_confidence_level()])
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
self.attr_src_field.set_text('')
|
|
|
|
self.attr_conf_field.set_text('')
|
|
|
|
self.attr_delete_btn.set_sensitive(1)
|
2003-03-03 04:32:53 +00:00
|
|
|
self.attr_edit_btn.set_sensitive(1)
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2003-03-03 04:32:53 +00:00
|
|
|
self.attr_type.set_text('')
|
2002-10-20 14:25:16 +00:00
|
|
|
self.attr_value.set_text('')
|
|
|
|
self.attr_src_field.set_text('')
|
|
|
|
self.attr_conf_field.set_text('')
|
|
|
|
self.attr_delete_btn.set_sensitive(0)
|
2003-03-03 04:32:53 +00:00
|
|
|
self.attr_edit_btn.set_sensitive(0)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def aka_double_click(self,obj,event):
|
2002-11-21 04:41:40 +00:00
|
|
|
if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.on_aka_update_clicked(obj)
|
2002-11-21 04:41:40 +00:00
|
|
|
elif event.type == gtk.gdk.BUTTON_PRESS and event.button == 3:
|
2002-10-20 14:25:16 +00:00
|
|
|
menu = gtk.Menu()
|
|
|
|
item = gtk.TearoffMenuItem()
|
|
|
|
item.show()
|
|
|
|
menu.append(item)
|
|
|
|
msg = _("Make the selected name the preferred name")
|
|
|
|
Utils.add_menuitem(menu,msg,None,self.change_name)
|
2003-10-20 02:47:03 +00:00
|
|
|
menu.popup(None,None,None,event.button,event.time)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_aka_update_clicked(self,obj):
|
|
|
|
import NameEdit
|
2004-08-11 03:42:38 +00:00
|
|
|
store,node = self.ntree.get_selected()
|
|
|
|
if node:
|
|
|
|
NameEdit.NameEditor(self,self.ntree.get_object(node),
|
2004-03-22 04:41:35 +00:00
|
|
|
self.name_edit_callback,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def load_photo(self,photo):
|
|
|
|
"""loads, scales, and displays the person's main photo"""
|
|
|
|
self.load_obj = photo
|
|
|
|
if photo == None:
|
2004-11-29 03:24:02 +00:00
|
|
|
self.person_photo.hide()
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
try:
|
2002-11-15 03:49:39 +00:00
|
|
|
i = pixbuf_new_from_file(photo)
|
2002-10-20 14:25:16 +00:00
|
|
|
ratio = float(max(i.get_height(),i.get_width()))
|
2004-08-13 04:34:07 +00:00
|
|
|
scale = float(_PICTURE_WIDTH)/ratio
|
2002-10-20 14:25:16 +00:00
|
|
|
x = int(scale*(i.get_width()))
|
|
|
|
y = int(scale*(i.get_height()))
|
2002-11-15 03:49:39 +00:00
|
|
|
i = i.scale_simple(x,y,INTERP_BILINEAR)
|
2004-11-29 03:24:02 +00:00
|
|
|
self.person_photo.set_from_pixbuf(i)
|
|
|
|
self.person_photo.show()
|
2002-10-20 14:25:16 +00:00
|
|
|
except:
|
2004-11-29 03:24:02 +00:00
|
|
|
self.person_photo.hide()
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def update_lists(self):
|
|
|
|
"""Updates the person's lists if anything has changed"""
|
|
|
|
if self.lists_changed:
|
2004-02-14 05:40:30 +00:00
|
|
|
self.person.set_event_list(self.elist)
|
|
|
|
self.person.set_alternate_names(self.nlist)
|
|
|
|
self.person.set_url_list(self.ulist)
|
|
|
|
self.person.set_attribute_list(self.alist)
|
|
|
|
self.person.set_address_list(self.plist)
|
2004-07-28 02:29:07 +00:00
|
|
|
self.person.set_birth_handle(self.birth.get_handle())
|
|
|
|
self.person.set_death_handle(self.death.get_handle())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_apply_person_clicked(self,obj):
|
2004-03-30 04:50:24 +00:00
|
|
|
|
2004-12-03 01:49:09 +00:00
|
|
|
self.window.hide()
|
2004-08-13 04:34:07 +00:00
|
|
|
trans = self.db.transaction_begin()
|
2004-09-20 03:12:51 +00:00
|
|
|
|
2004-05-02 04:10:33 +00:00
|
|
|
surname = unicode(self.surname.get_text())
|
2003-12-17 05:23:16 +00:00
|
|
|
suffix = unicode(self.suffix.get_text())
|
|
|
|
prefix = unicode(self.prefix.get_text())
|
2004-08-04 04:53:29 +00:00
|
|
|
ntype = unicode(self.ntype_field.child.get_text())
|
2003-12-17 05:23:16 +00:00
|
|
|
given = unicode(self.given.get_text())
|
|
|
|
nick = unicode(self.nick.get_text())
|
|
|
|
title = unicode(self.title.get_text())
|
|
|
|
idval = unicode(self.gid.get_text())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
name = self.pname
|
|
|
|
|
2004-09-19 15:17:57 +00:00
|
|
|
self.birth.set_date_object(self.birth_date_object)
|
2004-07-28 02:29:07 +00:00
|
|
|
self.birth.set_place_handle(self.get_place(self.bplace,1))
|
2003-09-20 19:56:27 +00:00
|
|
|
|
2004-06-27 03:10:06 +00:00
|
|
|
if idval != self.person.get_gramps_id():
|
2004-08-07 05:16:57 +00:00
|
|
|
person = self.db.get_person_from_gramps_id(idval)
|
2004-07-09 04:31:43 +00:00
|
|
|
if not person:
|
2004-06-27 03:10:06 +00:00
|
|
|
self.person.set_gramps_id(idval)
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-07-15 02:54:04 +00:00
|
|
|
n = GrampsCfg.get_nameof()(person)
|
2002-10-20 14:25:16 +00:00
|
|
|
msg1 = _("GRAMPS ID value was not changed.")
|
2003-02-27 00:29:37 +00:00
|
|
|
msg2 = _("You have attempted to change the GRAMPS ID to a value "
|
|
|
|
"of %(grampsid)s. This value is already used by %(person)s.") % {
|
2002-10-20 14:25:16 +00:00
|
|
|
'grampsid' : idval,
|
|
|
|
'person' : n }
|
2003-02-27 00:29:37 +00:00
|
|
|
WarningDialog(msg1,msg2)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if suffix != name.get_suffix():
|
|
|
|
name.set_suffix(suffix)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-10-09 01:35:58 +00:00
|
|
|
if self.use_patronymic:
|
|
|
|
if prefix != name.get_patronymic():
|
|
|
|
name.set_patronymic(prefix)
|
|
|
|
else:
|
|
|
|
if prefix != name.get_surname_prefix():
|
|
|
|
name.set_surname_prefix(prefix)
|
2002-12-04 04:58:07 +00:00
|
|
|
|
2004-01-20 23:30:15 +00:00
|
|
|
if const.NameTypesMap.has_value(ntype):
|
|
|
|
ntype = const.NameTypesMap.find_key(ntype)
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
ntype = "Birth Name"
|
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if ntype != name.get_type():
|
|
|
|
name.set_type(ntype)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if surname != name.get_surname():
|
|
|
|
name.set_surname(surname)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if given != name.get_first_name():
|
|
|
|
name.set_first_name(given)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if title != name.get_title():
|
|
|
|
name.set_title(title)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
name.set_source_reference_list(self.pname.get_source_references())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-10-09 01:35:58 +00:00
|
|
|
if name != self.person.get_primary_name():
|
2004-02-14 05:40:30 +00:00
|
|
|
self.person.set_primary_name(name)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if nick != self.person.get_nick_name():
|
|
|
|
self.person.set_nick_name(nick)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-06-13 15:08:07 +00:00
|
|
|
self.pdmap.clear()
|
2004-08-13 04:34:07 +00:00
|
|
|
for key in self.db.get_place_handles():
|
|
|
|
p = self.db.get_place_from_handle(key).get_display_info()
|
2003-06-13 15:08:07 +00:00
|
|
|
self.pdmap[p[0]] = key
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-21 06:11:59 +00:00
|
|
|
if self.orig_birth == None:
|
2004-03-30 04:50:24 +00:00
|
|
|
self.db.add_event(self.birth,trans)
|
2004-07-28 02:29:07 +00:00
|
|
|
self.person.set_birth_handle(self.birth.get_handle())
|
2004-02-21 06:11:59 +00:00
|
|
|
elif not self.orig_birth.are_equal(self.birth):
|
2004-03-30 04:50:24 +00:00
|
|
|
self.db.commit_event(self.birth,trans)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
# Update each of the families child lists to reflect any
|
|
|
|
# change in ordering due to the new birth date
|
2004-07-28 02:29:07 +00:00
|
|
|
family = self.person.get_main_parents_family_handle()
|
2002-10-20 14:25:16 +00:00
|
|
|
if (family):
|
2004-08-11 03:42:38 +00:00
|
|
|
f = self.db.find_family_from_handle(family,trans)
|
2004-07-28 02:29:07 +00:00
|
|
|
new_order = self.reorder_child_list(self.person,f.get_child_handle_list())
|
|
|
|
f.set_child_handle_list(new_order)
|
|
|
|
for (family, rel1, rel2) in self.person.get_parent_family_handle_list():
|
2004-08-11 03:42:38 +00:00
|
|
|
f = self.db.find_family_from_handle(family,trans)
|
2004-07-28 02:29:07 +00:00
|
|
|
new_order = self.reorder_child_list(self.person,f.get_child_handle_list())
|
|
|
|
f.set_child_handle_list(new_order)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-09-19 15:17:57 +00:00
|
|
|
self.death.set_date_object(self.death_date_object)
|
2004-07-28 02:29:07 +00:00
|
|
|
self.death.set_place_handle(self.get_place(self.dplace,1))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-21 06:11:59 +00:00
|
|
|
if self.orig_death == None:
|
2004-03-30 04:50:24 +00:00
|
|
|
self.db.add_event(self.death,trans)
|
2004-07-28 02:29:07 +00:00
|
|
|
self.person.set_death_handle(self.death.get_handle())
|
2004-02-21 06:11:59 +00:00
|
|
|
elif not self.orig_death.are_equal(self.death):
|
2004-03-30 04:50:24 +00:00
|
|
|
self.db.commit_event(self.death,trans)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
male = self.is_male.get_active()
|
|
|
|
female = self.is_female.get_active()
|
|
|
|
unknown = self.is_unknown.get_active()
|
2004-09-20 03:12:51 +00:00
|
|
|
error = False
|
2004-02-14 05:40:30 +00:00
|
|
|
if male and self.person.get_gender() != RelLib.Person.male:
|
|
|
|
self.person.set_gender(RelLib.Person.male)
|
2004-07-28 02:29:07 +00:00
|
|
|
for temp_family in self.person.get_family_handle_list():
|
|
|
|
if self.person == temp_family.get_mother_handle():
|
|
|
|
if temp_family.get_father_handle() != None:
|
2004-09-20 03:12:51 +00:00
|
|
|
error = True
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-07-28 02:29:07 +00:00
|
|
|
temp_family.set_mother_handle(None)
|
|
|
|
temp_family.set_father_handle(self.person)
|
2004-02-14 05:40:30 +00:00
|
|
|
elif female and self.person.get_gender() != RelLib.Person.female:
|
|
|
|
self.person.set_gender(RelLib.Person.female)
|
2004-07-28 02:29:07 +00:00
|
|
|
for temp_family in self.person.get_family_handle_list():
|
|
|
|
if self.person == temp_family.get_father_handle():
|
|
|
|
if temp_family.get_mother_handle() != None:
|
2004-09-20 03:12:51 +00:00
|
|
|
error = True
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-07-28 02:29:07 +00:00
|
|
|
temp_family.set_father_handle(None)
|
|
|
|
temp_family.set_mother_handle(self.person)
|
2004-02-14 05:40:30 +00:00
|
|
|
elif unknown and self.person.get_gender() != RelLib.Person.unknown:
|
|
|
|
self.person.set_gender(RelLib.Person.unknown)
|
2004-07-28 02:29:07 +00:00
|
|
|
for temp_family in self.person.get_family_handle_list():
|
|
|
|
if self.person == temp_family.get_father_handle():
|
|
|
|
if temp_family.get_mother_handle() != None:
|
2004-09-20 03:12:51 +00:00
|
|
|
error = True
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-07-28 02:29:07 +00:00
|
|
|
temp_family.set_father_handle(None)
|
|
|
|
temp_family.set_mother_handle(self.person)
|
|
|
|
if self.person == temp_family.get_mother_handle():
|
|
|
|
if temp_family.get_father_handle() != None:
|
2004-09-20 03:12:51 +00:00
|
|
|
error = True
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-07-28 02:29:07 +00:00
|
|
|
temp_family.set_mother_handle(None)
|
|
|
|
temp_family.set_father_handle(self.person)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-10-03 21:04:54 +00:00
|
|
|
if error:
|
2003-02-24 04:51:57 +00:00
|
|
|
msg2 = _("Problem changing the gender")
|
2002-10-20 14:25:16 +00:00
|
|
|
msg = _("Changing the gender caused problems "
|
|
|
|
"with marriage information.\nPlease check "
|
|
|
|
"the person's marriages.")
|
2002-10-21 01:18:07 +00:00
|
|
|
ErrorDialog(msg)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-12-17 16:06:36 +00:00
|
|
|
text = unicode(self.notes_buffer.get_text(self.notes_buffer.get_start_iter(),
|
|
|
|
self.notes_buffer.get_end_iter(),gtk.FALSE))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if text != self.person.get_note():
|
|
|
|
self.person.set_note(text)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-12-16 00:37:47 +00:00
|
|
|
format = self.preform.get_active()
|
2004-02-14 05:40:30 +00:00
|
|
|
if format != self.person.get_note_format():
|
|
|
|
self.person.set_note_format(format)
|
2003-12-10 14:21:48 +00:00
|
|
|
|
2004-08-13 04:34:07 +00:00
|
|
|
if self.complete.get_active() != self.person.get_complete_flag():
|
|
|
|
self.person.set_complete_flag(self.complete.get_active())
|
2003-12-03 03:49:39 +00:00
|
|
|
|
2004-10-03 21:04:54 +00:00
|
|
|
if not self.lds_not_loaded:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.check_lds()
|
2004-08-11 03:42:38 +00:00
|
|
|
lds_ord = RelLib.LdsOrd(self.person.get_lds_baptism())
|
|
|
|
if not self.lds_baptism.are_equal(lds_ord):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.person.set_lds_baptism(self.lds_baptism)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-08-11 03:42:38 +00:00
|
|
|
lds_ord = RelLib.LdsOrd(self.person.get_lds_endowment())
|
|
|
|
if not self.lds_endowment.are_equal(lds_ord):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.person.set_lds_endowment(self.lds_endowment)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-08-11 03:42:38 +00:00
|
|
|
lds_ord = RelLib.LdsOrd(self.person.get_lds_sealing())
|
|
|
|
if not self.lds_sealing.are_equal(lds_ord):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.person.set_lds_sealing(self.lds_sealing)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-10-29 05:04:43 +00:00
|
|
|
if self.lists_changed:
|
2004-02-14 05:40:30 +00:00
|
|
|
self.person.set_source_reference_list(self.srcreflist)
|
2004-09-20 03:12:51 +00:00
|
|
|
self.update_lists()
|
2003-10-29 05:04:43 +00:00
|
|
|
|
2004-09-29 03:19:01 +00:00
|
|
|
if not self.person.get_handle():
|
2004-08-28 19:49:34 +00:00
|
|
|
self.db.add_person(self.person, trans)
|
2004-10-01 02:38:23 +00:00
|
|
|
call_value = 0
|
2004-08-28 19:49:34 +00:00
|
|
|
else:
|
2004-09-29 03:19:01 +00:00
|
|
|
if not self.person.get_gramps_id():
|
|
|
|
self.person.set_gramps_id(self.db.find_next_person_gramps_id())
|
2004-10-01 02:38:23 +00:00
|
|
|
call_value = 1
|
2004-08-28 19:49:34 +00:00
|
|
|
self.db.commit_person(self.person, trans)
|
2004-05-19 06:13:36 +00:00
|
|
|
n = self.person.get_primary_name().get_regular_name()
|
2004-08-13 04:34:07 +00:00
|
|
|
self.db.transaction_commit(trans,_("Edit Person (%s)") % n)
|
2004-08-21 03:36:00 +00:00
|
|
|
if self.callback:
|
2004-10-01 02:38:23 +00:00
|
|
|
self.callback(self,call_value)
|
2004-08-04 04:53:29 +00:00
|
|
|
self.close()
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def get_place(self,field,makenew=0):
|
2004-08-24 03:48:15 +00:00
|
|
|
text = unicode(field.get_text().strip())
|
2002-10-20 14:25:16 +00:00
|
|
|
if text:
|
2003-06-13 15:08:07 +00:00
|
|
|
if self.pdmap.has_key(text):
|
2004-02-14 05:40:30 +00:00
|
|
|
return self.pdmap[text]
|
2002-10-20 14:25:16 +00:00
|
|
|
elif makenew:
|
2003-01-10 05:21:32 +00:00
|
|
|
place = RelLib.Place()
|
2002-10-20 14:25:16 +00:00
|
|
|
place.set_title(text)
|
2004-08-13 04:34:07 +00:00
|
|
|
trans = self.db.transaction_begin()
|
2004-06-27 18:08:19 +00:00
|
|
|
self.db.add_place(place,trans)
|
2004-08-13 04:34:07 +00:00
|
|
|
self.db.transaction_commit(trans,_('Add Place (%s)' % text))
|
2004-07-28 02:29:07 +00:00
|
|
|
self.pdmap[text] = place.get_handle()
|
2002-10-20 14:25:16 +00:00
|
|
|
self.add_places.append(place)
|
2004-07-28 02:29:07 +00:00
|
|
|
return place.get_handle()
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-08-07 05:16:57 +00:00
|
|
|
return None
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
2004-08-07 05:16:57 +00:00
|
|
|
return None
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-09-29 02:06:46 +00:00
|
|
|
def on_edit_name_clicked(self,obj):
|
|
|
|
import NameEdit
|
2004-09-30 18:32:56 +00:00
|
|
|
|
|
|
|
ntype = unicode(self.ntype_field.child.get_text())
|
|
|
|
self.pname.set_type(const.NameTypesMap.find_value(ntype))
|
|
|
|
self.pname.set_suffix(unicode(self.suffix.get_text()))
|
2004-10-04 04:28:58 +00:00
|
|
|
self.pname.set_surname(unicode(self.surname.get_text()))
|
2004-10-09 01:35:58 +00:00
|
|
|
if self.use_patronymic:
|
|
|
|
self.pname.set_patronymic(unicode(self.prefix.get_text()))
|
|
|
|
else:
|
|
|
|
self.pname.set_surname_prefix(unicode(self.prefix.get_text()))
|
2004-09-30 18:32:56 +00:00
|
|
|
self.pname.set_first_name(unicode(self.given.get_text()))
|
|
|
|
self.pname.set_title(unicode(self.title.get_text()))
|
|
|
|
|
2004-09-29 02:06:46 +00:00
|
|
|
NameEdit.NameEditor(self,self.pname,self.update_name,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-09-29 02:06:46 +00:00
|
|
|
def update_name(self,name):
|
|
|
|
self.write_primary_name()
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
def on_ldsbap_source_clicked(self,obj):
|
2004-02-14 05:40:30 +00:00
|
|
|
Sources.SourceSelector(self.lds_baptism.get_source_references(),
|
2003-10-30 04:17:05 +00:00
|
|
|
self,self.update_ldsbap_list)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def update_ldsbap_list(self,list):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_baptism.set_source_reference_list(list)
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_ldsbap_note_clicked(self,obj):
|
|
|
|
import NoteEdit
|
2004-02-20 03:57:54 +00:00
|
|
|
NoteEdit.NoteEditor(self.lds_baptism,self,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_ldsendow_source_clicked(self,obj):
|
2004-02-14 05:40:30 +00:00
|
|
|
Sources.SourceSelector(self.lds_endowment.get_source_references(),
|
2003-10-30 04:17:05 +00:00
|
|
|
self,self.set_ldsendow_list)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def set_ldsendow_list(self,list):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_endowment.set_source_reference_list(list)
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_ldsendow_note_clicked(self,obj):
|
|
|
|
import NoteEdit
|
2004-02-20 03:57:54 +00:00
|
|
|
NoteEdit.NoteEditor(self.lds_endowment,self,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_ldsseal_source_clicked(self,obj):
|
2004-02-14 05:40:30 +00:00
|
|
|
Sources.SourceSelector(self.lds_sealing.get_source_references(),
|
2003-10-30 04:17:05 +00:00
|
|
|
self,self.lds_seal_list)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def lds_seal_list(self,list):
|
2004-02-14 05:40:30 +00:00
|
|
|
self.lds_sealing.set_source_reference_list(list)
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_ldsseal_note_clicked(self,obj):
|
|
|
|
import NoteEdit
|
2004-02-20 03:57:54 +00:00
|
|
|
NoteEdit.NoteEditor(self.lds_sealing,self,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def load_person_image(self):
|
2004-02-21 06:11:59 +00:00
|
|
|
media_list = self.person.get_media_list()
|
|
|
|
if media_list:
|
|
|
|
ph = media_list[0]
|
2004-07-28 02:29:07 +00:00
|
|
|
object_handle = ph.get_reference_handle()
|
2004-08-11 03:42:38 +00:00
|
|
|
obj = self.db.get_object_from_handle(object_handle)
|
|
|
|
if self.load_obj != obj.get_path():
|
|
|
|
if obj.get_mime_type()[0:5] == "image":
|
|
|
|
self.load_photo(obj.get_path())
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
self.load_photo(None)
|
|
|
|
else:
|
|
|
|
self.load_photo(None)
|
|
|
|
|
|
|
|
def update_birth_info(self):
|
2004-09-19 15:17:57 +00:00
|
|
|
self.birth_date_object.copy(self.birth.get_date_object())
|
2004-02-14 05:40:30 +00:00
|
|
|
self.bdate.set_text(self.birth.get_date())
|
|
|
|
self.bplace.set_text(place_title(self.db,self.birth))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def update_death_info(self):
|
2004-09-19 15:17:57 +00:00
|
|
|
self.death_date_object.copy(self.death.get_date_object())
|
2004-02-14 05:40:30 +00:00
|
|
|
self.ddate.set_text(self.death.get_date())
|
|
|
|
self.dplace.set_text(place_title(self.db,self.death))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_switch_page(self,obj,a,page):
|
|
|
|
if page == 0:
|
|
|
|
self.load_person_image()
|
|
|
|
elif page == 2:
|
|
|
|
self.redraw_event_list()
|
2003-11-13 21:44:09 +00:00
|
|
|
elif page == 7 and self.not_loaded:
|
2004-09-20 03:12:51 +00:00
|
|
|
self.not_loaded = False
|
2003-11-13 21:44:09 +00:00
|
|
|
elif page == 9 and self.lds_not_loaded:
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lds_not_loaded = False
|
2002-10-20 14:25:16 +00:00
|
|
|
self.draw_lds()
|
2004-08-20 12:11:56 +00:00
|
|
|
note_buf = self.notes_buffer
|
|
|
|
text = unicode(note_buf.get_text(note_buf.get_start_iter(),
|
|
|
|
note_buf.get_end_iter(),gtk.FALSE))
|
2003-11-12 18:45:07 +00:00
|
|
|
if text:
|
|
|
|
Utils.bold_label(self.notes_label)
|
|
|
|
else:
|
|
|
|
Utils.unbold_label(self.notes_label)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-10-03 21:04:54 +00:00
|
|
|
if not self.lds_not_loaded:
|
2003-11-13 21:44:09 +00:00
|
|
|
self.check_lds()
|
2004-02-14 05:40:30 +00:00
|
|
|
if self.lds_baptism.is_empty() \
|
|
|
|
and self.lds_endowment.is_empty() \
|
|
|
|
and self.lds_sealing.is_empty():
|
2003-11-13 21:44:09 +00:00
|
|
|
Utils.unbold_label(self.lds_tab)
|
|
|
|
else:
|
|
|
|
Utils.bold_label(self.lds_tab)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
def change_name(self,obj):
|
2003-06-14 00:58:38 +00:00
|
|
|
sel_objs = self.ntree.get_selected_objects()
|
|
|
|
if sel_objs:
|
2002-10-20 14:25:16 +00:00
|
|
|
old = self.pname
|
2003-06-14 00:58:38 +00:00
|
|
|
new = sel_objs[0]
|
2002-10-20 14:25:16 +00:00
|
|
|
self.nlist.remove(new)
|
|
|
|
self.nlist.append(old)
|
|
|
|
self.redraw_name_list()
|
2003-01-10 05:21:32 +00:00
|
|
|
self.pname = RelLib.Name(new)
|
2004-09-20 03:12:51 +00:00
|
|
|
self.lists_changed = True
|
2002-10-20 14:25:16 +00:00
|
|
|
self.write_primary_name()
|
|
|
|
|
|
|
|
def write_primary_name(self):
|
|
|
|
# initial values
|
2004-07-15 02:54:04 +00:00
|
|
|
name = '<span size="larger" weight="bold">%s</span>' % GrampsCfg.get_nameof()(self.person)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.get_widget("activepersonTitle").set_text(name)
|
2003-02-28 04:49:18 +00:00
|
|
|
self.get_widget("activepersonTitle").set_use_markup(gtk.TRUE)
|
2004-02-14 05:40:30 +00:00
|
|
|
self.suffix.set_text(self.pname.get_suffix())
|
2004-10-09 01:35:58 +00:00
|
|
|
if self.use_patronymic:
|
|
|
|
self.prefix.set_text(self.pname.get_patronymic())
|
|
|
|
else:
|
|
|
|
self.prefix.set_text(self.pname.get_surname_prefix())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-05-02 04:10:33 +00:00
|
|
|
self.surname.set_text(self.pname.get_surname())
|
2004-02-14 05:40:30 +00:00
|
|
|
self.given.set_text(self.pname.get_first_name())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-08-04 04:53:29 +00:00
|
|
|
self.ntype_field.child.set_text(_(self.pname.get_type()))
|
2004-02-14 05:40:30 +00:00
|
|
|
self.title.set_text(self.pname.get_title())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-15 01:57:07 +00:00
|
|
|
def birth_dates_in_order(self,list):
|
|
|
|
"""Check any *valid* birthdates in the list to insure that they are in
|
|
|
|
numerically increasing order."""
|
2004-09-20 03:12:51 +00:00
|
|
|
inorder = True
|
2004-09-23 02:25:07 +00:00
|
|
|
prev_date = 0
|
2004-02-15 01:57:07 +00:00
|
|
|
for i in range(len(list)):
|
2004-07-28 02:29:07 +00:00
|
|
|
child_handle = list[i]
|
2004-08-07 05:16:57 +00:00
|
|
|
child = self.db.get_person_from_handle(child_handle)
|
2004-07-28 02:29:07 +00:00
|
|
|
if child.get_birth_handle():
|
* src/AddSpouse.py, src/ChooseParents.py, src/EditPerson.py,
src/EditPlace.py, src/EditSource.py, src/EventEdit.py,
src/FamilyView.py, src/GenericFilter.py,
src/Marriage.py, src/PedView.py, src/PeopleModel.py,
src/PlaceView.py, src/RelLib.py, src/SelectChild.py,
src/Sort.py, src/SourceView.py, src/SubstKeywords.py,
src/WriteGedcom.py, src/WriteXML.py, src/plugins/AncestorReport.py,
src/plugins/Ancestors.py, src/plugins/ChangeTypes.py,
src/plugins/DescendReport.py, src/plugins/DetDescendantReport.py,
src/plugins/EventCmp.py, src/plugins/FamilyGroup.py,
src/plugins/FanChart.py, src/plugins/FtmStyleAncestors.py,
src/plugins/FtmStyleDescendants.py, src/plugins/GraphViz.py,
src/plugins/IndivComplete.py, src/plugins/IndivSummary.py,
src/plugins/Merge.py, src/plugins/RelCalc.py, src/plugins/RelGraph.py,
src/plugins/Summary.py, src/plugins/TimeLine.py, src/plugins/Verify.py,
src/plugins/WebPage.py, src/plugins/WriteCD.py,
src/plugins/WritePkg.py, src/plugins/DetAncestralReport.py:
Use get_event_from_handle (not find_ ).
svn: r3462
2004-08-21 18:56:01 +00:00
|
|
|
event = self.db.get_event_from_handle(child.get_birth_handle())
|
2004-09-23 02:25:07 +00:00
|
|
|
child_date = event.get_date_object().get_sort_value()
|
2004-02-19 05:07:46 +00:00
|
|
|
else:
|
2004-02-15 01:57:07 +00:00
|
|
|
continue
|
2004-02-20 00:52:24 +00:00
|
|
|
if (prev_date <= child_date): # <= allows for twins
|
2004-02-15 01:57:07 +00:00
|
|
|
prev_date = child_date
|
|
|
|
else:
|
2004-09-20 03:12:51 +00:00
|
|
|
inorder = False
|
2004-02-15 01:57:07 +00:00
|
|
|
return inorder
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-15 01:57:07 +00:00
|
|
|
def reorder_child_list(self, person, 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."""
|
2004-06-29 03:51:49 +00:00
|
|
|
|
2004-02-15 01:57:07 +00:00
|
|
|
if (self.birth_dates_in_order(list)):
|
|
|
|
return(list)
|
|
|
|
|
|
|
|
# Build the person's date string once
|
2004-07-28 02:29:07 +00:00
|
|
|
event_handle = person.get_birth_handle()
|
|
|
|
if event_handle:
|
* src/AddSpouse.py, src/ChooseParents.py, src/EditPerson.py,
src/EditPlace.py, src/EditSource.py, src/EventEdit.py,
src/FamilyView.py, src/GenericFilter.py,
src/Marriage.py, src/PedView.py, src/PeopleModel.py,
src/PlaceView.py, src/RelLib.py, src/SelectChild.py,
src/Sort.py, src/SourceView.py, src/SubstKeywords.py,
src/WriteGedcom.py, src/WriteXML.py, src/plugins/AncestorReport.py,
src/plugins/Ancestors.py, src/plugins/ChangeTypes.py,
src/plugins/DescendReport.py, src/plugins/DetDescendantReport.py,
src/plugins/EventCmp.py, src/plugins/FamilyGroup.py,
src/plugins/FanChart.py, src/plugins/FtmStyleAncestors.py,
src/plugins/FtmStyleDescendants.py, src/plugins/GraphViz.py,
src/plugins/IndivComplete.py, src/plugins/IndivSummary.py,
src/plugins/Merge.py, src/plugins/RelCalc.py, src/plugins/RelGraph.py,
src/plugins/Summary.py, src/plugins/TimeLine.py, src/plugins/Verify.py,
src/plugins/WebPage.py, src/plugins/WriteCD.py,
src/plugins/WritePkg.py, src/plugins/DetAncestralReport.py:
Use get_event_from_handle (not find_ ).
svn: r3462
2004-08-21 18:56:01 +00:00
|
|
|
event = self.db.get_event_from_handle(event_handle)
|
2004-09-23 02:25:07 +00:00
|
|
|
person_bday = event.get_date_object().get_sort_value()
|
2004-02-19 05:07:46 +00:00
|
|
|
else:
|
2004-09-23 02:25:07 +00:00
|
|
|
person_bday = 0
|
2004-02-15 01:57:07 +00:00
|
|
|
|
|
|
|
# First, see if the person needs to be moved forward in the list
|
2004-06-29 03:51:49 +00:00
|
|
|
|
2004-07-28 02:29:07 +00:00
|
|
|
index = list.index(person.get_handle())
|
2004-02-15 01:57:07 +00:00
|
|
|
target = index
|
|
|
|
for i in range(index-1, -1, -1):
|
2004-08-07 05:16:57 +00:00
|
|
|
other = self.db.get_person_from_handle(list[i])
|
2004-07-28 02:29:07 +00:00
|
|
|
event_handle = other.get_birth_handle()
|
|
|
|
if event_handle:
|
* src/AddSpouse.py, src/ChooseParents.py, src/EditPerson.py,
src/EditPlace.py, src/EditSource.py, src/EventEdit.py,
src/FamilyView.py, src/GenericFilter.py,
src/Marriage.py, src/PedView.py, src/PeopleModel.py,
src/PlaceView.py, src/RelLib.py, src/SelectChild.py,
src/Sort.py, src/SourceView.py, src/SubstKeywords.py,
src/WriteGedcom.py, src/WriteXML.py, src/plugins/AncestorReport.py,
src/plugins/Ancestors.py, src/plugins/ChangeTypes.py,
src/plugins/DescendReport.py, src/plugins/DetDescendantReport.py,
src/plugins/EventCmp.py, src/plugins/FamilyGroup.py,
src/plugins/FanChart.py, src/plugins/FtmStyleAncestors.py,
src/plugins/FtmStyleDescendants.py, src/plugins/GraphViz.py,
src/plugins/IndivComplete.py, src/plugins/IndivSummary.py,
src/plugins/Merge.py, src/plugins/RelCalc.py, src/plugins/RelGraph.py,
src/plugins/Summary.py, src/plugins/TimeLine.py, src/plugins/Verify.py,
src/plugins/WebPage.py, src/plugins/WriteCD.py,
src/plugins/WritePkg.py, src/plugins/DetAncestralReport.py:
Use get_event_from_handle (not find_ ).
svn: r3462
2004-08-21 18:56:01 +00:00
|
|
|
event = self.db.get_event_from_handle(event_handle)
|
2004-09-23 02:25:07 +00:00
|
|
|
other_bday = event.get_date_object().get_sort_value()
|
|
|
|
if other_bday == 0:
|
2004-02-19 05:07:46 +00:00
|
|
|
continue;
|
2004-09-23 02:25:07 +00:00
|
|
|
if person_bday < other_bday:
|
2004-02-19 05:07:46 +00:00
|
|
|
target = i
|
|
|
|
else:
|
|
|
|
continue
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-15 01:57:07 +00:00
|
|
|
# Now try moving to a later position in the list
|
|
|
|
if (target == index):
|
|
|
|
for i in range(index, len(list)):
|
2004-08-07 05:16:57 +00:00
|
|
|
other = self.db.get_person_from_handle(list[i])
|
2004-07-28 02:29:07 +00:00
|
|
|
event_handle = other.get_birth_handle()
|
|
|
|
if event_handle:
|
* src/AddSpouse.py, src/ChooseParents.py, src/EditPerson.py,
src/EditPlace.py, src/EditSource.py, src/EventEdit.py,
src/FamilyView.py, src/GenericFilter.py,
src/Marriage.py, src/PedView.py, src/PeopleModel.py,
src/PlaceView.py, src/RelLib.py, src/SelectChild.py,
src/Sort.py, src/SourceView.py, src/SubstKeywords.py,
src/WriteGedcom.py, src/WriteXML.py, src/plugins/AncestorReport.py,
src/plugins/Ancestors.py, src/plugins/ChangeTypes.py,
src/plugins/DescendReport.py, src/plugins/DetDescendantReport.py,
src/plugins/EventCmp.py, src/plugins/FamilyGroup.py,
src/plugins/FanChart.py, src/plugins/FtmStyleAncestors.py,
src/plugins/FtmStyleDescendants.py, src/plugins/GraphViz.py,
src/plugins/IndivComplete.py, src/plugins/IndivSummary.py,
src/plugins/Merge.py, src/plugins/RelCalc.py, src/plugins/RelGraph.py,
src/plugins/Summary.py, src/plugins/TimeLine.py, src/plugins/Verify.py,
src/plugins/WebPage.py, src/plugins/WriteCD.py,
src/plugins/WritePkg.py, src/plugins/DetAncestralReport.py:
Use get_event_from_handle (not find_ ).
svn: r3462
2004-08-21 18:56:01 +00:00
|
|
|
event = self.db.get_event_from_handle(event_handle)
|
2004-09-23 02:25:07 +00:00
|
|
|
other_bday = event.get_date_object().get_sort_value()
|
|
|
|
if other_bday == "99999999":
|
2004-02-19 05:07:46 +00:00
|
|
|
continue;
|
2004-09-23 02:25:07 +00:00
|
|
|
if person_bday > other_bday:
|
2004-02-19 05:07:46 +00:00
|
|
|
target = i
|
|
|
|
else:
|
|
|
|
continue
|
2004-02-15 01:57:07 +00:00
|
|
|
|
|
|
|
# Actually need to move? Do it now.
|
|
|
|
if (target != index):
|
2004-07-28 02:29:07 +00:00
|
|
|
list.remove(person.get_handle())
|
|
|
|
list.insert(target,person.get_handle())
|
2004-02-15 01:57:07 +00:00
|
|
|
return list
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-04-26 23:17:51 +00:00
|
|
|
|
|
|
|
def short(val,size=60):
|
|
|
|
if len(val) > size:
|
|
|
|
return "%s..." % val[0:size]
|
|
|
|
else:
|
|
|
|
return val
|
2004-02-14 05:40:30 +00:00
|
|
|
|
|
|
|
def place_title(db,event):
|
2004-07-28 02:29:07 +00:00
|
|
|
pid = event.get_place_handle()
|
2004-02-14 05:40:30 +00:00
|
|
|
if pid:
|
2004-08-07 05:16:57 +00:00
|
|
|
return db.get_place_from_handle(pid).get_title()
|
2004-02-14 05:40:30 +00:00
|
|
|
else:
|
|
|
|
return u''
|
2004-05-02 04:10:33 +00:00
|
|
|
|
|
|
|
def build_dropdown(entry,strings):
|
|
|
|
store = gtk.ListStore(gobject.TYPE_STRING)
|
|
|
|
for value in strings:
|
2004-08-11 03:42:38 +00:00
|
|
|
node = store.append()
|
|
|
|
store.set(node,0,value)
|
2004-05-02 04:10:33 +00:00
|
|
|
completion = gtk.EntryCompletion()
|
|
|
|
completion.set_text_column(0)
|
|
|
|
completion.set_model(store)
|
|
|
|
entry.set_completion(completion)
|