Implement filterAcceptsRow for the ItemProxyModel, library filtering extended to ItemProxyModel

This commit is contained in:
BasioMeusPuga
2018-01-21 23:57:02 +05:30
parent 5ed5ce0504
commit ce90c0a6ea
4 changed files with 52 additions and 37 deletions

View File

@@ -16,10 +16,6 @@
# You should have received a copy of the GNU General Public License # You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
# TODO
# Implement filterAcceptsRow for the view_model
import os import os
import pickle import pickle
import pathlib import pathlib
@@ -108,14 +104,6 @@ class Library:
'file_exists': file_exists} 'file_exists': file_exists}
tooltip_string = title + '\nAuthor: ' + author + '\nYear: ' + str(year) tooltip_string = title + '\nAuthor: ' + author + '\nYear: ' + str(year)
if tags:
tooltip_string += ('\nTags: ' + tags)
# This remarkably ugly hack is because the QSortFilterProxyModel
# doesn't easily allow searching through multiple item roles
search_workaround_base = title + ' ' + author
if tags:
search_workaround_base += tags
# Additional data can be set using an incrementing # Additional data can be set using an incrementing
# QtCore.Qt.UserRole # QtCore.Qt.UserRole
@@ -130,21 +118,17 @@ class Library:
item = QtGui.QStandardItem() item = QtGui.QStandardItem()
item.setToolTip(tooltip_string) item.setToolTip(tooltip_string)
# The following order is needed to keep sorting working # Just keep the following order. It's way too much trouble otherwise
# search_workaround_base is present in 2 places so that the UserRole + 10
# value can be used to create a new UserRole + 4 value whenever there's
# a change in the directory tags
item.setData(title, QtCore.Qt.UserRole) item.setData(title, QtCore.Qt.UserRole)
item.setData(author, QtCore.Qt.UserRole + 1) item.setData(author, QtCore.Qt.UserRole + 1)
item.setData(year, QtCore.Qt.UserRole + 2) item.setData(year, QtCore.Qt.UserRole + 2)
item.setData(all_metadata, QtCore.Qt.UserRole + 3) item.setData(all_metadata, QtCore.Qt.UserRole + 3)
item.setData(search_workaround_base, QtCore.Qt.UserRole + 4) item.setData(tags, QtCore.Qt.UserRole + 4)
item.setData(file_exists, QtCore.Qt.UserRole + 5) item.setData(file_exists, QtCore.Qt.UserRole + 5)
item.setData(i[8], QtCore.Qt.UserRole + 6) # File hash item.setData(i[8], QtCore.Qt.UserRole + 6) # File hash
item.setData(position, QtCore.Qt.UserRole + 7) item.setData(position, QtCore.Qt.UserRole + 7)
item.setData(False, QtCore.Qt.UserRole + 8) # Is the cover being displayed? item.setData(False, QtCore.Qt.UserRole + 8) # Is the cover being displayed?
item.setData(date_added, QtCore.Qt.UserRole + 9) item.setData(date_added, QtCore.Qt.UserRole + 9)
item.setData(search_workaround_base, QtCore.Qt.UserRole + 10)
item.setIcon(QtGui.QIcon(img_pixmap)) item.setIcon(QtGui.QIcon(img_pixmap))
self.view_model.appendRow(item) self.view_model.appendRow(item)
@@ -181,8 +165,8 @@ class Library:
self.parent.libraryToolBar.searchBar.text()) self.parent.libraryToolBar.searchBar.text())
def create_proxymodel(self): def create_proxymodel(self):
self.proxy_model = QtCore.QSortFilterProxyModel() # self.proxy_model = QtCore.QSortFilterProxyModel()
# self.proxy_model = ItemProxyModel() self.proxy_model = ItemProxyModel()
self.proxy_model.setSourceModel(self.view_model) self.proxy_model.setSourceModel(self.view_model)
self.proxy_model.setSortCaseSensitivity(False) self.proxy_model.setSortCaseSensitivity(False)
s = QtCore.QSize(160, 250) # Set icon sizing here s = QtCore.QSize(160, 250) # Set icon sizing here
@@ -191,9 +175,11 @@ class Library:
self.update_proxymodel() self.update_proxymodel()
def update_proxymodel(self): def update_proxymodel(self):
self.proxy_model.setFilterRole(QtCore.Qt.UserRole + 4) self.proxy_model.invalidateFilter()
self.proxy_model.setFilterCaseSensitivity(QtCore.Qt.CaseInsensitive) self.proxy_model.setFilterParams(
self.proxy_model.setFilterWildcard( self.parent.libraryToolBar.searchBar.text(),
self.parent.active_library_filters)
self.proxy_model.setFilterFixedString(
self.parent.libraryToolBar.searchBar.text()) self.parent.libraryToolBar.searchBar.text())
self.parent.statusMessage.setText( self.parent.statusMessage.setText(
@@ -228,7 +214,7 @@ class Library:
db_library_directories = database.DatabaseFunctions( db_library_directories = database.DatabaseFunctions(
self.parent.database_path).fetch_data( self.parent.database_path).fetch_data(
('Path', 'Name', 'Tags'), ('Path', 'Name', 'Tags'),
'directories', 'directories', # This checks the directories table NOT the book one
{'Path': ''}, {'Path': ''},
'LIKE') 'LIKE')
@@ -261,12 +247,17 @@ class Library:
for i in range(self.view_model.rowCount()): for i in range(self.view_model.rowCount()):
this_item = self.view_model.item(i, 0) this_item = self.view_model.item(i, 0)
all_metadata = this_item.data(QtCore.Qt.UserRole + 3) all_metadata = this_item.data(QtCore.Qt.UserRole + 3)
search_workaround_base = this_item.data(QtCore.Qt.UserRole + 10) directory_name, directory_tags = get_tags(all_metadata)
for j in get_tags(all_metadata): this_item.setData(directory_name, QtCore.Qt.UserRole + 10)
if j: this_item.setData(directory_tags, QtCore.Qt.UserRole + 11)
search_workaround_base += j
this_item.setData(search_workaround_base, QtCore.Qt.UserRole + 4) # search_workaround_base = this_item.data(QtCore.Qt.UserRole + 10)
# for j in get_tags(all_metadata):
# if j:
# search_workaround_base += j
# this_item.setData(search_workaround_base, QtCore.Qt.UserRole + 4)
# Table Model # Table Model
for count, i in enumerate(self.table_model.display_data): for count, i in enumerate(self.table_model.display_data):

View File

@@ -21,12 +21,43 @@ import pathlib
from PyQt5 import QtCore, QtWidgets from PyQt5 import QtCore, QtWidgets
from resources import pie_chart from resources import pie_chart
class ItemProxyModel(QtCore.QSortFilterProxyModel): class ItemProxyModel(QtCore.QSortFilterProxyModel):
def __init__(self, parent=None): def __init__(self, parent=None):
super(ItemProxyModel, self).__init__(parent) super(ItemProxyModel, self).__init__(parent)
self.filter_text = None
self.active_library_filters = None
def setFilterParams(self, filter_text, active_library_filters):
self.filter_text = filter_text
self.active_library_filters = active_library_filters
def filterAcceptsRow(self, row, parent): def filterAcceptsRow(self, row, parent):
return True model = self.sourceModel()
this_index = model.index(row, 0)
title = model.data(this_index, QtCore.Qt.UserRole)
author = model.data(this_index, QtCore.Qt.UserRole + 1)
tags = model.data(this_index, QtCore.Qt.UserRole + 4)
directory_name = model.data(this_index, QtCore.Qt.UserRole + 10)
directory_tags = model.data(this_index, QtCore.Qt.UserRole + 11)
if self.active_library_filters:
if directory_name not in self.active_library_filters:
return False
else:
return False
if not self.filter_text:
return True
else:
valid_data = [i.lower() for i in (title, author, tags, directory_name, directory_tags) if i is not None]
for i in valid_data:
if self.filter_text.lower() in i:
return True
return False
class MostExcellentTableModel(QtCore.QAbstractTableModel): class MostExcellentTableModel(QtCore.QAbstractTableModel):

View File

@@ -186,9 +186,6 @@ class SettingsUI(QtWidgets.QDialog, settingswindow.Ui_Dialog):
self.thread.start() self.thread.start()
def finished_iterating(self): def finished_iterating(self):
# TODO
# Account for file tags
# The books the search thread has found # The books the search thread has found
# are now in self.thread.valid_files # are now in self.thread.valid_files
if not self.thread.valid_files: if not self.thread.valid_files:

View File

@@ -76,10 +76,6 @@ class BackGroundBookDeletion(QtCore.QThread):
class BackGroundBookSearch(QtCore.QThread): class BackGroundBookSearch(QtCore.QThread):
# TODO
# Change existing sorter module functionality to handle preset tags
# Change database to accomodate User Tags, Folder Name, Folder Tags
def __init__(self, data_list, parent=None): def __init__(self, data_list, parent=None):
super(BackGroundBookSearch, self).__init__(parent) super(BackGroundBookSearch, self).__init__(parent)
self.parent = parent self.parent = parent