2022-04-12 09:52:56 -07:00
|
|
|
import React from 'react';
|
|
|
|
|
2022-08-26 09:41:25 -07:00
|
|
|
import RelativeTimestamp from 'soapbox/components/relative_timestamp';
|
2022-08-18 09:52:04 -07:00
|
|
|
import { Avatar, HStack, Stack, Text } from 'soapbox/components/ui';
|
|
|
|
import VerificationBadge from 'soapbox/components/verification_badge';
|
2022-04-12 09:52:56 -07:00
|
|
|
|
2022-08-18 09:52:04 -07:00
|
|
|
import type { IChat } from 'soapbox/queries/chats';
|
2022-04-12 09:52:56 -07:00
|
|
|
|
2022-08-18 09:52:04 -07:00
|
|
|
interface IChatInterface {
|
|
|
|
chat: IChat,
|
2022-04-12 09:52:56 -07:00
|
|
|
onClick: (chat: any) => void,
|
|
|
|
}
|
|
|
|
|
2022-08-18 09:52:04 -07:00
|
|
|
const Chat: React.FC<IChatInterface> = ({ chat, onClick }) => {
|
2022-08-26 09:41:25 -07:00
|
|
|
// Temporary: remove once bad Staging data is removed.
|
|
|
|
if (!chat.account) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2022-04-12 09:52:56 -07:00
|
|
|
return (
|
2022-08-18 09:52:04 -07:00
|
|
|
<button
|
|
|
|
key={chat.id}
|
|
|
|
type='button'
|
|
|
|
onClick={() => onClick(chat)}
|
2022-08-25 10:44:19 -07:00
|
|
|
className='px-4 py-2 w-full flex flex-col hover:bg-gray-100 dark:hover:bg-gray-800'
|
2022-08-18 09:52:04 -07:00
|
|
|
>
|
2022-08-26 09:41:25 -07:00
|
|
|
<HStack alignItems='center' justifyContent='between' space={2} className='w-full'>
|
|
|
|
<HStack alignItems='center' space={2}>
|
|
|
|
<Avatar src={chat.account?.avatar} size={40} />
|
|
|
|
|
|
|
|
<Stack alignItems='start'>
|
|
|
|
<div className='flex items-center space-x-1 flex-grow'>
|
|
|
|
<Text weight='bold' size='sm' truncate>{chat.account?.display_name || `@${chat.account.username}`}</Text>
|
|
|
|
{chat.account?.verified && <VerificationBadge />}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
{chat.last_message?.content && (
|
|
|
|
<Text size='sm' weight='medium' theme='muted' truncate className='max-w-[200px]'>
|
|
|
|
{chat.last_message?.content}
|
|
|
|
</Text>
|
|
|
|
)}
|
|
|
|
</Stack>
|
|
|
|
</HStack>
|
|
|
|
|
|
|
|
{chat.last_message && (
|
|
|
|
<HStack alignItems='center' space={2}>
|
|
|
|
{chat.last_message.unread && (
|
|
|
|
<div className='w-2 h-2 rounded-full bg-secondary-500' />
|
|
|
|
)}
|
|
|
|
|
|
|
|
<RelativeTimestamp timestamp={chat.last_message.created_at} size='sm' />
|
|
|
|
</HStack>
|
|
|
|
)}
|
2022-08-18 09:52:04 -07:00
|
|
|
</HStack>
|
|
|
|
</button>
|
2022-04-12 09:52:56 -07:00
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Chat;
|