2008-02-15 Gary Burton <gary.burton@zen.co.uk>

* src/DataViews/RelationView.py:
	* src/Editors/_EditFamily.py: prevent right mouse button causing crash.
	Bug #1729



svn: r10041
This commit is contained in:
Gary Burton 2008-02-15 22:44:39 +00:00
parent 15e789467b
commit 6ba049eb94
3 changed files with 41 additions and 31 deletions

View File

@ -1,3 +1,8 @@
2008-02-15 Gary Burton <gary.burton@zen.co.uk>
* src/DataViews/RelationView.py:
* src/Editors/_EditFamily.py: prevent right mouse button causing crash.
Bug #1729
2008-02-15 Benny Malengier <benny.malengier@gramps-project.org> 2008-02-15 Benny Malengier <benny.malengier@gramps-project.org>
* src/DisplayTabs/_SourceEmbedList.py: * src/DisplayTabs/_SourceEmbedList.py:
* src/DisplayTabs/_PersonRefEmbedList.py: * src/DisplayTabs/_PersonRefEmbedList.py:

View File

@ -1217,7 +1217,7 @@ class RelationshipView(PageView.PersonNavView):
self.row += 1 self.row += 1
def edit_button_press(self, obj, event, handle): def edit_button_press(self, obj, event, handle):
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 1 \ if event.type == gtk.gdk.BUTTON_PRESS \
or event.keyval in (_RETURN, _KP_ENTER): or event.keyval in (_RETURN, _KP_ENTER):
self.edit_person(obj, handle) self.edit_person(obj, handle)
@ -1230,7 +1230,7 @@ class RelationshipView(PageView.PersonNavView):
pass pass
def edit_family(self, obj, event, handle): def edit_family(self, obj, event, handle):
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 1 \ if event.type == gtk.gdk.BUTTON_PRESS \
or event.keyval in (_RETURN, _KP_ENTER): or event.keyval in (_RETURN, _KP_ENTER):
from Editors import EditFamily from Editors import EditFamily
family = self.dbstate.db.get_family_from_handle(handle) family = self.dbstate.db.get_family_from_handle(handle)
@ -1240,7 +1240,8 @@ class RelationshipView(PageView.PersonNavView):
pass pass
def add_family(self, obj, event, handle): def add_family(self, obj, event, handle):
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 1: if event.type == gtk.gdk.BUTTON_PRESS \
or event.keyval in (_RETURN, _KP_ENTER):
from Editors import EditFamily from Editors import EditFamily
family = gen.lib.Family() family = gen.lib.Family()
person = self.dbstate.active person = self.dbstate.active
@ -1280,20 +1281,22 @@ class RelationshipView(PageView.PersonNavView):
self.edit_person(obj, phandle) self.edit_person(obj, phandle)
def add_child_to_fam(self, obj, event, handle): def add_child_to_fam(self, obj, event, handle):
callback = lambda x: self.callback_add_child(x, handle) if event.type == gtk.gdk.BUTTON_PRESS \
from Editors import EditPerson or event.keyval in (_RETURN, _KP_ENTER):
person = gen.lib.Person() callback = lambda x: self.callback_add_child(x, handle)
family = self.dbstate.db.get_family_from_handle(handle) from Editors import EditPerson
father = self.dbstate.db.get_person_from_handle( person = gen.lib.Person()
family.get_father_handle()) family = self.dbstate.db.get_family_from_handle(handle)
if father: father = self.dbstate.db.get_person_from_handle(
name = father.get_primary_name().get_surname() family.get_father_handle())
person.get_primary_name().set_surname(name) if father:
try: name = father.get_primary_name().get_surname()
EditPerson(self.dbstate, self.uistate, [], person, person.get_primary_name().set_surname(name)
callback=callback) try:
except Errors.WindowActiveError: EditPerson(self.dbstate, self.uistate, [], person,
pass callback=callback)
except Errors.WindowActiveError:
pass
def callback_add_child(self, person, family_handle): def callback_add_child(self, person, family_handle):
ref = gen.lib.ChildRef() ref = gen.lib.ChildRef()
@ -1312,22 +1315,24 @@ class RelationshipView(PageView.PersonNavView):
def sel_child_to_fam(self, obj, event, handle): def sel_child_to_fam(self, obj, event, handle):
from Selectors import selector_factory from Selectors import selector_factory
SelectPerson = selector_factory('Person') if event.type == gtk.gdk.BUTTON_PRESS \
family = self.dbstate.db.get_family_from_handle(handle) or event.keyval in (_RETURN, _KP_ENTER):
# it only makes sense to skip those who are already in the family SelectPerson = selector_factory('Person')
skip_list = [family.get_father_handle(), \ family = self.dbstate.db.get_family_from_handle(handle)
family.get_mother_handle()] + \ # it only makes sense to skip those who are already in the family
[x.ref for x in family.get_child_ref_list() ] skip_list = [family.get_father_handle(), \
family.get_mother_handle()] + \
[x.ref for x in family.get_child_ref_list() ]
sel = SelectPerson(self.dbstate, self.uistate, [], sel = SelectPerson(self.dbstate, self.uistate, [],
_("Select Child"), skip=skip_list) _("Select Child"), skip=skip_list)
person = sel.run() person = sel.run()
if person: if person:
self.callback_add_child(person, handle) self.callback_add_child(person, handle)
def select_family(self, obj, event, handle): def select_family(self, obj, event, handle):
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 1 \ if event.type == gtk.gdk.BUTTON_PRESS \
or event.keyval in (_RETURN, _KP_ENTER): or event.keyval in (_RETURN, _KP_ENTER):
from Selectors import selector_factory from Selectors import selector_factory
SelectFamily = selector_factory('Family') SelectFamily = selector_factory('Family')

View File

@ -780,7 +780,7 @@ class EditFamily(EditPrimary):
'select the existing family')) 'select the existing family'))
def edit_person(self, obj, event, handle): def edit_person(self, obj, event, handle):
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 1 \ if event.type == gtk.gdk.BUTTON_PRESS \
or event.keyval in (_RETURN, _KP_ENTER): or event.keyval in (_RETURN, _KP_ENTER):
from _EditPerson import EditPerson from _EditPerson import EditPerson
try: try: