Skip to content

Search not working if find contains $or condition, and search contains more than one field #18

@victormunoz

Description

@victormunoz

For example, this options parameter does not work:

var options={
        find:{ $or:[ {'status':0}, {'status':2} ]},
        search: {
            value: "hello",
            fields: ['name','city']
        }
    };

It seems the searching fields conditions are added to the $or of the find, but I think this is not the expected behaviour. Instead, it should create an $and element containing two $or (one for the find and another one for the search fields), like this:

var options={
        find:{ 
            $and:[ 
                 {$or:[ {'status':0}, {'status':2} ] },
                 {$or:[ {'name':{'$regex': 'hello', '$options': 'i'}}, {'city':{'$regex': 'hello', '$options': 'i'}} ] }
            }
        }
    };

I think an "else" is needed in the "if" of the line 37 of mongoose-datatables.js

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions