2022-04-28 18:54:33 +02:00
|
|
|
import Sider from 'antd/lib/layout/Sider';
|
|
|
|
import { useRecoilValue } from 'recoil';
|
2022-09-07 09:00:28 +02:00
|
|
|
import { FC } from 'react';
|
2022-10-27 23:47:15 -07:00
|
|
|
import dynamic from 'next/dynamic';
|
2023-03-13 15:23:14 -07:00
|
|
|
import { Spin } from 'antd';
|
2022-04-28 14:36:05 -07:00
|
|
|
import { ChatMessage } from '../../../interfaces/chat-message.model';
|
2022-09-07 09:00:28 +02:00
|
|
|
import styles from './Sidebar.module.scss';
|
2022-05-25 20:38:40 -07:00
|
|
|
|
2023-03-01 16:19:02 -08:00
|
|
|
import {
|
|
|
|
currentUserAtom,
|
|
|
|
visibleChatMessagesSelector,
|
|
|
|
isChatAvailableSelector,
|
|
|
|
} from '../../stores/ClientConfigStore';
|
2022-04-28 18:54:33 +02:00
|
|
|
|
2022-10-27 23:47:15 -07:00
|
|
|
// Lazy loaded components
|
2023-01-10 16:39:12 -08:00
|
|
|
const ChatContainer = dynamic(
|
|
|
|
() => import('../../chat/ChatContainer/ChatContainer').then(mod => mod.ChatContainer),
|
|
|
|
{
|
|
|
|
ssr: false,
|
|
|
|
},
|
2022-10-27 23:47:15 -07:00
|
|
|
);
|
|
|
|
|
2022-09-07 09:00:28 +02:00
|
|
|
export const Sidebar: FC = () => {
|
2022-10-10 16:26:09 -07:00
|
|
|
const currentUser = useRecoilValue(currentUserAtom);
|
2022-09-04 17:58:06 -07:00
|
|
|
const messages = useRecoilValue<ChatMessage[]>(visibleChatMessagesSelector);
|
2023-03-01 16:19:02 -08:00
|
|
|
const isChatAvailable = useRecoilValue(isChatAvailableSelector);
|
|
|
|
|
2022-10-10 18:33:15 -07:00
|
|
|
if (!currentUser) {
|
2023-03-13 15:23:14 -07:00
|
|
|
return (
|
2023-04-26 23:31:23 +01:00
|
|
|
<Sider className={styles.root} collapsedWidth={0} width={100}>
|
2023-03-13 15:23:14 -07:00
|
|
|
<Spin spinning size="large" />
|
|
|
|
</Sider>
|
|
|
|
);
|
2022-10-10 18:33:15 -07:00
|
|
|
}
|
|
|
|
|
2022-10-10 16:26:09 -07:00
|
|
|
const { id, isModerator, displayName } = currentUser;
|
2022-04-28 18:54:33 +02:00
|
|
|
return (
|
2022-09-07 09:00:28 +02:00
|
|
|
<Sider className={styles.root} collapsedWidth={0} width={320}>
|
2022-06-24 21:30:54 -07:00
|
|
|
<ChatContainer
|
|
|
|
messages={messages}
|
2022-10-10 16:26:09 -07:00
|
|
|
usernameToHighlight={displayName}
|
|
|
|
chatUserId={id}
|
|
|
|
isModerator={isModerator}
|
2023-03-01 16:19:02 -08:00
|
|
|
chatAvailable={isChatAvailable}
|
2023-03-13 15:23:14 -07:00
|
|
|
showInput={!!currentUser}
|
2022-06-24 21:30:54 -07:00
|
|
|
/>
|
2022-04-28 14:36:05 -07:00
|
|
|
</Sider>
|
2022-04-28 18:54:33 +02:00
|
|
|
);
|
2022-09-07 09:00:28 +02:00
|
|
|
};
|