pleroma/app/soapbox/features/chats/components/chat-widget.tsx
2022-09-22 14:03:12 -04:00

35 lines
794 B
TypeScript

import React, { useEffect } from 'react';
import { connectDirectStream } from 'soapbox/actions/streaming';
import { ChatProvider } from 'soapbox/contexts/chat-context';
import { useAppDispatch, useOwnAccount } from 'soapbox/hooks';
import ChatPane from './chat-pane/chat-pane';
const ChatWidget = () => {
const account = useOwnAccount();
const dispatch = useAppDispatch();
const path = location.pathname;
const shouldHideWidget = Boolean(path.match(/^\/chats/));
useEffect(() => {
const disconnect = dispatch(connectDirectStream());
return (() => {
disconnect();
});
}, []);
if (!account?.chats_onboarded || shouldHideWidget) {
return null;
}
return (
<ChatProvider>
<ChatPane />
</ChatProvider>
);
};
export default ChatWidget;