mirror of
https://github.com/ItzCrazyKns/Perplexica.git
synced 2025-10-25 16:38:16 +00:00
119 lines
4.3 KiB
TypeScript
119 lines
4.3 KiB
TypeScript
import { Dialog, DialogPanel } from '@headlessui/react';
|
|
import { Loader2, Trash2 } from 'lucide-react';
|
|
import { useState } from 'react';
|
|
import { AnimatePresence, motion } from 'framer-motion';
|
|
import { ConfigModelProvider } from '@/lib/config/types';
|
|
import { toast } from 'sonner';
|
|
|
|
const DeleteProvider = ({
|
|
modelProvider,
|
|
setProviders,
|
|
}: {
|
|
modelProvider: ConfigModelProvider;
|
|
setProviders: React.Dispatch<React.SetStateAction<ConfigModelProvider[]>>;
|
|
}) => {
|
|
const [open, setOpen] = useState(false);
|
|
const [loading, setLoading] = useState(false);
|
|
|
|
const handleDelete = async (e: React.FormEvent) => {
|
|
e.preventDefault();
|
|
setLoading(true);
|
|
try {
|
|
const res = await fetch(`/api/providers/${modelProvider.id}`, {
|
|
method: 'DELETE',
|
|
headers: {
|
|
'Content-Type': 'application/json',
|
|
},
|
|
});
|
|
|
|
if (!res.ok) {
|
|
throw new Error('Failed to delete provider');
|
|
}
|
|
|
|
setProviders((prev) => {
|
|
return prev.filter((p) => p.id !== modelProvider.id);
|
|
});
|
|
|
|
toast.success('Provider deleted successfully.');
|
|
} catch (error) {
|
|
console.error('Error deleting provider:', error);
|
|
toast.error('Failed to delete provider.');
|
|
} finally {
|
|
setLoading(false);
|
|
}
|
|
};
|
|
|
|
return (
|
|
<>
|
|
<button
|
|
onClick={(e) => {
|
|
e.stopPropagation();
|
|
setOpen(true);
|
|
}}
|
|
className="group p-1.5 rounded-md hover:bg-light-200 hover:dark:bg-dark-200 transition-colors group"
|
|
title="Delete provider"
|
|
>
|
|
<Trash2
|
|
size={14}
|
|
className="text-black/60 dark:text-white/60 group-hover:text-red-500 group-hover:dark:text-red-400"
|
|
/>
|
|
</button>
|
|
<AnimatePresence>
|
|
{open && (
|
|
<Dialog
|
|
static
|
|
open={open}
|
|
onClose={() => setOpen(false)}
|
|
className="relative z-[60]"
|
|
>
|
|
<motion.div
|
|
initial={{ opacity: 0 }}
|
|
animate={{ opacity: 1 }}
|
|
exit={{ opacity: 0 }}
|
|
transition={{ duration: 0.1 }}
|
|
className="fixed inset-0 flex w-screen items-center justify-center p-4 bg-black/30 backdrop-blur-sm"
|
|
>
|
|
<DialogPanel className="w-full mx-4 lg:w-[600px] max-h-[85vh] flex flex-col border bg-light-primary dark:bg-dark-primary border-light-secondary dark:border-dark-secondary rounded-lg">
|
|
<div className="px-6 pt-6 pb-4">
|
|
<h3 className="text-black/90 dark:text-white/90 font-medium">
|
|
Delete provider
|
|
</h3>
|
|
</div>
|
|
<div className="border-t border-light-200 dark:border-dark-200" />
|
|
<div className="flex-1 overflow-y-auto px-6 py-4">
|
|
<p className="text-SM text-black/60 dark:text-white/60">
|
|
Are you sure you want to delete the provider "
|
|
{modelProvider.name}"? This action cannot be undone.
|
|
</p>
|
|
</div>
|
|
<div className="px-6 py-6 flex justify-end space-x-2">
|
|
<button
|
|
disabled={loading}
|
|
onClick={() => setOpen(false)}
|
|
className="px-4 py-2 rounded-lg text-sm border border-light-200 dark:border-dark-200 text-black dark:text-white bg-light-secondary/50 dark:bg-dark-secondary/50 hover:bg-light-secondary hover:dark:bg-dark-secondary hover:border-light-300 hover:dark:border-dark-300 flex flex-row items-center space-x-1 active:scale-95 transition duration-200"
|
|
>
|
|
Cancel
|
|
</button>
|
|
<button
|
|
disabled={loading}
|
|
onClick={handleDelete}
|
|
className="px-4 py-2 rounded-lg text-sm bg-red-500 text-white font-medium disabled:opacity-85 hover:opacity-85 active:scale-95 transition duration-200"
|
|
>
|
|
{loading ? (
|
|
<Loader2 className="animate-spin" size={16} />
|
|
) : (
|
|
'Delete'
|
|
)}
|
|
</button>
|
|
</div>
|
|
</DialogPanel>
|
|
</motion.div>
|
|
</Dialog>
|
|
)}
|
|
</AnimatePresence>
|
|
</>
|
|
);
|
|
};
|
|
|
|
export default DeleteProvider;
|