mirror of
https://github.com/owncast/owncast.git
synced 2025-01-04 15:47:41 +03:00
33 lines
1.1 KiB
TypeScript
33 lines
1.1 KiB
TypeScript
import Sider from 'antd/lib/layout/Sider';
|
|
import { useRecoilValue } from 'recoil';
|
|
import { ChatMessage } from '../../../interfaces/chat-message.model';
|
|
import ChatContainer from '../../chat/ChatContainer';
|
|
import s from './Sidebar.module.scss';
|
|
import {
|
|
chatMessagesAtom,
|
|
chatVisibilityAtom,
|
|
chatStateAtom,
|
|
} from '../../stores/ClientConfigStore';
|
|
import { ChatState, ChatVisibilityState } from '../../../interfaces/application-state';
|
|
import ChatTextField from '../../chat/ChatTextField/ChatTextField';
|
|
|
|
export default function Sidebar() {
|
|
const messages = useRecoilValue<ChatMessage[]>(chatMessagesAtom);
|
|
const chatVisibility = useRecoilValue<ChatVisibilityState>(chatVisibilityAtom);
|
|
const chatState = useRecoilValue<ChatState>(chatStateAtom);
|
|
|
|
return (
|
|
<Sider
|
|
className={s.root}
|
|
collapsed={chatVisibility === ChatVisibilityState.Hidden}
|
|
collapsedWidth={0}
|
|
width={320}
|
|
>
|
|
<div className={s.chatHeader}>
|
|
<span>stream chat</span>
|
|
</div>
|
|
<ChatContainer messages={messages} state={chatState} />
|
|
<ChatTextField />
|
|
</Sider>
|
|
);
|
|
}
|