object sharing support
svn: r6178
This commit is contained in:
parent
4dbe382a67
commit
56e93152d4
@ -1,3 +1,11 @@
|
|||||||
|
2006-03-18 Don Allingham <don@gramps-project.org>
|
||||||
|
* src/Editors/_EditFamily.py: add add_person functionality
|
||||||
|
* src/DisplayTabs.py: add share option to sources
|
||||||
|
* src/glade/gramps.glade: change dialog size
|
||||||
|
* src/ListModel.py: fixed column widths, ellipses
|
||||||
|
* src/SelectEvent.py: grab correct field
|
||||||
|
* src/SelectSource.py: added
|
||||||
|
|
||||||
2006-03-18 Alex Roitman <shura@gramps-project.org>
|
2006-03-18 Alex Roitman <shura@gramps-project.org>
|
||||||
* configure.in: Remove scrollkeeper checks and other unused
|
* configure.in: Remove scrollkeeper checks and other unused
|
||||||
statements.
|
statements.
|
||||||
|
@ -622,16 +622,17 @@ class EventEmbedList(EmbeddedList):
|
|||||||
|
|
||||||
sel = SelectEvent.SelectEvent(self.dbstate.db,"Event Select")
|
sel = SelectEvent.SelectEvent(self.dbstate.db,"Event Select")
|
||||||
event = sel.run()
|
event = sel.run()
|
||||||
try:
|
if event:
|
||||||
ref = RelLib.EventRef()
|
try:
|
||||||
if self.obj.__class__.__name__ == 'Person':
|
ref = RelLib.EventRef()
|
||||||
ref.set_role((RelLib.EventRef.PRIMARY,''))
|
if self.obj.__class__.__name__ == 'Person':
|
||||||
else:
|
ref.set_role((RelLib.EventRef.PRIMARY,''))
|
||||||
ref.set_role((RelLib.EventRef.FAMILY,''))
|
else:
|
||||||
EditEventRef(self.dbstate,self.uistate,self.track,
|
ref.set_role((RelLib.EventRef.FAMILY,''))
|
||||||
event, ref, self.obj, self.event_added)
|
EditEventRef(self.dbstate,self.uistate,self.track,
|
||||||
except Errors.WindowActiveError:
|
event, ref, self.obj, self.event_added)
|
||||||
pass
|
except Errors.WindowActiveError:
|
||||||
|
pass
|
||||||
|
|
||||||
def edit_button_clicked(self,obj):
|
def edit_button_clicked(self,obj):
|
||||||
ref = self.get_selected()
|
ref = self.get_selected()
|
||||||
@ -1371,7 +1372,7 @@ class SourceEmbedList(EmbeddedList):
|
|||||||
def __init__(self,dbstate,uistate,track,obj):
|
def __init__(self,dbstate,uistate,track,obj):
|
||||||
self.obj = obj
|
self.obj = obj
|
||||||
EmbeddedList.__init__(self, dbstate, uistate, track,
|
EmbeddedList.__init__(self, dbstate, uistate, track,
|
||||||
_('Sources'), SourceRefModel)
|
_('Sources'), SourceRefModel, True)
|
||||||
|
|
||||||
def get_icon_name(self):
|
def get_icon_name(self):
|
||||||
return 'gramps-event'
|
return 'gramps-event'
|
||||||
@ -1393,6 +1394,21 @@ class SourceEmbedList(EmbeddedList):
|
|||||||
except Errors.WindowActiveError:
|
except Errors.WindowActiveError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
def share_button_clicked(self,obj):
|
||||||
|
from Editors import EditSourceRef
|
||||||
|
import SelectSource
|
||||||
|
|
||||||
|
sel = SelectSource.SelectSource(self.dbstate.db,"Source Select")
|
||||||
|
src = sel.run()
|
||||||
|
sref = RelLib.SourceRef()
|
||||||
|
if src:
|
||||||
|
try:
|
||||||
|
ref = RelLib.SourceRef()
|
||||||
|
EditSourceRef(self.dbstate,self.uistate,self.track,
|
||||||
|
src, sref, self.add_callback)
|
||||||
|
except Errors.WindowActiveError:
|
||||||
|
pass
|
||||||
|
|
||||||
def add_callback(self,reference, primary):
|
def add_callback(self,reference, primary):
|
||||||
self.get_data().append(reference)
|
self.get_data().append(reference)
|
||||||
self.changed = True
|
self.changed = True
|
||||||
|
@ -105,7 +105,7 @@ class ChildEmbedList(EmbeddedList):
|
|||||||
"""
|
"""
|
||||||
self.family = family
|
self.family = family
|
||||||
EmbeddedList.__init__(self, dbstate, uistate, track,
|
EmbeddedList.__init__(self, dbstate, uistate, track,
|
||||||
_('Children'), ChildModel)
|
_('Children'), ChildModel, True)
|
||||||
|
|
||||||
def find_index(self,obj):
|
def find_index(self,obj):
|
||||||
"""
|
"""
|
||||||
@ -184,41 +184,67 @@ class ChildEmbedList(EmbeddedList):
|
|||||||
return [(1,0),(1,1),(1,2),(1,3),(1,4),(1,5),(1,6),(0,8),(0,9)]
|
return [(1,0),(1,1),(1,2),(1,3),(1,4),(1,5),(1,6),(0,8),(0,9)]
|
||||||
|
|
||||||
def add_button_clicked(self,obj):
|
def add_button_clicked(self,obj):
|
||||||
# we could workout the death years of the parents here and
|
from Editors import EditPerson
|
||||||
# set a suitable filter_spec on the PersonSelector
|
|
||||||
# we might also be able to set a filter that only includes
|
|
||||||
# people that are not already listed as children in another
|
|
||||||
# family.
|
|
||||||
selector = PersonSelector(self.dbstate,self.uistate,self.track)
|
|
||||||
|
|
||||||
# this need the window handle of the main EditFamily window
|
person = RelLib.Person()
|
||||||
# to make the PersonSelector transient to it. I am not sure
|
EditPerson(self.dbstate,self.uistate,[],person, self.new_child_added)
|
||||||
# want the best way is to get that handle from here.
|
|
||||||
#selector.set_transient_for(self.window)
|
|
||||||
|
|
||||||
# Connect this to the method used to add a new child.
|
def new_child_added(self, person):
|
||||||
#selector.connect('add-object',self.on_add_child)
|
self.family.add_child_handle(person.get_handle())
|
||||||
|
self.rebuild()
|
||||||
|
|
||||||
|
def share_button_clicked(self,obj):
|
||||||
|
from SelectPerson import SelectPerson
|
||||||
|
|
||||||
|
# it only makes sense to skip those who are already in the family
|
||||||
|
|
||||||
selector.connect('add-object',self.on_change_child)
|
skip = [self.family.get_father_handle(),
|
||||||
|
self.family.get_mother_handle()] + self.family.get_child_handle_list()
|
||||||
|
|
||||||
def on_change_child(self, selector_window, obj):
|
sel = SelectPerson(self.dbstate.db, "Select Child",
|
||||||
if obj.__class__ == RelLib.Person:
|
skip=[ x for x in skip if x])
|
||||||
try:
|
person = sel.run()
|
||||||
person = obj
|
|
||||||
self.family.add_child_handle(person.get_handle())
|
if person:
|
||||||
self.rebuild()
|
self.family.add_child_handle(person.get_handle())
|
||||||
except:
|
self.rebuild()
|
||||||
log.warn(
|
|
||||||
"Failed to update child: \n"
|
# def add_button_clicked(self,obj):
|
||||||
"obj returned from selector was: %s\n"
|
# # we could workout the death years of the parents here and
|
||||||
% (repr(obj),))
|
# # set a suitable filter_spec on the PersonSelector
|
||||||
raise
|
# # we might also be able to set a filter that only includes
|
||||||
else:
|
# # people that are not already listed as children in another
|
||||||
log.warn(
|
# # family.
|
||||||
"Object selector returned obj.__class__ = %s, it should "
|
# selector = PersonSelector(self.dbstate,self.uistate,self.track)
|
||||||
"have been of type %s." % (obj.__class__.__name__,
|
|
||||||
RelLib.Person.__name__))
|
# # this need the window handle of the main EditFamily window
|
||||||
selector_window.close()
|
# # to make the PersonSelector transient to it. I am not sure
|
||||||
|
# # want the best way is to get that handle from here.
|
||||||
|
# #selector.set_transient_for(self.window)
|
||||||
|
|
||||||
|
# # Connect this to the method used to add a new child.
|
||||||
|
# #selector.connect('add-object',self.on_add_child)
|
||||||
|
|
||||||
|
# selector.connect('add-object',self.on_change_child)
|
||||||
|
|
||||||
|
# def on_change_child(self, selector_window, obj):
|
||||||
|
# if obj.__class__ == RelLib.Person:
|
||||||
|
# try:
|
||||||
|
# person = obj
|
||||||
|
# self.family.add_child_handle(person.get_handle())
|
||||||
|
# self.rebuild()
|
||||||
|
# except:
|
||||||
|
# log.warn(
|
||||||
|
# "Failed to update child: \n"
|
||||||
|
# "obj returned from selector was: %s\n"
|
||||||
|
# % (repr(obj),))
|
||||||
|
# raise
|
||||||
|
# else:
|
||||||
|
# log.warn(
|
||||||
|
# "Object selector returned obj.__class__ = %s, it should "
|
||||||
|
# "have been of type %s." % (obj.__class__.__name__,
|
||||||
|
# RelLib.Person.__name__))
|
||||||
|
# selector_window.close()
|
||||||
|
|
||||||
def del_button_clicked(self,obj):
|
def del_button_clicked(self,obj):
|
||||||
handle = self.get_selected()
|
handle = self.get_selected()
|
||||||
|
@ -18,8 +18,8 @@
|
|||||||
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
#
|
#
|
||||||
|
|
||||||
from gobject import TYPE_STRING, TYPE_PYOBJECT, TYPE_OBJECT, TYPE_BOOLEAN
|
|
||||||
import gtk
|
import gtk
|
||||||
|
import pango
|
||||||
import const
|
import const
|
||||||
|
|
||||||
gtk26 = gtk.pygtk_version >= (2,6,0)
|
gtk26 = gtk.pygtk_version >= (2,6,0)
|
||||||
@ -39,15 +39,16 @@ class ListModel:
|
|||||||
def __init__(self,tree,dlist,select_func=None,
|
def __init__(self,tree,dlist,select_func=None,
|
||||||
event_func=None,mode=gtk.SELECTION_SINGLE):
|
event_func=None,mode=gtk.SELECTION_SINGLE):
|
||||||
self.tree = tree
|
self.tree = tree
|
||||||
|
self.tree.set_fixed_height_mode(True)
|
||||||
self.mylist = []
|
self.mylist = []
|
||||||
self.data_index = 0
|
self.data_index = 0
|
||||||
for l in dlist:
|
for l in dlist:
|
||||||
if len(l)>3 and l[3] == TOGGLE:
|
if len(l)>3 and l[3] == TOGGLE:
|
||||||
self.mylist.append(TYPE_BOOLEAN)
|
self.mylist.append(bool)
|
||||||
else:
|
else:
|
||||||
self.mylist.append(TYPE_STRING)
|
self.mylist.append(str)
|
||||||
self.data_index += 1
|
self.data_index += 1
|
||||||
self.mylist.append(TYPE_PYOBJECT)
|
self.mylist.append(object)
|
||||||
|
|
||||||
self.function = {}
|
self.function = {}
|
||||||
self.tree.set_rules_hint(True)
|
self.tree.set_rules_hint(True)
|
||||||
@ -62,6 +63,9 @@ class ListModel:
|
|||||||
|
|
||||||
cnum = 0
|
cnum = 0
|
||||||
for name in dlist:
|
for name in dlist:
|
||||||
|
if not name[2]:
|
||||||
|
continue
|
||||||
|
|
||||||
if len(name) == 3:
|
if len(name) == 3:
|
||||||
name = (name[0],name[1],name[2],TEXT,False, None)
|
name = (name[0],name[1],name[2],TEXT,False, None)
|
||||||
elif len(name) == 4:
|
elif len(name) == 4:
|
||||||
@ -73,7 +77,7 @@ class ListModel:
|
|||||||
column.add_attribute(renderer,'active',cnum)
|
column.add_attribute(renderer,'active',cnum)
|
||||||
elif gtk26 and name[3] == COMBO:
|
elif gtk26 and name[3] == COMBO:
|
||||||
store = gtk.ListStore(str)
|
store = gtk.ListStore(str)
|
||||||
model = gtk.ListStore(str,TYPE_OBJECT)
|
model = gtk.ListStore(str, object)
|
||||||
for val in name[4]:
|
for val in name[4]:
|
||||||
model.append((val,store))
|
model.append((val,store))
|
||||||
self.function[cnum] = name[5]
|
self.function[cnum] = name[5]
|
||||||
@ -88,6 +92,7 @@ class ListModel:
|
|||||||
else:
|
else:
|
||||||
renderer = gtk.CellRendererText()
|
renderer = gtk.CellRendererText()
|
||||||
renderer.set_fixed_height_from_font(True)
|
renderer.set_fixed_height_from_font(True)
|
||||||
|
renderer.set_property('ellipsize', pango.ELLIPSIZE_END)
|
||||||
if name[5]:
|
if name[5]:
|
||||||
renderer.set_property('editable',True)
|
renderer.set_property('editable',True)
|
||||||
renderer.connect('edited',self.edited_cb, cnum)
|
renderer.connect('edited',self.edited_cb, cnum)
|
||||||
@ -108,6 +113,9 @@ class ListModel:
|
|||||||
column.set_clickable(True)
|
column.set_clickable(True)
|
||||||
column.set_sort_column_id(name[1])
|
column.set_sort_column_id(name[1])
|
||||||
|
|
||||||
|
column.set_sizing(gtk.TREE_VIEW_COLUMN_FIXED)
|
||||||
|
column.set_fixed_width(name[2])
|
||||||
|
|
||||||
cnum += 1
|
cnum += 1
|
||||||
self.cids.append(name[1])
|
self.cids.append(name[1])
|
||||||
if name[0] != '':
|
if name[0] != '':
|
||||||
|
@ -64,9 +64,8 @@ class SelectEvent:
|
|||||||
|
|
||||||
Utils.set_titles(self.top,title_label,title)
|
Utils.set_titles(self.top,title_label,title)
|
||||||
|
|
||||||
titles = [(_('Description'),4,150), (_('ID'),1,50),
|
titles = [(_('Description'),4,250), (_('ID'),1,75),
|
||||||
(_('Type'),2,70), (_('Date'),3,50), (_('Place'),3,150),
|
(_('Type'),2,75), (_('Date'),3,150), ('',4,0) ]
|
||||||
(_('Cause'),3,50), ('',4,0) ]
|
|
||||||
self.ncols = len(titles)
|
self.ncols = len(titles)
|
||||||
|
|
||||||
self.model = ListModel.ListModel(self.elist,titles)
|
self.model = ListModel.ListModel(self.elist,titles)
|
||||||
@ -98,7 +97,7 @@ class SelectEvent:
|
|||||||
pname = u''
|
pname = u''
|
||||||
date = DateHandler.get_date(event)
|
date = DateHandler.get_date(event)
|
||||||
cause = event.get_cause()
|
cause = event.get_cause()
|
||||||
self.model.add([desc,the_id,name,date,pname,cause],handle)
|
self.model.add([desc,the_id,name,date],handle)
|
||||||
|
|
||||||
self.model.connect_model()
|
self.model.connect_model()
|
||||||
|
|
||||||
@ -109,7 +108,7 @@ class SelectEvent:
|
|||||||
store,node = self.model.get_selected()
|
store,node = self.model.get_selected()
|
||||||
if node:
|
if node:
|
||||||
data = self.model.get_data(node,range(self.ncols))
|
data = self.model.get_data(node,range(self.ncols))
|
||||||
handle = data[6]
|
handle = data[4]
|
||||||
return_value = self.db.get_event_from_handle(handle)
|
return_value = self.db.get_event_from_handle(handle)
|
||||||
else:
|
else:
|
||||||
return_value = None
|
return_value = None
|
||||||
|
104
src/SelectSource.py
Normal file
104
src/SelectSource.py
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
#
|
||||||
|
# Gramps - a GTK+/GNOME based genealogy program
|
||||||
|
#
|
||||||
|
# Copyright (C) 2003-2005 Donald N. Allingham
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
#
|
||||||
|
|
||||||
|
# $Id: SelectEvent.py 6155 2006-03-16 20:24:27Z rshura $
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# internationalization
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
from TransUtils import sgettext as _
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# GTK/Gnome modules
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
import gtk
|
||||||
|
import gtk.glade
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# gramps modules
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
import const
|
||||||
|
import Utils
|
||||||
|
import ListModel
|
||||||
|
import RelLib
|
||||||
|
import DateHandler
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# SelectEvent
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
class SelectSource:
|
||||||
|
|
||||||
|
def __init__(self,db,title,parent_window=None):
|
||||||
|
|
||||||
|
self.db = db
|
||||||
|
self.glade = gtk.glade.XML(const.gladeFile,"select_person","gramps")
|
||||||
|
self.top = self.glade.get_widget('select_person')
|
||||||
|
title_label = self.glade.get_widget('title')
|
||||||
|
self.elist = self.glade.get_widget('plist')
|
||||||
|
|
||||||
|
Utils.set_titles(self.top,title_label,title)
|
||||||
|
|
||||||
|
titles = [(_('Title'),4,350), (_('ID'),1,50), ('',0,0)]
|
||||||
|
self.ncols = len(titles)
|
||||||
|
|
||||||
|
self.model = ListModel.ListModel(self.elist,titles)
|
||||||
|
|
||||||
|
self.redraw()
|
||||||
|
self.top.show()
|
||||||
|
|
||||||
|
if parent_window:
|
||||||
|
self.top.set_transient_for(parent_window)
|
||||||
|
|
||||||
|
def redraw(self):
|
||||||
|
self.model.clear()
|
||||||
|
self.model.new_model()
|
||||||
|
|
||||||
|
for handle in self.db.get_source_handles():
|
||||||
|
source = self.db.get_source_from_handle(handle)
|
||||||
|
desc = source.get_title()
|
||||||
|
the_id = source.get_gramps_id()
|
||||||
|
self.model.add([desc,the_id,handle])
|
||||||
|
self.model.connect_model()
|
||||||
|
|
||||||
|
def run(self):
|
||||||
|
val = self.top.run()
|
||||||
|
|
||||||
|
if val == gtk.RESPONSE_OK:
|
||||||
|
store,node = self.model.get_selected()
|
||||||
|
if node:
|
||||||
|
data = self.model.get_data(node,range(self.ncols))
|
||||||
|
handle = data[2]
|
||||||
|
return_value = self.db.get_source_from_handle(handle)
|
||||||
|
else:
|
||||||
|
return_value = None
|
||||||
|
self.top.destroy()
|
||||||
|
return return_value
|
||||||
|
else:
|
||||||
|
self.top.destroy()
|
||||||
|
return None
|
@ -4023,7 +4023,7 @@ Text Beside Icons</property>
|
|||||||
<property name="type">GTK_WINDOW_TOPLEVEL</property>
|
<property name="type">GTK_WINDOW_TOPLEVEL</property>
|
||||||
<property name="window_position">GTK_WIN_POS_CENTER_ON_PARENT</property>
|
<property name="window_position">GTK_WIN_POS_CENTER_ON_PARENT</property>
|
||||||
<property name="modal">True</property>
|
<property name="modal">True</property>
|
||||||
<property name="default_width">500</property>
|
<property name="default_width">600</property>
|
||||||
<property name="default_height">450</property>
|
<property name="default_height">450</property>
|
||||||
<property name="resizable">True</property>
|
<property name="resizable">True</property>
|
||||||
<property name="destroy_with_parent">False</property>
|
<property name="destroy_with_parent">False</property>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user