Fill out the follower component

This commit is contained in:
Gabe Kangas
2022-05-03 14:17:05 -07:00
parent 2cfb336411
commit 008f607cf7
8 changed files with 70 additions and 26 deletions

View File

@@ -1,10 +1,11 @@
import { Spin } from 'antd';
import { Virtuoso } from 'react-virtuoso';
import { useState, useMemo, useCallback, useEffect, useRef } from 'react';
import { LoadingOutlined } from '@ant-design/icons';
import { ChatMessage } from '../../interfaces/chat-message.model';
import { ChatState } from '../../interfaces/application-state';
import ChatUserMessage from './ChatUserMessage';
import { LoadingOutlined } from '@ant-design/icons';
import { MessageType } from '../../interfaces/socket-events';
interface Props {
messages: ChatMessage[];
@@ -16,8 +17,19 @@ export default function ChatContainer(props: Props) {
const loading = state === ChatState.Loading;
const chatContainerRef = useRef(null);
const spinIcon = <LoadingOutlined style={{fontSize: '32px'}} spin />
const spinIcon = <LoadingOutlined style={{ fontSize: '32px' }} spin />;
const getViewForMessage = message => {
switch (message.type) {
case MessageType.CHAT:
return <ChatUserMessage message={message} showModeratorMenu={false} />;
default:
return null;
}
return null;
};
console.log(messages);
return (
<div>
<h1>Chat</h1>
@@ -26,9 +38,7 @@ export default function ChatContainer(props: Props) {
ref={chatContainerRef}
initialTopMostItemIndex={999}
data={messages}
itemContent={(index, message) => (
<ChatUserMessage message={message} showModeratorMenu={false} />
)}
itemContent={(index, message) => getViewForMessage(message)}
followOutput="smooth"
/>
</div>