2
0
mirror of https://github.com/frappe/books.git synced 2025-01-25 16:18:33 +00:00

Support 'in' and 'not in' in db filters

This commit is contained in:
Faris Ansari 2018-04-18 12:18:20 +05:30
parent 66284ec5b3
commit 6fb782b300

View File

@ -393,20 +393,36 @@ module.exports = class Database extends Observable {
let conditions = []; let conditions = [];
let values = []; let values = [];
for (let key in filters) { for (let key in filters) {
let field = `ifnull(${key}, '')`;
const value = filters[key]; const value = filters[key];
if (value instanceof Array) { if (value instanceof Array) {
const condition = value[0];
let condition = value[0];
let comparisonValue = value[1];
let placeholder = '?';
// if its like, we should add the wildcard "%" if the user has not added // if its like, we should add the wildcard "%" if the user has not added
if (condition.toLowerCase()==='includes') { if (condition.toLowerCase()==='includes') {
condition = 'like'; condition = 'like';
} }
if (['like', 'includes'].includes(condition.toLowerCase()) && !value[1].includes('%')) { if (['like', 'includes'].includes(condition.toLowerCase()) && !comparisonValue.includes('%')) {
value[1] = `%${value[1]}%`; comparisonValue = `%${comparisonValue}%`;
} }
conditions.push(`ifnull(${key}, '') ${condition} ?`); if (['in', 'not in'].includes(condition) && Array.isArray(comparisonValue)) {
values.push(value[1]); placeholder = `(${comparisonValue.map(v => '?').join(", ")})`;
}
conditions.push(`${field} ${condition} ${placeholder}`);
if (Array.isArray(comparisonValue)) {
values = values.concat(comparisonValue);
} else {
values.push(comparisonValue);
}
} else { } else {
conditions.push(`ifnull(${key}, '') = ?`); conditions.push(`${field} = ?`);
values.push(value); values.push(value);
} }
} }