import React, { useRef } from 'react'; import { Avatar, HStack, Icon, Stack, Text } from 'soapbox/components/ui'; import VerificationBadge from 'soapbox/components/verification_badge'; import { useChatContext } from 'soapbox/contexts/chat-context'; import ChatBox from './chat-box'; import ChatPaneHeader from './chat-pane-header'; /** Floating desktop chat window. */ const ChatWindow = () => { const { chat, setChat, isOpen, toggleChatPane } = useChatContext(); const inputRef = useRef(); const closeChat = () => setChat(null); const openAndFocusChat = () => { toggleChatPane(); inputRef.current?.focus(); }; if (!chat) return null; return ( <> {isOpen && ( )} {isOpen && ( )}
{chat.account.display_name} {chat.account.verified && }
{chat.account.acct}
} secondaryAction={isOpen ? undefined : openAndFocusChat} secondaryActionIcon={isOpen ? undefined : require('@tabler/icons/edit.svg')} isToggleable={!isOpen} isOpen={isOpen} onToggle={toggleChatPane} /> null} /> ); }; export default ChatWindow;