bigbuffet-rw/app/soapbox/features/emoji/search.ts

66 lines
1.5 KiB
TypeScript
Raw Normal View History

2022-07-04 19:08:47 -07:00
import { Index } from 'flexsearch';
import data from './data';
2022-07-04 21:03:09 -07:00
import type { Emoji } from './index';
2022-07-09 09:03:22 -07:00
// import type { Emoji as EmojiMart, CustomEmoji } from 'emoji-mart';
2022-07-04 19:08:47 -07:00
const index = new Index({
2022-07-04 23:37:07 -07:00
tokenize: 'full',
2022-07-04 19:08:47 -07:00
optimize: true,
2022-07-04 23:37:07 -07:00
context: true,
2022-07-04 19:08:47 -07:00
});
for (const [key, emoji] of Object.entries(data.emojis)) {
2022-07-09 16:32:34 -07:00
index.add('n' + key, emoji.name);
2022-07-04 19:08:47 -07:00
}
2022-07-04 16:07:04 -07:00
2022-07-04 13:30:35 -07:00
export interface searchOptions {
maxResults?: number;
2022-07-04 23:37:07 -07:00
custom?: any,
2022-07-04 13:30:35 -07:00
}
2022-07-09 09:03:22 -07:00
export const addCustomToPool = (customEmojis: any[]) => {
2022-07-09 16:32:34 -07:00
// @ts-ignore
for (const key in index.register) {
if (key[0] === 'c') {
index.remove(key); // remove old custom emojis
}
}
2022-07-04 19:08:47 -07:00
let i = 0;
2022-07-04 13:30:35 -07:00
2022-07-04 19:08:47 -07:00
for (const emoji of customEmojis) {
2022-07-09 16:32:34 -07:00
index.add('c' + i++, emoji.id);
2022-07-04 19:08:47 -07:00
}
2022-07-04 13:30:35 -07:00
};
2022-07-09 16:32:34 -07:00
// we can share an index by prefixing custom emojis with 'c' and native with 'n'
2022-07-04 23:37:07 -07:00
const search = (str: string, { maxResults = 5, custom }: searchOptions = {}, custom_emojis?: any): Emoji[] => {
2022-07-05 00:11:24 -07:00
return index.search(str, maxResults)
2022-07-04 19:08:47 -07:00
.flatMap(id => {
2022-07-09 16:32:34 -07:00
// @ts-ignore
if (id[0] === 'c') {
const { shortcode, static_url } = custom_emojis.get((id as string).substr(1)).toJS();
2022-07-04 20:11:46 -07:00
2022-07-04 19:08:47 -07:00
return {
id: shortcode,
colons: ':' + shortcode + ':',
custom: true,
imageUrl: static_url,
};
}
2022-07-09 16:32:34 -07:00
const { skins } = data.emojis[(id as string).substr(1)];
2022-07-04 19:08:47 -07:00
return {
2022-07-09 16:32:34 -07:00
id: (id as string).substr(1),
2022-07-04 20:11:46 -07:00
colons: ':' + id + ':',
2022-07-04 19:08:47 -07:00
unified: skins[0].unified,
native: skins[0].native,
};
});
2022-07-04 13:30:35 -07:00
};
export default search;