Development of feathers-nedb-fuzzy-search have moved to rayfoss.
Add fuzzy $search
to NeDB service.find
queries.
npm install feathers-nedb-fuzzy-search
const search = require('feathers-nedb-fuzzy-search')
const messages = app.service('messages')
// enable for message service, may use app.hooks too
messages.hooks({
before: {
find: search()
}
})
messages.find({
query: {
$search: 'some string to search for'
}
})
feathers-nedb-fuzzy-search
take two options:
search({
fields: ['search.this.path', 'this.path.too', 'title'],
deep: true
})
fields
- Specify which fields to search.deep
- If true andfields
is undefined, will search deep in objects.
const feathers = require('feathers')
const hooks = require('feathers-hooks')
const NeDB = require('nedb')
const service = require('feathers-nedb')
const search = require('feathers-nedb-fuzzy-search')
const Model = new NeDB({
filename: './example.db',
autoload: true
})
const app = feathers()
app.configure(hooks())
app.use('/test', service({ Model }))
app.hooks({
before: {
find: search({
// if omitted, then it will search all properties of documents
fields: ['title', 'description']
})
}
})
// you need node v7 or above for async / await syntax
async function testDatabase () {
let service = app.service('test')
await service.create([
{ 'title': 'asdf' },
{ 'title': 'qwerty' },
{ 'title': 'zxcvb' },
{ 'title': 'hello world' },
{ 'title': 'world around' },
{ 'title': 'cats are awesome' },
])
let res = await service.find({ query: { $search: 'world' } })
console.log(res)
// [ { title: 'world around', _id: '1RDM5BJWX4DWr1Jg' },
// { title: 'hello world', _id: 'dX4bpdM1IsAFkAZd' } ]
}
testDatabase()
.catch(e => console.error(e))
npm test # runs mocha, see test.js
MIT © 2017 Arve Seljebu