Fill out the follower component
This commit is contained in:
@@ -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>
|
||||
|
||||
Reference in New Issue
Block a user