diff --git a/src/AddMedia.py b/src/AddMedia.py index fe3b51f74..a338a1510 100644 --- a/src/AddMedia.py +++ b/src/AddMedia.py @@ -135,7 +135,7 @@ class AddMediaObject: if self.update: self.update() self.object = mobj - self.db.commit_media_object(self.object) + self.db.commit_media_object(mobj) def on_name_changed(self,obj): """ diff --git a/src/FamilyView.py b/src/FamilyView.py index eecc66bd3..35ad5865c 100644 --- a/src/FamilyView.py +++ b/src/FamilyView.py @@ -686,12 +686,14 @@ class FamilyView: self.family = self.parent.db.new_family() self.person.add_family_id(self.family.get_id()) if self.person.get_gender() == RelLib.Person.male: - self.family.set_father_id(self.person) + self.family.set_father_id(self.person.get_id()) else: - self.family.set_mother_id(self.person) + self.family.set_mother_id(self.person.get_id()) - self.family.add_child_id(epo.person) + self.family.add_child_id(epo.person.get_id()) epo.person.add_parent_family_id(self.family.get_id(),"Birth","Birth") + self.parent.db.commit_person(epo.person) + self.parent.db.commit_family(self.family) self.display_marriage(self.family) def select_child_clicked(self,obj): @@ -715,7 +717,7 @@ class FamilyView: id = self.child_model.get_value(iter,2) child = self.parent.db.get_person(id) - self.family.remove_child_id(child) + self.family.remove_child_id(child.get_id()) child.remove_parent_family_id(self.family) if len(self.family.get_child_id_list()) == 0: @@ -995,8 +997,15 @@ class FamilyView: fiter = self.child_model.get_path(iter) val = self.parent.db.get_person_display(child.get_id()) i += 1 + + event = self.parent.db.find_event_from_id(val[3]) + if event: + dval = event.get_date() + else: + dval = u'' + self.child_model.set(iter,0,i,1,val[0],2,val[1],3,val[2], - 4,val[3],5,status,6,val[6]) + 4,dval,5,status,6,val[6]) def build_parents_menu(self,family,event): """Builds the menu that allows editing operations on the child list""" diff --git a/src/MediaView.py b/src/MediaView.py index 81efa9d2f..4172a8609 100644 --- a/src/MediaView.py +++ b/src/MediaView.py @@ -200,9 +200,10 @@ class MediaView: id = store.get_value(iter,1) object = self.db.find_object_from_id(id) self.obj = object - Utils.add_menuitem(menu,_("View in the default viewer"),None,self.popup_view_photo) + Utils.add_menuitem(menu,_("View in the default viewer"),None, + self.popup_view_photo) if object.get_mime_type()[0:5] == "image": - Utils.add_menuitem(menu,_("Edit with the GIMP"),\ + Utils.add_menuitem(menu,_("Edit with the GIMP"), None,self.popup_edit_photo) if object.get_local() == 0: Utils.add_menuitem(menu,_("Convert to local copy"),None, @@ -268,7 +269,6 @@ class MediaView: self.id2col[id] = iter self.model.set(iter, 0, title, 1, id, 2, type, 3, path, 4, stitle) - def on_add_clicked(self,obj): """Add a new media object to the media list""" import AddMedia @@ -290,7 +290,7 @@ class MediaView: return id = store.get_value(iter,1) - mobj = self.db.get_object(id) + mobj = self.db.find_object_from_id(id) if self.is_object_used(mobj): ans = ImageSelect.DeleteMediaQuery(mobj,self.db,self.update) QuestionDialog(_('Delete Media Object?'), @@ -306,7 +306,8 @@ class MediaView: self.update(0) def is_object_used(self,mobj): - for p in self.db.get_family_id_map().values(): + for family_id in self.db.get_family_keys(): + p = self.db.find_family_from_id(family_id) for o in p.get_media_list(): if o.get_reference_id() == mobj.get_id(): return 1 diff --git a/src/PlaceView.py b/src/PlaceView.py index cab39de39..ed491160b 100644 --- a/src/PlaceView.py +++ b/src/PlaceView.py @@ -225,7 +225,11 @@ class PlaceView: used = 0 for key in self.db.get_person_keys(): p = self.db.get_person(key) - event_list = [p.get_birth(), p.get_death()] + p.get_event_list()[:] + event_list = [] + for e in [p.get_birth_id(),p.get_death_id()] + p.get_event_list(): + event = self.db.find_event_from_id(e) + if event: + event_list.append(event) if p.get_lds_baptism(): event_list.append(p.get_lds_baptism()) if p.get_lds_endowment(): @@ -236,8 +240,13 @@ class PlaceView: if event.get_place_id() == place: used = 1 - for f in self.db.get_family_id_map().values(): - event_list = f.get_event_list()[:] + for fid in self.db.get_family_keys(): + f = self.db.find_family_from_id(fid) + event_list = [] + for e in f.get_event_list(): + event = self.db.find_event_from_id(e) + if event: + event_list.append(event) if f.get_lds_sealing(): event_list.append(f.get_lds_sealing()) for event in event_list: