mirror of
https://github.com/danny-avila/LibreChat.git
synced 2026-02-20 17:34:10 +01:00
51 lines
1.3 KiB
TypeScript
51 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>
|
||
|
|
);
|
||
|
|
}
|