From 1467a4f28003d04ab22c0ef9b96a0b53b531c2a8 Mon Sep 17 00:00:00 2001 From: Don Allingham Date: Wed, 5 Apr 2006 22:36:48 +0000 Subject: [PATCH] Fix place selecton on LDS ords svn: r6274 --- src/DisplayTabs.py | 51 +++++++++++--- src/Editors/_EditFamily.py | 6 +- src/Editors/_EditLdsOrd.py | 133 ++++++++++++++++++++++++++++++++++++- src/GrampsWidgets.py | 2 - src/RelLib/_LdsOrd.py | 5 +- 5 files changed, 180 insertions(+), 17 deletions(-) diff --git a/src/DisplayTabs.py b/src/DisplayTabs.py index 8e6b5be41..be28095dd 100644 --- a/src/DisplayTabs.py +++ b/src/DisplayTabs.py @@ -1205,6 +1205,13 @@ class LdsEmbedList(EmbeddedList): EmbeddedList.__init__(self, dbstate, uistate, track, _('LDS'), LdsModel) + def get_editor(self): + from Editors import EditLdsOrd + return EditLdsOrd + + def new_data(self): + return RelLib.LdsOrd() + def get_data(self): return self.data @@ -1212,12 +1219,9 @@ class LdsEmbedList(EmbeddedList): return ((1,0),(1,1),(1,2),(1,3),(1,4)) def add_button_clicked(self,obj): - lds = RelLib.LdsOrd() try: - from Editors import EditLdsOrd - - EditLdsOrd(self.dbstate, self.uistate, self.track, - lds, self.add_callback) + self.get_editor()(self.dbstate, self.uistate, self.track, + self.new_data(), self.add_callback) except Errors.WindowActiveError: pass @@ -1229,16 +1233,45 @@ class LdsEmbedList(EmbeddedList): lds = self.get_selected() if lds: try: - from Editors import EditLdsOrd - - EditLdsOrd(self.dbstate, self.uistate, self.track, - lds, self.edit_callback) + self.get_editor()(self.dbstate, self.uistate, self.track, + lds, self.edit_callback) except Errors.WindowActiveError: pass def edit_callback(self,name): self.rebuild() + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +class FamilyLdsEmbedList(LdsEmbedList): + + _HANDLE_COL = 5 +# _DND_TYPE = DdTargets.ADDRESS + + _column_names = [ + (_('Type'), 0, 150), + (_('Date'), 1, 150), + (_('Status'), 3, 75), + (_('Temple'), 2, 200), + (_('Place'), 3, 100), + ] + + def __init__(self,dbstate,uistate,track,data): + LdsEmbedList.__init__(self, dbstate, uistate, track, data) + + def get_editor(self): + from Editors import EditFamilyLdsOrd + return EditFamilyLdsOrd + + def new_data(self): + lds = RelLib.LdsOrd() + lds.set_type(RelLib.LdsOrd.SEAL_TO_SPOUSE) + return lds + #------------------------------------------------------------------------- # # diff --git a/src/Editors/_EditFamily.py b/src/Editors/_EditFamily.py index 75ca4d52a..fbcc86bfd 100644 --- a/src/Editors/_EditFamily.py +++ b/src/Editors/_EditFamily.py @@ -486,6 +486,11 @@ class EditFamily(EditPrimary): GalleryTab(self.dbstate, self.uistate, self.track, self.obj.get_media_list())) + self.lds_list = self._add_tab( + notebook, + FamilyLdsEmbedList(self.dbstate,self.uistate,self.track, + self.obj.get_lds_ord_list())) + notebook.show_all() self.hidden = (notebook, self.top.get_widget('info')) @@ -767,7 +772,6 @@ class EditFamily(EditPrimary): original = None if not original and not self.object_is_empty(): - print self.obj.serialize() trans = self.db.transaction_begin() # find the father, add the family handle to the father diff --git a/src/Editors/_EditLdsOrd.py b/src/Editors/_EditLdsOrd.py index 971f3af28..d30365686 100644 --- a/src/Editors/_EditLdsOrd.py +++ b/src/Editors/_EditLdsOrd.py @@ -60,7 +60,7 @@ from GrampsWidgets import * #------------------------------------------------------------------------- # -# EditAttribute class +# EditLdsOrd class # #------------------------------------------------------------------------- class EditLdsOrd(EditSecondary): @@ -213,7 +213,135 @@ class EditLdsOrd(EditSecondary): def save(self,*obj): """ Called when the OK button is pressed. Gets data from the - form and updates the Attribute data structure. + form and updates the LdsOrd data structure. + """ + + (need_new, handle) = self.place_field.get_place_info() + if need_new: + place_obj = RelLib.Place() + place_obj.set_title(handle) + trans = self.db.transaction_begin() + self.db.add_place(place_obj,trans) + self.db.transaction_commit(trans,_("Add Place")) + self.obj.set_place_handle(place_obj.get_handle()) + else: + self.obj.set_place_handle(handle) + + if self.callback: + self.callback(self.obj) + self.close_window(obj) + +#------------------------------------------------------------------------- +# +# EditFamilyLdsOrd +# +#------------------------------------------------------------------------- +class EditFamilyLdsOrd(EditSecondary): + """ + Displays a dialog that allows the user to edit an attribute. + """ + + def __init__(self, state, uistate, track, attrib, callback): + """ + Displays the dialog box. + + parent - The class that called the Address editor. + attrib - The attribute that is to be edited + title - The title of the dialog box + list - list of options for the pop down menu + """ + EditSecondary.__init__(self, state, uistate, track, attrib, callback) + + def _local_init(self): + self.top = gtk.glade.XML(const.gladeFile, "lds_person_edit","gramps") + self.define_top_level(self.top.get_widget("lds_person_edit"), + self.top.get_widget('title'), + _('LDS Ordinance Editor')) + + def _connect_signals(self): + self.define_cancel_button(self.top.get_widget('cancel')) + self.define_help_button(self.top.get_widget('help'),'adv-at') + self.define_ok_button(self.top.get_widget('ok'),self.save) + + def _setup_fields(self): + + self.parents_label = self.top.get_widget('parents_label') + self.parents = self.top.get_widget('parents') + self.parents_select = self.top.get_widget('parents_select') + + self.priv = PrivacyButton( + self.top.get_widget("private"), + self.obj) + + self.date_field = MonitoredDate( + self.top.get_widget("date"), + self.top.get_widget("date_stat"), + self.obj.get_date_object(), + self.window, self.db.readonly) + + self.place_field = PlaceEntry( + self.top.get_widget("place"), + self.obj.get_place_handle(), + self.dbstate.get_place_completion(), + self.db.readonly) + + self.type_menu = MonitoredMenu( + self.top.get_widget('type'), + self.obj.set_type, + self.obj.get_type, + [(_('Sealed to Spouse'),RelLib.LdsOrd.SEAL_TO_SPOUSE)], + self.db.readonly) + + temple_list = [] + for val in lds.temple_codes.keys(): + temple_list.append((lds.temple_codes[val],val)) + + self.temple_menu = MonitoredStrMenu( + self.top.get_widget('temple'), + self.obj.set_temple, + self.obj.get_temple, + temple_list, + self.db.readonly) + + self.status_menu = MonitoredMenu( + self.top.get_widget('status'), + self.obj.set_status, + self.obj.get_status, + [(_(''), RelLib.LdsOrd.STATUS_NONE), + (_('Canceled'), RelLib.LdsOrd.STATUS_CANCELED), + (_("Cleared"), RelLib.LdsOrd.STATUS_CLEARED), + (_("Completed"), RelLib.LdsOrd.STATUS_COMPLETED), + (_("DNS"), RelLib.LdsOrd.STATUS_DNS), + (_("Pre-1970"), RelLib.LdsOrd.STATUS_PRE_1970), + (_("Qualified"), RelLib.LdsOrd.STATUS_QUALIFIED), + (_("DNS/CAN"), RelLib.LdsOrd.STATUS_DNS_CAN), + (_("Submitted"), RelLib.LdsOrd.STATUS_SUBMITTED), + (_("Uncleared"), RelLib.LdsOrd.STATUS_UNCLEARED),], + self.db.readonly) + + def _create_tabbed_pages(self): + notebook = gtk.Notebook() + self.srcref_list = self._add_tab( + notebook, + SourceEmbedList(self.dbstate,self.uistate, self.track, + self.obj.source_list)) + + self.note_tab = self._add_tab( + notebook, + NoteTab(self.dbstate, self.uistate, self.track, + self.obj.get_note_object())) + + notebook.show_all() + vbox = self.top.get_widget('vbox').pack_start(notebook,True) + + def build_menu_names(self, attrib): + label = _("LDS Ordinance") + return (label, _('LDS Ordinance Editor')) + + def save(self,*obj): + """ + Called when the OK button is pressed. Gets data from the + form and updates the LdsOrd data structure. """ (need_new, handle) = self.place_field.get_place_info() @@ -227,7 +355,6 @@ class EditLdsOrd(EditSecondary): else: self.obj.set_place_handle(handle) - print self.obj.get_place_handle() if self.callback: self.callback(self.obj) self.close_window(obj) diff --git a/src/GrampsWidgets.py b/src/GrampsWidgets.py index 135c6d7bb..4feeaac5b 100644 --- a/src/GrampsWidgets.py +++ b/src/GrampsWidgets.py @@ -376,10 +376,8 @@ class MonitoredMenu: self.obj.set_active(0) def on_change(self, obj): - print "ON CHANGE" self.set_val(self.model.get_value(obj.get_active_iter(), 1)) if self.changed: - print "CALL" self.changed() class MonitoredStrMenu: diff --git a/src/RelLib/_LdsOrd.py b/src/RelLib/_LdsOrd.py index 58a63aae2..09e0eeab2 100644 --- a/src/RelLib/_LdsOrd.py +++ b/src/RelLib/_LdsOrd.py @@ -88,11 +88,12 @@ class LdsOrd(SourceNote,DateBase,PlaceBase,PrivacyBase): def serialize(self): return (SourceNote.serialize(self), - DateBase.serialize(self),self.place, + DateBase.serialize(self), + self.type,self.place, self.famc,self.temple,self.status) def unserialize(self,data): - (sn,date,self.place, + (sn,date,self.type,self.place, self.famc,self.temple,self.status) = data SourceNote.unserialize(self,sn) DateBase.unserialize(self,date)