2002-10-20 14:25:16 +00:00
|
|
|
#
|
|
|
|
# Gramps - a GTK+/GNOME based genealogy program
|
|
|
|
#
|
2003-05-22 03:37:33 +00:00
|
|
|
# Copyright (C) 2000-2003 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 string
|
|
|
|
import pickle
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# GTK/Gnome modules
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
import gtk
|
|
|
|
import gtk.glade
|
2003-03-03 04:32:53 +00:00
|
|
|
import gnome
|
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
|
|
|
|
import GrampsCfg
|
|
|
|
import ImageSelect
|
|
|
|
import sort
|
|
|
|
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
|
|
|
|
|
2003-02-24 04:51:57 +00:00
|
|
|
from QuestionDialog import QuestionDialog, 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
|
|
|
|
|
|
|
_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)]
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# EditPerson class
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
class EditPerson:
|
|
|
|
|
2003-06-16 04:57:25 +00:00
|
|
|
def __init__(self,person,db,callback=None):
|
2002-10-20 14:25:16 +00:00
|
|
|
"""Creates an edit window. Associates a person with the window."""
|
|
|
|
self.person = person
|
|
|
|
self.original_id = person.getId()
|
|
|
|
self.db = db
|
|
|
|
self.callback = callback
|
|
|
|
self.path = db.getSavePath()
|
|
|
|
self.not_loaded = 1
|
|
|
|
self.lds_not_loaded = 1
|
|
|
|
self.lists_changed = 0
|
|
|
|
self.update_birth = 0
|
|
|
|
self.update_death = 0
|
2003-06-13 15:08:07 +00:00
|
|
|
self.pdmap = {}
|
2002-10-20 14:25:16 +00:00
|
|
|
self.add_places = []
|
2003-07-01 19:04:47 +00:00
|
|
|
self.should_guess_gender = (self.original_id == '' and
|
|
|
|
person.getGender () ==
|
|
|
|
RelLib.Person.unknown)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
for key in db.getPlaceKeys():
|
|
|
|
p = db.getPlaceDisplay(key)
|
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")
|
2003-10-29 05:04:43 +00:00
|
|
|
self.gallery = ImageSelect.Gallery(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.surname_field = self.get_widget("surname")
|
|
|
|
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")
|
|
|
|
self.bplace = self.get_widget("birthPlace")
|
|
|
|
self.bpcombo = self.get_widget("bpcombo")
|
|
|
|
self.dpcombo = self.get_widget("dpcombo")
|
|
|
|
self.sncombo = self.get_widget("sncombo")
|
|
|
|
self.ddate = self.get_widget("deathDate")
|
|
|
|
self.dplace = self.get_widget("deathPlace")
|
|
|
|
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")
|
2002-10-20 14:25:16 +00:00
|
|
|
|
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")
|
|
|
|
|
2003-01-10 05:21:32 +00:00
|
|
|
self.death = RelLib.Event(person.getDeath())
|
|
|
|
self.birth = RelLib.Event(person.getBirth())
|
|
|
|
self.pname = RelLib.Name(person.getPrimaryName())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
self.elist = person.getEventList()[:]
|
|
|
|
self.nlist = person.getAlternateNames()[:]
|
|
|
|
self.alist = person.getAttributeList()[:]
|
|
|
|
self.ulist = person.getUrlList()[:]
|
|
|
|
self.plist = person.getAddressList()[:]
|
|
|
|
|
2003-10-29 05:04:43 +00:00
|
|
|
if person:
|
|
|
|
self.srcreflist = person.getSourceRefList()
|
|
|
|
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)
|
2003-11-13 21:44:09 +00:00
|
|
|
if self.person.getPhotoList():
|
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
|
2003-01-06 05:14:49 +00:00
|
|
|
etitles = [(_('Event'),-1,150),(_('Description'),-1,150),
|
|
|
|
(_('Date'),-1,100),(_('Place'),-1,100)]
|
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
|
|
|
|
2003-06-13 15:08:07 +00:00
|
|
|
place_list = self.pdmap.keys()
|
2003-05-23 02:12:55 +00:00
|
|
|
place_list.sort()
|
|
|
|
self.autoplace = AutoComp.AutoCombo(self.bpcombo, place_list)
|
|
|
|
self.autodeath = AutoComp.AutoCombo(self.dpcombo, place_list, self.autoplace)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.comp = AutoComp.AutoCombo(self.sncombo,self.db.getSurnames())
|
|
|
|
|
|
|
|
self.gid.set_text(person.getId())
|
|
|
|
self.gid.set_editable(GrampsCfg.id_edit)
|
|
|
|
|
2003-01-10 05:21:32 +00:00
|
|
|
self.lds_baptism = RelLib.LdsOrd(self.person.getLdsBaptism())
|
|
|
|
self.lds_endowment = RelLib.LdsOrd(self.person.getLdsEndowment())
|
|
|
|
self.lds_sealing = RelLib.LdsOrd(self.person.getLdsSeal())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-11-11 00:32:28 +00:00
|
|
|
if GrampsCfg.uselds \
|
|
|
|
or (not self.lds_baptism.isEmpty()) \
|
|
|
|
or (not self.lds_endowment.isEmpty()) \
|
2003-11-14 22:50:03 +00:00
|
|
|
or (not self.lds_sealing.isEmpty()):
|
2002-10-20 14:25:16 +00:00
|
|
|
self.get_widget("lds_tab").show()
|
|
|
|
self.get_widget("lds_page").show()
|
2003-11-11 00:32:28 +00:00
|
|
|
if (not self.lds_baptism.isEmpty()) \
|
|
|
|
or (not self.lds_endowment.isEmpty()) \
|
|
|
|
or (not self.lds_sealing.isEmpty()):
|
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-01-07 04:58:51 +00:00
|
|
|
self.autotype = AutoComp.AutoCombo(self.ntype_field,types)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.write_primary_name()
|
|
|
|
|
2003-01-10 05:21:32 +00:00
|
|
|
if person.getGender() == RelLib.Person.male:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.is_male.set_active(1)
|
2003-01-10 05:21:32 +00:00
|
|
|
elif person.getGender() == RelLib.Person.female:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.is_female.set_active(1)
|
|
|
|
else:
|
|
|
|
self.is_unknown.set_active(1)
|
|
|
|
|
|
|
|
self.nick.set_text(person.getNickName())
|
|
|
|
self.load_person_image()
|
|
|
|
|
|
|
|
# set notes data
|
|
|
|
self.notes_buffer = self.notes_field.get_buffer()
|
2003-11-09 23:14:18 +00:00
|
|
|
if person.getNote():
|
2003-12-10 14:21:48 +00:00
|
|
|
self.notes_buffer.set_text(person.getNote())
|
|
|
|
if person.getNoteObj().getFormat() == 1:
|
|
|
|
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
|
|
|
|
2002-11-15 03:49:39 +00:00
|
|
|
self.event_list.drag_dest_set(gtk.DEST_DEFAULT_ALL,pycode_tgts,ACTION_COPY)
|
|
|
|
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)
|
2003-01-10 05:21:32 +00:00
|
|
|
self.event_list.connect('drag_data_received',self.ev_drag_data_received)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2002-11-15 03:49:39 +00:00
|
|
|
self.web_list.drag_dest_set(gtk.DEST_DEFAULT_ALL,pycode_tgts,ACTION_COPY)
|
|
|
|
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
|
|
|
|
2003-10-30 04:17:05 +00:00
|
|
|
self.bdate_check = DateEdit.DateEdit(self.bdate,
|
|
|
|
self.get_widget("birth_stat"))
|
2003-01-02 04:31:52 +00:00
|
|
|
self.bdate_check.set_calendar(self.birth.getDateObj().get_calendar())
|
|
|
|
|
2003-10-30 04:17:05 +00:00
|
|
|
self.ddate_check = DateEdit.DateEdit(self.ddate,
|
|
|
|
self.get_widget("death_stat"))
|
2003-01-02 04:31:52 +00:00
|
|
|
self.ddate_check.set_calendar(self.death.getDateObj().get_calendar())
|
|
|
|
|
|
|
|
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,
|
|
|
|
"on_addphoto_clicked" : self.gallery.on_add_photo_clicked,
|
2003-12-12 05:36:38 +00:00
|
|
|
"on_selectphoto_clicked" : self.gallery.on_select_photo_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,
|
|
|
|
"on_deletephoto_clicked" : self.gallery.on_delete_photo_clicked,
|
|
|
|
"on_edit_properties_clicked": self.gallery.popup_change_description,
|
2003-03-03 04:32:53 +00:00
|
|
|
"on_editphoto_clicked" : self.gallery.on_edit_photo_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,
|
|
|
|
"on_name_note_clicked" : self.on_name_note_clicked,
|
|
|
|
"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_name_source_clicked" : self.on_primary_name_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,
|
|
|
|
"on_givenName_focus_out_event": self.on_givenName_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
|
|
|
})
|
|
|
|
|
|
|
|
self.update_birth_death()
|
|
|
|
|
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'))
|
|
|
|
|
2003-12-03 03:49:39 +00:00
|
|
|
if self.person.getComplete():
|
|
|
|
self.complete.set_active(1)
|
|
|
|
|
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()
|
2003-03-21 04:25:55 +00:00
|
|
|
self.window.show()
|
2003-03-14 05:46:02 +00:00
|
|
|
|
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)
|
|
|
|
|
|
|
|
def lds_field(self,ord,combo,date,place):
|
|
|
|
combo.set_popdown_strings(_temple_names)
|
2003-11-13 21:44:09 +00:00
|
|
|
if not ord.isEmpty():
|
2002-10-20 14:25:16 +00:00
|
|
|
stat = ord.getStatus()
|
|
|
|
date.set_text(ord.getDate())
|
|
|
|
if ord.getTemple() != "":
|
|
|
|
name = const.lds_temple_to_abrev[ord.getTemple()]
|
|
|
|
else:
|
|
|
|
name = ""
|
|
|
|
combo.entry.set_text(name)
|
|
|
|
else:
|
|
|
|
stat = 0
|
|
|
|
combo.entry.set_text("")
|
|
|
|
|
2003-01-06 05:14:49 +00:00
|
|
|
AutoComp.AutoEntry(place,None,self.autoplace)
|
2002-10-20 14:25:16 +00:00
|
|
|
if ord and ord.getPlace():
|
|
|
|
place.set_text(ord.getPlace().get_title())
|
|
|
|
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:
|
|
|
|
self.ldsfam = self.lds_sealing.getFamily()
|
|
|
|
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
|
|
|
|
flist = [self.person.getMainParents()]
|
|
|
|
for (fam,mrel,frel) in self.person.getParentList():
|
|
|
|
flist.append(fam)
|
|
|
|
for fam in flist:
|
|
|
|
if fam == None:
|
|
|
|
continue
|
|
|
|
f = fam.getFather()
|
|
|
|
m = fam.getMother()
|
|
|
|
if f and m:
|
|
|
|
name = _("%(father)s and %(mother)s") % {
|
|
|
|
'father' : GrampsCfg.nameof(f),
|
|
|
|
'mother' : GrampsCfg.nameof(m) }
|
|
|
|
elif f:
|
|
|
|
name = GrampsCfg.nameof(f)
|
|
|
|
elif m:
|
|
|
|
name = GrampsCfg.nameof(m)
|
|
|
|
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):
|
|
|
|
self.should_guess_gender = 0
|
|
|
|
|
|
|
|
def on_givenName_focus_out_event (self, entry, event):
|
|
|
|
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:
|
|
|
|
self.is_unknown.set_active (1)
|
|
|
|
elif gender == RelLib.Person.male:
|
|
|
|
self.is_male.set_active (1)
|
|
|
|
else:
|
|
|
|
self.is_female.set_active (1)
|
|
|
|
|
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):
|
2003-11-17 00:41:32 +00:00
|
|
|
self.lds_baptism.setStatus(obj.get_data("val"))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def set_lds_endow(self,obj):
|
2003-11-17 00:41:32 +00:00
|
|
|
self.lds_endowment.setStatus(obj.get_data("val"))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def set_lds_seal(self,obj):
|
2003-11-17 00:41:32 +00:00
|
|
|
self.lds_sealing.setStatus(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
|
2003-01-06 05:14:49 +00:00
|
|
|
elif person == self.person.getId():
|
|
|
|
self.move_element(self.elist,self.etree.get_selected_row(),row)
|
|
|
|
else:
|
|
|
|
foo = pickle.loads(data[2]);
|
|
|
|
for src in foo.getSourceRefList():
|
|
|
|
base = src.getBase()
|
|
|
|
newbase = self.db.findSourceNoMap(base.getId())
|
|
|
|
src.setBase(newbase)
|
|
|
|
place = foo.getPlace()
|
|
|
|
if place:
|
|
|
|
foo.setPlace(self.db.findPlaceNoMap(place.getId()))
|
|
|
|
self.elist.insert(row,foo)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
self.lists_changed = 1
|
|
|
|
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]);
|
2002-10-20 14:25:16 +00:00
|
|
|
data = str(('pevent',self.person.getId(),pickled));
|
|
|
|
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
|
2003-01-06 05:14:49 +00:00
|
|
|
elif person == self.person.getId():
|
|
|
|
self.move_element(self.ulist,self.wtree.get_selected_row(),row)
|
|
|
|
else:
|
|
|
|
foo = pickle.loads(data[2]);
|
|
|
|
self.ulist.append(foo)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.lists_changed = 1
|
|
|
|
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]);
|
|
|
|
data = str(('url',self.person.getId(),pickled));
|
|
|
|
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
|
2003-01-06 05:14:49 +00:00
|
|
|
elif person == self.person.getId():
|
|
|
|
self.move_element(self.alist,self.atree.get_selected_row(),row)
|
|
|
|
else:
|
|
|
|
foo = pickle.loads(data[2]);
|
|
|
|
for src in foo.getSourceRefList():
|
|
|
|
base = src.getBase()
|
|
|
|
newbase = self.db.findSourceNoMap(base.getId())
|
|
|
|
src.setBase(newbase)
|
|
|
|
self.alist.append(foo)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.lists_changed = 1
|
|
|
|
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]);
|
|
|
|
data = str(('pattr',self.person.getId(),pickled));
|
|
|
|
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
|
2003-01-06 05:14:49 +00:00
|
|
|
elif person == self.person.getId():
|
|
|
|
self.move_element(self.plist,self.ptree.get_selected_row(),row)
|
|
|
|
else:
|
|
|
|
foo = pickle.loads(data[2]);
|
|
|
|
for src in foo.getSourceRefList():
|
|
|
|
base = src.getBase()
|
|
|
|
newbase = self.db.findSourceNoMap(base.getId())
|
|
|
|
src.setBase(newbase)
|
2003-01-08 05:41:35 +00:00
|
|
|
self.plist.insert(row,foo)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
self.lists_changed = 1
|
|
|
|
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]);
|
|
|
|
data = str(('paddr',self.person.getId(),pickled));
|
|
|
|
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:
|
2003-06-11 03:26:02 +00:00
|
|
|
iter = self.ntree.add([name.getName(),_(name.getType())],name)
|
|
|
|
self.nmap[str(name)] = iter
|
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:
|
2003-06-11 03:26:02 +00:00
|
|
|
iter = self.wtree.add([url.get_path(),url.get_description()],url)
|
|
|
|
self.wmap[str(url)] = iter
|
|
|
|
|
2002-11-21 04:41:40 +00:00
|
|
|
if len(self.ulist) > 0:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.web_go.set_sensitive(0)
|
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:
|
|
|
|
self.web_go.set_sensitive(0)
|
|
|
|
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:
|
|
|
|
location = "%s %s %s %s" % (addr.getStreet(),addr.getCity(),
|
|
|
|
addr.getState(),addr.getCountry())
|
2003-06-11 03:26:02 +00:00
|
|
|
iter = self.ptree.add([addr.getDate(),location],addr)
|
|
|
|
self.pmap[str(addr)] = iter
|
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:
|
2003-06-11 02:54:57 +00:00
|
|
|
iter = self.atree.add([const.display_pattr(attr.getType()),attr.getValue()],attr)
|
|
|
|
self.amap[str(attr)] = iter
|
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 = {}
|
2002-11-21 04:41:40 +00:00
|
|
|
for event in self.elist:
|
2003-06-11 02:54:57 +00:00
|
|
|
iter = self.etree.add([const.display_pevent(event.getName()),event.getDescription(),
|
|
|
|
event.getQuoteDate(),event.getPlaceName()],event)
|
|
|
|
self.emap[str(event)] = iter
|
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:
|
|
|
|
self.update_birth = 0
|
|
|
|
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:
|
|
|
|
self.update_death = 0
|
|
|
|
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
|
* 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
|
|
|
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
|
|
|
|
pname = self.person.getPrimaryName().getName()
|
* 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
|
|
|
|
pname = self.person.getPrimaryName().getName()
|
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()
|
|
|
|
store,iter = sel.get_selected()
|
|
|
|
if iter:
|
|
|
|
row = store.get_path(iter)
|
|
|
|
sel.select_path((row[0]-1))
|
|
|
|
|
|
|
|
def on_down_clicked(self,obj):
|
|
|
|
sel = obj.get_selection()
|
|
|
|
store,iter = sel.get_selected()
|
|
|
|
if iter:
|
|
|
|
row = store.get_path(iter)
|
|
|
|
sel.select_path((row[0]+1))
|
|
|
|
|
|
|
|
def on_event_add_clicked(self,obj):
|
|
|
|
"""Brings up the EventEditor for a new event"""
|
|
|
|
import EventEdit
|
|
|
|
pname = self.person.getPrimaryName().getName()
|
|
|
|
EventEdit.EventEditor(self,pname,const.personalEvents,
|
2003-08-11 00:59:16 +00:00
|
|
|
const.save_event,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
|
|
|
|
self.update_birth = 1
|
|
|
|
pname = self.person.getPrimaryName().getName()
|
|
|
|
event = self.birth
|
2003-12-17 05:23:16 +00:00
|
|
|
event.setDate(unicode(self.bdate.get_text()))
|
|
|
|
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:
|
|
|
|
event.setPlace(p)
|
|
|
|
EventEdit.EventEditor(self,pname,const.personalEvents,
|
2003-08-11 00:59:16 +00:00
|
|
|
const.save_event,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
|
|
|
|
self.update_death = 1
|
|
|
|
pname = self.person.getPrimaryName().getName()
|
|
|
|
event = self.death
|
2003-12-17 05:23:16 +00:00
|
|
|
event.setDate(unicode(self.ddate.get_text()))
|
|
|
|
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:
|
|
|
|
event.setPlace(p)
|
|
|
|
EventEdit.EventEditor(self,pname,const.personalEvents,
|
2003-08-11 00:59:16 +00:00
|
|
|
const.save_event,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"""
|
2002-11-21 04:41:40 +00:00
|
|
|
store,iter = self.ntree.get_selected()
|
|
|
|
if iter:
|
|
|
|
self.nlist.remove(self.ntree.get_object(iter))
|
2002-10-20 14:25:16 +00:00
|
|
|
self.lists_changed = 1
|
|
|
|
self.redraw_name_list()
|
|
|
|
|
|
|
|
def on_delete_url_clicked(self,obj):
|
|
|
|
"""Deletes the selected URL from the URL list"""
|
2002-11-21 04:41:40 +00:00
|
|
|
store,iter = self.wtree.get_selected()
|
|
|
|
if iter:
|
|
|
|
self.ulist.remove(self.wtree.get_object(iter))
|
2002-10-20 14:25:16 +00:00
|
|
|
self.lists_changed = 1
|
|
|
|
self.redraw_url_list()
|
|
|
|
|
|
|
|
def on_delete_attr_clicked(self,obj):
|
|
|
|
"""Deletes the selected attribute from the attribute list"""
|
2002-11-21 04:41:40 +00:00
|
|
|
store,iter = self.atree.get_selected()
|
|
|
|
if iter:
|
|
|
|
self.alist.remove(self.atree.get_object(iter))
|
2002-10-20 14:25:16 +00:00
|
|
|
self.lists_changed = 1
|
|
|
|
self.redraw_attr_list()
|
|
|
|
|
|
|
|
def on_delete_addr_clicked(self,obj):
|
|
|
|
"""Deletes the selected address from the address list"""
|
2002-11-21 04:41:40 +00:00
|
|
|
store,iter = self.ptree.get_selected()
|
|
|
|
if iter:
|
|
|
|
self.plist.remove(self.ptree.get_object(iter))
|
2002-10-20 14:25:16 +00:00
|
|
|
self.lists_changed = 1
|
|
|
|
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"""
|
|
|
|
if self.did_data_change():
|
2003-02-24 04:51:57 +00:00
|
|
|
n = "<i>%s</i>" % self.person.getPrimaryName().getRegularName()
|
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:
|
2002-11-28 05:52:02 +00:00
|
|
|
self.gallery.close()
|
|
|
|
self.window.destroy()
|
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"""
|
|
|
|
if self.did_data_change():
|
2003-02-28 04:49:18 +00:00
|
|
|
n = "<i>%s</i>" % self.person.getPrimaryName().getRegularName()
|
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
|
|
|
return 1
|
|
|
|
else:
|
2002-11-28 05:52:02 +00:00
|
|
|
self.gallery.close()
|
|
|
|
self.window.destroy()
|
2002-10-20 14:25:16 +00:00
|
|
|
return 0
|
|
|
|
|
|
|
|
def cancel_callback(self):
|
|
|
|
"""If the user answered yes to abandoning changes, close the window"""
|
2002-11-28 05:52:02 +00:00
|
|
|
self.gallery.close()
|
|
|
|
self.window.destroy()
|
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
|
|
|
|
original record"""
|
2003-09-20 19:56:27 +00:00
|
|
|
|
2003-08-07 04:38:06 +00:00
|
|
|
surname = unicode(self.surname_field.get_text())
|
2003-12-17 05:23:16 +00:00
|
|
|
self.birth.setDate(unicode(self.bdate.get_text()))
|
|
|
|
self.death.setDate(unicode(self.ddate.get_text()))
|
|
|
|
|
|
|
|
ntype = unicode(self.ntype_field.entry.get_text())
|
|
|
|
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())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
changed = 0
|
|
|
|
name = self.person.getPrimaryName()
|
|
|
|
|
2003-12-03 03:49:39 +00:00
|
|
|
if self.complete.get_active() != self.person.getComplete():
|
|
|
|
changed = 1
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
if self.person.getId() != idval:
|
|
|
|
changed = 1
|
|
|
|
if suffix != name.getSuffix():
|
|
|
|
changed = 1
|
2002-12-04 04:58:07 +00:00
|
|
|
if prefix != name.getSurnamePrefix():
|
|
|
|
changed = 1
|
2003-10-12 04:26:00 +00:00
|
|
|
if surname.upper() != name.getSurname().upper():
|
|
|
|
changed = 1
|
2004-01-20 23:30:15 +00:00
|
|
|
if ntype != const.NameTypesMap.find_value(name.getType()):
|
2002-10-20 14:25:16 +00:00
|
|
|
changed = 1
|
|
|
|
if given != name.getFirstName():
|
|
|
|
changed = 1
|
|
|
|
if nick != self.person.getNickName():
|
|
|
|
changed = 1
|
|
|
|
if title != name.getTitle():
|
|
|
|
changed = 1
|
|
|
|
if self.pname.getNote() != name.getNote():
|
|
|
|
changed = 1
|
|
|
|
if self.lds_not_loaded == 0 and self.check_lds():
|
2003-01-10 05:21:32 +00:00
|
|
|
changed = 1
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-06-27 11:59:09 +00:00
|
|
|
bplace = unicode(string.strip(self.bplace.get_text()))
|
|
|
|
dplace = unicode(string.strip(self.dplace.get_text()))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2003-06-13 15:08:07 +00:00
|
|
|
if self.pdmap.has_key(bplace):
|
|
|
|
p1 = self.db.getPlaceMap()[self.pdmap[bplace]]
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
p1 = None
|
|
|
|
if bplace != "":
|
|
|
|
changed = 1
|
|
|
|
self.birth.setPlace(p1)
|
|
|
|
|
2003-06-13 15:08:07 +00:00
|
|
|
if self.pdmap.has_key(dplace):
|
|
|
|
p1 = self.db.getPlaceMap()[self.pdmap[dplace]]
|
2002-10-20 14:25:16 +00:00
|
|
|
else:
|
|
|
|
p1 = None
|
|
|
|
if dplace != "":
|
|
|
|
changed = 1
|
|
|
|
self.death.setPlace(p1)
|
|
|
|
|
|
|
|
if not self.birth.are_equal(self.person.getBirth()):
|
|
|
|
changed = 1
|
|
|
|
if not self.death.are_equal(self.person.getDeath()):
|
|
|
|
changed = 1
|
2003-01-10 05:21:32 +00:00
|
|
|
if male and self.person.getGender() != RelLib.Person.male:
|
2002-10-20 14:25:16 +00:00
|
|
|
changed = 1
|
2003-01-10 05:21:32 +00:00
|
|
|
elif female and self.person.getGender() != RelLib.Person.female:
|
2002-10-20 14:25:16 +00:00
|
|
|
changed = 1
|
2003-01-10 05:21:32 +00:00
|
|
|
elif unknown and self.person.getGender() != RelLib.Person.unknown:
|
2002-10-20 14:25:16 +00:00
|
|
|
changed = 1
|
|
|
|
if text != self.person.getNote() or self.lists_changed:
|
|
|
|
changed = 1
|
2003-12-16 00:37:47 +00:00
|
|
|
if format != self.person.getNoteFormat():
|
2003-12-10 14:21:48 +00:00
|
|
|
changed = 1
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
if self.lds_not_loaded == 0:
|
|
|
|
if not self.lds_baptism.are_equal(self.person.getLdsBaptism()):
|
|
|
|
changed= 1
|
|
|
|
|
|
|
|
if not self.lds_endowment.are_equal(self.person.getLdsEndowment()):
|
|
|
|
changed = 1
|
|
|
|
|
|
|
|
if not self.lds_sealing.are_equal(self.person.getLdsSeal()):
|
|
|
|
changed = 1
|
|
|
|
|
|
|
|
return changed
|
|
|
|
|
|
|
|
def check_lds(self):
|
2003-12-17 05:23:16 +00:00
|
|
|
self.lds_baptism.setDate(unicode(self.ldsbap_date.get_text()))
|
|
|
|
temple = unicode(self.ldsbap_temple.entry.get_text())
|
2002-10-20 14:25:16 +00:00
|
|
|
if const.lds_temple_codes.has_key(temple):
|
|
|
|
self.lds_baptism.setTemple(const.lds_temple_codes[temple])
|
|
|
|
else:
|
|
|
|
self.lds_baptism.setTemple("")
|
|
|
|
self.lds_baptism.setPlace(self.get_place(self.ldsbapplace,1))
|
|
|
|
|
2003-12-17 05:23:16 +00:00
|
|
|
self.lds_endowment.setDate(unicode(self.ldsend_date.get_text()))
|
|
|
|
temple = unicode(self.ldsend_temple.entry.get_text())
|
2002-10-20 14:25:16 +00:00
|
|
|
if const.lds_temple_codes.has_key(temple):
|
|
|
|
self.lds_endowment.setTemple(const.lds_temple_codes[temple])
|
|
|
|
else:
|
|
|
|
self.lds_endowment.setTemple("")
|
|
|
|
self.lds_endowment.setPlace(self.get_place(self.ldsendowplace,1))
|
|
|
|
|
2003-12-17 05:23:16 +00:00
|
|
|
self.lds_sealing.setDate(unicode(self.ldsseal_date.get_text()))
|
|
|
|
temple = unicode(self.ldsseal_temple.entry.get_text())
|
2002-10-20 14:25:16 +00:00
|
|
|
if const.lds_temple_codes.has_key(temple):
|
|
|
|
self.lds_sealing.setTemple(const.lds_temple_codes[temple])
|
|
|
|
else:
|
|
|
|
self.lds_sealing.setTemple("")
|
|
|
|
self.lds_sealing.setFamily(self.ldsfam)
|
|
|
|
self.lds_sealing.setPlace(self.get_place(self.ldssealplace,1))
|
|
|
|
|
|
|
|
def on_event_delete_clicked(self,obj):
|
|
|
|
"""Delete the selected event"""
|
|
|
|
if Utils.delete_selected(obj,self.elist):
|
|
|
|
self.lists_changed = 1
|
|
|
|
self.redraw_event_list()
|
|
|
|
|
|
|
|
def update_birth_death(self):
|
|
|
|
self.bdate.set_text(self.birth.getDate())
|
|
|
|
self.bplace.set_text(self.birth.getPlaceName())
|
2003-01-02 04:31:52 +00:00
|
|
|
self.bdate_check.set_calendar(self.birth.getDateObj().get_calendar())
|
2002-10-20 14:25:16 +00:00
|
|
|
self.ddate.set_text(self.death.getDate())
|
2003-01-02 04:31:52 +00:00
|
|
|
self.ddate_check.set_calendar(self.death.getDateObj().get_calendar())
|
2002-10-20 14:25:16 +00:00
|
|
|
self.dplace.set_text(self.death.getPlaceName())
|
|
|
|
self.dplace.set_text(self.death.getPlaceName())
|
|
|
|
|
|
|
|
def on_update_attr_clicked(self,obj):
|
|
|
|
import AttrEdit
|
2002-11-21 04:41:40 +00:00
|
|
|
store,iter = self.atree.get_selected()
|
|
|
|
if iter:
|
|
|
|
attr = self.atree.get_object(iter)
|
2002-10-20 14:25:16 +00:00
|
|
|
pname = self.person.getPrimaryName().getName()
|
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
|
2002-11-21 04:41:40 +00:00
|
|
|
store,iter = self.ptree.get_selected()
|
|
|
|
if iter:
|
* 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,self.ptree.get_object(iter),
|
|
|
|
self.addr_edit_callback,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_update_url_clicked(self,obj):
|
|
|
|
import UrlEdit
|
2003-03-03 04:32:53 +00:00
|
|
|
store,iter = self.wtree.get_selected()
|
|
|
|
if iter:
|
2002-10-20 14:25:16 +00:00
|
|
|
pname = self.person.getPrimaryName().getName()
|
2003-06-11 03:26:02 +00:00
|
|
|
url = self.wtree.get_object(iter)
|
* 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
|
|
|
|
|
|
|
store,iter = self.etree.get_selected()
|
|
|
|
if not iter:
|
|
|
|
return
|
|
|
|
pname = self.person.getPrimaryName().getName()
|
|
|
|
event = self.etree.get_object(iter)
|
|
|
|
EventEdit.EventEditor(self,pname,const.personalEvents,
|
2003-08-11 00:59:16 +00:00
|
|
|
const.save_event,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):
|
|
|
|
store,iter = obj.get_selected()
|
|
|
|
if iter:
|
|
|
|
row = store.get_path(iter)
|
|
|
|
event = self.elist[row[0]]
|
|
|
|
self.event_date_field.set_text(event.getDate())
|
|
|
|
self.event_place_field.set_text(event.getPlaceName())
|
2003-03-03 04:32:53 +00:00
|
|
|
self.event_name_field.set_text(const.display_pevent(event.getName()))
|
2002-10-20 14:25:16 +00:00
|
|
|
self.event_cause_field.set_text(event.getCause())
|
2003-04-26 23:17:51 +00:00
|
|
|
self.event_descr_field.set_text(short(event.getDescription()))
|
2002-10-20 14:25:16 +00:00
|
|
|
if len(event.getSourceRefList()) > 0:
|
|
|
|
psrc = event.getSourceRefList()[0]
|
2003-04-26 23:17:51 +00:00
|
|
|
self.event_src_field.set_text(short(psrc.getBase().getTitle()))
|
2002-10-20 14:25:16 +00:00
|
|
|
self.event_conf_field.set_text(const.confidence[psrc.getConfidence()])
|
|
|
|
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):
|
2002-11-21 04:41:40 +00:00
|
|
|
store,iter = self.ptree.get_selected()
|
2002-10-20 14:25:16 +00:00
|
|
|
if iter:
|
2002-11-21 04:41:40 +00:00
|
|
|
addr = self.ptree.get_object(iter)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.addr_start.set_text(addr.getDate())
|
|
|
|
self.addr_street.set_text(addr.getStreet())
|
|
|
|
self.addr_city.set_text(addr.getCity())
|
|
|
|
self.addr_state.set_text(addr.getState())
|
|
|
|
self.addr_country.set_text(addr.getCountry())
|
|
|
|
self.addr_postal.set_text(addr.getPostal())
|
2003-12-09 06:02:36 +00:00
|
|
|
self.addr_phone.set_text(addr.getPhone())
|
2002-10-20 14:25:16 +00:00
|
|
|
if len(addr.getSourceRefList()) > 0:
|
|
|
|
psrc = addr.getSourceRefList()[0]
|
|
|
|
self.addr_conf_field.set_text(const.confidence[psrc.getConfidence()])
|
2003-04-26 23:17:51 +00:00
|
|
|
self.addr_src_field.set_text(short(psrc.getBase().getTitle()))
|
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):
|
2002-11-21 04:41:40 +00:00
|
|
|
store,iter = self.ntree.get_selected()
|
2002-10-20 14:25:16 +00:00
|
|
|
if iter:
|
2002-11-21 04:41:40 +00:00
|
|
|
name = self.ntree.get_object(iter)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.alt_given_field.set_text(name.getFirstName())
|
|
|
|
self.alt_title_field.set_text(name.getTitle())
|
|
|
|
self.alt_last_field.set_text(name.getSurname())
|
|
|
|
self.alt_suffix_field.set_text(name.getSuffix())
|
2002-12-04 04:58:07 +00:00
|
|
|
self.alt_prefix_field.set_text(name.getSurnamePrefix())
|
2004-01-20 23:30:15 +00:00
|
|
|
self.name_type_field.set_text(const.NameTypesMap.find_value(name.getType()))
|
2002-10-20 14:25:16 +00:00
|
|
|
if len(name.getSourceRefList()) > 0:
|
|
|
|
psrc = name.getSourceRefList()[0]
|
2003-04-26 23:17:51 +00:00
|
|
|
self.name_src_field.set_text(short(psrc.getBase().getTitle()))
|
2002-10-20 14:25:16 +00:00
|
|
|
self.name_conf_field.set_text(const.confidence[psrc.getConfidence()])
|
|
|
|
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):
|
2002-11-21 04:41:40 +00:00
|
|
|
store,iter = self.wtree.get_selected()
|
2002-10-20 14:25:16 +00:00
|
|
|
if iter:
|
2002-11-21 04:41:40 +00:00
|
|
|
url = self.wtree.get_object(iter)
|
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):
|
2002-11-21 04:41:40 +00:00
|
|
|
store,iter = self.atree.get_selected()
|
2002-10-20 14:25:16 +00:00
|
|
|
if iter:
|
2002-11-21 04:41:40 +00:00
|
|
|
attr = self.atree.get_object(iter)
|
2003-03-03 04:32:53 +00:00
|
|
|
self.attr_type.set_text(const.display_pattr(attr.getType()))
|
2003-04-26 23:17:51 +00:00
|
|
|
self.attr_value.set_text(short(attr.getValue()))
|
2002-10-20 14:25:16 +00:00
|
|
|
if len(attr.getSourceRefList()) > 0:
|
|
|
|
psrc = attr.getSourceRefList()[0]
|
2003-04-26 23:17:51 +00:00
|
|
|
self.attr_src_field.set_text(short(psrc.getBase().getTitle()))
|
2002-10-20 14:25:16 +00:00
|
|
|
self.attr_conf_field.set_text(const.confidence[psrc.getConfidence()])
|
|
|
|
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
|
2002-11-21 04:41:40 +00:00
|
|
|
store,iter = self.ntree.get_selected()
|
|
|
|
if iter:
|
* 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
|
|
|
NameEdit.NameEditor(self,self.ntree.get_object(iter),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:
|
|
|
|
self.get_widget("personPix").hide()
|
|
|
|
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()))
|
|
|
|
scale = float(const.picWidth)/ratio
|
|
|
|
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)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.get_widget("personPix").set_from_pixbuf(i)
|
|
|
|
self.get_widget("personPix").show()
|
|
|
|
except:
|
|
|
|
self.get_widget("personPix").hide()
|
|
|
|
|
|
|
|
def update_lists(self):
|
|
|
|
"""Updates the person's lists if anything has changed"""
|
|
|
|
if self.lists_changed:
|
|
|
|
self.person.setEventList(self.elist)
|
|
|
|
self.person.setAlternateNames(self.nlist)
|
|
|
|
self.person.setUrlList(self.ulist)
|
|
|
|
self.person.setAttributeList(self.alist)
|
|
|
|
self.person.setAddressList(self.plist)
|
|
|
|
self.person.setBirth(self.birth)
|
|
|
|
self.person.setDeath(self.death)
|
|
|
|
Utils.modified()
|
|
|
|
|
|
|
|
def on_apply_person_clicked(self,obj):
|
2003-12-17 05:23:16 +00:00
|
|
|
surname = unicode(self.surname_field.get_text())
|
|
|
|
suffix = unicode(self.suffix.get_text())
|
|
|
|
prefix = unicode(self.prefix.get_text())
|
|
|
|
ntype = unicode(self.ntype_field.entry.get_text())
|
|
|
|
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
|
|
|
|
|
2003-12-17 05:23:16 +00:00
|
|
|
self.birth.setDate(unicode(self.bdate.get_text()))
|
2003-09-20 19:56:27 +00:00
|
|
|
self.birth.setPlace(self.get_place(self.bplace,1))
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
if idval != self.person.getId():
|
|
|
|
m = self.db.getPersonMap()
|
|
|
|
if not m.has_key(idval):
|
|
|
|
if m.has_key(self.person.getId()):
|
|
|
|
del m[self.person.getId()]
|
|
|
|
m[idval] = self.person
|
|
|
|
self.person.setId(idval)
|
|
|
|
Utils.modified()
|
|
|
|
else:
|
|
|
|
n = GrampsCfg.nameof(m[idval])
|
|
|
|
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
|
|
|
|
|
|
|
if suffix != name.getSuffix():
|
|
|
|
name.setSuffix(suffix)
|
|
|
|
|
2002-12-04 04:58:07 +00:00
|
|
|
if prefix != name.getSurnamePrefix():
|
|
|
|
name.setSurnamePrefix(prefix)
|
|
|
|
|
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"
|
|
|
|
|
|
|
|
if ntype != name.getType():
|
|
|
|
name.setType(ntype)
|
|
|
|
|
2003-10-12 04:26:00 +00:00
|
|
|
if surname != name.getSurname():
|
|
|
|
name.setSurname(surname)
|
|
|
|
self.db.addSurname(surname)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
if given != name.getFirstName():
|
|
|
|
name.setFirstName(given)
|
|
|
|
|
|
|
|
if title != name.getTitle():
|
|
|
|
name.setTitle(title)
|
|
|
|
|
|
|
|
name.setSourceRefList(self.pname.getSourceRefList())
|
|
|
|
|
|
|
|
if not name.are_equal(self.person.getPrimaryName()):
|
|
|
|
self.person.setPrimaryName(name)
|
|
|
|
Utils.modified()
|
|
|
|
|
|
|
|
if nick != self.person.getNickName():
|
|
|
|
self.person.setNickName(nick)
|
|
|
|
Utils.modified()
|
|
|
|
|
2003-06-13 15:08:07 +00:00
|
|
|
self.pdmap.clear()
|
2002-10-20 14:25:16 +00:00
|
|
|
for key in self.db.getPlaceKeys():
|
|
|
|
p = self.db.getPlaceDisplay(key)
|
2003-06-13 15:08:07 +00:00
|
|
|
self.pdmap[p[0]] = key
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
if not self.person.getBirth().are_equal(self.birth):
|
|
|
|
self.person.setBirth(self.birth)
|
2003-04-20 03:52:54 +00:00
|
|
|
Utils.modified()
|
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
|
|
|
|
family = self.person.getMainParents()
|
|
|
|
if (family):
|
|
|
|
new_order = reorder_child_list(self.person,family.getChildList())
|
|
|
|
family.setChildList(new_order)
|
|
|
|
for (family, rel1, rel2) in self.person.getParentList():
|
|
|
|
new_order = reorder_child_list(self.person,family.getChildList())
|
|
|
|
family.setChildList(new_order)
|
|
|
|
|
2003-12-17 05:23:16 +00:00
|
|
|
self.death.setDate(unicode(self.ddate.get_text()))
|
2002-10-20 14:25:16 +00:00
|
|
|
self.death.setPlace(self.get_place(self.dplace,1))
|
|
|
|
|
|
|
|
if not self.person.getDeath().are_equal(self.death):
|
|
|
|
self.person.setDeath(self.death)
|
2003-04-20 03:52:54 +00:00
|
|
|
Utils.modified()
|
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()
|
|
|
|
error = 0
|
2003-01-10 05:21:32 +00:00
|
|
|
if male and self.person.getGender() != RelLib.Person.male:
|
|
|
|
self.person.setGender(RelLib.Person.male)
|
2002-10-20 14:25:16 +00:00
|
|
|
for temp_family in self.person.getFamilyList():
|
|
|
|
if self.person == temp_family.getMother():
|
|
|
|
if temp_family.getFather() != None:
|
|
|
|
error = 1
|
|
|
|
else:
|
|
|
|
temp_family.setMother(None)
|
|
|
|
temp_family.setFather(self.person)
|
|
|
|
Utils.modified()
|
2003-01-10 05:21:32 +00:00
|
|
|
elif female and self.person.getGender() != RelLib.Person.female:
|
|
|
|
self.person.setGender(RelLib.Person.female)
|
2002-10-20 14:25:16 +00:00
|
|
|
for temp_family in self.person.getFamilyList():
|
|
|
|
if self.person == temp_family.getFather():
|
|
|
|
if temp_family.getMother() != None:
|
|
|
|
error = 1
|
|
|
|
else:
|
|
|
|
temp_family.setFather(None)
|
|
|
|
temp_family.setMother(self.person)
|
|
|
|
Utils.modified()
|
2003-01-10 05:21:32 +00:00
|
|
|
elif unknown and self.person.getGender() != RelLib.Person.unknown:
|
|
|
|
self.person.setGender(RelLib.Person.unknown)
|
2002-10-20 14:25:16 +00:00
|
|
|
for temp_family in self.person.getFamilyList():
|
|
|
|
if self.person == temp_family.getFather():
|
|
|
|
if temp_family.getMother() != None:
|
|
|
|
error = 1
|
|
|
|
else:
|
|
|
|
temp_family.setFather(None)
|
|
|
|
temp_family.setMother(self.person)
|
|
|
|
if self.person == temp_family.getMother():
|
|
|
|
if temp_family.getFather() != None:
|
|
|
|
error = 1
|
|
|
|
else:
|
|
|
|
temp_family.setMother(None)
|
|
|
|
temp_family.setFather(self.person)
|
|
|
|
Utils.modified()
|
|
|
|
|
|
|
|
if error == 1:
|
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
|
|
|
|
|
|
|
if text != self.person.getNote():
|
|
|
|
self.person.setNote(text)
|
|
|
|
Utils.modified()
|
|
|
|
|
2003-12-16 00:37:47 +00:00
|
|
|
format = self.preform.get_active()
|
|
|
|
if format != self.person.getNoteFormat():
|
|
|
|
self.person.setNoteFormat(format)
|
|
|
|
Utils.modified()
|
2003-12-10 14:21:48 +00:00
|
|
|
|
2003-12-03 03:49:39 +00:00
|
|
|
if self.complete.get_active() != self.person.getComplete():
|
|
|
|
self.person.setComplete(self.complete.get_active())
|
|
|
|
Utils.modified()
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
if self.lds_not_loaded == 0:
|
|
|
|
self.check_lds()
|
2003-01-10 05:21:32 +00:00
|
|
|
ord = RelLib.LdsOrd(self.person.getLdsBaptism())
|
2002-10-20 14:25:16 +00:00
|
|
|
if not self.lds_baptism.are_equal(ord):
|
|
|
|
self.person.setLdsBaptism(self.lds_baptism)
|
|
|
|
Utils.modified()
|
|
|
|
|
2003-01-10 05:21:32 +00:00
|
|
|
ord = RelLib.LdsOrd(self.person.getLdsEndowment())
|
2002-10-20 14:25:16 +00:00
|
|
|
if not self.lds_endowment.are_equal(ord):
|
|
|
|
self.person.setLdsEndowment(self.lds_endowment)
|
|
|
|
Utils.modified()
|
|
|
|
|
2003-01-10 05:21:32 +00:00
|
|
|
ord = RelLib.LdsOrd(self.person.getLdsSeal())
|
2002-10-20 14:25:16 +00:00
|
|
|
if not self.lds_sealing.are_equal(ord):
|
|
|
|
self.person.setLdsSeal(self.lds_sealing)
|
|
|
|
Utils.modified()
|
|
|
|
|
2003-10-29 05:04:43 +00:00
|
|
|
if self.lists_changed:
|
|
|
|
self.person.setSourceRefList(self.srcreflist)
|
|
|
|
Utils.modified()
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
self.update_lists()
|
|
|
|
if self.callback:
|
2003-12-17 18:38:02 +00:00
|
|
|
self.callback(self)
|
2003-04-20 03:52:54 +00:00
|
|
|
|
2002-11-28 05:52:02 +00:00
|
|
|
self.gallery.close()
|
|
|
|
self.window.destroy()
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def get_place(self,field,makenew=0):
|
2003-12-17 05:23:16 +00:00
|
|
|
text = unicode(string.strip(field.get_text()))
|
2002-10-20 14:25:16 +00:00
|
|
|
if text:
|
2003-06-13 15:08:07 +00:00
|
|
|
if self.pdmap.has_key(text):
|
|
|
|
return self.db.getPlaceMap()[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)
|
|
|
|
self.db.addPlace(place)
|
2003-06-13 15:08:07 +00:00
|
|
|
self.pdmap[text] = place.getId()
|
2002-10-20 14:25:16 +00:00
|
|
|
self.add_places.append(place)
|
|
|
|
Utils.modified()
|
|
|
|
return place
|
|
|
|
else:
|
|
|
|
return None
|
|
|
|
else:
|
|
|
|
return None
|
|
|
|
|
|
|
|
def on_primary_name_source_clicked(self,obj):
|
2003-10-30 04:17:05 +00:00
|
|
|
Sources.SourceSelector(self.pname.getSourceRefList(),self,
|
|
|
|
self.update_primary_name)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def update_primary_name(self,list):
|
|
|
|
self.pname.setSourceRefList(list)
|
|
|
|
self.lists_changed = 1
|
|
|
|
|
|
|
|
def on_name_note_clicked(self,obj):
|
|
|
|
import NoteEdit
|
* 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
|
|
|
NoteEdit.NoteEditor(self.pname,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_ldsbap_source_clicked(self,obj):
|
2003-10-30 04:17:05 +00:00
|
|
|
Sources.SourceSelector(self.lds_baptism.getSourceRefList(),
|
|
|
|
self,self.update_ldsbap_list)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def update_ldsbap_list(self,list):
|
|
|
|
self.lds_baptism.setSourceRefList(list)
|
|
|
|
self.lists_changed = 1
|
|
|
|
|
|
|
|
def on_ldsbap_note_clicked(self,obj):
|
|
|
|
import NoteEdit
|
* 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
|
|
|
NoteEdit.NoteEditor(self.lds_baptism,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_ldsendow_source_clicked(self,obj):
|
2003-10-30 04:17:05 +00:00
|
|
|
Sources.SourceSelector(self.lds_endowment.getSourceRefList(),
|
|
|
|
self,self.set_ldsendow_list)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def set_ldsendow_list(self,list):
|
|
|
|
self.lds_endowment.setSourceRefList(list)
|
|
|
|
self.lists_changed = 1
|
|
|
|
|
|
|
|
def on_ldsendow_note_clicked(self,obj):
|
|
|
|
import NoteEdit
|
* 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
|
|
|
NoteEdit.NoteEditor(self.lds_endowment,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def on_ldsseal_source_clicked(self,obj):
|
2003-10-30 04:17:05 +00:00
|
|
|
Sources.SourceSelector(self.lds_sealing.getSourceRefList(),
|
|
|
|
self,self.lds_seal_list)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def lds_seal_list(self,list):
|
|
|
|
self.lds_sealing.setSourceRefList(list)
|
|
|
|
self.lists_changed = 1
|
|
|
|
|
|
|
|
def on_ldsseal_note_clicked(self,obj):
|
|
|
|
import NoteEdit
|
* 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
|
|
|
NoteEdit.NoteEditor(self.lds_sealing,self.window)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
def load_person_image(self):
|
|
|
|
photo_list = self.person.getPhotoList()
|
|
|
|
if photo_list:
|
|
|
|
ph = photo_list[0]
|
|
|
|
object = ph.getReference()
|
|
|
|
if self.load_obj != object.getPath():
|
|
|
|
if object.getMimeType()[0:5] == "image":
|
|
|
|
self.load_photo(object.getPath())
|
|
|
|
else:
|
|
|
|
self.load_photo(None)
|
|
|
|
else:
|
|
|
|
self.load_photo(None)
|
|
|
|
|
|
|
|
def update_birth_info(self):
|
|
|
|
self.bdate.set_text(self.birth.getDate())
|
|
|
|
self.bplace.set_text(self.birth.getPlaceName())
|
|
|
|
|
|
|
|
def update_death_info(self):
|
|
|
|
self.ddate.set_text(self.death.getDate())
|
|
|
|
self.dplace.set_text(self.death.getPlaceName())
|
|
|
|
|
|
|
|
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:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.not_loaded = 0
|
2003-11-13 21:44:09 +00:00
|
|
|
elif page == 9 and self.lds_not_loaded:
|
2002-10-20 14:25:16 +00:00
|
|
|
self.lds_not_loaded = 0
|
|
|
|
self.draw_lds()
|
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-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
|
|
|
|
2003-11-13 21:44:09 +00:00
|
|
|
if self.lds_not_loaded == 0:
|
|
|
|
self.check_lds()
|
|
|
|
if self.lds_baptism.isEmpty() \
|
|
|
|
and self.lds_endowment.isEmpty() \
|
|
|
|
and self.lds_sealing.isEmpty():
|
|
|
|
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)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.lists_changed = 1
|
|
|
|
self.write_primary_name()
|
|
|
|
|
|
|
|
def write_primary_name(self):
|
|
|
|
# initial values
|
2003-02-28 04:49:18 +00:00
|
|
|
name = '<span size="larger" weight="bold">%s</span>' % GrampsCfg.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)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.suffix.set_text(self.pname.getSuffix())
|
2002-12-04 04:58:07 +00:00
|
|
|
self.prefix.set_text(self.pname.getSurnamePrefix())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
self.surname_field.set_text(self.pname.getSurname())
|
|
|
|
self.given.set_text(self.pname.getFirstName())
|
|
|
|
|
|
|
|
self.ntype_field.entry.set_text(_(self.pname.getType()))
|
|
|
|
self.title.set_text(self.pname.getTitle())
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# birth_dates_in_order
|
|
|
|
#
|
|
|
|
# Check any *valid* birthdates in the list to insure that they are in
|
|
|
|
# numerically increasing order.
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
def birth_dates_in_order(list):
|
|
|
|
inorder = 1
|
|
|
|
prev_date = "00000000"
|
|
|
|
for i in range(len(list)):
|
|
|
|
child = list[i]
|
|
|
|
bday = child.getBirth().getDateObj()
|
|
|
|
child_date = sort.build_sort_date(bday)
|
|
|
|
if (child_date == "99999999"):
|
|
|
|
continue
|
|
|
|
if (prev_date <= child_date): # <= allows for twins
|
|
|
|
prev_date = child_date
|
|
|
|
else:
|
|
|
|
inorder = 0
|
|
|
|
return inorder
|
|
|
|
|
|
|
|
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# reorder_child_list
|
|
|
|
#
|
|
|
|
# Reorder the child list to put the specified person in his/her
|
|
|
|
# correct birth order. Only check *valid* birthdates. Move the person
|
|
|
|
# as short a distance as possible.
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
def reorder_child_list(person, list):
|
|
|
|
if (birth_dates_in_order(list)):
|
|
|
|
return(list)
|
|
|
|
|
|
|
|
# Build the person's date string once
|
|
|
|
person_bday = sort.build_sort_date(person.getBirth().getDateObj())
|
|
|
|
|
|
|
|
# First, see if the person needs to be moved forward in the list
|
|
|
|
index = list.index(person)
|
|
|
|
target = index
|
|
|
|
for i in range(index-1, -1, -1):
|
|
|
|
other_bday = sort.build_sort_date(list[i].getBirth().getDateObj())
|
|
|
|
if (other_bday == "99999999"):
|
|
|
|
continue;
|
|
|
|
if (person_bday < other_bday):
|
|
|
|
target = i
|
|
|
|
|
|
|
|
# Now try moving to a later position in the list
|
|
|
|
if (target == index):
|
|
|
|
for i in range(index, len(list)):
|
|
|
|
other_bday = sort.build_sort_date(list[i].getBirth().getDateObj())
|
|
|
|
if (other_bday == "99999999"):
|
|
|
|
continue;
|
|
|
|
if (person_bday > other_bday):
|
|
|
|
target = i
|
|
|
|
|
|
|
|
# Actually need to move? Do it now.
|
|
|
|
if (target != index):
|
|
|
|
list.remove(person)
|
|
|
|
list.insert(target,person)
|
|
|
|
return list
|
|
|
|
|
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
|