import React from 'react';
import Tooltip from 'react-tooltip-lite';
import { Avatar } from './Avatar';
import { ContactName } from './conversation/ContactName';
import { LocalizerType } from '../types/Util';
import {
  AcceptCallType,
  CallDetailsType,
  DeclineCallType,
} from '../state/ducks/calling';

export type PropsType = {
  acceptCall: (_: AcceptCallType) => void;
  callDetails?: CallDetailsType;
  declineCall: (_: DeclineCallType) => void;
  i18n: LocalizerType;
};

type CallButtonProps = {
  classSuffix: string;
  tabIndex: number;
  tooltipContent: string;
  onClick: () => void;
};

const CallButton = ({
  classSuffix,
  onClick,
  tabIndex,
  tooltipContent,
}: CallButtonProps): JSX.Element => {
  return (
    <button
      className={`module-incoming-call__icon module-incoming-call__button--${classSuffix}`}
      onClick={onClick}
      tabIndex={tabIndex}
    >
      <Tooltip
        arrowSize={6}
        content={tooltipContent}
        direction="bottom"
        distance={16}
        hoverDelay={0}
      >
        <div />
      </Tooltip>
    </button>
  );
};

// tslint:disable-next-line max-func-body-length
export const IncomingCallBar = ({
  acceptCall,
  callDetails,
  declineCall,
  i18n,
}: PropsType): JSX.Element | null => {
  if (!callDetails) {
    return null;
  }

  const {
    avatarPath,
    callId,
    color,
    title,
    name,
    phoneNumber,
    profileName,
  } = callDetails;

  return (
    <div className="module-incoming-call">
      <div className="module-incoming-call__contact">
        <div className="module-incoming-call__contact--avatar">
          <Avatar
            avatarPath={avatarPath}
            color={color || 'ultramarine'}
            noteToSelf={false}
            conversationType="direct"
            i18n={i18n}
            name={name}
            phoneNumber={phoneNumber}
            profileName={profileName}
            title={title}
            size={52}
          />
        </div>
        <div className="module-incoming-call__contact--name">
          <div className="module-incoming-call__contact--name-header">
            <ContactName
              name={name}
              phoneNumber={phoneNumber}
              profileName={profileName}
              title={title}
              i18n={i18n}
            />
          </div>
          <div
            dir="auto"
            className="module-incoming-call__contact--message-text"
          >
            {i18n(
              callDetails.isVideoCall
                ? 'incomingVideoCall'
                : 'incomingAudioCall'
            )}
          </div>
        </div>
      </div>
      <div className="module-incoming-call__actions">
        {callDetails.isVideoCall ? (
          <>
            <CallButton
              classSuffix="decline"
              onClick={() => {
                declineCall({ callId });
              }}
              tabIndex={0}
              tooltipContent={i18n('declineCall')}
            />
            <CallButton
              classSuffix="accept-video-as-audio"
              onClick={() => {
                acceptCall({ callId, asVideoCall: false });
              }}
              tabIndex={0}
              tooltipContent={i18n('acceptCallWithoutVideo')}
            />
            <CallButton
              classSuffix="accept-video"
              onClick={() => {
                acceptCall({ callId, asVideoCall: true });
              }}
              tabIndex={0}
              tooltipContent={i18n('acceptCall')}
            />
          </>
        ) : (
          <>
            <CallButton
              classSuffix="decline"
              onClick={() => {
                declineCall({ callId });
              }}
              tabIndex={0}
              tooltipContent={i18n('declineCall')}
            />
            <CallButton
              classSuffix="accept-audio"
              onClick={() => {
                acceptCall({ callId, asVideoCall: false });
              }}
              tabIndex={0}
              tooltipContent={i18n('acceptCall')}
            />
          </>
        )}
      </div>
    </div>
  );
};