bigbuffet-rw/app/soapbox/features/chats/chat-room.tsx

56 lines
1.4 KiB
TypeScript
Raw Normal View History

2022-06-17 11:05:37 -07:00
import { Map as ImmutableMap } from 'immutable';
2022-09-08 07:24:20 -07:00
import React, { useEffect } from 'react';
2022-06-17 11:05:37 -07:00
import { fetchChat, markChatRead } from 'soapbox/actions/chats';
import { Column } from 'soapbox/components/ui';
import { useAppSelector, useAppDispatch } from 'soapbox/hooks';
import { makeGetChat } from 'soapbox/selectors';
import { getAcct } from 'soapbox/utils/accounts';
import { displayFqn as getDisplayFqn } from 'soapbox/utils/state';
import ChatBox from './components/chat-box';
2022-06-17 11:05:37 -07:00
const getChat = makeGetChat();
interface IChatRoom {
params: {
chatId: string,
}
}
/** Fullscreen chat UI. */
const ChatRoom: React.FC<IChatRoom> = ({ params }) => {
const dispatch = useAppDispatch();
const displayFqn = useAppSelector(getDisplayFqn);
const chat = useAppSelector(state => {
const chat = state.chats.items.get(params.chatId, ImmutableMap()).toJS() as any;
return getChat(state, chat);
});
const markRead = () => {
if (!chat) return;
dispatch(markChatRead(chat.id));
};
useEffect(() => {
dispatch(fetchChat(params.chatId));
markRead();
}, [params.chatId]);
// If this component is loaded at all, we can instantly mark new messages as read.
useEffect(() => {
markRead();
}, [chat?.unread]);
if (!chat) return null;
return (
<Column label={`@${getAcct(chat.account as any, displayFqn)}`}>
2022-09-08 07:24:20 -07:00
<ChatBox chat={chat as any} autosize />
2022-06-17 11:05:37 -07:00
</Column>
);
};
export default ChatRoom;