/* * @Author: ZhaoYing * @Date: 2026-02-03 14:10:20 * @Last Modified by: ZhaoYing * @Last Modified time: 2026-04-14 16:55:26 */ import { type FC, useEffect, useState, useRef } from 'react' import { useParams, useNavigate } from 'react-router-dom'; import { useTranslation } from 'react-i18next'; import { App, Row, Col, Tooltip, Space, Button, Flex } from 'antd' import PageHeader from '@/components/Layout/PageHeader' import { getOntologyClassList, deleteOntologyClass } from '@/api/ontology' import type { OntologyClassData, OntologyClassModalRef, OntologyClassExtractModalRef, OntologyClassItem } from '@/views/Ontology/types' import RbCard from '@/components/RbCard'; import OntologyClassModal from '../components/OntologyClassModal' import SearchInput from '@/components/SearchInput'; import OntologyClassExtractModal from '../components/OntologyClassExtractModal' import BodyWrapper from '@/components/Empty/BodyWrapper' import Tag from '@/components/Tag' import { useI18n } from '@/store/locale' /** * Ontology detail page component * Displays and manages classes within a specific ontology scene */ const Detail: FC = () => { // Hooks const { t } = useTranslation(); const navigate = useNavigate() const { id } = useParams() const { modal, message } = App.useApp() const { language } = useI18n() // Refs const ontologyClassModalRef = useRef(null) const ontologyClassExtractModalRef = useRef(null) // State const [query, setQuery] = useState<{ class_name?: string; }>({}); const [loading, setLoading] = useState(false) const [data, setData] = useState({} as OntologyClassData) // Fetch data when component mounts or dependencies change useEffect(() => { getData() }, [id, query]) useEffect(() => { document.title = `${data.scene_name} - ${t('memoryBear')}`; }, [data.scene_name, language]) /** * Fetch ontology class list data */ const getData = () => { if (!id) return; setLoading(true) getOntologyClassList({ ...query, scene_id: id }) .then(res => { setData(res as OntologyClassData) }) .finally(() => { setLoading(false) }) } /** * Delete an ontology class with confirmation * @param item - The class item to delete */ const handleDelete = (item: OntologyClassItem) => { modal.confirm({ title: t('common.confirmDeleteDesc', { name: item.class_name }), okText: t('common.delete'), cancelText: t('common.cancel'), okType: 'danger', onOk: () => { deleteOntologyClass(item.class_id) .then(() => { getData(); message.success(t('common.deleteSuccess')) }) } }) } /** * Open modal to add a new class */ const handleAdd = () => { ontologyClassModalRef.current?.handleOpen(data.scene_id) } /** * Open modal to extract classes using LLM */ const handleExtract = () => { ontologyClassExtractModalRef.current?.handleOpen(data) } return ( <> {data.scene_name} {data.is_system_default ? {t('common.default')} : undefined}
} extra={ {data.is_system_default ? undefined : ( )} navigate(-1)}>
{t('common.return')}
} />
setQuery({ class_name: value })} className="rb:w-full!" /> {data.items?.map(item => ( handleDelete(item)} >
)} >
{item.class_description}
))}
) } export default Detail