-
Notifications
You must be signed in to change notification settings - Fork 3.1k
/
Copy pathEmojiTrie.js
35 lines (30 loc) · 1.3 KB
/
EmojiTrie.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import emojis from '../../assets/emojis';
import Trie from './Trie';
import Timing from './actions/Timing';
import CONST from '../CONST';
Timing.start(CONST.TIMING.TRIE_INITIALIZATION);
const emojisTrie = new Trie();
// Inserting all emojis into the Trie object
for (let i = 0; i < emojis.length; i++) {
if (emojis[i].name) {
const node = emojisTrie.search(emojis[i].name);
if (!node) {
emojisTrie.add(emojis[i].name, {code: emojis[i].code, suggestions: []});
} else {
emojisTrie.update(emojis[i].name, {code: emojis[i].code, suggestions: node.metaData.suggestions});
}
if (emojis[i].keywords) {
for (let j = 0; j < emojis[i].keywords.length; j++) {
const keywordNode = emojisTrie.search(emojis[i].keywords[j]);
if (!keywordNode) {
emojisTrie.add(emojis[i].keywords[j], {suggestions: [{code: emojis[i].code, name: emojis[i].name}]});
} else {
emojisTrie.update(emojis[i].keywords[j],
{...keywordNode.metaData, suggestions: [...keywordNode.metaData.suggestions, {code: emojis[i].code, name: emojis[i].name}]});
}
}
}
}
}
Timing.end(CONST.TIMING.TRIE_INITIALIZATION);
export default emojisTrie;