import { createFileRoute } from '@tanstack/react-router' import { route } from '@/constants/routes' import { useState } from 'react' import { useAssistant } from '@/hooks/useAssistant' import HeaderPage from '@/containers/HeaderPage' import { IconCirclePlus, IconPencil, IconTrash } from '@tabler/icons-react' import AddEditAssistant from '@/containers/dialogs/AddEditAssistant' import { Dialog, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, } from '@/components/ui/dialog' import { Button } from '@/components/ui/button' import { AvatarEmoji } from '@/containers/AvatarEmoji' // eslint-disable-next-line @typescript-eslint/no-explicit-any export const Route = createFileRoute(route.assistant as any)({ component: Assistant, }) function Assistant() { const { assistants, addAssistant, updateAssistant, deleteAssistant } = useAssistant() const [open, setOpen] = useState(false) const [editingKey, setEditingKey] = useState(null) const [deleteConfirmOpen, setDeleteConfirmOpen] = useState(false) const [deletingId, setDeletingId] = useState(null) const handleDelete = (id: string) => { setDeletingId(id) setDeleteConfirmOpen(true) } const confirmDelete = () => { if (deletingId) { deleteAssistant(deletingId) setDeleteConfirmOpen(false) setDeletingId(null) } } const handleSave = (assistant: Assistant) => { if (editingKey) { updateAssistant(assistant) } else { addAssistant(assistant) } setOpen(false) setEditingKey(null) } return (
Assistants
{assistants.map((assistant) => (

{assistant.name}

{/*
*/}
{ setEditingKey(assistant.id) setOpen(true) }} >
handleDelete(assistant.id)} >

{assistant.description}

))}
{ setEditingKey(null) setOpen(true) }} >
a.id === editingKey) : undefined } onSave={handleSave} /> Delete Assistant Are you sure you want to delete this assistant? This action cannot be undone.
) }