mirror of
https://github.com/infiniflow/ragflow.git
synced 2025-12-08 20:42:30 +08:00
### What problem does this PR solve? Fix: Refactoring and enhancing the functionality of the delete confirmation dialog component - Refactoring and enhancing the functionality of the delete confirmation dialog component - Modifying the style of the user center ### Type of change - [x] Bug Fix (non-breaking change which fixes an issue)
79 lines
2.2 KiB
TypeScript
79 lines
2.2 KiB
TypeScript
import {
|
|
ConfirmDeleteDialog,
|
|
ConfirmDeleteDialogNode,
|
|
} from '@/components/confirm-delete-dialog';
|
|
import {
|
|
DropdownMenu,
|
|
DropdownMenuContent,
|
|
DropdownMenuItem,
|
|
DropdownMenuSeparator,
|
|
DropdownMenuTrigger,
|
|
} from '@/components/ui/dropdown-menu';
|
|
import { useDeleteAgent } from '@/hooks/use-agent-request';
|
|
import { IFlow } from '@/interfaces/database/agent';
|
|
import { PenLine, Trash2 } from 'lucide-react';
|
|
import { MouseEventHandler, PropsWithChildren, useCallback } from 'react';
|
|
import { useTranslation } from 'react-i18next';
|
|
import { useRenameAgent } from './use-rename-agent';
|
|
|
|
export function AgentDropdown({
|
|
children,
|
|
showAgentRenameModal,
|
|
agent: agent,
|
|
}: PropsWithChildren &
|
|
Pick<ReturnType<typeof useRenameAgent>, 'showAgentRenameModal'> & {
|
|
agent: IFlow;
|
|
}) {
|
|
const { t } = useTranslation();
|
|
const { deleteAgent } = useDeleteAgent();
|
|
|
|
const handleShowAgentRenameModal: MouseEventHandler<HTMLDivElement> =
|
|
useCallback(
|
|
(e) => {
|
|
e.stopPropagation();
|
|
showAgentRenameModal(agent);
|
|
},
|
|
[agent, showAgentRenameModal],
|
|
);
|
|
|
|
const handleDelete: MouseEventHandler<HTMLDivElement> = useCallback(() => {
|
|
deleteAgent([agent.id]);
|
|
}, [agent.id, deleteAgent]);
|
|
|
|
return (
|
|
<DropdownMenu>
|
|
<DropdownMenuTrigger asChild>{children}</DropdownMenuTrigger>
|
|
<DropdownMenuContent>
|
|
<DropdownMenuItem onClick={handleShowAgentRenameModal}>
|
|
{t('common.rename')} <PenLine />
|
|
</DropdownMenuItem>
|
|
<DropdownMenuSeparator />
|
|
<ConfirmDeleteDialog
|
|
onOk={handleDelete}
|
|
title={t('deleteModal.delAgent')}
|
|
content={{
|
|
node: (
|
|
<ConfirmDeleteDialogNode
|
|
avatar={{ avatar: agent.avatar, name: agent.title }}
|
|
name={agent.title}
|
|
/>
|
|
),
|
|
}}
|
|
>
|
|
<DropdownMenuItem
|
|
className="text-state-error"
|
|
onSelect={(e) => {
|
|
e.preventDefault();
|
|
}}
|
|
onClick={(e) => {
|
|
e.stopPropagation();
|
|
}}
|
|
>
|
|
{t('common.delete')} <Trash2 />
|
|
</DropdownMenuItem>
|
|
</ConfirmDeleteDialog>
|
|
</DropdownMenuContent>
|
|
</DropdownMenu>
|
|
);
|
|
}
|