emoji-mart-lazyload/src/utils/emoji-index.js

155 lines
3.8 KiB
JavaScript
Raw Normal View History

import data from '../data'
2017-09-17 08:54:22 +00:00
import { getData, getSanitizedData, uniq } from '.'
2016-07-19 16:27:24 +00:00
var originalPool = {}
var index = {}
var emojisList = {}
var emoticonsList = {}
for (let emoji in data.emojis) {
let emojiData = data.emojis[emoji],
{ short_names, emoticons } = emojiData,
2016-07-22 16:23:47 +00:00
id = short_names[0]
2017-09-17 08:54:22 +00:00
if (emoticons) {
emoticons.forEach(emoticon => {
if (emoticonsList[emoticon]) {
return
}
2016-07-22 16:23:47 +00:00
emoticonsList[emoticon] = id
2017-09-17 08:54:22 +00:00
})
}
2016-07-22 16:23:47 +00:00
emojisList[id] = getSanitizedData(id)
originalPool[id] = emojiData
}
function addCustomToPool(custom, pool) {
custom.forEach((emoji) => {
let emojiId = emoji.id || emoji.short_names[0]
if (emojiId && !pool[emojiId]) {
pool[emojiId] = getData(emoji)
emojisList[emojiId] = getSanitizedData(emoji)
}
})
}
function search(value, { emojisToShowFilter, maxResults, include, exclude, custom = [] } = {}) {
addCustomToPool(custom, originalPool)
maxResults || (maxResults = 75)
include || (include = [])
exclude || (exclude = [])
var results = null,
pool = originalPool
if (value.length) {
if (value == '-' || value == '-1') {
return [emojisList['-1']]
}
var values = value.toLowerCase().split(/[\s|,|\-|_]+/),
allResults = []
if (values.length > 2) {
values = [values[0], values[1]]
}
if (include.length || exclude.length) {
pool = {}
2017-09-17 08:54:22 +00:00
data.categories.forEach(category => {
2017-04-24 01:03:12 +00:00
let isIncluded = include && include.length ? include.indexOf(category.name.toLowerCase()) > -1 : true
let isExcluded = exclude && exclude.length ? exclude.indexOf(category.name.toLowerCase()) > -1 : false
2017-09-17 08:54:22 +00:00
if (!isIncluded || isExcluded) {
return
}
2017-09-17 08:54:22 +00:00
category.emojis.forEach(emojiId => pool[emojiId] = data.emojis[emojiId])
})
if (custom.length) {
let customIsIncluded = include && include.length ? include.indexOf('custom') > -1 : true
let customIsExcluded = exclude && exclude.length ? exclude.indexOf('custom') > -1 : false
if (customIsIncluded && !customIsExcluded) {
addCustomToPool(custom, pool)
}
}
}
allResults = values.map((value) => {
var aPool = pool,
aIndex = index,
length = 0
2017-09-17 08:54:22 +00:00
for (let charIndex = 0; charIndex < value.length; charIndex++) {
const char = value[charIndex]
length++
aIndex[char] || (aIndex[char] = {})
aIndex = aIndex[char]
if (!aIndex.results) {
let scores = {}
aIndex.results = []
aIndex.pool = {}
for (let id in aPool) {
let emoji = aPool[id],
{ search } = emoji,
sub = value.substr(0, length),
subIndex = search.indexOf(sub)
if (subIndex != -1) {
let score = subIndex + 1
if (sub == id) score = 0
aIndex.results.push(emojisList[id])
aIndex.pool[id] = emoji
scores[id] = score
}
}
aIndex.results.sort((a, b) => {
var aScore = scores[a.id],
bScore = scores[b.id]
return aScore - bScore
})
}
aPool = aIndex.pool
}
return aIndex.results
}).filter(a => a)
if (allResults.length > 1) {
2017-09-17 08:54:22 +00:00
results = uniq(allResults)
} else if (allResults.length) {
results = allResults[0]
} else {
results = []
}
}
if (results) {
if (emojisToShowFilter) {
results = results.filter((result) => emojisToShowFilter(data.emojis[result.id].unified))
}
if (results && results.length > maxResults) {
results = results.slice(0, maxResults)
2017-04-04 16:00:32 +00:00
}
}
return results
}
export default { search, emojis: emojisList, emoticons: emoticonsList }