2002-10-20 14:25:16 +00:00
|
|
|
#
|
|
|
|
# Gramps - a GTK+/GNOME based genealogy program
|
|
|
|
#
|
2005-02-25 17:06:04 +00:00
|
|
|
# Copyright (C) 2000-2005 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-11-12 18:45:07 +00:00
|
|
|
# $Id$
|
|
|
|
|
2005-02-25 17:06:04 +00:00
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Standard python modules
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
from gettext import gettext as _
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# GTK/Gnome modules
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
import gtk.glade
|
2003-11-19 02:29:41 +00:00
|
|
|
import gnome
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# gramps modules
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
import const
|
|
|
|
import Utils
|
|
|
|
import AutoComp
|
|
|
|
import Sources
|
2003-01-10 05:21:32 +00:00
|
|
|
import RelLib
|
2005-01-01 04:27:15 +00:00
|
|
|
import NameDisplay
|
2005-03-09 16:06:22 +00:00
|
|
|
import Date
|
2005-03-06 23:47:26 +00:00
|
|
|
import DateEdit
|
|
|
|
import DateHandler
|
2005-08-05 03:41:23 +00:00
|
|
|
import Spell
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# NameEditor class
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
class NameEditor:
|
|
|
|
|
2005-04-01 05:33:22 +00:00
|
|
|
def __init__(self,parent,name,callback,parent_window=None):
|
2005-02-27 05:51:59 +00:00
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
self.parent = parent
|
2003-11-12 18:45:07 +00:00
|
|
|
self.db = self.parent.db
|
* src/AddrEdit.py, src/AttrEdit.py, src/EditPerson.py,
src/EditSource.py, src/EventEdit.py, src/ImageSelect.py,
src/Marriage.py, src/NameEdit.py, src/NoteEdit.py,
src/Sources.py, src/UrlEdit.py, src/Witness.py:
Register windows opened for existing objects. Prevent editing
same object twice.
svn: r2905
2004-02-24 05:37:06 +00:00
|
|
|
if name:
|
|
|
|
if self.parent.child_windows.has_key(name):
|
|
|
|
self.parent.child_windows[name].present(None)
|
|
|
|
return
|
|
|
|
else:
|
|
|
|
self.win_key = name
|
|
|
|
else:
|
|
|
|
self.win_key = self
|
2002-10-20 14:25:16 +00:00
|
|
|
self.name = name
|
2003-06-11 03:26:02 +00:00
|
|
|
self.callback = callback
|
* src/AddrEdit.py, src/AttrEdit.py, src/EditPerson.py,
src/EditSource.py, src/EventEdit.py, src/ImageSelect.py,
src/Marriage.py, src/NameEdit.py, src/NoteEdit.py,
src/Sources.py, src/UrlEdit.py, src/Witness.py:
Register windows opened for existing objects. Prevent editing
same object twice.
svn: r2905
2004-02-24 05:37:06 +00:00
|
|
|
self.child_windows = {}
|
2003-08-17 02:14:33 +00:00
|
|
|
self.top = gtk.glade.XML(const.dialogFile, "name_edit","gramps")
|
2002-10-20 14:25:16 +00:00
|
|
|
self.window = self.top.get_widget("name_edit")
|
|
|
|
self.given_field = self.top.get_widget("alt_given")
|
2004-09-29 02:06:46 +00:00
|
|
|
self.sort_as = self.top.get_widget("sort_as")
|
|
|
|
self.display_as = self.top.get_widget("display_as")
|
|
|
|
self.group_as = self.top.get_widget("group_as")
|
2002-10-20 14:25:16 +00:00
|
|
|
self.title_field = self.top.get_widget("alt_title")
|
|
|
|
self.suffix_field = self.top.get_widget("alt_suffix")
|
2005-01-19 00:36:06 +00:00
|
|
|
self.patronymic_field = self.top.get_widget("patronymic")
|
2004-08-05 04:14:21 +00:00
|
|
|
self.combo = self.top.get_widget("alt_surname_list")
|
2005-03-06 23:47:26 +00:00
|
|
|
self.date = self.top.get_widget('date')
|
2005-03-09 16:06:22 +00:00
|
|
|
|
|
|
|
if self.name:
|
|
|
|
self.srcreflist = self.name.get_source_references()
|
|
|
|
self.date_obj = self.name.get_date_object()
|
|
|
|
else:
|
|
|
|
self.srcreflist = []
|
|
|
|
self.date_obj = Date.Date()
|
|
|
|
|
2005-03-06 23:47:26 +00:00
|
|
|
self.date.set_text(DateHandler.displayer.display(self.date_obj))
|
|
|
|
|
|
|
|
self.date_check = DateEdit.DateEdit(
|
|
|
|
self.date_obj, self.date,
|
|
|
|
self.top.get_widget("date_stat"), self.window)
|
2004-08-05 04:14:21 +00:00
|
|
|
|
2004-08-13 04:34:07 +00:00
|
|
|
AutoComp.fill_combo(self.combo,self.parent.db.get_surname_list())
|
2004-08-23 16:22:38 +00:00
|
|
|
self.surname_field = self.combo.get_child()
|
2004-10-07 17:48:29 +00:00
|
|
|
self.prefix_field = self.top.get_widget("alt_prefix")
|
2004-08-05 04:14:21 +00:00
|
|
|
|
2004-08-23 16:22:38 +00:00
|
|
|
self.type_combo = self.top.get_widget("name_type")
|
2002-10-20 14:25:16 +00:00
|
|
|
self.note_field = self.top.get_widget("alt_note")
|
2005-08-05 03:41:23 +00:00
|
|
|
self.spell = Spell.Spell(self.note_field)
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
self.slist = self.top.get_widget('slist')
|
|
|
|
self.priv = self.top.get_widget("priv")
|
2003-11-12 18:45:07 +00:00
|
|
|
self.sources_label = self.top.get_widget("sourcesName")
|
|
|
|
self.notes_label = self.top.get_widget("noteName")
|
2003-12-15 20:00:47 +00:00
|
|
|
self.flowed = self.top.get_widget("alt_flowed")
|
|
|
|
self.preform = self.top.get_widget("alt_preform")
|
2004-09-29 02:06:46 +00:00
|
|
|
self.group_over = self.top.get_widget('group_over')
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-01-20 23:30:15 +00:00
|
|
|
types = const.NameTypesMap.get_values()
|
2002-10-20 14:25:16 +00:00
|
|
|
types.sort()
|
2004-08-23 16:22:38 +00:00
|
|
|
AutoComp.fill_combo(self.type_combo,types)
|
2005-01-08 00:20:42 +00:00
|
|
|
self.type_field = self.type_combo.get_child()
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2005-01-08 00:20:42 +00:00
|
|
|
full_name = NameDisplay.displayer.display_name(name)
|
2003-03-03 04:32:53 +00:00
|
|
|
|
2003-03-05 06:01:31 +00:00
|
|
|
alt_title = self.top.get_widget("title")
|
2003-03-03 04:32:53 +00:00
|
|
|
|
2005-02-25 17:06:04 +00:00
|
|
|
if full_name == "":
|
2004-09-29 02:06:46 +00:00
|
|
|
tmsg = _("Name Editor")
|
2003-06-03 02:54:56 +00:00
|
|
|
else:
|
2004-09-29 02:06:46 +00:00
|
|
|
tmsg = _("Name Editor for %s") % full_name
|
2003-03-06 06:12:51 +00:00
|
|
|
|
2004-09-29 02:06:46 +00:00
|
|
|
Utils.set_titles(self.window, alt_title, tmsg, _('Name Editor'))
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2005-02-27 05:51:59 +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'),
|
2005-04-01 05:33:22 +00:00
|
|
|
self.top.get_widget('del_src'), self.db.readonly)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
self.note_buffer = self.note_field.get_buffer()
|
|
|
|
|
2003-11-12 18:45:07 +00:00
|
|
|
self.top.signal_autoconnect({
|
2004-09-29 02:06:46 +00:00
|
|
|
"on_help_name_clicked" : self.on_help_clicked,
|
|
|
|
"on_name_edit_ok_clicked" : self.on_name_edit_ok_clicked,
|
2004-02-19 19:15:27 +00:00
|
|
|
"on_name_edit_cancel_clicked" : self.close,
|
2004-09-29 02:06:46 +00:00
|
|
|
"on_name_edit_delete_event" : self.on_delete_event,
|
|
|
|
"on_group_over_toggled" : self.on_group_over_toggled,
|
|
|
|
"on_switch_page" : self.on_switch_page
|
2003-11-12 18:45:07 +00:00
|
|
|
})
|
|
|
|
|
2002-10-20 14:25:16 +00:00
|
|
|
if name != None:
|
2004-02-14 05:40:30 +00:00
|
|
|
self.given_field.set_text(name.get_first_name())
|
|
|
|
self.surname_field.set_text(name.get_surname())
|
|
|
|
self.title_field.set_text(name.get_title())
|
|
|
|
self.suffix_field.set_text(name.get_suffix())
|
2004-10-07 17:48:29 +00:00
|
|
|
self.prefix_field.set_text(name.get_surname_prefix())
|
2004-08-23 16:22:38 +00:00
|
|
|
self.type_field.set_text(_(name.get_type()))
|
2005-01-19 00:36:06 +00:00
|
|
|
self.patronymic_field.set_text(name.get_patronymic())
|
2004-02-14 05:40:30 +00:00
|
|
|
self.priv.set_active(name.get_privacy())
|
|
|
|
if name.get_note():
|
2004-02-20 00:52:24 +00:00
|
|
|
self.note_buffer.set_text(name.get_note())
|
2003-11-12 18:45:07 +00:00
|
|
|
Utils.bold_label(self.notes_label)
|
2004-02-20 00:52:24 +00:00
|
|
|
if name.get_note_format() == 1:
|
2003-12-15 20:00:47 +00:00
|
|
|
self.preform.set_active(1)
|
2004-02-20 00:52:24 +00:00
|
|
|
else:
|
2003-12-15 20:00:47 +00:00
|
|
|
self.flowed.set_active(1)
|
2004-09-29 02:06:46 +00:00
|
|
|
self.display_as.set_active(name.get_display_as())
|
|
|
|
self.sort_as.set_active(name.get_display_as())
|
2004-09-30 18:32:56 +00:00
|
|
|
grp_as = name.get_group_as()
|
|
|
|
if grp_as:
|
|
|
|
self.group_as.set_text(name.get_group_as())
|
|
|
|
else:
|
|
|
|
self.group_as.set_text(name.get_surname())
|
2004-09-29 02:06:46 +00:00
|
|
|
else:
|
|
|
|
self.display_as.set_active(0)
|
|
|
|
self.sort_as.set_active(0)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
* 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
|
|
|
if parent_window:
|
|
|
|
self.window.set_transient_for(parent_window)
|
2004-09-30 18:32:56 +00:00
|
|
|
self.surname_field.connect('changed',self.update_group_as)
|
2004-02-20 00:52:24 +00:00
|
|
|
self.add_itself_to_menu()
|
|
|
|
self.window.show()
|
2004-02-19 19:15:27 +00:00
|
|
|
|
2004-09-30 18:32:56 +00:00
|
|
|
def update_group_as(self,obj):
|
|
|
|
if not self.group_over.get_active():
|
2005-02-25 17:06:04 +00:00
|
|
|
if self.name and self.name.get_group_as() != self.name.get_surname():
|
2004-09-30 18:32:56 +00:00
|
|
|
val = self.name.get_group_as()
|
|
|
|
else:
|
2005-08-03 02:31:18 +00:00
|
|
|
name = unicode(self.surname_field.get_text())
|
|
|
|
val = self.db.get_name_group_mapping(name)
|
2004-09-30 18:32:56 +00:00
|
|
|
self.group_as.set_text(val)
|
|
|
|
|
2004-09-29 02:06:46 +00:00
|
|
|
def on_group_over_toggled(self,obj):
|
|
|
|
if obj.get_active():
|
2005-02-24 00:25:34 +00:00
|
|
|
self.group_as.set_sensitive(True)
|
|
|
|
self.group_as.set_editable(True)
|
2004-09-29 02:06:46 +00:00
|
|
|
else:
|
2005-08-03 02:31:18 +00:00
|
|
|
field_value = unicode(self.surname_field.get_text())
|
2005-07-26 23:02:53 +00:00
|
|
|
mapping = self.db.get_name_group_mapping(field_value)
|
|
|
|
self.group_as.set_text(mapping)
|
2005-02-24 00:25:34 +00:00
|
|
|
self.group_as.set_sensitive(False)
|
|
|
|
self.group_as.set_editable(False)
|
2004-09-29 02:06:46 +00:00
|
|
|
|
2004-05-13 22:45:51 +00:00
|
|
|
def on_delete_event(self,*obj):
|
2004-02-20 00:52:24 +00:00
|
|
|
self.close_child_windows()
|
|
|
|
self.remove_itself_from_menu()
|
2004-02-19 19:15:27 +00:00
|
|
|
|
2004-05-13 22:45:51 +00:00
|
|
|
def close(self,*obj):
|
2004-02-20 00:52:24 +00:00
|
|
|
self.close_child_windows()
|
|
|
|
self.remove_itself_from_menu()
|
|
|
|
self.window.destroy()
|
2004-02-19 19:15:27 +00:00
|
|
|
|
|
|
|
def close_child_windows(self):
|
* src/AddrEdit.py, src/AttrEdit.py, src/EditPerson.py,
src/EditSource.py, src/EventEdit.py, src/ImageSelect.py,
src/Marriage.py, src/NameEdit.py, src/NoteEdit.py,
src/Sources.py, src/UrlEdit.py, src/Witness.py:
Register windows opened for existing objects. Prevent editing
same object twice.
svn: r2905
2004-02-24 05:37:06 +00:00
|
|
|
for child_window in self.child_windows.values():
|
2004-02-20 00:52:24 +00:00
|
|
|
child_window.close(None)
|
* src/AddrEdit.py, src/AttrEdit.py, src/EditPerson.py,
src/EditSource.py, src/EventEdit.py, src/ImageSelect.py,
src/Marriage.py, src/NameEdit.py, src/NoteEdit.py,
src/Sources.py, src/UrlEdit.py, src/Witness.py:
Register windows opened for existing objects. Prevent editing
same object twice.
svn: r2905
2004-02-24 05:37:06 +00:00
|
|
|
self.child_windows = {}
|
2004-02-19 19:15:27 +00:00
|
|
|
|
|
|
|
def add_itself_to_menu(self):
|
* src/AddrEdit.py, src/AttrEdit.py, src/EditPerson.py,
src/EditSource.py, src/EventEdit.py, src/ImageSelect.py,
src/Marriage.py, src/NameEdit.py, src/NoteEdit.py,
src/Sources.py, src/UrlEdit.py, src/Witness.py:
Register windows opened for existing objects. Prevent editing
same object twice.
svn: r2905
2004-02-24 05:37:06 +00:00
|
|
|
self.parent.child_windows[self.win_key] = self
|
2004-02-20 00:52:24 +00:00
|
|
|
if not self.name:
|
|
|
|
label = _("New Name")
|
|
|
|
else:
|
|
|
|
label = self.name.get_name()
|
|
|
|
if not label.strip():
|
|
|
|
label = _("New Name")
|
|
|
|
label = "%s: %s" % (_('Alternate Name'),label)
|
|
|
|
self.parent_menu_item = gtk.MenuItem(label)
|
|
|
|
self.parent_menu_item.set_submenu(gtk.Menu())
|
|
|
|
self.parent_menu_item.show()
|
2004-02-25 03:20:53 +00:00
|
|
|
self.parent.winsmenu.append(self.parent_menu_item)
|
|
|
|
self.winsmenu = self.parent_menu_item.get_submenu()
|
2004-02-20 00:52:24 +00:00
|
|
|
self.menu_item = gtk.MenuItem(_('Name Editor'))
|
2004-02-19 19:15:27 +00:00
|
|
|
self.menu_item.connect("activate",self.present)
|
|
|
|
self.menu_item.show()
|
2004-02-25 03:20:53 +00:00
|
|
|
self.winsmenu.append(self.menu_item)
|
2004-02-19 19:15:27 +00:00
|
|
|
|
|
|
|
def remove_itself_from_menu(self):
|
* src/AddrEdit.py, src/AttrEdit.py, src/EditPerson.py,
src/EditSource.py, src/EventEdit.py, src/ImageSelect.py,
src/Marriage.py, src/NameEdit.py, src/NoteEdit.py,
src/Sources.py, src/UrlEdit.py, src/Witness.py:
Register windows opened for existing objects. Prevent editing
same object twice.
svn: r2905
2004-02-24 05:37:06 +00:00
|
|
|
del self.parent.child_windows[self.win_key]
|
2004-02-19 19:15:27 +00:00
|
|
|
self.menu_item.destroy()
|
2004-02-25 03:20:53 +00:00
|
|
|
self.winsmenu.destroy()
|
2004-02-20 00:52:24 +00:00
|
|
|
self.parent_menu_item.destroy()
|
2004-02-19 19:15:27 +00:00
|
|
|
|
2004-05-13 22:45:51 +00:00
|
|
|
def present(self,*obj):
|
2004-02-19 19:15:27 +00:00
|
|
|
self.window.present()
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-05-13 22:45:51 +00:00
|
|
|
def on_help_clicked(self,*obj):
|
2003-11-19 02:29:41 +00:00
|
|
|
"""Display the relevant portion of GRAMPS manual"""
|
2005-05-03 02:13:44 +00:00
|
|
|
gnome.help_display('gramps-manual','adv-an')
|
2003-11-19 02:29:41 +00:00
|
|
|
|
2004-02-19 13:40:09 +00:00
|
|
|
def on_name_edit_ok_clicked(self,obj):
|
2003-12-17 05:23:16 +00:00
|
|
|
first = unicode(self.given_field.get_text())
|
|
|
|
last = unicode(self.surname_field.get_text())
|
|
|
|
title = unicode(self.title_field.get_text())
|
2004-10-07 17:48:29 +00:00
|
|
|
prefix = unicode(self.prefix_field.get_text())
|
2003-12-17 05:23:16 +00:00
|
|
|
suffix = unicode(self.suffix_field.get_text())
|
2005-01-19 00:36:06 +00:00
|
|
|
patronymic = unicode(self.patronymic_field.get_text())
|
2003-12-17 16:06:36 +00:00
|
|
|
note = unicode(self.note_buffer.get_text(self.note_buffer.get_start_iter(),
|
2005-02-24 00:25:34 +00:00
|
|
|
self.note_buffer.get_end_iter(),False))
|
2003-12-15 20:00:47 +00:00
|
|
|
format = self.preform.get_active()
|
2002-10-20 14:25:16 +00:00
|
|
|
priv = self.priv.get_active()
|
|
|
|
|
2004-08-23 16:22:38 +00:00
|
|
|
mtype = unicode(self.type_field.get_text())
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-05-13 22:45:51 +00:00
|
|
|
if const.NameTypesMap.has_value(mtype):
|
|
|
|
mtype = const.NameTypesMap.find_key(mtype)
|
2005-09-13 03:34:59 +00:00
|
|
|
if not mtype:
|
2004-05-13 22:45:51 +00:00
|
|
|
mtype = "Also Known As"
|
2002-10-20 14:25:16 +00:00
|
|
|
|
|
|
|
if self.name == None:
|
2003-01-10 05:21:32 +00:00
|
|
|
self.name = RelLib.Name()
|
2002-10-20 14:25:16 +00:00
|
|
|
self.parent.nlist.append(self.name)
|
2005-03-09 17:12:58 +00:00
|
|
|
|
|
|
|
self.name.set_date_object(self.date_obj)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
self.name.set_source_reference_list(self.srcreflist)
|
2004-09-29 02:06:46 +00:00
|
|
|
|
2005-08-03 02:31:18 +00:00
|
|
|
grp_as = unicode(self.group_as.get_text())
|
|
|
|
srn = unicode(self.surname_field.get_text())
|
2004-09-30 18:32:56 +00:00
|
|
|
|
2004-09-29 02:06:46 +00:00
|
|
|
if self.name.get_display_as() != self.display_as.get_active():
|
|
|
|
self.name.set_display_as(self.display_as.get_active())
|
|
|
|
self.parent.lists_changed = 1
|
2004-10-07 17:48:29 +00:00
|
|
|
|
|
|
|
prefix = unicode(self.prefix_field.get_text())
|
|
|
|
if self.name.get_surname_prefix() != prefix:
|
|
|
|
self.name.set_surname_prefix(prefix)
|
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2004-09-29 02:06:46 +00:00
|
|
|
if self.name.get_sort_as() != self.sort_as.get_active():
|
|
|
|
self.name.set_sort_as(self.sort_as.get_active())
|
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2005-04-09 03:11:03 +00:00
|
|
|
if not self.group_over.get_active():
|
2004-09-30 18:32:56 +00:00
|
|
|
self.name.set_group_as("")
|
2004-09-29 02:06:46 +00:00
|
|
|
self.parent.lists_changed = 1
|
2004-09-30 18:32:56 +00:00
|
|
|
elif self.name.get_group_as() != grp_as:
|
|
|
|
if grp_as not in self.db.get_name_group_keys():
|
|
|
|
from QuestionDialog import QuestionDialog2
|
2005-02-27 05:51:59 +00:00
|
|
|
q = QuestionDialog2(
|
|
|
|
_("Group all people with the same name?"),
|
|
|
|
_("You have the choice of grouping all people with the "
|
|
|
|
"name of %(surname)s with the name of %(group_name)s, or "
|
|
|
|
"just mapping this particular name.") % { 'surname' : srn,
|
|
|
|
'group_name':grp_as},
|
|
|
|
_("Group all"),
|
|
|
|
_("Group this name only"))
|
2004-09-30 18:32:56 +00:00
|
|
|
val = q.run()
|
|
|
|
if val:
|
|
|
|
self.name.set_group_as("")
|
|
|
|
self.db.set_name_group_mapping(srn,grp_as)
|
|
|
|
else:
|
|
|
|
self.name.set_group_as(grp_as)
|
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2005-01-19 00:36:06 +00:00
|
|
|
self.update_name(first,last,suffix,patronymic,title,mtype,note,format,priv)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2003-06-11 03:26:02 +00:00
|
|
|
self.callback(self.name)
|
2004-02-20 00:52:24 +00:00
|
|
|
self.close(obj)
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2005-01-19 00:36:06 +00:00
|
|
|
def update_name(self,first,last,suffix,patronymic,title,type,note,format,priv):
|
2002-10-20 14:25:16 +00:00
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if self.name.get_first_name() != first:
|
|
|
|
self.name.set_first_name(first)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if self.name.get_surname() != last:
|
|
|
|
self.name.set_surname(last)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if self.name.get_suffix() != suffix:
|
|
|
|
self.name.set_suffix(suffix)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2005-01-19 00:36:06 +00:00
|
|
|
if self.name.get_patronymic() != patronymic:
|
|
|
|
self.name.set_patronymic(patronymic)
|
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if self.name.get_title() != title:
|
|
|
|
self.name.set_title(title)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if self.name.get_type() != type:
|
|
|
|
self.name.set_type(type)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if self.name.get_note() != note:
|
|
|
|
self.name.set_note(note)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if self.name.get_note_format() != format:
|
|
|
|
self.name.set_note_format(format)
|
2003-12-15 20:00:47 +00:00
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2004-02-14 05:40:30 +00:00
|
|
|
if self.name.get_privacy() != priv:
|
|
|
|
self.name.set_privacy(priv)
|
2002-10-20 14:25:16 +00:00
|
|
|
self.parent.lists_changed = 1
|
|
|
|
|
2003-11-12 18:45:07 +00:00
|
|
|
def on_switch_page(self,obj,a,page):
|
2005-04-01 05:33:22 +00:00
|
|
|
start = self.note_buffer.get_start_iter()
|
|
|
|
stop = self.note_buffer.get_end_iter()
|
|
|
|
text = unicode(self.note_buffer.get_text(start, stop, False))
|
2003-11-12 18:45:07 +00:00
|
|
|
if text:
|
|
|
|
Utils.bold_label(self.notes_label)
|
|
|
|
else:
|
|
|
|
Utils.unbold_label(self.notes_label)
|