// Copyright 2019 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import * as React from 'react'; import classNames from 'classnames'; import type { SkinToneKey } from './lib'; import { emojiToImage, getImagePath } from './lib'; export const EmojiSizes = [16, 18, 20, 24, 28, 32, 48, 64, 66] as const; export type EmojiSizeType = (typeof EmojiSizes)[number]; export type OwnProps = { emoji?: string; shortName?: string; skinTone?: SkinToneKey | number; size?: EmojiSizeType; children?: React.ReactNode; title?: string; }; export type Props = OwnProps & Pick, 'style' | 'className'>; // the DOM structure of this Emoji should match the other emoji implementations: // ts/components/conversation/Emojify.tsx // ts/quill/emoji/blot.tsx export const Emoji = React.memo( React.forwardRef( ( { className, emoji, shortName, size = 28, skinTone, style = {}, title, }: Props, ref ) => { let image = ''; if (shortName) { image = getImagePath(shortName, skinTone); } else if (emoji) { image = emojiToImage(emoji) || ''; } return ( ); } ) );