Only show unattached notes in note view

svn: r8981
This commit is contained in:
Benny Malengier 2007-09-16 12:14:16 +00:00
parent cd1d69fe12
commit fe5b0aa03d
3 changed files with 67 additions and 0 deletions

View File

@ -1,3 +1,7 @@
2007-09-16 Benny Malengier <benny.malengier@gramps-project.org>
* src/DisplayModels/_BaseModel.py: Add comments
* src/DisplayModels/_NoteModel.py: Only show unattached notes in note view
2007-09-16 Zsolt Foldvari <zfoldvar@users.sourceforge.net> 2007-09-16 Zsolt Foldvari <zfoldvar@users.sourceforge.net>
* src/BaseDoc.py (PaperStyle): Allow custom margin setting in __init__. * src/BaseDoc.py (PaperStyle): Allow custom margin setting in __init__.

View File

@ -221,6 +221,10 @@ class BaseModel(gtk.GenericTreeModel):
return [ x[1] for x in self.sort_data ] return [ x[1] for x in self.sort_data ]
def _rebuild_search(self,ignore=None): def _rebuild_search(self,ignore=None):
""" function called when view must be build, given a search text
in the top search bar
Remark: this method is overridden in NoteModel !
"""
self.total = 0 self.total = 0
if self.db.is_open(): if self.db.is_open():
if self.search and self.search.text: if self.search and self.search.text:
@ -237,6 +241,10 @@ class BaseModel(gtk.GenericTreeModel):
self.node_map.clear_map() self.node_map.clear_map()
def _rebuild_filter(self, ignore=None): def _rebuild_filter(self, ignore=None):
""" function called when view must be build, given filter options
in the filter sidebar
Remark: this method is overridden in NoteModel !
"""
self.total = 0 self.total = 0
if self.db.is_open(): if self.db.is_open():
if self.search: if self.search:

View File

@ -81,6 +81,61 @@ class NoteModel(BaseModel):
BaseModel.__init__(self, db, scol, order, BaseModel.__init__(self, db, scol, order,
search=search, skip=skip, sort_map=sort_map) search=search, skip=skip, sort_map=sort_map)
def __unattached_note(self, handle):
""" function that returns true if note is not attached to another
object
"""
if handle :
return len([x for x in self.db.find_backlink_handles(handle)]) == 0
return False
def _rebuild_search(self,ignore=None):
""" function called when view must be build, given a search text
in the top search bar
Remark: this method is overrides BaseModel as only unattached notes
must be shown
"""
self.total = 0
if self.db.is_open():
if self.search and self.search.text:
dlist = [h for h in self.sort_keys()\
if self.search.match(h) and \
h not in self.skip and h != ignore and \
self.__unattached_note(h)]
else:
dlist = [h for h in self.sort_keys() \
if h not in self.skip and h != ignore and \
self.__unattached_note(h)]
self.displayed = len(dlist)
self.node_map.set_path_map(dlist)
else:
self.displayed = 0
self.node_map.clear_map()
def _rebuild_filter(self, ignore=None):
""" function called when view must be build, given filter options
in the filter sidebar
Remark: this method is overrides BaseModel as only unattached notes
must be shown
"""
self.total = 0
if self.db.is_open():
if self.search:
dlist = self.search.apply(self.db,
[ k for k in self.sort_keys()\
if k != ignore and \
self.__unattached_note(h)])
else:
dlist = [ k for k in self.sort_keys() \
if k != ignore and \
self.__unattached_note(h)]
self.displayed = len(dlist)
self.node_map.set_path_map(dlist)
else:
self.displayed = 0
self.node_map.clear_map()
def on_get_n_columns(self): def on_get_n_columns(self):
return len(self.fmap)+1 return len(self.fmap)+1