import React from 'react';
import { ConversationListItemProps, ConversationListItemWithDetails } from './ConversationListItem';
import { MessageSearchResult, MessageSearchResultProps } from './MessageSearchResult';

export type SearchResultsProps = {
  contacts: Array<ConversationListItemProps>;
  conversations: Array<ConversationListItemProps>;
  hideMessagesHeader: boolean;
  messages: Array<MessageSearchResultProps>;
  searchTerm: string;
};

type PropsHousekeeping = {
  openConversationExternal: (id: string, messageId?: string) => void;
};

type Props = SearchResultsProps & PropsHousekeeping;

export class SearchResults extends React.Component<Props> {
  public render() {
    const {
      conversations,
      contacts,
      hideMessagesHeader,
      messages,
      openConversationExternal,
      searchTerm,
    } = this.props;

    const haveConversations = conversations && conversations.length;
    const haveContacts = contacts && contacts.length;
    const haveMessages = messages && messages.length;
    const noResults = !haveConversations && !haveContacts && !haveMessages;

    return (
      <div className="module-search-results">
        {noResults ? (
          <div className="module-search-results__no-results">
            {window.i18n('noSearchResults', [searchTerm])}
          </div>
        ) : null}
        {haveConversations ? (
          <div className="module-search-results__conversations">
            <div className="module-search-results__conversations-header">
              {window.i18n('conversationsHeader')}
            </div>
            {conversations.map(conversation => (
              <ConversationListItemWithDetails
                key={conversation.phoneNumber}
                {...conversation}
                onClick={openConversationExternal}
              />
            ))}
          </div>
        ) : null}
        {haveContacts ? this.renderContacts(window.i18n('contactsHeader'), contacts) : null}

        {haveMessages ? (
          <div className="module-search-results__messages">
            {hideMessagesHeader ? null : (
              <div className="module-search-results__messages-header">
                {window.i18n('messagesHeader')}
              </div>
            )}
            {messages.map(message => (
              <MessageSearchResult
                key={message.id}
                {...message}
                onClick={openConversationExternal}
              />
            ))}
          </div>
        ) : null}
      </div>
    );
  }
  private renderContacts(header: string, items: Array<ConversationListItemProps>) {
    const { openConversationExternal } = this.props;

    return (
      <div className="module-search-results__contacts">
        <div className="module-search-results__contacts-header">{header}</div>
        {items.map(contact => (
          <ConversationListItemWithDetails
            key={contact.phoneNumber}
            {...contact}
            onClick={openConversationExternal}
          />
        ))}
      </div>
    );
  }
}