LibreChat/client/src/components/SidePanel/Agents/DuplicateAgent.tsx
Danny Avila 18ad89be2c
🤖 feat: Add Agent Duplication Functionality with Permission (#5022)
* 🤖 feat: Add Agent Duplication Functionality with Permission

* 🐛 fix: Enhance Agent Duplication Logic and Filter Sensitive Data

* refactor(agents/v1): reorganized variables and error logging

* refactor: remove duplication permission

* chore: update librechat-data-provider version to 0.7.64

* fix: optimize agent duplication

---------

Co-authored-by: Marco Beretta <81851188+berry-13@users.noreply.github.com>
2024-12-17 19:47:39 -05:00

50 lines
1.3 KiB
TypeScript

import { CopyIcon } from 'lucide-react';
import { useDuplicateAgentMutation } from '~/data-provider';
import { cn, removeFocusOutlines } from '~/utils';
import { useToastContext } from '~/Providers';
import { useLocalize } from '~/hooks';
export default function DuplicateAgent({ agent_id }: { agent_id: string }) {
const localize = useLocalize();
const { showToast } = useToastContext();
const duplicateAgent = useDuplicateAgentMutation({
onSuccess: () => {
showToast({
message: localize('com_ui_agent_duplicated'),
status: 'success',
});
},
onError: (error) => {
console.error(error);
showToast({
message: localize('com_ui_agent_duplicate_error'),
status: 'error',
});
},
});
if (!agent_id) {
return null;
}
const handleDuplicate = () => {
duplicateAgent.mutate({ agent_id });
};
return (
<button
className={cn(
'btn btn-neutral border-token-border-light relative h-9 rounded-lg font-medium',
removeFocusOutlines,
)}
aria-label={localize('com_ui_duplicate') + ' ' + localize('com_ui_agent')}
type="button"
onClick={handleDuplicate}
>
<div className="flex w-full items-center justify-center gap-2 text-primary">
<CopyIcon className="size-4" />
</div>
</button>
);
}