You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tailchat/shared/redux/hooks/useConverseMessage.ts

54 lines
1.5 KiB
TypeScript

import { useCallback } from 'react';
import { getCachedConverseInfo } from '../../cache/cache';
import { useAsync } from '../../hooks/useAsync';
import { showErrorToasts } from '../../manager/ui';
import {
fetchConverseMessage,
sendMessage,
SendMessagePayload,
} from '../../model/message';
import { chatActions } from '../slices';
import { useAppDispatch, useAppSelector } from './useAppSelector';
/**
* 会话消息管理
*/
export function useConverseMessage(converseId: string) {
const converse = useAppSelector((state) => state.chat.converses[converseId]);
const dispatch = useAppDispatch();
const messages = converse?.messages ?? [];
const { loading, error } = useAsync(async () => {
if (!converse) {
const converse = await getCachedConverseInfo(converseId);
dispatch(chatActions.setConverseInfo(converse));
const messages = await fetchConverseMessage(converseId);
dispatch(
chatActions.appendConverseMessage({
converseId,
messages,
})
);
}
}, [converse, converseId]);
const handleSendMessage = useCallback(async (payload: SendMessagePayload) => {
// TODO: 增加临时消息, 对网络环境不佳的状态进行优化
try {
const message = await sendMessage(payload);
dispatch(
chatActions.appendConverseMessage({
converseId,
messages: [message],
})
);
} catch (err) {
showErrorToasts(err);
}
}, []);
return { messages, loading, error, handleSendMessage };
}