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

56 lines
1.2 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 20:59:39 -07:00
import { Emoji as EmojiType } from './index';
2022-07-04 19:08:47 -07:00
import type { Emoji, CustomEmoji } from 'emoji-mart';
const index = new Index({
tokenize: 'forward',
optimize: true,
});
for (const [key, emoji] of Object.entries(data.emojis)) {
index.add(key, emoji.name);
}
2022-07-04 16:07:04 -07:00
2022-07-04 13:30:35 -07:00
export interface searchOptions {
maxResults?: number;
}
2022-07-04 19:08:47 -07:00
export const addCustomToPool = (customEmojis: Emoji<CustomEmoji>[]) => {
let i = 0;
2022-07-04 13:30:35 -07:00
2022-07-04 19:08:47 -07:00
for (const emoji of customEmojis) {
index.add(i++, emoji.id);
}
2022-07-04 13:30:35 -07:00
};
2022-07-04 20:59:39 -07:00
const search = (str: string, options: searchOptions, custom_emojis: any): EmojiType[] => {
2022-07-04 19:08:47 -07:00
return index.search(str, options.maxResults)
.flatMap(id => {
if (Number.isInteger(id)) {
const { shortcode, static_url } = custom_emojis.get(id).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-04 20:11:46 -07:00
const { skins } = data.emojis[id];
2022-07-04 19:08:47 -07:00
return {
2022-07-04 20:11:46 -07:00
id: id as string,
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;