1
0
mirror of https://github.com/d47081/qBittorrent.git synced 2025-01-25 14:04:23 +00:00

Merge pull request #10928 from Piccirello/webui-search-filter

Support exclusions in WebUI table filters
This commit is contained in:
Vladimir Golovnev 2019-08-10 21:46:11 +03:00 committed by GitHub
commit 2d28f50acd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 40 additions and 24 deletions

View File

@ -1274,12 +1274,9 @@ const TorrentsTable = new Class({
} }
} }
if (filterTerms) { if ((filterTerms !== undefined) && (filterTerms !== null)
for (let i = 0; i < filterTerms.length; ++i) { && (filterTerms.length > 0) && !containsAllTerms(name, filterTerms))
if (name.indexOf(filterTerms[i]) === -1) return false;
return false;
}
}
return true; return true;
}, },
@ -1523,16 +1520,6 @@ const SearchResultsTable = new Class({
}, },
getFilteredAndSortedRows: function() { getFilteredAndSortedRows: function() {
const containsAll = function(text, searchTerms) {
text = text.toLowerCase();
for (let i = 0; i < searchTerms.length; ++i) {
if (text.indexOf(searchTerms[i].toLowerCase()) === -1)
return false;
}
return true;
};
const getSizeFilters = function() { const getSizeFilters = function() {
let minSize = (searchSizeFilter.min > 0.00) ? (searchSizeFilter.min * Math.pow(1024, searchSizeFilter.minUnit)) : 0.00; let minSize = (searchSizeFilter.min > 0.00) ? (searchSizeFilter.min * Math.pow(1024, searchSizeFilter.minUnit)) : 0.00;
let maxSize = (searchSizeFilter.max > 0.00) ? (searchSizeFilter.max * Math.pow(1024, searchSizeFilter.maxUnit)) : 0.00; let maxSize = (searchSizeFilter.max > 0.00) ? (searchSizeFilter.max * Math.pow(1024, searchSizeFilter.maxUnit)) : 0.00;
@ -1577,8 +1564,8 @@ const SearchResultsTable = new Class({
for (let i = 0; i < rows.length; ++i) { for (let i = 0; i < rows.length; ++i) {
const row = rows[i]; const row = rows[i];
if (searchInTorrentName && !containsAll(row.full_data.fileName, searchTerms)) continue; if (searchInTorrentName && !containsAllTerms(row.full_data.fileName, searchTerms)) continue;
if ((filterTerms.length > 0) && !containsAll(row.full_data.fileName, filterTerms)) continue; if ((filterTerms.length > 0) && !containsAllTerms(row.full_data.fileName, filterTerms)) continue;
if ((sizeFilters.min > 0.00) && (row.full_data.fileSize < sizeFilters.min)) continue; if ((sizeFilters.min > 0.00) && (row.full_data.fileSize < sizeFilters.min)) continue;
if ((sizeFilters.max > 0.00) && (row.full_data.fileSize > sizeFilters.max)) continue; if ((sizeFilters.max > 0.00) && (row.full_data.fileSize > sizeFilters.max)) continue;
if ((seedsFilters.min > 0) && (row.full_data.nbSeeders < seedsFilters.min)) continue; if ((seedsFilters.min > 0) && (row.full_data.nbSeeders < seedsFilters.min)) continue;
@ -1913,12 +1900,7 @@ const TorrentFilesTable = new Class({
} }
} }
const lowercaseName = node.name.toLowerCase(); if (containsAllTerms(node.name, filterTerms)) {
const matchesFilter = filterTerms.every(function(term) {
return (lowercaseName.indexOf(term) !== -1);
});
if (matchesFilter) {
const row = this.getRow(node); const row = this.getRow(node);
filteredRows.push(row); filteredRows.push(row);
return true; return true;

View File

@ -167,3 +167,37 @@ function toFixedPointString(number, digits) {
const power = Math.pow(10, digits); const power = Math.pow(10, digits);
return (Math.floor(power * number) / power).toFixed(digits); return (Math.floor(power * number) / power).toFixed(digits);
} }
/**
*
* @param {String} text the text to search
* @param {Array<String>} terms terms to search for within the text
* @returns {Boolean} true if all terms match the text, false otherwise
*/
function containsAllTerms(text, terms) {
const textToSearch = text.toLowerCase();
for (let i = 0; i < terms.length; ++i) {
const term = terms[i].trim().toLowerCase();
if ((term[0] === '-')) {
// ignore lonely -
if (term.length === 1)
continue;
// disallow any text after -
if (textToSearch.indexOf(term.substring(1)) !== -1)
return false;
}
else if ((term[0] === '+')) {
// ignore lonely +
if (term.length === 1)
continue;
// require any text after +
if (textToSearch.indexOf(term.substring(1)) === -1)
return false;
}
else if (textToSearch.indexOf(term) === -1){
return false;
}
}
return true;
}