2007-09-11 Don Allingham <don@gramps-project.org>
* src/PageView.py: add some documentation svn: r8962
This commit is contained in:
parent
fd5bb08aa3
commit
55d5734423
@ -1,3 +1,6 @@
|
|||||||
|
2007-09-11 Don Allingham <don@gramps-project.org>
|
||||||
|
* src/PageView.py: add some documentation
|
||||||
|
|
||||||
2007-09-08 Benny Malengier <benny.malengier@gramps-project.org>
|
2007-09-08 Benny Malengier <benny.malengier@gramps-project.org>
|
||||||
* src/PageView.py : cleanup
|
* src/PageView.py : cleanup
|
||||||
* src/QuickReports.py: fix error getting source handle
|
* src/QuickReports.py: fix error getting source handle
|
||||||
|
250
src/PageView.py
250
src/PageView.py
@ -20,6 +20,10 @@
|
|||||||
|
|
||||||
# $Id$
|
# $Id$
|
||||||
|
|
||||||
|
"""
|
||||||
|
Provide the base classes for GRAMPS' DataView classes
|
||||||
|
"""
|
||||||
|
|
||||||
#----------------------------------------------------------------
|
#----------------------------------------------------------------
|
||||||
#
|
#
|
||||||
# python
|
# python
|
||||||
@ -55,12 +59,17 @@ NAVIGATION_PERSON = 0
|
|||||||
|
|
||||||
EMPTY_SEARCH = (0, '', False)
|
EMPTY_SEARCH = (0, '', False)
|
||||||
|
|
||||||
#----------------------------------------------------------------
|
#------------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
# PageView
|
# PageView
|
||||||
#
|
#
|
||||||
#----------------------------------------------------------------
|
#------------------------------------------------------------------------------
|
||||||
class PageView:
|
class PageView:
|
||||||
|
"""
|
||||||
|
The PageView class is the base class for all Data Views in GRAMPS. All
|
||||||
|
Views should derive from this class. The ViewManager understands the public
|
||||||
|
interface of this class
|
||||||
|
"""
|
||||||
|
|
||||||
def __init__(self, title, dbstate, uistate):
|
def __init__(self, title, dbstate, uistate):
|
||||||
self.title = title
|
self.title = title
|
||||||
@ -73,21 +82,29 @@ class PageView:
|
|||||||
self.additional_uis = []
|
self.additional_uis = []
|
||||||
self.widget = None
|
self.widget = None
|
||||||
self.model = None
|
self.model = None
|
||||||
self.ui = '<ui></ui>'
|
self.ui_def = '<ui></ui>'
|
||||||
self.dbstate.connect('no-database',self.disable_action_group)
|
self.dbstate.connect('no-database', self.disable_action_group)
|
||||||
self.dbstate.connect('database-changed',self.enable_action_group)
|
self.dbstate.connect('database-changed', self.enable_action_group)
|
||||||
self.dirty = True
|
self.dirty = True
|
||||||
self.active = False
|
self.active = False
|
||||||
self.handle_col = 0
|
self.handle_col = 0
|
||||||
self.selection = None
|
self.selection = None
|
||||||
|
self.func_list = {}
|
||||||
|
|
||||||
def call_function(self, key):
|
def call_function(self, key):
|
||||||
|
"""
|
||||||
|
Calls the function associated with the key value
|
||||||
|
"""
|
||||||
self.func_list.get(key)()
|
self.func_list.get(key)()
|
||||||
|
|
||||||
def post(self):
|
def post(self):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def set_active(self):
|
def set_active(self):
|
||||||
|
"""
|
||||||
|
Called with the PageView is set as active. If the page is "dirty",
|
||||||
|
then we rebuild the data.
|
||||||
|
"""
|
||||||
self.active = True
|
self.active = True
|
||||||
if self.dirty:
|
if self.dirty:
|
||||||
self.uistate.set_busy_cursor(True)
|
self.uistate.set_busy_cursor(True)
|
||||||
@ -95,49 +112,97 @@ class PageView:
|
|||||||
self.uistate.set_busy_cursor(False)
|
self.uistate.set_busy_cursor(False)
|
||||||
|
|
||||||
def set_inactive(self):
|
def set_inactive(self):
|
||||||
|
"""
|
||||||
|
Marks page as being active (currently displayed)
|
||||||
|
"""
|
||||||
self.active = False
|
self.active = False
|
||||||
|
|
||||||
def build_tree(self):
|
def build_tree(self):
|
||||||
pass
|
"""
|
||||||
|
Rebuilds the current display. This must be overridden by the derived
|
||||||
|
class.
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
def navigation_type(self):
|
def navigation_type(self):
|
||||||
|
"""
|
||||||
|
Indictates the navigation type. Currently, we only support navigation
|
||||||
|
for views that are Person centric.
|
||||||
|
"""
|
||||||
return NAVIGATION_NONE
|
return NAVIGATION_NONE
|
||||||
|
|
||||||
def ui_definition(self):
|
def ui_definition(self):
|
||||||
return self.ui
|
"""
|
||||||
|
returns the XML UI definition for the UIManager
|
||||||
|
"""
|
||||||
|
return self.ui_def
|
||||||
|
|
||||||
def additional_ui_definitions(self):
|
def additional_ui_definitions(self):
|
||||||
|
"""
|
||||||
|
Returns any additional interfaces for the UIManager that the view
|
||||||
|
needs to define.
|
||||||
|
"""
|
||||||
return self.additional_uis
|
return self.additional_uis
|
||||||
|
|
||||||
def disable_action_group(self):
|
def disable_action_group(self):
|
||||||
|
"""
|
||||||
|
Turns off the visibility of the View's action group, if defined
|
||||||
|
"""
|
||||||
if self.action_group:
|
if self.action_group:
|
||||||
self.action_group.set_visible(False)
|
self.action_group.set_visible(False)
|
||||||
|
|
||||||
def enable_action_group(self,obj):
|
def enable_action_group(self, obj):
|
||||||
|
"""
|
||||||
|
Turns on the visibility of the View's action group, if defined
|
||||||
|
"""
|
||||||
if self.action_group:
|
if self.action_group:
|
||||||
self.action_group.set_visible(True)
|
self.action_group.set_visible(True)
|
||||||
|
|
||||||
def get_stock(self):
|
def get_stock(self):
|
||||||
try:
|
"""
|
||||||
return gtk.STOCK_MEDIA_MISSING
|
Returns image associated with the view, which is used for the
|
||||||
except AttributeError:
|
icon for the button.
|
||||||
|
"""
|
||||||
return gtk.STOCK_MISSING_IMAGE
|
return gtk.STOCK_MISSING_IMAGE
|
||||||
|
|
||||||
def get_title(self):
|
def get_title(self):
|
||||||
|
"""
|
||||||
|
Returns the title of the view. This is used to define the text for the
|
||||||
|
button, and for the tab label.
|
||||||
|
"""
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
def get_display(self):
|
def get_display(self):
|
||||||
|
"""
|
||||||
|
Builds the graphical display, returning the top level widget.
|
||||||
|
"""
|
||||||
if not self.widget:
|
if not self.widget:
|
||||||
self.widget = self.build_widget()
|
self.widget = self.build_widget()
|
||||||
return self.widget
|
return self.widget
|
||||||
|
|
||||||
def build_widget(self):
|
def build_widget(self):
|
||||||
assert False
|
"""
|
||||||
|
Builds the container widget for the interface. Must be overridden by the
|
||||||
|
the base class. Returns a gtk container widget.
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
def define_actions(self):
|
def define_actions(self):
|
||||||
assert False
|
"""
|
||||||
|
Defines the UIManager actions. Called by the ViewManager to set up the
|
||||||
|
View. The user typically defines self.action_list and
|
||||||
|
self.action_toggle_list in this function.
|
||||||
|
|
||||||
def _build_action_group(self):
|
Derived classes must override this function.
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def __build_action_group(self):
|
||||||
|
"""
|
||||||
|
Creates an UIManager ActionGroup from the values in self.action_list
|
||||||
|
and self.action_toggle_list. The user should define these in
|
||||||
|
self.define_actions
|
||||||
|
"""
|
||||||
self.action_group = gtk.ActionGroup(self.title)
|
self.action_group = gtk.ActionGroup(self.title)
|
||||||
if len(self.action_list) > 0:
|
if len(self.action_list) > 0:
|
||||||
self.action_group.add_actions(self.action_list)
|
self.action_group.add_actions(self.action_list)
|
||||||
@ -146,53 +211,62 @@ class PageView:
|
|||||||
|
|
||||||
def add_action(self, name, stock_icon, label, accel=None, tip=None,
|
def add_action(self, name, stock_icon, label, accel=None, tip=None,
|
||||||
callback=None):
|
callback=None):
|
||||||
self.action_list.append((name,stock_icon,label,accel,tip,callback))
|
self.action_list.append((name, stock_icon, label, accel, tip, callback))
|
||||||
|
|
||||||
def add_toggle_action(self, name, stock_icon, label, accel=None,
|
def add_toggle_action(self, name, stock_icon, label, accel=None,
|
||||||
tip=None, callback=None, value=False):
|
tip=None, callback=None, value=False):
|
||||||
self.action_toggle_list.append((name,stock_icon,label,accel,
|
self.action_toggle_list.append((name, stock_icon, label, accel,
|
||||||
tip,callback,value))
|
tip, callback, value))
|
||||||
|
|
||||||
def get_actions(self):
|
def get_actions(self):
|
||||||
if not self.action_group:
|
if not self.action_group:
|
||||||
self._build_action_group()
|
self.__build_action_group()
|
||||||
return [self.action_group] + self.additional_action_groups
|
return [self.action_group] + self.additional_action_groups
|
||||||
|
|
||||||
def add_action_group(self,group):
|
def add_action_group(self, group):
|
||||||
self.additional_action_groups.append(group)
|
self.additional_action_groups.append(group)
|
||||||
|
|
||||||
def change_page(self):
|
def change_page(self):
|
||||||
self.uistate.clear_filter_results()
|
self.uistate.clear_filter_results()
|
||||||
|
|
||||||
def edit(self,obj):
|
def edit(self, obj):
|
||||||
pass
|
"""
|
||||||
|
Template function to allow the editing of the selected object
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
def remove(self,obj):
|
def remove(self, obj):
|
||||||
pass
|
"""
|
||||||
|
Template function to allow the removal of the selected object
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
def add(self,obj):
|
def add(self, obj):
|
||||||
pass
|
"""
|
||||||
|
Template function to allow the adding of a new object
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
def key_press(self,obj,event):
|
def key_press(self, obj, event):
|
||||||
#act if no modifier, and allow Num Lock as MOD2_MASK
|
#act if no modifier, and allow Num Lock as MOD2_MASK
|
||||||
if not event.state or event.state in (gtk.gdk.MOD2_MASK,):
|
if not event.state or event.state in (gtk.gdk.MOD2_MASK, ):
|
||||||
if event.keyval in (gtk.keysyms.Return, gtk.keysyms.KP_Enter):
|
if event.keyval in (gtk.keysyms.Return, gtk.keysyms.KP_Enter):
|
||||||
self.edit(obj)
|
self.edit(obj)
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def blist(self,store,path,iter,sel_list):
|
def blist(self, store, path, node, sel_list):
|
||||||
handle = store.get_value(iter,self.handle_col)
|
handle = store.get_value(node, self.handle_col)
|
||||||
sel_list.append(handle)
|
sel_list.append(handle)
|
||||||
|
|
||||||
def selected_handles(self):
|
def selected_handles(self):
|
||||||
mlist = []
|
mlist = []
|
||||||
self.selection.selected_foreach(self.blist,mlist)
|
self.selection.selected_foreach(self.blist, mlist)
|
||||||
return mlist
|
return mlist
|
||||||
|
|
||||||
def first_selected(self):
|
def first_selected(self):
|
||||||
mlist = []
|
mlist = []
|
||||||
self.selection.selected_foreach(self.blist,mlist)
|
self.selection.selected_foreach(self.blist, mlist)
|
||||||
if mlist:
|
if mlist:
|
||||||
return mlist[0]
|
return mlist[0]
|
||||||
else:
|
else:
|
||||||
@ -206,7 +280,7 @@ class BookMarkView(PageView):
|
|||||||
self.setup_bookmarks(bookmarks)
|
self.setup_bookmarks(bookmarks)
|
||||||
|
|
||||||
def goto_handle(self, obj):
|
def goto_handle(self, obj):
|
||||||
pass
|
raise NotImplementedError
|
||||||
|
|
||||||
def setup_bookmarks(self, bookmarks):
|
def setup_bookmarks(self, bookmarks):
|
||||||
self.bookmarks = self.bm_type(
|
self.bookmarks = self.bm_type(
|
||||||
@ -247,9 +321,9 @@ class BookMarkView(PageView):
|
|||||||
def define_actions(self):
|
def define_actions(self):
|
||||||
self.book_action = gtk.ActionGroup(self.title + '/Bookmark')
|
self.book_action = gtk.ActionGroup(self.title + '/Bookmark')
|
||||||
self.book_action.add_actions([
|
self.book_action.add_actions([
|
||||||
('AddBook','gramps-bookmark-new', _('_Add bookmark'),'<control>d',None,
|
('AddBook', 'gramps-bookmark-new', _('_Add bookmark'), '<control>d', None,
|
||||||
self.add_bookmark),
|
self.add_bookmark),
|
||||||
('EditBook','gramps-bookmark-edit', _('_Edit bookmarks'),'<control>b',None,
|
('EditBook', 'gramps-bookmark-edit', _('_Edit bookmarks'), '<control>b', None,
|
||||||
self.edit_bookmarks),
|
self.edit_bookmarks),
|
||||||
])
|
])
|
||||||
|
|
||||||
@ -262,7 +336,7 @@ class BookMarkView(PageView):
|
|||||||
#----------------------------------------------------------------
|
#----------------------------------------------------------------
|
||||||
class PersonNavView(BookMarkView):
|
class PersonNavView(BookMarkView):
|
||||||
|
|
||||||
def __init__(self,title,dbstate,uistate, callback=None):
|
def __init__(self, title, dbstate, uistate, callback=None):
|
||||||
BookMarkView.__init__(self, title, dbstate, uistate,
|
BookMarkView.__init__(self, title, dbstate, uistate,
|
||||||
dbstate.db.get_bookmarks(),
|
dbstate.db.get_bookmarks(),
|
||||||
Bookmarks.Bookmarks)
|
Bookmarks.Bookmarks)
|
||||||
@ -277,7 +351,7 @@ class PersonNavView(BookMarkView):
|
|||||||
|
|
||||||
self.fwd_action = gtk.ActionGroup(self.title + '/Forward')
|
self.fwd_action = gtk.ActionGroup(self.title + '/Forward')
|
||||||
self.fwd_action.add_actions([
|
self.fwd_action.add_actions([
|
||||||
('Forward',gtk.STOCK_GO_FORWARD,_("_Forward"),
|
('Forward', gtk.STOCK_GO_FORWARD, _("_Forward"),
|
||||||
"<ALT>Right", _("Go to the next person in the history"),
|
"<ALT>Right", _("Go to the next person in the history"),
|
||||||
self.fwd_clicked)
|
self.fwd_clicked)
|
||||||
])
|
])
|
||||||
@ -285,7 +359,7 @@ class PersonNavView(BookMarkView):
|
|||||||
# add the Backward action group to handle the Forward button
|
# add the Backward action group to handle the Forward button
|
||||||
self.back_action = gtk.ActionGroup(self.title + '/Backward')
|
self.back_action = gtk.ActionGroup(self.title + '/Backward')
|
||||||
self.back_action.add_actions([
|
self.back_action.add_actions([
|
||||||
('Back',gtk.STOCK_GO_BACK,_("_Back"),
|
('Back', gtk.STOCK_GO_BACK, _("_Back"),
|
||||||
"<ALT>Left", _("Go to the previous person in the history"),
|
"<ALT>Left", _("Go to the previous person in the history"),
|
||||||
self.back_clicked)
|
self.back_clicked)
|
||||||
])
|
])
|
||||||
@ -317,13 +391,13 @@ class PersonNavView(BookMarkView):
|
|||||||
self.fwd_action.set_visible(False)
|
self.fwd_action.set_visible(False)
|
||||||
self.back_action.set_visible(False)
|
self.back_action.set_visible(False)
|
||||||
|
|
||||||
def enable_action_group(self,obj):
|
def enable_action_group(self, obj):
|
||||||
"""
|
"""
|
||||||
Normally, this would not be overridden from the base class. However,
|
Normally, this would not be overridden from the base class. However,
|
||||||
in this case, we have additional action groups that need to be
|
in this case, we have additional action groups that need to be
|
||||||
handled correctly.
|
handled correctly.
|
||||||
"""
|
"""
|
||||||
BookMarkView.enable_action_group(self,obj)
|
BookMarkView.enable_action_group(self, obj)
|
||||||
|
|
||||||
self.fwd_action.set_visible(True)
|
self.fwd_action.set_visible(True)
|
||||||
self.back_action.set_visible(True)
|
self.back_action.set_visible(True)
|
||||||
@ -331,18 +405,18 @@ class PersonNavView(BookMarkView):
|
|||||||
self.fwd_action.set_sensitive(not hobj.at_end())
|
self.fwd_action.set_sensitive(not hobj.at_end())
|
||||||
self.back_action.set_sensitive(not hobj.at_front())
|
self.back_action.set_sensitive(not hobj.at_front())
|
||||||
|
|
||||||
def set_default_person(self,obj):
|
def set_default_person(self, obj):
|
||||||
active = self.dbstate.active
|
active = self.dbstate.active
|
||||||
if active:
|
if active:
|
||||||
self.dbstate.db.set_default_person_handle(active.get_handle())
|
self.dbstate.db.set_default_person_handle(active.get_handle())
|
||||||
|
|
||||||
def home(self,obj):
|
def home(self, obj):
|
||||||
defperson = self.dbstate.db.get_default_person()
|
defperson = self.dbstate.db.get_default_person()
|
||||||
if defperson:
|
if defperson:
|
||||||
self.dbstate.change_active_person(defperson)
|
self.dbstate.change_active_person(defperson)
|
||||||
|
|
||||||
def jump(self):
|
def jump(self):
|
||||||
dialog = gtk.Dialog(_('Jump to by GRAMPS ID'),None,
|
dialog = gtk.Dialog(_('Jump to by GRAMPS ID'), None,
|
||||||
gtk.DIALOG_NO_SEPARATOR)
|
gtk.DIALOG_NO_SEPARATOR)
|
||||||
dialog.set_border_width(12)
|
dialog.set_border_width(12)
|
||||||
label = gtk.Label('<span weight="bold" size="larger">%s</span>' % _('Jump to by GRAMPS ID'))
|
label = gtk.Label('<span weight="bold" size="larger">%s</span>' % _('Jump to by GRAMPS ID'))
|
||||||
@ -351,11 +425,11 @@ class PersonNavView(BookMarkView):
|
|||||||
dialog.vbox.set_spacing(10)
|
dialog.vbox.set_spacing(10)
|
||||||
dialog.vbox.set_border_width(12)
|
dialog.vbox.set_border_width(12)
|
||||||
hbox = gtk.HBox()
|
hbox = gtk.HBox()
|
||||||
hbox.pack_start(gtk.Label("%s: " % _('ID')),False)
|
hbox.pack_start(gtk.Label("%s: " % _('ID')), False)
|
||||||
text = gtk.Entry()
|
text = gtk.Entry()
|
||||||
text.set_activates_default(True)
|
text.set_activates_default(True)
|
||||||
hbox.pack_start(text,False)
|
hbox.pack_start(text, False)
|
||||||
dialog.vbox.pack_start(hbox,False)
|
dialog.vbox.pack_start(hbox, False)
|
||||||
dialog.add_buttons(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL,
|
dialog.add_buttons(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL,
|
||||||
gtk.STOCK_JUMP_TO, gtk.RESPONSE_OK)
|
gtk.STOCK_JUMP_TO, gtk.RESPONSE_OK)
|
||||||
dialog.set_default_response(gtk.RESPONSE_OK)
|
dialog.set_default_response(gtk.RESPONSE_OK)
|
||||||
@ -372,16 +446,16 @@ class PersonNavView(BookMarkView):
|
|||||||
_("Error: %s is not a valid GRAMPS ID") % gid)
|
_("Error: %s is not a valid GRAMPS ID") % gid)
|
||||||
dialog.destroy()
|
dialog.destroy()
|
||||||
|
|
||||||
def filter_editor(self,obj):
|
def filter_editor(self, obj):
|
||||||
from FilterEditor import FilterEditor
|
from FilterEditor import FilterEditor
|
||||||
|
|
||||||
try:
|
try:
|
||||||
FilterEditor('Person',const.CUSTOM_FILTERS,
|
FilterEditor('Person', const.CUSTOM_FILTERS,
|
||||||
self.dbstate,self.uistate)
|
self.dbstate, self.uistate)
|
||||||
except Errors.WindowActiveError:
|
except Errors.WindowActiveError:
|
||||||
pass
|
return
|
||||||
|
|
||||||
def fwd_clicked(self,obj,step=1):
|
def fwd_clicked(self, obj, step=1):
|
||||||
hobj = self.uistate.phistory
|
hobj = self.uistate.phistory
|
||||||
hobj.lock = True
|
hobj.lock = True
|
||||||
if not hobj.at_end():
|
if not hobj.at_end():
|
||||||
@ -401,7 +475,7 @@ class PersonNavView(BookMarkView):
|
|||||||
self.back_action.set_sensitive(True)
|
self.back_action.set_sensitive(True)
|
||||||
hobj.lock = False
|
hobj.lock = False
|
||||||
|
|
||||||
def back_clicked(self,obj,step=1):
|
def back_clicked(self, obj, step=1):
|
||||||
hobj = self.uistate.phistory
|
hobj = self.uistate.phistory
|
||||||
hobj.lock = True
|
hobj.lock = True
|
||||||
if not hobj.at_front():
|
if not hobj.at_front():
|
||||||
@ -461,7 +535,7 @@ class ListView(BookMarkView):
|
|||||||
|
|
||||||
self.filter_class = filter_class
|
self.filter_class = filter_class
|
||||||
self.renderer = gtk.CellRendererText()
|
self.renderer = gtk.CellRendererText()
|
||||||
self.renderer.set_property('ellipsize',pango.ELLIPSIZE_END)
|
self.renderer.set_property('ellipsize', pango.ELLIPSIZE_END)
|
||||||
self.sort_col = 0
|
self.sort_col = 0
|
||||||
self.columns = []
|
self.columns = []
|
||||||
self.colinfo = columns
|
self.colinfo = columns
|
||||||
@ -470,7 +544,7 @@ class ListView(BookMarkView):
|
|||||||
self.signal_map = signal_map
|
self.signal_map = signal_map
|
||||||
self.multiple_selection = multiple
|
self.multiple_selection = multiple
|
||||||
self.generic_filter = None
|
self.generic_filter = None
|
||||||
dbstate.connect('database-changed',self.change_db)
|
dbstate.connect('database-changed', self.change_db)
|
||||||
|
|
||||||
def build_filter_container(self, box, filter_class):
|
def build_filter_container(self, box, filter_class):
|
||||||
self.filter_sidebar = filter_class(self.dbstate, self.uistate,
|
self.filter_sidebar = filter_class(self.dbstate, self.uistate,
|
||||||
@ -520,20 +594,21 @@ class ListView(BookMarkView):
|
|||||||
"nothing was selected."))
|
"nothing was selected."))
|
||||||
|
|
||||||
def jump(self):
|
def jump(self):
|
||||||
dialog = gtk.Dialog(_('Jump to by GRAMPS ID'),None,
|
dialog = gtk.Dialog(_('Jump to by GRAMPS ID'), None,
|
||||||
gtk.DIALOG_NO_SEPARATOR)
|
gtk.DIALOG_NO_SEPARATOR)
|
||||||
dialog.set_border_width(12)
|
dialog.set_border_width(12)
|
||||||
label = gtk.Label('<span weight="bold" size="larger">%s</span>' % _('Jump to by GRAMPS ID'))
|
label = gtk.Label('<span weight="bold" size="larger">%s</span>' %
|
||||||
|
_('Jump to by GRAMPS ID'))
|
||||||
label.set_use_markup(True)
|
label.set_use_markup(True)
|
||||||
dialog.vbox.add(label)
|
dialog.vbox.add(label)
|
||||||
dialog.vbox.set_spacing(10)
|
dialog.vbox.set_spacing(10)
|
||||||
dialog.vbox.set_border_width(12)
|
dialog.vbox.set_border_width(12)
|
||||||
hbox = gtk.HBox()
|
hbox = gtk.HBox()
|
||||||
hbox.pack_start(gtk.Label("%s: " % _('ID')),False)
|
hbox.pack_start(gtk.Label("%s: " % _('ID')), False)
|
||||||
text = gtk.Entry()
|
text = gtk.Entry()
|
||||||
text.set_activates_default(True)
|
text.set_activates_default(True)
|
||||||
hbox.pack_start(text,False)
|
hbox.pack_start(text, False)
|
||||||
dialog.vbox.pack_start(hbox,False)
|
dialog.vbox.pack_start(hbox, False)
|
||||||
dialog.add_buttons(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL,
|
dialog.add_buttons(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL,
|
||||||
gtk.STOCK_JUMP_TO, gtk.RESPONSE_OK)
|
gtk.STOCK_JUMP_TO, gtk.RESPONSE_OK)
|
||||||
dialog.set_default_response(gtk.RESPONSE_OK)
|
dialog.set_default_response(gtk.RESPONSE_OK)
|
||||||
@ -570,7 +645,7 @@ class ListView(BookMarkView):
|
|||||||
self.vbox.set_border_width(4)
|
self.vbox.set_border_width(4)
|
||||||
self.vbox.set_spacing(4)
|
self.vbox.set_spacing(4)
|
||||||
|
|
||||||
self.search_bar = SearchBar(self.dbstate,self.uistate,
|
self.search_bar = SearchBar(self.dbstate, self.uistate,
|
||||||
self.search_build_tree)
|
self.search_build_tree)
|
||||||
filter_box = self.search_bar.build()
|
filter_box = self.search_bar.build()
|
||||||
|
|
||||||
@ -579,8 +654,8 @@ class ListView(BookMarkView):
|
|||||||
self.list.set_headers_visible(True)
|
self.list.set_headers_visible(True)
|
||||||
self.list.set_headers_clickable(True)
|
self.list.set_headers_clickable(True)
|
||||||
self.list.set_fixed_height_mode(True)
|
self.list.set_fixed_height_mode(True)
|
||||||
self.list.connect('button-press-event',self.button_press)
|
self.list.connect('button-press-event', self.button_press)
|
||||||
self.list.connect('key-press-event',self.key_press)
|
self.list.connect('key-press-event', self.key_press)
|
||||||
if self.drag_info():
|
if self.drag_info():
|
||||||
self.list.connect('drag_data_get', self.drag_data_get)
|
self.list.connect('drag_data_get', self.drag_data_get)
|
||||||
self.list.connect('drag_begin', self.drag_begin)
|
self.list.connect('drag_begin', self.drag_begin)
|
||||||
@ -590,11 +665,11 @@ class ListView(BookMarkView):
|
|||||||
scrollwindow.set_shadow_type(gtk.SHADOW_ETCHED_IN)
|
scrollwindow.set_shadow_type(gtk.SHADOW_ETCHED_IN)
|
||||||
scrollwindow.add(self.list)
|
scrollwindow.add(self.list)
|
||||||
|
|
||||||
self.vbox.pack_start(filter_box,False)
|
self.vbox.pack_start(filter_box, False)
|
||||||
self.vbox.pack_start(scrollwindow,True)
|
self.vbox.pack_start(scrollwindow, True)
|
||||||
|
|
||||||
self.renderer = gtk.CellRendererText()
|
self.renderer = gtk.CellRendererText()
|
||||||
self.renderer.set_property('ellipsize',pango.ELLIPSIZE_END)
|
self.renderer.set_property('ellipsize', pango.ELLIPSIZE_END)
|
||||||
self.inactive = False
|
self.inactive = False
|
||||||
|
|
||||||
self.columns = []
|
self.columns = []
|
||||||
@ -602,7 +677,7 @@ class ListView(BookMarkView):
|
|||||||
self.selection = self.list.get_selection()
|
self.selection = self.list.get_selection()
|
||||||
if self.multiple_selection:
|
if self.multiple_selection:
|
||||||
self.selection.set_mode(gtk.SELECTION_MULTIPLE)
|
self.selection.set_mode(gtk.SELECTION_MULTIPLE)
|
||||||
self.selection.connect('changed',self.row_changed)
|
self.selection.connect('changed', self.row_changed)
|
||||||
|
|
||||||
self.setup_filter()
|
self.setup_filter()
|
||||||
|
|
||||||
@ -614,7 +689,7 @@ class ListView(BookMarkView):
|
|||||||
def search_build_tree(self):
|
def search_build_tree(self):
|
||||||
self.build_tree()
|
self.build_tree()
|
||||||
|
|
||||||
def row_changed(self,obj):
|
def row_changed(self, obj):
|
||||||
"""Called with a row is changed. Check the selected objects from
|
"""Called with a row is changed. Check the selected objects from
|
||||||
the person_tree to get the IDs of the selected objects. Set the
|
the person_tree to get the IDs of the selected objects. Set the
|
||||||
active person to the first person in the list. If no one is
|
active person to the first person in the list. If no one is
|
||||||
@ -633,7 +708,7 @@ class ListView(BookMarkView):
|
|||||||
|
|
||||||
if selected_ids:
|
if selected_ids:
|
||||||
data = (self.drag_info().drag_type, id(self), selected_ids[0], 0)
|
data = (self.drag_info().drag_type, id(self), selected_ids[0], 0)
|
||||||
sel_data.set(sel_data.target, 8 ,pickle.dumps(data))
|
sel_data.set(sel_data.target, 8 , pickle.dumps(data))
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def setup_filter(self):
|
def setup_filter(self):
|
||||||
@ -642,7 +717,7 @@ class ListView(BookMarkView):
|
|||||||
"""
|
"""
|
||||||
cols = []
|
cols = []
|
||||||
for pair in [pair for pair in self.column_order() if pair[0]]:
|
for pair in [pair for pair in self.column_order() if pair[0]]:
|
||||||
cols.append((self.colinfo[pair[1]],pair[1]))
|
cols.append((self.colinfo[pair[1]], pair[1]))
|
||||||
self.search_bar.setup_filter(cols)
|
self.search_bar.setup_filter(cols)
|
||||||
|
|
||||||
def goto_handle(self, handle):
|
def goto_handle(self, handle):
|
||||||
@ -658,7 +733,7 @@ class ListView(BookMarkView):
|
|||||||
path = self.model.on_get_path(handle)
|
path = self.model.on_get_path(handle)
|
||||||
self.selection.unselect_all()
|
self.selection.unselect_all()
|
||||||
self.selection.select_path(path)
|
self.selection.select_path(path)
|
||||||
self.list.scroll_to_cell(path,None,1,0.5,0)
|
self.list.scroll_to_cell(path, None, 1, 0.5, 0)
|
||||||
except KeyError:
|
except KeyError:
|
||||||
self.selection.unselect_all()
|
self.selection.unselect_all()
|
||||||
|
|
||||||
@ -681,14 +756,13 @@ class ListView(BookMarkView):
|
|||||||
if Config.get(Config.FILTER):
|
if Config.get(Config.FILTER):
|
||||||
search = EMPTY_SEARCH
|
search = EMPTY_SEARCH
|
||||||
else:
|
else:
|
||||||
search = (False,self.search_bar.get_value())
|
search = (False, self.search_bar.get_value())
|
||||||
|
|
||||||
self.model = self.make_model(self.dbstate.db, self.sort_col, order,
|
self.model = self.make_model(self.dbstate.db, self.sort_col, order,
|
||||||
search=search,
|
search=search,
|
||||||
sort_map=self.column_order())
|
sort_map=self.column_order())
|
||||||
|
|
||||||
self.list.set_model(self.model)
|
self.list.set_model(self.model)
|
||||||
colmap = self.column_order()
|
|
||||||
|
|
||||||
if handle:
|
if handle:
|
||||||
path = self.model.on_get_path(handle)
|
path = self.model.on_get_path(handle)
|
||||||
@ -720,7 +794,7 @@ class ListView(BookMarkView):
|
|||||||
else:
|
else:
|
||||||
column = gtk.TreeViewColumn(name, self.renderer, text=pair[1])
|
column = gtk.TreeViewColumn(name, self.renderer, text=pair[1])
|
||||||
|
|
||||||
column.connect('clicked',self.column_clicked,index)
|
column.connect('clicked', self.column_clicked, index)
|
||||||
column.set_resizable(True)
|
column.set_resizable(True)
|
||||||
column.set_sizing(gtk.TREE_VIEW_COLUMN_FIXED)
|
column.set_sizing(gtk.TREE_VIEW_COLUMN_FIXED)
|
||||||
column.set_fixed_width(pair[2])
|
column.set_fixed_width(pair[2])
|
||||||
@ -737,7 +811,7 @@ class ListView(BookMarkView):
|
|||||||
else:
|
else:
|
||||||
filter_info = (False, self.search_bar.get_value())
|
filter_info = (False, self.search_bar.get_value())
|
||||||
|
|
||||||
self.model = self.make_model(self.dbstate.db,self.sort_col,
|
self.model = self.make_model(self.dbstate.db, self.sort_col,
|
||||||
search=filter_info)
|
search=filter_info)
|
||||||
self.list.set_model(self.model)
|
self.list.set_model(self.model)
|
||||||
|
|
||||||
@ -751,7 +825,7 @@ class ListView(BookMarkView):
|
|||||||
else:
|
else:
|
||||||
self.dirty = True
|
self.dirty = True
|
||||||
|
|
||||||
def filter_toggle_action(self,obj):
|
def filter_toggle_action(self, obj):
|
||||||
if obj.get_active():
|
if obj.get_active():
|
||||||
self.search_bar.hide()
|
self.search_bar.hide()
|
||||||
self.filter_pane.show()
|
self.filter_pane.show()
|
||||||
@ -763,16 +837,16 @@ class ListView(BookMarkView):
|
|||||||
Config.set(Config.FILTER, active)
|
Config.set(Config.FILTER, active)
|
||||||
self.build_tree()
|
self.build_tree()
|
||||||
|
|
||||||
def filter_editor(self,obj):
|
def filter_editor(self, obj):
|
||||||
from FilterEditor import FilterEditor
|
from FilterEditor import FilterEditor
|
||||||
|
|
||||||
try:
|
try:
|
||||||
FilterEditor(self.FILTER_TYPE ,const.CUSTOM_FILTERS,
|
FilterEditor(self.FILTER_TYPE , const.CUSTOM_FILTERS,
|
||||||
self.dbstate, self.uistate)
|
self.dbstate, self.uistate)
|
||||||
except Errors.WindowActiveError:
|
except Errors.WindowActiveError:
|
||||||
pass
|
return
|
||||||
|
|
||||||
def change_db(self,db):
|
def change_db(self, db):
|
||||||
for sig in self.signal_map:
|
for sig in self.signal_map:
|
||||||
db.connect(sig, self.signal_map[sig])
|
db.connect(sig, self.signal_map[sig])
|
||||||
|
|
||||||
@ -784,14 +858,14 @@ class ListView(BookMarkView):
|
|||||||
else:
|
else:
|
||||||
self.dirty = True
|
self.dirty = True
|
||||||
|
|
||||||
def row_add(self,handle_list):
|
def row_add(self, handle_list):
|
||||||
if self.active:
|
if self.active:
|
||||||
for handle in handle_list:
|
for handle in handle_list:
|
||||||
self.model.add_row_by_handle(handle)
|
self.model.add_row_by_handle(handle)
|
||||||
else:
|
else:
|
||||||
self.dirty = True
|
self.dirty = True
|
||||||
|
|
||||||
def row_update(self,handle_list):
|
def row_update(self, handle_list):
|
||||||
if self.model:
|
if self.model:
|
||||||
self.model.prev_handle = None
|
self.model.prev_handle = None
|
||||||
if self.active:
|
if self.active:
|
||||||
@ -800,7 +874,7 @@ class ListView(BookMarkView):
|
|||||||
else:
|
else:
|
||||||
self.dirty = True
|
self.dirty = True
|
||||||
|
|
||||||
def row_delete(self,handle_list):
|
def row_delete(self, handle_list):
|
||||||
if self.active:
|
if self.active:
|
||||||
for handle in handle_list:
|
for handle in handle_list:
|
||||||
self.model.delete_row_by_handle(handle)
|
self.model.delete_row_by_handle(handle)
|
||||||
@ -838,10 +912,10 @@ class ListView(BookMarkView):
|
|||||||
self.add_toggle_action('Filter', None, _('_Filter'),
|
self.add_toggle_action('Filter', None, _('_Filter'),
|
||||||
callback=self.filter_toggle_action)
|
callback=self.filter_toggle_action)
|
||||||
|
|
||||||
def column_editor(self,obj):
|
def column_editor(self, obj):
|
||||||
pass
|
raise NotImplementedError
|
||||||
|
|
||||||
def button_press(self,obj,event):
|
def button_press(self, obj, event):
|
||||||
from QuickReports import create_quickreport_menu
|
from QuickReports import create_quickreport_menu
|
||||||
if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1:
|
if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1:
|
||||||
self.edit(obj)
|
self.edit(obj)
|
||||||
@ -849,7 +923,7 @@ class ListView(BookMarkView):
|
|||||||
elif event.type == gtk.gdk.BUTTON_PRESS and event.button == 3:
|
elif event.type == gtk.gdk.BUTTON_PRESS and event.button == 3:
|
||||||
menu = self.uistate.uimanager.get_widget('/Popup')
|
menu = self.uistate.uimanager.get_widget('/Popup')
|
||||||
#construct quick reports if needed
|
#construct quick reports if needed
|
||||||
if menu and self.QR_CATEGORY>-1 :
|
if menu and self.QR_CATEGORY > -1 :
|
||||||
qr_menu = self.uistate.uimanager.\
|
qr_menu = self.uistate.uimanager.\
|
||||||
get_widget('/Popup/QuickReport').get_submenu()
|
get_widget('/Popup/QuickReport').get_submenu()
|
||||||
if qr_menu :
|
if qr_menu :
|
||||||
@ -873,14 +947,14 @@ class ListView(BookMarkView):
|
|||||||
|
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def key_press(self,obj,event):
|
def key_press(self, obj, event):
|
||||||
if not event.state or event.state in (gtk.gdk.MOD2_MASK,):
|
if not event.state or event.state in (gtk.gdk.MOD2_MASK, ):
|
||||||
if event.keyval in (gtk.keysyms.Return, gtk.keysyms.KP_Enter):
|
if event.keyval in (gtk.keysyms.Return, gtk.keysyms.KP_Enter):
|
||||||
self.edit(obj)
|
self.edit(obj)
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def double_click(self,obj,event):
|
def double_click(self, obj, event):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def change_page(self):
|
def change_page(self):
|
||||||
|
Loading…
x
Reference in New Issue
Block a user