Files
cinny/src/app/plugins/recent-emoji.ts
T

45 lines
1.5 KiB
TypeScript
Raw Normal View History

2023-06-12 21:15:23 +10:00
import { MatrixClient } from 'matrix-js-sdk';
import { getAccountData } from '../utils/room';
import { IEmoji, emojis } from './emoji';
import { AccountDataEvent } from '../../types/matrix/accountData';
type EmojiUnicode = string;
type EmojiUsageCount = number;
export type IRecentEmojiContent = {
recent_emoji?: [EmojiUnicode, EmojiUsageCount][];
};
export const getRecentEmojis = (mx: MatrixClient, limit?: number): IEmoji[] => {
const recentEmojiEvent = getAccountData(mx, AccountDataEvent.ElementRecentEmoji);
const recentEmoji = recentEmojiEvent?.getContent<IRecentEmojiContent>().recent_emoji;
if (!Array.isArray(recentEmoji)) return [];
return recentEmoji
.sort((e1, e2) => e2[1] - e1[1])
.slice(0, limit)
.reduce<IEmoji[]>((list, [unicode]) => {
const emoji = emojis.find((e) => e.unicode === unicode);
if (emoji) list.push(emoji);
return list;
}, []);
};
export function addRecentEmoji(mx: MatrixClient, unicode: string) {
const recentEmojiEvent = getAccountData(mx, AccountDataEvent.ElementRecentEmoji);
const recentEmoji = recentEmojiEvent?.getContent<IRecentEmojiContent>().recent_emoji ?? [];
const emojiIndex = recentEmoji.findIndex(([u]) => u === unicode);
let entry: [EmojiUnicode, EmojiUsageCount];
if (emojiIndex < 0) {
entry = [unicode, 1];
} else {
[entry] = recentEmoji.splice(emojiIndex, 1);
entry[1] += 1;
}
recentEmoji.unshift(entry);
mx.setAccountData(AccountDataEvent.ElementRecentEmoji, {
recent_emoji: recentEmoji.slice(0, 100),
});
}