import { type ReactNode } from 'react';
import { clsx } from 'clsx';

type TooltipProps = {
  children: ReactNode;
  position?:
    | 'right-center'
    | 'right-top'
    | 'right-bottom'
    | 'left-center'
    | 'left-top'
    | 'left-bottom'
    | 'top-center'
    | 'top-left'
    | 'top-right'
    | 'bottom-center'
    | 'bottom-left'
    | 'bottom-right';
};

export function Tooltip(props: TooltipProps) {
  const { children, position = 'right-center' } = props;

  let positionClass = '';
  if (position === 'right-center') {
    positionClass = 'left-full top-1/2 -translate-y-1/2 translate-x-1 ';
  } else if (position === 'top-center') {
    positionClass = 'bottom-full left-1/2 -translate-x-1/2 -translate-y-0.5';
  } else if (position === 'bottom-center') {
    positionClass = 'top-full left-1/2 -translate-x-1/2 translate-y-0.5';
  } else if (position === 'left-center') {
    positionClass = 'right-full top-1/2 -translate-y-1/2 -translate-x-1';
  } else if (position === 'right-top') {
    positionClass = 'left-full top-0';
  } else if (position === 'right-bottom') {
    positionClass = 'left-full bottom-0';
  } else if (position === 'left-top') {
    positionClass = 'right-full top-0';
  } else if (position === 'left-bottom') {
    positionClass = 'right-full bottom-0';
  } else if (position === 'top-left') {
    positionClass = 'bottom-full left-0';
  } else if (position === 'top-right') {
    positionClass = 'bottom-full right-0';
  } else if (position === 'bottom-left') {
    positionClass = 'top-full left-0';
  } else if (position === 'bottom-right') {
    positionClass = 'top-full right-0';
  }

  return (
    <span
      className={clsx(
        'pointer-events-none absolute z-10 block w-max transform rounded-md bg-gray-900 px-2 py-1 text-sm font-medium text-white opacity-0 shadow-sm duration-100 group-hover:opacity-100',
        positionClass
      )}
    >
      {children}
    </span>
  );
}