2024-07-17 14:49:11 +08:00
|
|
|
import MessageItem from '@/components/message-item';
|
2024-02-26 18:38:54 +08:00
|
|
|
import { MessageType } from '@/constants/chat';
|
2024-09-09 19:20:16 +08:00
|
|
|
import { Flex, Spin } from 'antd';
|
2024-02-27 19:05:50 +08:00
|
|
|
import {
|
2024-08-22 18:01:48 +08:00
|
|
|
useCreateConversationBeforeUploadDocument,
|
2024-02-27 19:05:50 +08:00
|
|
|
useGetFileIcon,
|
2024-03-20 11:13:51 +08:00
|
|
|
useGetSendButtonDisabled,
|
2024-07-17 14:49:11 +08:00
|
|
|
useSendButtonDisabled,
|
2024-08-30 17:53:30 +08:00
|
|
|
useSendNextMessage,
|
2024-02-27 19:05:50 +08:00
|
|
|
} from '../hooks';
|
2024-05-16 20:15:02 +08:00
|
|
|
import { buildMessageItemReference } from '../utils';
|
2024-02-27 19:05:50 +08:00
|
|
|
|
2024-08-14 17:26:47 +08:00
|
|
|
import MessageInput from '@/components/message-input';
|
2024-09-09 19:20:16 +08:00
|
|
|
import PdfDrawer from '@/components/pdf-drawer';
|
|
|
|
|
import { useClickDrawer } from '@/components/pdf-drawer/hooks';
|
2024-08-30 17:53:30 +08:00
|
|
|
import {
|
|
|
|
|
useFetchNextConversation,
|
|
|
|
|
useGetChatSearchParams,
|
|
|
|
|
} from '@/hooks/chat-hooks';
|
2024-07-25 18:53:10 +08:00
|
|
|
import { useFetchUserInfo } from '@/hooks/user-setting-hooks';
|
2024-08-27 14:45:17 +08:00
|
|
|
import { memo } from 'react';
|
2024-07-17 14:49:11 +08:00
|
|
|
import styles from './index.less';
|
2024-02-22 17:14:25 +08:00
|
|
|
|
2024-02-19 19:16:23 +08:00
|
|
|
const ChatContainer = () => {
|
2024-08-30 17:53:30 +08:00
|
|
|
const { conversationId } = useGetChatSearchParams();
|
|
|
|
|
const { data: conversation } = useFetchNextConversation();
|
|
|
|
|
|
2024-02-29 14:26:59 +08:00
|
|
|
const {
|
|
|
|
|
ref,
|
2024-08-27 14:45:17 +08:00
|
|
|
loading,
|
2024-08-30 17:53:30 +08:00
|
|
|
sendLoading,
|
|
|
|
|
derivedMessages,
|
2024-03-20 11:13:51 +08:00
|
|
|
handleInputChange,
|
|
|
|
|
handlePressEnter,
|
|
|
|
|
value,
|
2024-08-29 18:37:18 +08:00
|
|
|
regenerateMessage,
|
2024-08-30 17:53:30 +08:00
|
|
|
removeMessageById,
|
|
|
|
|
} = useSendNextMessage();
|
|
|
|
|
|
2024-03-05 16:30:28 +08:00
|
|
|
const { visible, hideModal, documentId, selectedChunk, clickDocumentButton } =
|
|
|
|
|
useClickDrawer();
|
2024-03-20 11:13:51 +08:00
|
|
|
const disabled = useGetSendButtonDisabled();
|
2024-06-24 16:41:45 +08:00
|
|
|
const sendDisabled = useSendButtonDisabled(value);
|
2024-02-27 19:05:50 +08:00
|
|
|
useGetFileIcon();
|
2024-07-25 18:53:10 +08:00
|
|
|
const { data: userInfo } = useFetchUserInfo();
|
2024-08-22 18:01:48 +08:00
|
|
|
const { createConversationBeforeUploadDocument } =
|
|
|
|
|
useCreateConversationBeforeUploadDocument();
|
2024-02-19 19:16:23 +08:00
|
|
|
|
|
|
|
|
return (
|
2024-03-05 16:30:28 +08:00
|
|
|
<>
|
|
|
|
|
<Flex flex={1} className={styles.chatContainer} vertical>
|
|
|
|
|
<Flex flex={1} vertical className={styles.messageContainer}>
|
|
|
|
|
<div>
|
2024-03-20 18:20:42 +08:00
|
|
|
<Spin spinning={loading}>
|
2024-08-30 17:53:30 +08:00
|
|
|
{derivedMessages?.map((message, i) => {
|
2024-03-20 18:20:42 +08:00
|
|
|
return (
|
|
|
|
|
<MessageItem
|
2024-05-16 20:15:02 +08:00
|
|
|
loading={
|
|
|
|
|
message.role === MessageType.Assistant &&
|
|
|
|
|
sendLoading &&
|
2024-08-30 17:53:30 +08:00
|
|
|
derivedMessages.length - 1 === i
|
2024-05-16 20:15:02 +08:00
|
|
|
}
|
2024-03-20 18:20:42 +08:00
|
|
|
key={message.id}
|
|
|
|
|
item={message}
|
2024-07-17 14:49:11 +08:00
|
|
|
nickname={userInfo.nickname}
|
|
|
|
|
avatar={userInfo.avatar}
|
2024-08-30 17:53:30 +08:00
|
|
|
reference={buildMessageItemReference(
|
|
|
|
|
{
|
|
|
|
|
message: derivedMessages,
|
|
|
|
|
reference: conversation.reference,
|
|
|
|
|
},
|
|
|
|
|
message,
|
|
|
|
|
)}
|
2024-03-20 18:20:42 +08:00
|
|
|
clickDocumentButton={clickDocumentButton}
|
2024-08-29 11:24:27 +08:00
|
|
|
index={i}
|
2024-08-29 14:32:04 +08:00
|
|
|
removeMessageById={removeMessageById}
|
2024-08-29 18:37:18 +08:00
|
|
|
regenerateMessage={regenerateMessage}
|
|
|
|
|
sendLoading={sendLoading}
|
2024-03-20 18:20:42 +08:00
|
|
|
></MessageItem>
|
|
|
|
|
);
|
|
|
|
|
})}
|
|
|
|
|
</Spin>
|
2024-03-05 16:30:28 +08:00
|
|
|
</div>
|
|
|
|
|
<div ref={ref} />
|
|
|
|
|
</Flex>
|
2024-08-14 17:26:47 +08:00
|
|
|
<MessageInput
|
|
|
|
|
disabled={disabled}
|
|
|
|
|
sendDisabled={sendDisabled}
|
|
|
|
|
sendLoading={sendLoading}
|
|
|
|
|
value={value}
|
|
|
|
|
onInputChange={handleInputChange}
|
|
|
|
|
onPressEnter={handlePressEnter}
|
2024-08-22 18:01:48 +08:00
|
|
|
conversationId={conversationId}
|
|
|
|
|
createConversationBeforeUploadDocument={
|
|
|
|
|
createConversationBeforeUploadDocument
|
|
|
|
|
}
|
2024-08-14 17:26:47 +08:00
|
|
|
></MessageInput>
|
2024-02-22 17:14:25 +08:00
|
|
|
</Flex>
|
2024-09-09 19:20:16 +08:00
|
|
|
<PdfDrawer
|
|
|
|
|
visible={visible}
|
|
|
|
|
hideModal={hideModal}
|
|
|
|
|
documentId={documentId}
|
|
|
|
|
chunk={selectedChunk}
|
|
|
|
|
></PdfDrawer>
|
2024-03-05 16:30:28 +08:00
|
|
|
</>
|
2024-02-19 19:16:23 +08:00
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
2024-08-27 14:45:17 +08:00
|
|
|
export default memo(ChatContainer);
|