diff --git a/src/EditPerson.glade b/src/EditPerson.glade index fda61daa7..27b912358 100644 --- a/src/EditPerson.glade +++ b/src/EditPerson.glade @@ -895,7 +895,7 @@ False True False - False + True False @@ -1294,7 +1294,7 @@ GtkTable table10 - 4 + 5 3 False 0 @@ -1469,8 +1469,8 @@ 0 1 - 3 - 4 + 4 + 5 0 0 False @@ -1495,8 +1495,8 @@ 2 3 - 3 - 4 + 4 + 5 3 3 False @@ -1599,6 +1599,84 @@ 1 2 + 4 + 5 + 0 + 0 + False + False + False + False + True + False + + + + + GtkLabel + label267 + + GTK_JUSTIFY_CENTER + False + 0 + 0.5 + 0 + 3 + + 1 + 2 + 3 + 4 + 0 + 0 + False + False + False + False + True + False + + + + + GtkLabel + label268 + + GTK_JUSTIFY_CENTER + False + 1 + 0.5 + 5 + 3 + + 0 + 1 + 3 + 4 + 0 + 0 + False + False + False + False + True + False + + + + + GtkLabel + name_type + + GTK_JUSTIFY_CENTER + False + 0 + 0.5 + 0 + 0 + + 2 + 3 3 4 0 @@ -1708,8 +1786,8 @@ on_name_button_press Sun, 04 Nov 2001 15:40:59 GMT - 2 - 450,50 + 3 + 350,100,50 GTK_SELECTION_SINGLE True GTK_SHADOW_IN @@ -1718,7 +1796,20 @@ GtkLabel CList:title label57 - + + GTK_JUSTIFY_CENTER + False + 0.5 + 0.5 + 0 + 0 + + + + GtkLabel + CList:title + label57a + GTK_JUSTIFY_CENTER False 0.5 @@ -5376,7 +5467,7 @@ GtkTable table23 - 5 + 6 2 False 0 @@ -5451,8 +5542,8 @@ 1 2 - 4 - 5 + 5 + 6 3 3 False @@ -5485,8 +5576,8 @@ 0 1 - 4 - 5 + 5 + 6 0 0 False @@ -5506,8 +5597,8 @@ 1 2 - 3 - 4 + 4 + 5 0 0 False @@ -5670,6 +5761,70 @@ False + + + GtkLabel + label266 + + GTK_JUSTIFY_CENTER + False + 1 + 0.5 + 5 + 8 + + 0 + 1 + 3 + 4 + 0 + 0 + False + False + False + False + True + False + + + + + GtkCombo + name_type + True + False + False + True + False + Married Name +Also Known As + + + 1 + 2 + 3 + 4 + 3 + 3 + True + False + False + False + True + False + + + + GtkEntry + GtkCombo:entry + combo-entry2 + True + True + True + 0 + Married Name + + diff --git a/src/EditPerson.py b/src/EditPerson.py index d0f9e83d7..68569ac0e 100644 --- a/src/EditPerson.py +++ b/src/EditPerson.py @@ -174,6 +174,7 @@ class EditPerson: self.alt_given_field = self.get_widget("alt_given") self.alt_last_field = self.get_widget("alt_last") self.alt_suffix_field = self.get_widget("alt_suffix") + self.name_type_field = self.get_widget("name_type") self.surname_field = self.get_widget("surname") self.suffix = self.get_widget("suffix") self.given = self.get_widget("givenName") @@ -227,7 +228,7 @@ class EditPerson: self.gid.set_text(person.getId()) self.gid.set_editable(GrampsCfg.id_edit) self.event_list.set_column_visibility(3,GrampsCfg.show_detail) - self.name_list.set_column_visibility(1,GrampsCfg.show_detail) + self.name_list.set_column_visibility(2,GrampsCfg.show_detail) self.attr_list.set_column_visibility(2,GrampsCfg.show_detail) self.addr_list.set_column_visibility(2,GrampsCfg.show_detail) @@ -972,6 +973,7 @@ class EditPerson: self.alt_given_field.set_text(name.getFirstName()) self.alt_last_field.set_text(name.getSurname()) self.alt_suffix_field.set_text(name.getSuffix()) + self.name_type_field.set_text(name.getType()) self.name_details_field.set_text(Utils.get_detail_text(name)) def on_web_list_select_row(self,obj,row,b,c): @@ -1350,7 +1352,7 @@ def update_ord(func,ord,date,temple,stat,place): # #------------------------------------------------------------------------- def disp_name(name): - return [name.getName(),Utils.get_detail_flags(name)] + return [name.getName(),name.getType(),Utils.get_detail_flags(name)] #------------------------------------------------------------------------- # diff --git a/src/GrampsParser.py b/src/GrampsParser.py index d7097a2a1..de54476bd 100644 --- a/src/GrampsParser.py +++ b/src/GrampsParser.py @@ -192,20 +192,20 @@ class GrampsParser: self.event = Event() self.event_type = u2l(attrs["type"]) if attrs.has_key("conf"): - self.conf = int(attrs["conf"]) + self.event.conf = int(attrs["conf"]) else: - self.conf = 2 + self.event.conf = 2 if attrs.has_key("priv"): self.event.private = int(attrs["priv"]) def start_attribute(self,attrs): self.attribute = Attribute() if attrs.has_key("conf"): - self.conf = int(attrs["conf"]) + self.attribute.conf = int(attrs["conf"]) else: - self.conf = 2 + self.attribute.conf = 2 if attrs.has_key("priv"): - self.attribute.privacy = int(attrs["priv"]) + self.attribute.private = int(attrs["priv"]) if attrs.has_key('type'): self.attribute.setType(u2l(attrs["type"])) if attrs.has_key('value'): @@ -225,9 +225,9 @@ class GrampsParser: self.address = Address() self.person.addAddress(self.address) if attrs.has_key("conf"): - self.conf = int(attrs["conf"]) + self.address.conf = int(attrs["conf"]) else: - self.conf = 2 + self.address.conf = 2 if attrs.has_key("priv"): self.address.private = int(attrs["priv"]) @@ -311,10 +311,12 @@ class GrampsParser: def start_name(self,attrs): self.name = Name() + if attrs.has_key("type"): + self.name.setType(u2l(attrs["type"])) if attrs.has_key("conf"): - self.conf = int(attrs["conf"]) + self.name.conf = int(attrs["conf"]) else: - self.conf = 2 + self.name.conf = 2 if attrs.has_key("priv"): self.name.private = int(attrs["priv"]) @@ -722,6 +724,8 @@ class GrampsParser: def stop_aka(self,tag): self.person.addAlternateName(self.name) + if self.name.getType() == "": + self.name.setType("Also Known As") self.name = None func_map = { diff --git a/src/NameEdit.py b/src/NameEdit.py index a24e2988f..8993b903d 100644 --- a/src/NameEdit.py +++ b/src/NameEdit.py @@ -32,6 +32,7 @@ import libglade #------------------------------------------------------------------------- import const import Utils +import AutoComp from RelLib import * from intl import gettext @@ -52,8 +53,10 @@ class NameEditor: self.given_field = self.top.get_widget("alt_given") self.surname_field = self.top.get_widget("alt_last") self.suffix_field = self.top.get_widget("alt_suffix") + self.type_field = self.top.get_widget("name_type") self.note_field = self.top.get_widget("alt_note") - Utils.attach_surnames(self.top.get_widget("alt_surname_list")) + slist = self.top.get_widget("alt_surname_list") + self.combo = AutoComp.AutoCombo(slist,const.surnames) self.priv = self.top.get_widget("priv") if self.name: @@ -70,11 +73,13 @@ class NameEditor: self.window.editable_enters(self.given_field) self.window.editable_enters(self.surname_field) self.window.editable_enters(self.suffix_field) + self.window.editable_enters(self.type_field.entry) if name != None: self.given_field.set_text(name.getFirstName()) self.surname_field.set_text(name.getSurname()) self.suffix_field.set_text(name.getSuffix()) + self.type_field.entry.set_text(_(name.getType())) self.priv.set_active(name.getPrivacy()) self.note_field.set_point(0) self.note_field.insert_defaults(name.getNote()) @@ -97,19 +102,25 @@ class NameEditor: suffix = self.suffix_field.get_text() note = self.note_field.get_chars(0,-1) priv = self.priv.get_active() + + type = self.type_field.entry.get_text() + if const.NameTypesMap.has_key(type): + type = const.NameTypesMap[type] + else: + type = "Also Known As" if self.name == None: self.name = Name() self.name.setSourceRefList(self.srcreflist) self.parent.nlist.append(self.name) - self.update_name(first,last,suffix,note,priv) + self.update_name(first,last,suffix,type,note,priv) self.parent.lists_changed = 1 self.parent.redraw_name_list() Utils.destroy_passed_object(obj) - def update_name(self,first,last,suffix,note,priv): + def update_name(self,first,last,suffix,type,note,priv): if self.name.getFirstName() != first: self.name.setFirstName(first) @@ -126,6 +137,10 @@ class NameEditor: self.name.setSuffix(suffix) self.parent.lists_changed = 1 + if self.name.getType() != type: + self.name.setType(type) + self.parent.lists_changed = 1 + if self.name.getNote() != note: self.name.setNote(note) self.parent.lists_changed = 1 diff --git a/src/RelLib.py b/src/RelLib.py index 2304432f0..e18bab2c1 100644 --- a/src/RelLib.py +++ b/src/RelLib.py @@ -729,11 +729,21 @@ class Name(DataObj): self.Surname = source.Surname self.Suffix = source.Suffix self.Title = source.Title + self.type = source.type else: self.FirstName = "" self.Surname = "" self.Suffix = "" self.Title = "" + self.type = "" + + def setType(self,type): + """sets the type of the Name instance""" + self.type = type + + def getType(self): + """returns the type of the Name instance""" + return self.type def setFirstName(self,name): """sets the given name for the Name instance""" diff --git a/src/WriteXML.py b/src/WriteXML.py index 9c2d53761..a96d7c5ea 100644 --- a/src/WriteXML.py +++ b/src/WriteXML.py @@ -169,14 +169,14 @@ class XmlWriter: total = len(personList) + len(familyList) + len(placeList) + len(sourceList) self.g.write('\n') - self.g.write('\n') + self.g.write('\n') self.g.write("\n") self.g.write("
\n") self.g.write(" \n" % len(self.db.getPlaceMap().values())) self.g.write(" \n") self.write_line("resname",owner.getName(),3) @@ -492,7 +492,11 @@ class XmlWriter: def dump_name(self,label,name,index=1): sp = " "*index - self.g.write('%s<%s%s>\n' % (sp,label,conf_priv(name))) + type = name.getType() + if type: + self.g.write('%s<%s type="%s"%s>\n' % (sp,label,type,conf_priv(name))) + else: + self.g.write('%s<%s%s>\n' % (sp,label,conf_priv(name))) self.write_line("first",name.getFirstName(),index+1) self.write_line("last",name.getSurname(),index+1) self.write_line("suffix",name.getSuffix(),index+1) diff --git a/src/const.py b/src/const.py index 3d557ddbd..f132a9bc5 100644 --- a/src/const.py +++ b/src/const.py @@ -857,3 +857,7 @@ lds_ssealing = [ ] +NameTypesMap = { + _("Also Known As") : "Also Known As", + _("Married") : "Married", + }