2023-09-01 11:12:30 +00:00
|
|
|
export const getRandomEmoji = () => {
|
|
|
|
const emojis = [
|
|
|
|
"8986",
|
|
|
|
"9200",
|
|
|
|
"128204",
|
|
|
|
"127773",
|
|
|
|
"127891",
|
|
|
|
"127947",
|
|
|
|
"128076",
|
|
|
|
"128077",
|
|
|
|
"128187",
|
|
|
|
"128188",
|
|
|
|
"128512",
|
|
|
|
"128522",
|
|
|
|
"128578",
|
|
|
|
];
|
|
|
|
|
|
|
|
return emojis[Math.floor(Math.random() * emojis.length)];
|
|
|
|
};
|
|
|
|
|
|
|
|
export const renderEmoji = (
|
|
|
|
emoji:
|
|
|
|
| string
|
|
|
|
| {
|
|
|
|
name: string;
|
|
|
|
color: string;
|
|
|
|
}
|
|
|
|
) => {
|
|
|
|
if (!emoji) return;
|
|
|
|
|
|
|
|
if (typeof emoji === "object")
|
|
|
|
return (
|
2024-02-29 10:01:44 +00:00
|
|
|
<span style={{ fontSize: "16px", color: emoji.color }} className="material-symbols-rounded">
|
2023-09-01 11:12:30 +00:00
|
|
|
{emoji.name}
|
|
|
|
</span>
|
|
|
|
);
|
|
|
|
else return isNaN(parseInt(emoji)) ? emoji : String.fromCodePoint(parseInt(emoji));
|
|
|
|
};
|
|
|
|
|
|
|
|
export const groupReactions: (reactions: any[], key: string) => { [key: string]: any[] } = (
|
|
|
|
reactions: any,
|
|
|
|
key: string
|
|
|
|
) => {
|
2024-02-29 10:01:44 +00:00
|
|
|
const groupedReactions = reactions.reduce((acc: any, reaction: any) => {
|
|
|
|
if (!acc[reaction[key]]) {
|
|
|
|
acc[reaction[key]] = [];
|
|
|
|
}
|
|
|
|
acc[reaction[key]].push(reaction);
|
|
|
|
return acc;
|
|
|
|
}, {} as { [key: string]: any[] });
|
2023-09-01 11:12:30 +00:00
|
|
|
|
|
|
|
return groupedReactions;
|
|
|
|
};
|
2024-03-06 13:45:48 +00:00
|
|
|
|
|
|
|
export const convertHexEmojiToDecimal = (emojiUnified: string): string => {
|
|
|
|
if (!emojiUnified) return "";
|
|
|
|
|
|
|
|
return emojiUnified
|
|
|
|
.split("-")
|
|
|
|
.map((e) => parseInt(e, 16))
|
|
|
|
.join("-");
|
|
|
|
};
|