import { Spin } from 'antd';
import { Virtuoso } from 'react-virtuoso';
import { useMemo, useRef } from 'react';
import { LoadingOutlined } from '@ant-design/icons';
import { MessageType, NameChangeEvent } from '../../../interfaces/socket-events';
import s from './ChatContainer.module.scss';
import { ChatMessage } from '../../../interfaces/chat-message.model';
import { ChatUserMessage } from '..';
import ChatActionMessage from '../ChatActionMessage';
interface Props {
  messages: ChatMessage[];
  loading: boolean;
  usernameToHighlight: string;
  chatUserId: string;
  isModerator: boolean;
}
export default function ChatContainer(props: Props) {
  const { messages, loading, usernameToHighlight, chatUserId, isModerator } = props;
  const chatContainerRef = useRef(null);
  const spinIcon = ;
  const getNameChangeViewForMessage = (message: NameChangeEvent) => {
    const { oldName } = message;
    const { user } = message;
    const { displayName } = user;
    const body = `${oldName} is now known as ${displayName}`;
    return ;
  };
  const getViewForMessage = message => {
    switch (message.type) {
      case MessageType.CHAT:
        return (
          
        );
      case MessageType.NAME_CHANGE:
        return getNameChangeViewForMessage(message);
      default:
        return null;
    }
  };
  const MessagesTable = useMemo(
    () => (
       getViewForMessage(message)}
        followOutput="smooth"
      />
    ),
    [messages, usernameToHighlight, chatUserId, isModerator],
  );
  return (
    
      
        stream chat
      
      
        {MessagesTable}
      
     
  );
}