mirror of
https://github.com/infiniflow/ragflow.git
synced 2026-02-07 11:05:05 +08:00
### What problem does this PR solve? Feat: Users can chat directly without first creating a conversation. #11768 ### Type of change - [x] New Feature (non-breaking change which adds functionality)
70 lines
2.0 KiB
TypeScript
70 lines
2.0 KiB
TypeScript
import { ConfirmDeleteDialog } from '@/components/confirm-delete-dialog';
|
|
import {
|
|
DropdownMenu,
|
|
DropdownMenuContent,
|
|
DropdownMenuItem,
|
|
DropdownMenuTrigger,
|
|
} from '@/components/ui/dropdown-menu';
|
|
import {
|
|
useGetChatSearchParams,
|
|
useRemoveConversation,
|
|
} from '@/hooks/use-chat-request';
|
|
import { IConversation } from '@/interfaces/database/chat';
|
|
import { Trash2 } from 'lucide-react';
|
|
import { MouseEventHandler, PropsWithChildren, useCallback } from 'react';
|
|
import { useTranslation } from 'react-i18next';
|
|
import { useChatUrlParams } from '../hooks/use-chat-url';
|
|
|
|
export function ConversationDropdown({
|
|
children,
|
|
conversation,
|
|
removeTemporaryConversation,
|
|
}: PropsWithChildren & {
|
|
conversation: IConversation;
|
|
removeTemporaryConversation?: (conversationId: string) => void;
|
|
}) {
|
|
const { t } = useTranslation();
|
|
const { setConversationBoth } = useChatUrlParams();
|
|
const { removeConversation } = useRemoveConversation();
|
|
const { isNew } = useGetChatSearchParams();
|
|
|
|
const handleDelete: MouseEventHandler<HTMLDivElement> =
|
|
useCallback(async () => {
|
|
if (isNew === 'true' && removeTemporaryConversation) {
|
|
removeTemporaryConversation(conversation.id);
|
|
} else {
|
|
const code = await removeConversation([conversation.id]);
|
|
if (code === 0) {
|
|
setConversationBoth('', '');
|
|
}
|
|
}
|
|
}, [
|
|
conversation.id,
|
|
isNew,
|
|
removeConversation,
|
|
removeTemporaryConversation,
|
|
setConversationBoth,
|
|
]);
|
|
|
|
return (
|
|
<DropdownMenu>
|
|
<DropdownMenuTrigger asChild>{children}</DropdownMenuTrigger>
|
|
<DropdownMenuContent>
|
|
<ConfirmDeleteDialog onOk={handleDelete}>
|
|
<DropdownMenuItem
|
|
className="text-state-error"
|
|
onSelect={(e) => {
|
|
e.preventDefault();
|
|
}}
|
|
onClick={(e) => {
|
|
e.stopPropagation();
|
|
}}
|
|
>
|
|
{t('common.delete')} <Trash2 />
|
|
</DropdownMenuItem>
|
|
</ConfirmDeleteDialog>
|
|
</DropdownMenuContent>
|
|
</DropdownMenu>
|
|
);
|
|
}
|