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

* src/DataViews/RelationView.py:
	* src/Editors/_EditFamily.py:
	* src/Editors/_EditChildRef.py
	Fix crash on doubleclicking buttons. Bug #1802



svn: r10096
This commit is contained in:
Gary Burton 2008-02-22 22:09:39 +00:00
parent a1450a8c29
commit a58e6fdb60
4 changed files with 56 additions and 22 deletions

View File

@ -1,3 +1,9 @@
2008-02-22 Gary Burton <gary.burton@zen.co.uk>
* src/DataViews/RelationView.py:
* src/Editors/_EditFamily.py:
* src/Editors/_EditChildRef.py
Fix crash on doubleclicking buttons. Bug #1802
2008-02-22 Douglas S. Blank <dblank@cs.brynmawr.edu> 2008-02-22 Douglas S. Blank <dblank@cs.brynmawr.edu>
* src/DataViews/GrampletView.py: translate "Gramplet" * src/DataViews/GrampletView.py: translate "Gramplet"
* src/plugins/Makefile.am : add AgeOnDate.py QR * src/plugins/Makefile.am : add AgeOnDate.py QR

View File

@ -89,6 +89,8 @@ _SDATA_START = 2
_SDATA_STOP = 4 _SDATA_STOP = 4
_RETURN = gtk.gdk.keyval_from_name("Return") _RETURN = gtk.gdk.keyval_from_name("Return")
_KP_ENTER = gtk.gdk.keyval_from_name("KP_Enter") _KP_ENTER = gtk.gdk.keyval_from_name("KP_Enter")
_LEFT_BUTTON = 1
_RIGHT_BUTTON = 3
class AttachList: class AttachList:
@ -1024,7 +1026,7 @@ class RelationshipView(PageView.PersonNavView):
the collapse state must change, so a parent, siblings id, the collapse state must change, so a parent, siblings id,
family id, family children id, etc family id, family children id, etc
""" """
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 1: if button_activated(event, _LEFT_BUTTON):
person, handle = pair person, handle = pair
if self.collapsed_items.has_key(person.handle): if self.collapsed_items.has_key(person.handle):
if handle in self.collapsed_items[person.handle]: if handle in self.collapsed_items[person.handle]:
@ -1036,9 +1038,9 @@ class RelationshipView(PageView.PersonNavView):
self.redraw() self.redraw()
def _button_press(self, obj, event, handle): def _button_press(self, obj, event, handle):
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 1: if button_activated(event, _LEFT_BUTTON):
self.dbstate.change_active_handle(handle) self.dbstate.change_active_handle(handle)
elif event.type == gtk.gdk.BUTTON_PRESS and event.button == 3: elif button_activated(event, _RIGHT_BUTTON):
myMenu = gtk.Menu() myMenu = gtk.Menu()
myMenu.append(self.build_menu_item(handle)) myMenu.append(self.build_menu_item(handle))
myMenu.popup(None, None, None, event.button, event.time) myMenu.popup(None, None, None, event.button, event.time)
@ -1220,8 +1222,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 \ if button_activated(event, _LEFT_BUTTON):
or event.keyval in (_RETURN, _KP_ENTER):
self.edit_person(obj, handle) self.edit_person(obj, handle)
def edit_person(self, obj, handle): def edit_person(self, obj, handle):
@ -1233,8 +1234,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 \ if button_activated(event, _LEFT_BUTTON):
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)
try: try:
@ -1243,8 +1243,7 @@ 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 \ if button_activated(event, _LEFT_BUTTON):
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
@ -1284,8 +1283,7 @@ 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):
if event.type == gtk.gdk.BUTTON_PRESS \ if button_activated(event, _LEFT_BUTTON):
or event.keyval in (_RETURN, _KP_ENTER):
callback = lambda x: self.callback_add_child(x, handle) callback = lambda x: self.callback_add_child(x, handle)
from Editors import EditPerson from Editors import EditPerson
person = gen.lib.Person() person = gen.lib.Person()
@ -1318,8 +1316,7 @@ 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
if event.type == gtk.gdk.BUTTON_PRESS \ if button_activated(event, _LEFT_BUTTON):
or event.keyval in (_RETURN, _KP_ENTER):
SelectPerson = selector_factory('Person') SelectPerson = selector_factory('Person')
family = self.dbstate.db.get_family_from_handle(handle) family = self.dbstate.db.get_family_from_handle(handle)
# it only makes sense to skip those who are already in the family # it only makes sense to skip those who are already in the family
@ -1335,8 +1332,7 @@ class RelationshipView(PageView.PersonNavView):
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 \ if button_activated(event, _LEFT_BUTTON):
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')
@ -1395,7 +1391,7 @@ class RelationshipView(PageView.PersonNavView):
pass pass
def add_parent_family(self, obj, event, handle): def add_parent_family(self, obj, event, handle):
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 1: if button_activated(event, _LEFT_BUTTON):
from Editors import EditFamily from Editors import EditFamily
family = gen.lib.Family() family = gen.lib.Family()
person = self.dbstate.active person = self.dbstate.active
@ -1410,13 +1406,13 @@ class RelationshipView(PageView.PersonNavView):
pass pass
def delete_family(self, obj, event, handle): def delete_family(self, obj, event, handle):
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 1: if button_activated(event, _LEFT_BUTTON):
gen.utils.remove_parent_from_family(self.dbstate.db, gen.utils.remove_parent_from_family(self.dbstate.db,
self.dbstate.active.handle, self.dbstate.active.handle,
handle) handle)
def delete_parent_family(self, obj, event, handle): def delete_parent_family(self, obj, event, handle):
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 1: if button_activated(event, _LEFT_BUTTON):
gen.utils.remove_child_from_family(self.dbstate.db, gen.utils.remove_child_from_family(self.dbstate.db,
self.dbstate.active.handle, self.dbstate.active.handle,
handle) handle)
@ -1448,3 +1444,13 @@ def has_children(db,p):
if childlist and len(childlist) > 0: if childlist and len(childlist) > 0:
return True return True
return False return False
def button_activated(event, mouse_button):
if (event.type == gtk.gdk.BUTTON_PRESS and \
event.button == mouse_button) or \
(event.type == gtk.gdk.KEY_PRESS and \
event.keyval in (_RETURN, _KP_ENTER)):
return True
else:
return False

