90 lines
2.4 KiB
TypeScript
90 lines
2.4 KiB
TypeScript
'use client';
|
|
import { useState } from 'react';
|
|
import { useRouter } from 'next/navigation';
|
|
import { AlertModal } from '@/components/modal/alert-modal';
|
|
import { Button } from '@repo/shadcn/button';
|
|
import {
|
|
Tooltip,
|
|
TooltipContent,
|
|
TooltipProvider,
|
|
TooltipTrigger,
|
|
} from '@repo/shadcn/tooltip';
|
|
import { Edit, Trash } from 'lucide-react';
|
|
import { SurveyTable } from '@/feactures/users/schemas/users';
|
|
import { useDeleteUser } from '@/feactures/users/hooks/use-mutation-users';
|
|
import { AccountPlanModal } from '../user-modal';
|
|
|
|
interface CellActionProps {
|
|
data: SurveyTable;
|
|
}
|
|
|
|
export const CellAction: React.FC<CellActionProps> = ({ data }) => {
|
|
const [loading, setLoading] = useState(false);
|
|
const [open, setOpen] = useState(false);
|
|
const [edit, setEdit] = useState(false);
|
|
const { mutate: deleteUser } = useDeleteUser();
|
|
|
|
const onConfirm = async () => {
|
|
try {
|
|
setLoading(true);
|
|
deleteUser(data.id!);
|
|
setOpen(false);
|
|
} catch (error) {
|
|
console.error('Error:', error);
|
|
} finally {
|
|
setLoading(false);
|
|
}
|
|
};
|
|
|
|
return (
|
|
<>
|
|
<AlertModal
|
|
isOpen={open}
|
|
onClose={() => setOpen(false)}
|
|
onConfirm={onConfirm}
|
|
loading={loading}
|
|
title="¿Estás seguro que desea deshabilitar este usuario?"
|
|
description="Esta acción no se puede deshacer."
|
|
/>
|
|
|
|
<AccountPlanModal open={edit} onOpenChange={setEdit} defaultValues={data}/>
|
|
|
|
<div className="flex gap-1">
|
|
<TooltipProvider>
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<Button
|
|
variant="outline"
|
|
size="icon"
|
|
onClick={() => setEdit(true)}
|
|
>
|
|
<Edit className="h-4 w-4" />
|
|
</Button>
|
|
</TooltipTrigger>
|
|
<TooltipContent>
|
|
<p>Editar</p>
|
|
</TooltipContent>
|
|
</Tooltip>
|
|
</TooltipProvider>
|
|
|
|
<TooltipProvider>
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<Button
|
|
variant="outline"
|
|
size="icon"
|
|
onClick={() => setOpen(true)}
|
|
>
|
|
<Trash className="h-4 w-4" />
|
|
</Button>
|
|
</TooltipTrigger>
|
|
<TooltipContent>
|
|
<p>Deshabilitar</p>
|
|
</TooltipContent>
|
|
</Tooltip>
|
|
</TooltipProvider>
|
|
</div>
|
|
</>
|
|
);
|
|
};
|