3073: Add/edit personfilter is VERY slow in one database
svn: r12748
This commit is contained in:
parent
cdaddc3479
commit
6e5f90e580
@ -214,44 +214,6 @@ class MyLesserEqualGreater(gtk.ComboBox):
|
|||||||
else:
|
else:
|
||||||
self.set_active(self.clist.index('equal to'))
|
self.set_active(self.clist.index('equal to'))
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
# MySource - Combo box with list of sources with a standard interface
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
class MySource(gtk.ComboBox):
|
|
||||||
|
|
||||||
def __init__(self, db):
|
|
||||||
gtk.ComboBox.__init__(self)
|
|
||||||
self.db = db
|
|
||||||
store = gtk.ListStore(gobject.TYPE_STRING)
|
|
||||||
self.set_model(store)
|
|
||||||
cell = gtk.CellRendererText()
|
|
||||||
self.pack_start(cell, True)
|
|
||||||
self.add_attribute(cell, 'text', 0)
|
|
||||||
|
|
||||||
self.slist = []
|
|
||||||
for src_handle in self.db.get_source_handles(sort_handles=True):
|
|
||||||
src = self.db.get_source_from_handle(src_handle)
|
|
||||||
self.slist.append(src.get_gramps_id())
|
|
||||||
title = src.get_title()
|
|
||||||
if len(title) > 44:
|
|
||||||
title = title[:40] + "..."
|
|
||||||
store.append(row=["%s [%s]" % (title, src.get_gramps_id())])
|
|
||||||
|
|
||||||
self.set_active(0)
|
|
||||||
self.show()
|
|
||||||
|
|
||||||
def get_text(self):
|
|
||||||
active = self.get_active()
|
|
||||||
if active < 0:
|
|
||||||
return ""
|
|
||||||
return self.slist[active]
|
|
||||||
|
|
||||||
def set_text(self, val):
|
|
||||||
if val in self.slist:
|
|
||||||
self.set_active(self.slist.index(val))
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
# MyPlaces - AutoCombo text entry with list of places attached. Provides
|
# MyPlaces - AutoCombo text entry with list of places attached. Provides
|
||||||
@ -272,6 +234,8 @@ class MyPlaces(gtk.Entry):
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
class MyID(gtk.HBox):
|
class MyID(gtk.HBox):
|
||||||
|
_invalid_id_txt = _('Not a valid ID')
|
||||||
|
_empty_id_txt = _invalid_id_txt
|
||||||
|
|
||||||
obj_name = {
|
obj_name = {
|
||||||
'Person' : _('Person'),
|
'Person' : _('Person'),
|
||||||
@ -348,13 +312,30 @@ class MyID(gtk.HBox):
|
|||||||
return name
|
return name
|
||||||
|
|
||||||
def set_text(self, val):
|
def set_text(self, val):
|
||||||
try:
|
if not val:
|
||||||
name = self.name_from_gramps_id(val)
|
self.tooltips.set_tip(self.entry, self._empty_id_txt)
|
||||||
self.tooltips.set_tip(self.entry, name)
|
else:
|
||||||
except AttributeError:
|
try:
|
||||||
self.tooltips.set_tip(self.entry, _('Not a valid ID'))
|
name = self.name_from_gramps_id(val)
|
||||||
|
self.tooltips.set_tip(self.entry, name)
|
||||||
|
except AttributeError:
|
||||||
|
self.tooltips.set_tip(self.entry, self._invalid_id_txt)
|
||||||
self.entry.set_text(val)
|
self.entry.set_text(val)
|
||||||
|
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# MySource - select ID of sources with a standard interface
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
class MySource(MyID):
|
||||||
|
|
||||||
|
_empty_id_txt = _('Give or select a source ID, leave empty to find objects'
|
||||||
|
' with no source.')
|
||||||
|
def __init__(self, dbstate, uistate, track):
|
||||||
|
MyID.__init__(self, dbstate, uistate, track, namespace='Source')
|
||||||
|
self.tooltips.set_tip(self.entry, self._empty_id_txt)
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
@ -486,7 +467,7 @@ class EditRule(ManagedWindow.ManagedWindow):
|
|||||||
t = MyID(self.dbstate, self.uistate, self.track,
|
t = MyID(self.dbstate, self.uistate, self.track,
|
||||||
self.namespace)
|
self.namespace)
|
||||||
elif v == _('Source ID:'):
|
elif v == _('Source ID:'):
|
||||||
t = MySource(self.db)
|
t = MySource(self.dbstate, self.uistate, self.track)
|
||||||
elif v == _('Filter name:'):
|
elif v == _('Filter name:'):
|
||||||
t = MyFilters(self.filterdb.get_filters(self.namespace),
|
t = MyFilters(self.filterdb.get_filters(self.namespace),
|
||||||
self.filter_name)
|
self.filter_name)
|
||||||
|
@ -48,12 +48,21 @@ class HasSourceOf(Rule):
|
|||||||
description = _('Matches people who have a particular source')
|
description = _('Matches people who have a particular source')
|
||||||
|
|
||||||
def prepare(self,db):
|
def prepare(self,db):
|
||||||
|
if self.list[0] == '':
|
||||||
|
self.source_handle = None
|
||||||
|
self.nosource = True
|
||||||
|
return
|
||||||
|
|
||||||
|
self.nosource = False
|
||||||
try:
|
try:
|
||||||
self.source_handle = db.get_source_from_gramps_id(self.list[0]).get_handle()
|
self.source_handle = db.get_source_from_gramps_id(self.list[0]).get_handle()
|
||||||
except:
|
except:
|
||||||
self.source_handle = None
|
self.source_handle = None
|
||||||
|
|
||||||
def apply(self,db,person):
|
def apply(self, db, person):
|
||||||
if not self.source_handle:
|
if not self.source_handle:
|
||||||
return False
|
if self.nosource:
|
||||||
return person.has_source_reference( self.source_handle)
|
return len(person.get_source_references()) == 0
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
return person.has_source_reference(self.source_handle)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user