import React from 'react';

import { SizeClassType } from '../../util/emoji';

import { RenderTextCallbackType } from '../../types/Util';

type Props = {
  text: string;
  /** A class name to be added to the generated emoji images */
  sizeClass: SizeClassType;
  /** Allows you to customize now non-newlines are rendered. Simplest is just a <span>. */
  renderNonEmoji?: RenderTextCallbackType;
  isGroup: boolean;
};

const defaultRenderNonEmoji = (text: string | undefined) => <>{text || ''}</>;

export const Emojify = (props: Props): JSX.Element => {
  const { text, renderNonEmoji, sizeClass, isGroup } = props;
  if (!renderNonEmoji) {
    return <>{defaultRenderNonEmoji(text)}</>;
  }
  const rendered = renderNonEmoji?.({ text: text || '', key: 1, isGroup });
  let size = 1.0;
  switch (sizeClass) {
    case 'jumbo':
      size = 2.0;
      break;
    case 'large':
      size = 1.8;
      break;
    case 'medium':
      size = 1.5;
      break;
    case 'small':
      size = 1.1;
      break;
    case 'default':
    default:
      size = 1.0;
  }

  return <span style={{ fontSize: `${size}rem`, userSelect: 'inherit' }}>{rendered}</span>;
};