Use custom search index instead of lunr

Builds the index as the user search
Supports substring search
exclude-unsupported-native-emojis
Etienne Lemay 2016-07-22 14:23:16 -04:00
parent ee73a5d898
commit be1e6705c3
2 changed files with 31 additions and 36 deletions

View File

@ -32,7 +32,6 @@
"emoji-data": "git://github.com/iamcal/emoji-data.git#6daffc10d8e8fd06b80ec24c9bdcb65218f71563", "emoji-data": "git://github.com/iamcal/emoji-data.git#6daffc10d8e8fd06b80ec24c9bdcb65218f71563",
"emojilib": "2.0.2", "emojilib": "2.0.2",
"inflection": "1.10.0", "inflection": "1.10.0",
"lunr": "0.7.1",
"mkdirp": "0.5.1", "mkdirp": "0.5.1",
"react": "15.2.0", "react": "15.2.0",
"react-addons-test-utils": "15.2.0", "react-addons-test-utils": "15.2.0",

View File

@ -1,24 +1,14 @@
import lunr from 'lunr'
import data from '../../data' import data from '../../data'
import {getSanitizedData} from '.' import {getSanitizedData} from '.'
var index = {}
var emojisList = {} var emojisList = {}
var emoticonsList = {} var emoticonsList = {}
var index = lunr(function() {
this.pipeline.reset()
this.field('short_name', { boost: 2 })
this.field('emoticons')
this.field('name')
this.ref('id')
})
for (let emoji in data.emojis) { for (let emoji in data.emojis) {
let emojiData = data.emojis[emoji], let emojiData = data.emojis[emoji],
{ short_names, name, emoticons } = emojiData, { short_names, emoticons } = emojiData,
id = short_names[0] id = short_names[0]
for (let emoticon of emoticons) { for (let emoticon of emoticons) {
@ -28,39 +18,45 @@ for (let emoji in data.emojis) {
} }
emojisList[id] = getSanitizedData(id) emojisList[id] = getSanitizedData(id)
index.add({
id: id,
emoticons: emoticons,
short_name: tokenize(id),
name: tokenize(name),
})
} }
function search(value, maxResults = 75) { function search(value, maxResults = 75) {
var results = null var results = null
if (value.length) { if (value.length) {
results = index.search(tokenize(value)).map((result) => var aPool = data.emojis,
emojisList[result.ref] aIndex = index,
) i = 0
results = results.slice(0, maxResults) value = value.toLowerCase()
for (let char of value.split('')) {
i++
aIndex[char] || (aIndex[char] = {})
aIndex = aIndex[char]
if (!aIndex.results) {
aIndex.results = []
aIndex.pool = {}
for (let id in aPool) {
let emoji = aPool[id],
{ search } = emoji
if (search.indexOf(value.substr(0, i)) != -1) {
aIndex.results.push(emojisList[id])
aIndex.pool[id] = emoji
}
}
}
aPool = aIndex.pool
results = aIndex.results.slice(0, maxResults)
}
} }
return results return results
} }
function tokenize (string = '') {
if (string[0] == '-' || string[0] == '+') {
return string.split('')
}
if (/(:|;|=)-/.test(string)) {
return [string]
}
return string.split(/[-|_|\s]+/)
}
export default { search, emojis: emojisList, emoticons: emoticonsList } export default { search, emojis: emojisList, emoticons: emoticonsList }