Support searching for multiple (2) terms
parent
7e9835dd80
commit
5721f5f694
|
@ -1,6 +1,6 @@
|
||||||
import data from '../../data'
|
import data from '../../data'
|
||||||
|
|
||||||
import {getSanitizedData} from '.'
|
import {getSanitizedData, intersect} from '.'
|
||||||
|
|
||||||
var index = {}
|
var index = {}
|
||||||
var emojisList = {}
|
var emojisList = {}
|
||||||
|
@ -24,14 +24,20 @@ function search(value, maxResults = 75) {
|
||||||
var results = null
|
var results = null
|
||||||
|
|
||||||
if (value.length) {
|
if (value.length) {
|
||||||
|
var values = value.toLowerCase().split(/[\s|,]+/),
|
||||||
|
allResults = []
|
||||||
|
|
||||||
|
if (values.length > 2) {
|
||||||
|
values = [values[0], values[1]]
|
||||||
|
}
|
||||||
|
|
||||||
|
allResults = values.map((value) => {
|
||||||
var aPool = data.emojis,
|
var aPool = data.emojis,
|
||||||
aIndex = index,
|
aIndex = index,
|
||||||
i = 0
|
length = 0
|
||||||
|
|
||||||
value = value.toLowerCase()
|
|
||||||
|
|
||||||
for (let char of value.split('')) {
|
for (let char of value.split('')) {
|
||||||
i++
|
length++
|
||||||
|
|
||||||
aIndex[char] || (aIndex[char] = {})
|
aIndex[char] || (aIndex[char] = {})
|
||||||
aIndex = aIndex[char]
|
aIndex = aIndex[char]
|
||||||
|
@ -44,7 +50,7 @@ function search(value, maxResults = 75) {
|
||||||
let emoji = aPool[id],
|
let emoji = aPool[id],
|
||||||
{ search } = emoji
|
{ search } = emoji
|
||||||
|
|
||||||
if (search.indexOf(value.substr(0, i)) != -1) {
|
if (search.indexOf(value.substr(0, length)) != -1) {
|
||||||
aIndex.results.push(emojisList[id])
|
aIndex.results.push(emojisList[id])
|
||||||
aIndex.pool[id] = emoji
|
aIndex.pool[id] = emoji
|
||||||
}
|
}
|
||||||
|
@ -52,8 +58,22 @@ function search(value, maxResults = 75) {
|
||||||
}
|
}
|
||||||
|
|
||||||
aPool = aIndex.pool
|
aPool = aIndex.pool
|
||||||
results = aIndex.results.slice(0, maxResults)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return aIndex.results
|
||||||
|
}).filter(a => a)
|
||||||
|
|
||||||
|
if (allResults.length > 1) {
|
||||||
|
results = intersect(...allResults)
|
||||||
|
} else if (allResults.length) {
|
||||||
|
results = allResults[0]
|
||||||
|
} else {
|
||||||
|
results = []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (results) {
|
||||||
|
results = results.slice(0, maxResults)
|
||||||
}
|
}
|
||||||
|
|
||||||
return results
|
return results
|
||||||
|
|
Loading…
Reference in New Issue