51 lines
1.3 KiB
TypeScript
51 lines
1.3 KiB
TypeScript
import React from 'react';
|
|
|
|
import unicodeMapping from 'soapbox/features/emoji/emoji_unicode_mapping_light';
|
|
import { useSettings } from 'soapbox/hooks';
|
|
import { joinPublicPath } from 'soapbox/utils/static';
|
|
|
|
import type { Map as ImmutableMap } from 'immutable';
|
|
|
|
interface IEmoji {
|
|
emoji: string;
|
|
emojiMap: ImmutableMap<string, ImmutableMap<string, string>>;
|
|
hovered: boolean;
|
|
}
|
|
|
|
const Emoji: React.FC<IEmoji> = ({ emoji, emojiMap, hovered }) => {
|
|
const autoPlayGif = useSettings().get('autoPlayGif');
|
|
|
|
// @ts-ignore
|
|
if (unicodeMapping[emoji]) {
|
|
// @ts-ignore
|
|
const { filename, shortCode } = unicodeMapping[emoji];
|
|
const title = shortCode ? `:${shortCode}:` : '';
|
|
|
|
return (
|
|
<img
|
|
draggable='false'
|
|
className='emojione block m-0'
|
|
alt={emoji}
|
|
title={title}
|
|
src={joinPublicPath(`/emoji/${filename}.svg`)}
|
|
/>
|
|
);
|
|
} else if (emojiMap.get(emoji as any)) {
|
|
const filename = (autoPlayGif || hovered) ? emojiMap.getIn([emoji, 'url']) : emojiMap.getIn([emoji, 'static_url']);
|
|
const shortCode = `:${emoji}:`;
|
|
|
|
return (
|
|
<img
|
|
draggable='false'
|
|
className='emojione block m-0'
|
|
alt={shortCode}
|
|
title={shortCode}
|
|
src={filename as string}
|
|
/>
|
|
);
|
|
} else {
|
|
return null;
|
|
}
|
|
};
|
|
|
|
export default Emoji;
|