View File

@ -62,6 +62,8 @@ from BasicUtils import name_displayer
_RETURN = gtk.gdk.keyval_from_name("Return") _RETURN = gtk.gdk.keyval_from_name("Return")
_KP_ENTER = gtk.gdk.keyval_from_name("KP_Enter") _KP_ENTER = gtk.gdk.keyval_from_name("KP_Enter")
_LEFT_BUTTOGN = 1
_RIGHT_BUTTON = 3
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -152,8 +154,7 @@ class EditChildRef(EditSecondary):
return (_('Child Reference'),_('Child Reference Editor')) return (_('Child Reference'),_('Child Reference Editor'))
def edit_child(self,obj,event): def edit_child(self,obj,event):
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 1 \ if button_activated(event, _LEFT_BUTTON):
or event.keyval in (_RETURN, _KP_ENTER):
from _EditPerson import EditPerson from _EditPerson import EditPerson
handle = self.obj.ref handle = self.obj.ref
try: try:
@ -178,3 +179,13 @@ class EditChildRef(EditSecondary):
if self.callback: if self.callback:
self.callback(self.obj) self.callback(self.obj)
self.close() self.close()
def button_activated(event, mouse_button):
if (event.type == gtk.gdk.BUTTON_PRESS and \
event.button == mouse_button) or \
(event.type == gtk.gdk.KEY_PRESS and \
event.keyval in (_RETURN, _KP_ENTER)):
return True
else:
return False

View File

@ -74,6 +74,8 @@ SelectPerson = selector_factory('Person')
_RETURN = gdk.keyval_from_name("Return") _RETURN = gdk.keyval_from_name("Return")
_KP_ENTER = gdk.keyval_from_name("KP_Enter") _KP_ENTER = gdk.keyval_from_name("KP_Enter")
_LEFT_BUTTON = 1
_RIGHT_BUTTON = 3
class ChildEmbedList(EmbeddedList): class ChildEmbedList(EmbeddedList):
""" """
@ -781,8 +783,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 \ if button_activated(event, _LEFT_BUTTON):
or event.keyval in (_RETURN, _KP_ENTER):
from _EditPerson import EditPerson from _EditPerson import EditPerson
try: try:
person = self.db.get_person_from_handle(handle) person = self.db.get_person_from_handle(handle)
@ -1039,3 +1040,13 @@ class EditFamily(EditPrimary):
else: else:
return ("", "") return ("", "")
return ("", "") return ("", "")
def button_activated(event, mouse_button):
if (event.type == gtk.gdk.BUTTON_PRESS and \
event.button == mouse_button) or \
(event.type == gtk.gdk.KEY_PRESS and \
event.keyval in (_RETURN, _KP_ENTER)):
return True
else:
return False