You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
99 lines
3.1 KiB
TypeScript
99 lines
3.1 KiB
TypeScript
import React from 'react';
|
|
import { ConversationListItemProps, ConversationListItemWithDetails } from './ConversationListItem';
|
|
import { MessageSearchResult, MessageSearchResultProps } from './MessageSearchResult';
|
|
|
|
import { LocalizerType } from '../types/Util';
|
|
|
|
export type SearchResultsProps = {
|
|
contacts: Array<ConversationListItemProps>;
|
|
conversations: Array<ConversationListItemProps>;
|
|
hideMessagesHeader: boolean;
|
|
messages: Array<MessageSearchResultProps>;
|
|
searchTerm: string;
|
|
};
|
|
|
|
type PropsHousekeeping = {
|
|
i18n: LocalizerType;
|
|
openConversationExternal: (id: string, messageId?: string) => void;
|
|
};
|
|
|
|
type Props = SearchResultsProps & PropsHousekeeping;
|
|
|
|
export class SearchResults extends React.Component<Props> {
|
|
public render() {
|
|
const {
|
|
conversations,
|
|
contacts,
|
|
hideMessagesHeader,
|
|
i18n,
|
|
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">
|
|
{i18n('noSearchResults', [searchTerm])}
|
|
</div>
|
|
) : null}
|
|
{haveConversations ? (
|
|
<div className="module-search-results__conversations">
|
|
<div className="module-search-results__conversations-header">
|
|
{i18n('conversationsHeader')}
|
|
</div>
|
|
{conversations.map(conversation => (
|
|
<ConversationListItemWithDetails
|
|
key={conversation.phoneNumber}
|
|
{...conversation}
|
|
onClick={openConversationExternal}
|
|
i18n={i18n}
|
|
/>
|
|
))}
|
|
</div>
|
|
) : null}
|
|
{haveContacts ? this.renderContacts(i18n('contactsHeader'), contacts) : null}
|
|
|
|
{haveMessages ? (
|
|
<div className="module-search-results__messages">
|
|
{hideMessagesHeader ? null : (
|
|
<div className="module-search-results__messages-header">{i18n('messagesHeader')}</div>
|
|
)}
|
|
{messages.map(message => (
|
|
<MessageSearchResult
|
|
key={message.id}
|
|
{...message}
|
|
onClick={openConversationExternal}
|
|
i18n={i18n}
|
|
/>
|
|
))}
|
|
</div>
|
|
) : null}
|
|
</div>
|
|
);
|
|
}
|
|
private renderContacts(header: string, items: Array<ConversationListItemProps>) {
|
|
const { i18n, 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}
|
|
i18n={i18n}
|
|
/>
|
|
))}
|
|
</div>
|
|
);
|
|
}
|
|
}
|