From 1f7594cfeea07d8ac6094fa98a1fca7b92a695f2 Mon Sep 17 00:00:00 2001 From: Don Allingham Date: Wed, 4 Aug 2004 04:53:29 +0000 Subject: [PATCH] * src/WriteXML.py: always write the default location for a place * src/EditPerson.py: don't for write of multimedia objects if not edited * src/ImageSelect.py: don't for write of multimedia objects if not edited * src/AutoComp.py: build ListStore for ComboBox and Entry * src/AddSpouse.py: use ComboBox * src/Marriage.py: use ComboBox * src/gramps.glade: Switch from gtk.Combo to gtk.ComboBox and gtk.ComboxEntry * src/EventEdit.py: handle autocompletion * src/RelLib.py: remove cPickle import * src/GrampsDbBase.py: fix has_handle functions svn: r3325 --- ChangeLog | 15 + example/gramps/data.gramps | Bin 5599 -> 24343 bytes src/AddSpouse.py | 12 +- src/AutoComp.py | 25 ++ src/EditPerson.py | 32 +- src/EventEdit.py | 21 +- src/GrampsDbBase.py | 5 +- src/ImageSelect.py | 10 +- src/Marriage.py | 14 +- src/ReadXML.py | 9 +- src/RelLib.py | 1 - src/WriteXML.py | 9 +- src/gramps.glade | 782 +++++++++++++------------------------ 13 files changed, 355 insertions(+), 580 deletions(-) diff --git a/ChangeLog b/ChangeLog index 2c7126ce4..2586c8301 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,18 @@ +2004-08-03 Don Allingham + * src/WriteXML.py: always write the default location for a place + * src/EditPerson.py: don't for write of multimedia objects if + not edited + * src/ImageSelect.py: don't for write of multimedia objects if + not edited + * src/AutoComp.py: build ListStore for ComboBox and Entry + * src/AddSpouse.py: use ComboBox + * src/Marriage.py: use ComboBox + * src/gramps.glade: Switch from gtk.Combo to gtk.ComboBox and + gtk.ComboxEntry + * src/EventEdit.py: handle autocompletion + * src/RelLib.py: remove cPickle import + * src/GrampsDbBase.py: fix has_handle functions + 2004-08-01 Don Allingham * src/WriteGedcom.py: move up from plugins directory * src/ReadGedcom.py: move up from plugins directory diff --git a/example/gramps/data.gramps b/example/gramps/data.gramps index ee302713f8b98c2c6368c9d6ee5509ddff6ac8e5..65d86ea43ee668d9aaf4f0c843626ae0f43b6669 100644 GIT binary patch literal 24343 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�`#WTRi z@XqC~q%#uo6iNAbbxVO}D)78jm9<+rSXF^4UJ86oRHUwusEEZqv)xO&A;$T8uEAom zDo}JcbCoxte>^8Y9zbrk^?p9y!@<-S8m?BeZL=+8YWiy<*l?9@?5T^!MCR9$xm^Wa zMUe6_I|WI0>Y8VhqRzF_C(6na{!CIf<@G{o@28Z!#CkMyUgZ(KA>KN5m#Wzb`PTFd)o4?f9 zO^4G;y<=^fAlTg8h;HfFk9@tZi+a8l>|DyxOrc&{KDUIdwyOoZ`#W}iAEMqC2SRHj zY1M%3Ox)L>K)6nRD@m&nud=bl{^^Y^4`#3E=LY??F6d6slF>-=qEj9&r!P+2FHDb4 zmio=|$Z9H9CRmFjQ~S58DN~y-J&G^2fXSg7H(-alSz%m$$_9JOS~2eDsU_0ukE>~a z=dfPlOwQZitC^h5TK1BwnLgD|#@*{DJ=93fsNYo$k1Y$g~&1-a9=)WHHbxgBswiN!4xz zyBjOfGSSx4s@~yyYf-=Y?<11W8#PuVBRbesc6kA7{q@fSE0flR;+h$RmNmfDRj{uK#nPLO86E)>2F5&H_`E$h= z4%n1Z)>$_)bD=CR$OUTQ@8A{`ZY6KUp0EVGQFMXRDcr82fS%Adx_Rw;uoVR>_L2G` zO1VsH%708OM-1P{g!3emE$!OQX4R@-^w!Hh?;?~;W`_Zn<8`I4D8mW3Tqeo154Zmx zamQ7yPB16pi8=0k|H7OKWlnLm6xO4xL~f3|SYhK{)BQ&rkR0@o&pq_bO1DEMcp`QC%p(6GQ1=#%_%%otu_LCs;-Br0Sir>SnDO~1x z(Q62~)$_(hTssOjXccFxY*oWc#rI$WPr&qXTNnzJR#WM^z~w01NDyAjyj9eVnHOUd z^CbQMdFrn?5Ul;v%e7Kz#&SLx)6&s zYzgO;g3H{qC|rKrsdqM=oSpG936h?;cWSzRT5ttA4+j~0!FQ)M#EZYdz2BV%DNjQy zQj#^e$n!#9*~}(x%O!=Y&8u^ZhpmQL7cL)KJVkHTy}ahn0c%l`q*Z$+tUFDu_q|qh zDU?;QmP2vUUm??Fp&d}T%~Nhw6K&WsD;~5b?TN+i*7*yM$IgJ1VYw{itupAjD7vf6 zPPvxe+^3Us?U>euL#w)&zo2$6BmIUp#Aq!|%*zFZ-ycZ!rY;txc)roz7JM&Ls^z|C z?v{d$SLivzzh#%&$crn*dGn>*`~JdRQKV~5sSBF=8LVeBT}SeRrhv7?1Y7kdz97X*j>+^pox* zf9w7yt)nhuJxj>@XNR9uBi`9bzhGPA+y_9WJm~@lI!K1*+PJ~PRW-D>m@@gjD`^X5 zs2^nZxiNQW>=XmvFdbmc5o82(cf(ZMZp}WBIwiK=S{-3KNmS$jmp74RBNLD5k?cPx zK(}lldl^{t(8o8`=x&W-heido1K|?VLAZbva1L4gV_=Gg37rE?|2fHtLoYcKYDl+l zn2ZWECSbaAvcA$T-ansf z&mB`?1Ezs2!f>P`?cBg4pGQza7No@EUIZ1GXPbY>yCpC@G?!3?J2&7DA@l$DzivPu zGL$rUnd(N8hd!D}!|HlL7paf=iF6$@JTmn;Qnhn4Ao8I}9fV{R8_yf2i_~*MjDE&< z;~8O;{UpH#z{<;YVNh;SYmOyhb>&-;KNT&AC?!Yn)|Heuctwq`|OEtdWde z05y!ChVK*#+cYa&i{CAbS%}dT3X?(~h8G6JPmV6FA=mGai=6%)XvTjt`&-HBPV-@K z$B1K|5XU?r{(S%A38Ya^NTWX(?S7;E1kQ*joDpw0vH!DYaGo5RpPs0}J~x{|}~k3I<)0007f*@1g(z diff --git a/src/AddSpouse.py b/src/AddSpouse.py index db57c2a50..49a4e857c 100644 --- a/src/AddSpouse.py +++ b/src/AddSpouse.py @@ -109,7 +109,6 @@ class AddSpouse: self.relation_def = self.glade.get_widget("reldef") self.rel_combo = self.glade.get_widget("rel_combo") - self.relation_type = self.glade.get_widget("rel_type") self.spouse_list = self.glade.get_widget("spouse_list") self.showall = self.glade.get_widget('showall') @@ -126,7 +125,6 @@ class AddSpouse: self.ok = self.glade.get_widget('spouse_ok') self.ok.set_sensitive(0) - self.rel_combo.set_popdown_strings(const.familyRelations) title = _("Choose Spouse/Partner of %s") % GrampsCfg.get_nameof()(person) Utils.set_titles(self.glade.get_widget('spouseDialog'), @@ -143,7 +141,7 @@ class AddSpouse: "destroy_passed_object" : Utils.destroy_passed_object }) - self.relation_type.set_text(const.family_relations[const.FREL_MARRIED][0]) + self.rel_combo.set_active(const.FAMILY_MARRIED) self.update_data() def add_columns(self,tree): @@ -192,8 +190,8 @@ class AddSpouse: """ import EditPerson - relation = const.save_frel(unicode(self.relation_type.get_text())) - if relation == "Partners": + relation = self.rel_combo.get_active() + if relation == const.FAMILY_CIVIL_UNION: if self.person.get_gender() == RelLib.Person.male: gen = RelLib.Person.male else: @@ -275,7 +273,7 @@ class AddSpouse: self.active_family.set_father_handle(spouse.get_handle()) self.active_family.set_mother_handle(self.person.get_handle()) - rtype = const.save_frel(unicode(self.relation_type.get_text())) + rtype = self.rel_combo.get_active() self.active_family.set_relationship(rtype) self.db.commit_family(self.active_family,trans) self.db.add_transaction(trans,_("Add Spouse")) @@ -342,7 +340,7 @@ class AddSpouse: return 1 def set_gender(self): - if self.rel_type.get_active() == const.FAMILY_CIVIL_UNION: + if self.rel_combo.get_active() == const.FAMILY_CIVIL_UNION: if self.gender == RelLib.Person.male: self.sgender = RelLib.Person.female else: diff --git a/src/AutoComp.py b/src/AutoComp.py index cdabf8863..387533bd2 100644 --- a/src/AutoComp.py +++ b/src/AutoComp.py @@ -290,4 +290,29 @@ class AutoEntry(AutoCompBase): gtk.Editable.select_region(entry,self.l, -1) return +def fill_combo(combo,data_list): + store = gtk.ListStore(gobject.TYPE_STRING) + + for data in data_list: + store.append(row=[data]) + + combo.set_model(store) + combo.set_text_column(0) + completion = gtk.EntryCompletion() + completion.set_model(store) + completion.set_minimum_key_length(1) + completion.set_text_column(0) + combo.child.set_completion(completion) + +def fill_entry(entry,data_list): + store = gtk.ListStore(gobject.TYPE_STRING) + + for data in data_list: + store.append(row=[data]) + + completion = gtk.EntryCompletion() + completion.set_model(store) + completion.set_minimum_key_length(1) + completion.set_text_column(0) + entry.set_completion(completion) diff --git a/src/EditPerson.py b/src/EditPerson.py index d1b1f2656..3c27cece4 100644 --- a/src/EditPerson.py +++ b/src/EditPerson.py @@ -308,7 +308,7 @@ class EditPerson: types = const.NameTypesMap.get_values() types.sort() - self.autotype = AutoComp.AutoCombo(self.ntype_field,types) + AutoComp.fill_combo(self.ntype_field,types) self.write_primary_name() if person.get_gender() == RelLib.Person.male: @@ -435,13 +435,13 @@ class EditPerson: child_window.close(None) self.child_windows = {} - def close(self,ok=0): + def close(self): event_list = [] for col in self.event_list.get_columns(): event_list.append(self.event_trans.find_key(col.get_title())) self.db.metadata['event_order'] = event_list - self.gallery.close(ok) + self.gallery.close() self.close_child_windows() self.remove_itself_from_winsmenu() self.window.destroy() @@ -484,7 +484,7 @@ class EditPerson: tree.append_column(column) def lds_field(self,ord,combo,date,place): - combo.set_popdown_strings(_temple_names) + AutoComp.fill_combo(combo,_temple_names) if not ord.is_empty(): stat = ord.get_status() date.set_text(ord.get_date()) @@ -492,10 +492,10 @@ class EditPerson: name = const.lds_temple_to_abrev[ord.get_temple()] else: name = "" - combo.entry.set_text(name) + combo.child.set_text(name) else: stat = 0 - combo.entry.set_text("") + combo.child.set_text("") build_dropdown(place,self.place_list) if ord and ord.get_place_handle(): @@ -1042,7 +1042,7 @@ class EditPerson: self.cancel_callback, self.save) else: - self.close(0) + self.close() def save(self): self.on_apply_person_clicked(None) @@ -1059,12 +1059,12 @@ class EditPerson: self.save) return 1 else: - self.close(0) + self.close() return 0 def cancel_callback(self): """If the user answered yes to abandoning changes, close the window""" - self.close(0) + self.close() def did_data_change(self): """Check to see if any of the data has changed from the @@ -1074,7 +1074,7 @@ class EditPerson: self.birth.set_date(unicode(self.bdate.get_text())) self.death.set_date(unicode(self.ddate.get_text())) - ntype = unicode(self.ntype_field.entry.get_text()) + ntype = unicode(self.ntype_field.child.get_text()) suffix = unicode(self.suffix.get_text()) prefix = unicode(self.prefix.get_text()) given = unicode(self.given.get_text()) @@ -1163,7 +1163,7 @@ class EditPerson: def check_lds(self): self.lds_baptism.set_date(unicode(self.ldsbap_date.get_text())) - temple = unicode(self.ldsbap_temple.entry.get_text()) + temple = unicode(self.ldsbap_temple.child.get_text()) if const.lds_temple_codes.has_key(temple): self.lds_baptism.set_temple(const.lds_temple_codes[temple]) else: @@ -1171,7 +1171,7 @@ class EditPerson: self.lds_baptism.set_place_handle(self.get_place(self.ldsbapplace,1)) self.lds_endowment.set_date(unicode(self.ldsend_date.get_text())) - temple = unicode(self.ldsend_temple.entry.get_text()) + temple = unicode(self.ldsend_temple.child.get_text()) if const.lds_temple_codes.has_key(temple): self.lds_endowment.set_temple(const.lds_temple_codes[temple]) else: @@ -1179,7 +1179,7 @@ class EditPerson: self.lds_endowment.set_place_handle(self.get_place(self.ldsendowplace,1)) self.lds_sealing.set_date(unicode(self.ldsseal_date.get_text())) - temple = unicode(self.ldsseal_temple.entry.get_text()) + temple = unicode(self.ldsseal_temple.child.get_text()) if const.lds_temple_codes.has_key(temple): self.lds_sealing.set_temple(const.lds_temple_codes[temple]) else: @@ -1438,7 +1438,7 @@ class EditPerson: surname = unicode(self.surname.get_text()) suffix = unicode(self.suffix.get_text()) prefix = unicode(self.prefix.get_text()) - ntype = unicode(self.ntype_field.entry.get_text()) + ntype = unicode(self.ntype_field.child.get_text()) given = unicode(self.given.get_text()) nick = unicode(self.nick.get_text()) title = unicode(self.title.get_text()) @@ -1607,7 +1607,7 @@ class EditPerson: self.db.commit_person(self.person, trans) n = self.person.get_primary_name().get_regular_name() self.db.add_transaction(trans,_("Edit Person (%s)") % n) - self.close(1) + self.close() def get_place(self,field,makenew=0): text = unicode(string.strip(field.get_text())) @@ -1747,7 +1747,7 @@ class EditPerson: self.surname.set_text(self.pname.get_surname()) self.given.set_text(self.pname.get_first_name()) - self.ntype_field.entry.set_text(_(self.pname.get_type())) + self.ntype_field.child.set_text(_(self.pname.get_type())) self.title.set_text(self.pname.get_title()) def birth_dates_in_order(self,list): diff --git a/src/EventEdit.py b/src/EventEdit.py index 0c55174e7..519a86204 100644 --- a/src/EventEdit.py +++ b/src/EventEdit.py @@ -121,7 +121,6 @@ class EventEditor: Utils.set_titles(self.window,title_label, etitle, _('Event Editor')) - self.name_field = self.top.get_widget("eventName") self.place_field = self.top.get_widget("eventPlace") self.cause_field = self.top.get_widget("eventCause") self.slist = self.top.get_widget("slist") @@ -131,7 +130,7 @@ class EventEditor: self.cause_field = self.top.get_widget("eventCause") self.descr_field = self.top.get_widget("event_description") self.note_field = self.top.get_widget("eventNote") - self.event_menu = self.top.get_widget("personalEvents") + self.event_menu = self.top.get_widget("personal_events") self.priv = self.top.get_widget("priv") self.calendar = self.top.get_widget("calendar") self.sources_label = self.top.get_widget("sourcesEvent") @@ -162,11 +161,11 @@ class EventEditor: self.top.get_widget('edit_witness'), self.top.get_widget('del_witness')) - AutoComp.AutoCombo(self.event_menu,self.elist) - AutoComp.AutoEntry(self.place_field,self.pmap.keys()) + AutoComp.fill_combo(self.event_menu,self.elist) + AutoComp.fill_entry(self.place_field,self.pmap.keys()) if event != None: - self.name_field.set_text(transname) + self.event_menu.child.set_text(transname) if (def_placename): self.place_field.set_text(def_placename) else: @@ -194,7 +193,7 @@ class EventEditor: Utils.bold_label(self.gallery_label) else: if def_event: - self.name_field.set_text(def_event) + self.event_menu.child.set_text(def_event) if def_placename: self.place_field.set_text(def_placename) self.date_check = DateEdit(self.date_field,self.top.get_widget("date_stat")) @@ -237,12 +236,12 @@ class EventEditor: self.window.show() def on_delete_event(self,obj,b): - self.gallery.close(0) + self.gallery.close() self.close_child_windows() self.remove_itself_from_menu() - def close(self,obj,ok=0): - self.gallery.close(ok) + def close(self,obj): + self.gallery.close() self.close_child_windows() self.remove_itself_from_menu() self.window.destroy() @@ -305,7 +304,7 @@ class EventEditor: trans = self.db.start_transaction() - ename = unicode(self.name_field.get_text()) + ename = unicode(self.event_menu.child.get_text()) self.date.set(unicode(self.date_field.get_text())) ecause = unicode(self.cause_field.get_text()) eplace_obj = self.get_place(self.place_field,trans) @@ -333,7 +332,7 @@ class EventEditor: self.update_event(ename,self.date,eplace_obj,edesc,enote,eformat, epriv,ecause,trans) self.db.add_transaction(trans,_("Edit Event")) - self.close(obj,1) + self.close(obj) self.parent.redraw_event_list() self.callback(self.event) diff --git a/src/GrampsDbBase.py b/src/GrampsDbBase.py index 9cc2eae7f..53d251897 100644 --- a/src/GrampsDbBase.py +++ b/src/GrampsDbBase.py @@ -488,10 +488,10 @@ class GrampsDbBase: return person.get_handle() def has_person_handle(self,val): - return self.person_map.get(val) + return self.person_map.has_key(str(val)) def has_family_handle(self,val): - return self.family_map.get(str(val)) + return self.family_map.has_key(str(val)) def try_to_find_person_from_handle(self,val): """finds a Person in the database from the passed gramps' ID. @@ -1123,7 +1123,6 @@ class GrampsDbBase: class Transaction: def __init__(self,msg,db): - print db self.db = db self.first = None self.last = None diff --git a/src/ImageSelect.py b/src/ImageSelect.py index d671611a8..3dbf28030 100644 --- a/src/ImageSelect.py +++ b/src/ImageSelect.py @@ -250,7 +250,7 @@ class Gallery(ImageSelect): self.sel = None self.photo = None - def close(self,ok=0): + def close(self): self.iconlist.hide() if self.canvas_list: for a in self.canvas_list.values(): @@ -259,14 +259,6 @@ class Gallery(ImageSelect): a[2].destroy() self.p_map = None self.canvas_list = None - # restore old photo list, in case we removed some and then - # hit cancel button or closed the window - if not ok: - if self.old_media_list is not None: - self.dataobj.set_media_list(self.old_media_list) - trans = self.db.start_transaction() - self.commit(self.dataobj,trans) - self.db.add_transaction(trans,_("Edit Media Object")) def on_canvas1_event(self,obj,event): """ diff --git a/src/Marriage.py b/src/Marriage.py index cfc97a961..5ac67bd78 100644 --- a/src/Marriage.py +++ b/src/Marriage.py @@ -204,11 +204,11 @@ class Marriage: self.gid.set_text(family.get_handle()) self.gid.set_editable(1) - self.lds_temple.set_popdown_strings(_temple_names) + AutoComp.fill_combo(self.lds_temple,_temple_names) place_list = self.pmap.keys() place_list.sort() - self.autoplace = AutoComp.AutoCombo(self.lds_place, place_list) + self.autoplace = AutoComp.fill_combo(self.lds_place, place_list) ord = self.family.get_lds_sealing() if ord: @@ -219,10 +219,10 @@ class Marriage: name = const.lds_temple_to_abrev[ord.get_temple()] else: name = "" - self.lds_temple.entry.set_text(name) + self.lds_temple.child.set_text(name) self.seal_stat = ord.get_status() else: - self.lds_temple.entry.set_text("") + self.lds_temple.child.set_text("") self.lds_place.entry.set_text("") self.seal_stat = 0 @@ -511,7 +511,7 @@ class Marriage: changed = 1 date = unicode(self.lds_date.get_text()) - temple = unicode(self.lds_temple.entry.get_text()) + temple = unicode(self.lds_temple.child.get_text()) if const.lds_temple_codes.has_key(temple): temple = const.lds_temple_codes[temple] else: @@ -588,7 +588,7 @@ class Marriage: self.family.set_complete(self.complete.get_active()) date = unicode(self.lds_date.get_text()) - temple = unicode(self.lds_temple.entry.get_text()) + temple = unicode(self.lds_temple.child.get_text()) if const.lds_temple_codes.has_key(temple): temple = const.lds_temple_codes[temple] else: @@ -760,7 +760,7 @@ class Marriage: Utils.unbold_label(self.notes_label) date = unicode(self.lds_date.get_text()) - temple = unicode(self.lds_temple.entry.get_text()) + temple = unicode(self.lds_temple.child.get_text()) if const.lds_temple_codes.has_key(temple): temple = const.lds_temple_codes[temple] else: diff --git a/src/ReadXML.py b/src/ReadXML.py index f239bc27e..89cf6bec2 100644 --- a/src/ReadXML.py +++ b/src/ReadXML.py @@ -427,14 +427,12 @@ class GrampsParser: return person def map_gid(self,id): - if self.idswap.get(id): - return self.idswap[id] - else: + if not self.idswap.get(id): if self.db.id_trans.get(str(id)): self.idswap[id] = self.db.find_next_gramps_id() else: self.idswap[id] = id - return self.idswap[id] + return self.idswap[id] def parse(self,file): self.trans = self.db.start_transaction() @@ -590,7 +588,8 @@ class GrampsParser: self.callback(float(self.count)/float(self.entries)) self.count = self.count + 1 - self.person = self.find_person_by_gramps_id(self.map_gid(attrs['id'])) + new_id = self.map_gid(attrs['id']) + self.person = self.find_person_by_gramps_id(new_id) if attrs.has_key("complete"): self.person.set_complete(int(attrs['complete'])) diff --git a/src/RelLib.py b/src/RelLib.py index cec9bbbbd..510f0e98b 100644 --- a/src/RelLib.py +++ b/src/RelLib.py @@ -35,7 +35,6 @@ import os import os.path import types from gettext import gettext as _ -import cPickle #------------------------------------------------------------------------- # diff --git a/src/WriteXML.py b/src/WriteXML.py index 182e05b1b..841966c33 100644 --- a/src/WriteXML.py +++ b/src/WriteXML.py @@ -211,7 +211,8 @@ class XmlWriter: self.g.write('\n') self.g.write("\n") self.g.write("
\n") - self.g.write(" \n' % (sp2,ord.get_status())) if ord.get_family_handle(): - self.g.write('%s\n' % (sp2,self.fix(ord.get_family_handle().get_gramps_id()))) + self.g.write('%s\n' % \ + (sp2,self.fix(ord.get_family_handle().get_gramps_id()))) if ord.get_note() != "": self.write_note("note",ord.get_note_object(),index+1) for s in ord.get_source_references(): @@ -657,9 +659,6 @@ class XmlWriter: zip = self.fix(loc.get_postal_code()) phone = self.fix(loc.get_phone()) - if not city and not state and not parish and not county and not country: - return - self.g.write(' GTK_ORIENTATION_HORIZONTAL GTK_TOOLBAR_BOTH True + True - + True Open database Open True - gtk-open + gtk-open + True + True + False + + False + True + - + True Save database Save As... True - gtk-save-as + gtk-save-as + True + True + False + + False + True + - + + True + True + True + True + + + False + False + + + + + True Go back in history Back True - gtk-go-back - True + gtk-go-back + True + True + False - True + False + True - + True Go forward in history Forward True - gtk-go-forward + gtk-go-forward + True + True + False - - - - - True - Make the Home Person the active person - Home - True - gtk-home - - - - - - - True - Generate reports - Reports - True - gtk-dnd-multiple - True - - - True + False + True - + + True + Make the Home Person the active person + Home + True + gtk-home + True + True + False + + + + False + True + + + + + + True + True + True + True + + + False + False + + + + + + True + Generate reports + Reports + True + gtk-dnd-multiple + True + True + False + + + + False + True + + + + + True Run tools Tools True tools.png + True + True + False - - - - - True - Add a new item - Add - True - gtk-add - True - - - True + False + True - + + True + True + True + True + + + False + False + + + + + + True + Add a new item + Add + True + gtk-add + True + True + False + + + + False + True + + + + + True Remove the currently selected item Remove True - gtk-remove + gtk-remove + True + True + False + + False + True + - + True Edit the selected item Edit True edit.png + True + True + False + + False + True + @@ -3654,10 +3752,6 @@ 0.5 0 0 - rel_type - - - 0 @@ -3669,68 +3763,6 @@ - - - True - True - True - False - True - False - - - - True - True - False - True - 0 - - True - * - False - - - - - - - True - GTK_SELECTION_BROWSE - - - - True - - - - True - - False - False - GTK_JUSTIFY_LEFT - False - False - 0 - 0.5 - 0 - 0 - - - - - - - - - 1 - 2 - 0 - 1 - - - - True @@ -3755,6 +3787,25 @@ + + + + True + Married +Unmarried +Civil Union +Unknown +Other + + + 1 + 2 + 0 + 1 + fill + fill + + 0 @@ -8108,7 +8159,6 @@ Other 0.5 0 0 - combo-entry3 1 @@ -8363,89 +8413,6 @@ Other - - - True - False - False - False - True - False - - - - True - True - True - True - 0 - - True - * - False - - - - - - True - GTK_SELECTION_BROWSE - - - - True - - - - True - - False - False - GTK_JUSTIFY_LEFT - False - False - 0 - 0.5 - 0 - 0 - - - - - - - - True - - - - True - - False - False - GTK_JUSTIFY_LEFT - False - False - 0 - 0.5 - 0 - 0 - - - - - - - - - 2 - 5 - 7 - 8 - - - - True @@ -8937,6 +8904,20 @@ Other + + + + True + + + 2 + 5 + 7 + 8 + fill + fill + + 0 @@ -12193,10 +12174,8 @@ Other 0.5 0 0 - combo-entry7 Temple: - @@ -12209,45 +12188,6 @@ Other - - - True - False - True - False - True - False - - - - True - True - True - True - 0 - - True - * - False - - - - - - True - GTK_SELECTION_BROWSE - - - - - 2 - 3 - 2 - 3 - - - - True @@ -12403,10 +12343,6 @@ Other 0.5 0 0 - combo-entry8 - - - 1 @@ -12467,45 +12403,6 @@ Other - - - True - False - True - False - True - False - - - - True - True - True - True - 0 - - True - * - False - - - - - - True - GTK_SELECTION_BROWSE - - - - - 2 - 3 - 7 - 8 - - - - True @@ -12673,10 +12570,6 @@ Other 0.5 0 0 - combo-entry9 - - - 1 @@ -12688,45 +12581,6 @@ Other - - - True - False - True - False - True - False - - - - True - True - True - True - 0 - - True - * - False - - - - - - True - GTK_SELECTION_BROWSE - - - - - 2 - 3 - 12 - 13 - - - - True @@ -12889,6 +12743,48 @@ Other + + + + True + + + 2 + 3 + 2 + 3 + fill + fill + + + + + + True + + + 2 + 3 + 7 + 8 + fill + fill + + + + + + True + + + 2 + 3 + 12 + 13 + fill + fill + + False @@ -14704,128 +14600,6 @@ Other - - - True - True - True - False - True - False - - - - True - True - True - True - 0 - - True - * - False - - - - - - True - GTK_SELECTION_BROWSE - - - - True - - - - True - - False - False - GTK_JUSTIFY_LEFT - False - False - 0 - 0.5 - 0 - 0 - - - - - - - - - 2 - 3 - 2 - 3 - - - - - - - True - False - True - False - True - False - - - - True - True - True - True - 0 - - True - * - False - - - - - - True - GTK_SELECTION_BROWSE - - - - True - - - - True - - False - False - GTK_JUSTIFY_LEFT - False - False - 0 - 0.5 - 0 - 0 - - - - - - - - - 2 - 3 - 3 - 4 - - - - True @@ -14887,6 +14661,34 @@ Other + + + + True + + + 2 + 3 + 3 + 4 + fill + fill + + + + + + True + + + 2 + 3 + 2 + 3 + fill + fill + + 0 @@ -26321,10 +26123,6 @@ Other 0.5 0 0 - eventName - - - 0 @@ -26586,68 +26384,6 @@ Other - - - True - False - True - False - True - False - - - - True - True - True - True - True - 0 - - True - * - False - - - - - - True - GTK_SELECTION_BROWSE - - - - True - - - - True - - False - False - GTK_JUSTIFY_LEFT - False - False - 0 - 0.5 - 0 - 0 - - - - - - - - - 1 - 4 - 0 - 1 - - - - True @@ -26687,6 +26423,20 @@ Other fill + + + + True + + + 1 + 4 + 0 + 1 + fill + fill + + False