pleroma/app/soapbox/features/chats/components/chat-window.tsx

68 lines
2.1 KiB
TypeScript
Raw Normal View History

2022-08-16 13:35:06 -07:00
import React, { useRef } from 'react';
2022-06-17 12:39:53 -07:00
2022-08-16 05:39:58 -07:00
import { Avatar, HStack, Icon, Stack, Text } from 'soapbox/components/ui';
2022-08-10 05:38:49 -07:00
import VerificationBadge from 'soapbox/components/verification_badge';
2022-08-16 13:35:06 -07:00
import { useChatContext } from 'soapbox/contexts/chat-context';
2022-06-17 12:39:53 -07:00
import ChatBox from './chat-box';
2022-08-10 05:38:49 -07:00
import ChatPaneHeader from './chat-pane-header';
2022-06-17 12:39:53 -07:00
/** Floating desktop chat window. */
2022-08-16 13:35:06 -07:00
const ChatWindow = () => {
const { chat, setChat, isOpen, toggleChatPane } = useChatContext();
const inputRef = useRef<HTMLTextAreaElement>();
const closeChat = () => setChat(null);
const openAndFocusChat = () => {
toggleChatPane();
inputRef.current?.focus();
};
2022-06-17 12:39:53 -07:00
if (!chat) return null;
return (
2022-08-10 05:38:49 -07:00
<>
<ChatPaneHeader
title={
<HStack alignItems='center' space={2}>
2022-08-16 13:35:06 -07:00
{isOpen && (
<button onClick={closeChat}>
<Icon
src={require('@tabler/icons/arrow-left.svg')}
className='h-6 w-6 text-gray-600 dark:text-gray-400'
/>
</button>
)}
2022-08-10 05:38:49 -07:00
<HStack alignItems='center' space={3}>
2022-08-16 13:35:06 -07:00
{isOpen && (
<Avatar src={chat.account.avatar} size={40} />
)}
2022-08-10 05:38:49 -07:00
<Stack alignItems='start'>
<div className='flex items-center space-x-1 flex-grow'>
<Text weight='semibold' truncate>{chat.account.display_name}</Text>
{chat.account.verified && <VerificationBadge />}
</div>
<Text theme='muted' truncate>{chat.account.acct}</Text>
</Stack>
</HStack>
</HStack>
}
2022-08-16 13:35:06 -07:00
secondaryAction={isOpen ? undefined : openAndFocusChat}
secondaryActionIcon={isOpen ? undefined : require('@tabler/icons/edit.svg')}
isToggleable={!isOpen}
isOpen={isOpen}
onToggle={toggleChatPane}
2022-08-10 05:38:49 -07:00
/>
<Stack className='overflow-hidden flex-grow h-full' space={2}>
2022-08-16 13:35:06 -07:00
<ChatBox chat={chat} inputRef={inputRef as any} onSetInputRef={() => null} />
2022-08-10 05:38:49 -07:00
</Stack>
</>
2022-06-17 12:39:53 -07:00
);
};
export default ChatWindow;