Spaces:
Running
Running
import { useQePrompts, } from "@/api/qePrompts/hooks"; | |
import { QePrompt } from "@/api/qePrompts/types"; | |
import React, { useState } from 'react'; | |
import { GoStar, GoStarFill, GoTrash } from 'react-icons/go'; | |
import Modal from 'react-modal'; | |
import './QePromptList.scss'; | |
import QePromptModal from './QePromptModal'; | |
Modal.setAppElement('#root'); | |
const QePromptList: React.FC = () => { | |
const { prompts, isLoading, error, createPrompt, updatePrompt, setAsDefaultPrompt, deletePrompt } = useQePrompts(); | |
const [sortField, setSortField] = useState<keyof QePrompt | 'created_at'>('id'); | |
const [sortDirection, setSortDirection] = useState<'asc' | 'desc'>('asc'); | |
const [selectedPrompt, setSelectedPrompt] = useState<QePrompt | null>(null); | |
const [isModalOpen, setIsModalOpen] = useState(false); | |
const [isEditMode, setIsEditMode] = useState(false); | |
const handleSort = (field: keyof QePrompt | 'created_at') => { | |
const newDirection = sortField === field && sortDirection === 'asc' ? 'desc' : 'asc'; | |
setSortField(field); | |
setSortDirection(newDirection); | |
const sortedPrompts = [...prompts].sort((a, b) => { | |
const aValue = field === 'created_at' ? a.created_at || '' : a[field]; | |
const bValue = field === 'created_at' ? b.created_at || '' : b[field]; | |
return newDirection === 'asc' ? (aValue > bValue ? 1 : -1) : (aValue < bValue ? 1 : -1); | |
}); | |
prompts.splice(0, prompts.length, ...sortedPrompts); | |
}; | |
const openEditModal = (prompt: QePrompt) => { | |
setSelectedPrompt(prompt); | |
setIsEditMode(true); | |
setIsModalOpen(true); | |
}; | |
const openCreateModal = () => { | |
setSelectedPrompt(null); // Ничего не передаем, запрос будет в модалке | |
setIsEditMode(false); | |
setIsModalOpen(true); | |
}; | |
const closeModal = () => { | |
setSelectedPrompt(null); | |
setIsModalOpen(false); | |
}; | |
const handleSave = async (prompt: QePrompt | Omit<QePrompt, 'id' | 'created_at'>) => { | |
if (isEditMode && 'id' in prompt) { | |
await updatePrompt(prompt as QePrompt); | |
} else { | |
await createPrompt(prompt as Omit<QePrompt, 'id' | 'created_at'>); | |
} | |
}; | |
const handleDelete = async (id: number) => { | |
if (window.confirm('Удаляем версию промпта?')) { | |
await deletePrompt(id); | |
} | |
}; | |
const handleSetDefault = async (id: number) => { | |
await setAsDefaultPrompt(id); | |
}; | |
if (isLoading) return <div>Loading...</div>; | |
if (error) return <div>Error: {error}</div>; | |
return ( | |
<div className="qe-prompt-list"> | |
<h1>Промпты Query Expansion</h1> | |
<button className="create-button" onClick={openCreateModal}> | |
Добавить промпт | |
</button> | |
<div className="table-container"> | |
<div className="table-header"> | |
<div className="table-cell"></div> | |
<div className="table-cell" onClick={() => handleSort('created_at')}> | |
Промпты | |
</div> | |
<div className="table-cell"></div> | |
</div> | |
{prompts.map(prompt => ( | |
<div key={prompt.id} className="table-row"> | |
<div className="table-cell"> | |
<button | |
className="set-default-button" | |
onClick={() => handleSetDefault(prompt.id)} | |
> | |
{prompt.is_default ? <GoStarFill size={20} /> : <GoStar size={20} />} | |
</button> | |
</div> | |
<div className="table-cell" onClick={() => openEditModal(prompt)}> | |
{prompt.name} | |
</div> | |
{/* <div className="table-cell" onClick={() => openEditModal(prompt)}> | |
{prompt.created_at || 'N/A'} | |
</div> */} | |
<div className="table-cell"> | |
<button className="delete-button" onClick={() => handleDelete(prompt.id)}> | |
<GoTrash size={20} /> | |
</button> | |
</div> | |
</div> | |
))} | |
</div> | |
<QePromptModal | |
isOpen={isModalOpen} | |
onRequestClose={closeModal} | |
prompt={selectedPrompt} | |
onSave={handleSave} | |
isEditMode={isEditMode} | |
/> | |
</div> | |
); | |
}; | |
export default QePromptList; |