'use client' import type { MouseEventHandler } from 'react' import React from 'react' import { useEffect } from 'react' import { useState } from 'react' import { RiCloseLine } from '@remixicon/react' import { useContext } from 'use-context-selector' import { useTranslation } from 'react-i18next' import cn from '@/utils/classnames' import Button from '@/app/components/base/button' import Input from '@/app/components/base/input' import Textarea from '@/app/components/base/textarea' import { SimpleSelect } from '@/app/components/base/select' import Modal from '@/app/components/base/modal' import { ToastContext } from '@/app/components/base/toast' import type { DataSet } from '@/models/datasets' import { tagBindingsCreate, tagBindingsRemove, updateDatasetSetting } from '@/service/datasets' import { useModalContext } from '@/context/modal-context' import { fetchDatasetsPermission, fetchDeptUserTree, fetchTypes, setDatasetsPermission, } from '@/service/common' import { TreeSelect as AntdTreeSelect } from 'antd' type RenameDatasetModalProps = { show: boolean dataset: DataSet onSuccess?: () => void onClose: () => void } const RenameDatasetModal = ({ show, dataset, onSuccess, onClose }: RenameDatasetModalProps) => { const { t } = useTranslation() const { notify } = useContext(ToastContext) const [loading, setLoading] = useState(false) const [name, setName] = useState(dataset.name) const [description, setDescription] = useState(dataset.description) const [externalKnowledgeId, setExternalKnowledgeId] = useState(dataset.external_knowledge_info.external_knowledge_id) const [externalKnowledgeApiId, setExternalKnowledgeApiId] = useState(dataset.external_knowledge_info.external_knowledge_api_id) const [type, setType] = useState(dataset.categories[0]?.id) const [editAuth, setEditAuth] = useState() const [editUserIds, setEditUserIds] = useState([]) const [lookUserIds, setLookUserIds] = useState([]) const [options, setOptions] = useState([]) useEffect(() => { fetchTypes({ url: '/tags/page', params: { page: 1, limit: 99999, tag_type: 'knowledge_category', }, }).then((res: any) => { setOptions(res.data.map((v: any) => ({ name: v.name, value: v.id })) || []) }) }, []) const onConfirm: MouseEventHandler = async () => { if (!name.trim()) { notify({ type: 'error', message: t('datasetSettings.form.nameError') }) return } try { setLoading(true) const body: Partial & { external_knowledge_id?: string; external_knowledge_api_id?: string } = { name, description, } if (externalKnowledgeId && externalKnowledgeApiId) { body.external_knowledge_id = externalKnowledgeId body.external_knowledge_api_id = externalKnowledgeApiId } await updateDatasetSetting({ datasetId: dataset.id, body, }) if (type) { if (dataset.categories[0]) { await tagBindingsRemove({ body: { tag_id: dataset.categories[0].id, target_id: dataset.id, type: 'knowledge_category', }, }) } await tagBindingsCreate({ body: { tag_ids: [type], target_id: dataset.id, type: 'knowledge_category', }, }) } await setDatasetsPermission({ url: `/datasets/${dataset.id}/permission`, body: { edit_auth: editAuth, edit_permission: editUserIds.map((v: any) => ({ id: v })), read_permission: lookUserIds.map((v: any) => ({ id: v })), }, }) notify({ type: 'success', message: t('common.actionMsg.modifiedSuccessfully') }) if (onSuccess) onSuccess() onClose() } catch (e) { notify({ type: 'error', message: t('common.actionMsg.modifiedUnsuccessfully') }) } finally { setLoading(false) } } const { setShowAccountSettingModal } = useModalContext() const optionsEditAuth = [ { name: '本账号', value: 1 }, { name: '本部门', value: 2 }, ] const [optionsDeptUser, setOptionsDeptUser] = useState([]) const [optionsDeptUserEdit, setOptionsDeptUserEdit] = useState([]) useEffect(() => { fetchDatasetsPermission({ url: `/datasets/${dataset.id}/permission`, }).then((res: any) => { setEditAuth(res.edit_auth) setEditUserIds(res.edit_permission.map((v: any) => v.id)) setLookUserIds(res.read_permission.map((v: any) => v.id)) }) }, []) useEffect(() => { fetchDeptUserTree({ url: '/dept/dept-accounts', }).then((res: any) => { const deep = (arr: any) => { return arr.map((v: any) => { v.treeId = v.dept_id || v.account_id v.treeName = v.dept_name || v.email if (v.children?.length > 0) v.treeChildren = deep(v.children) else if (v.accounts?.length > 0) v.treeChildren = deep(v.accounts) return v }) } setOptionsDeptUser(deep(res.data) || []) }) }, []) useEffect(() => { fetchDeptUserTree({ url: '/dept/dept-accounts', }).then((res: any) => { const deep = (arr: any) => { return arr.map((v: any) => { v.treeId = v.dept_id || v.account_id v.treeName = v.dept_name || v.email if (v.children?.length > 0) v.treeChildren = deep(v.children) else if (v.accounts?.length > 0) v.treeChildren = deep(v.accounts) return v }) } setOptionsDeptUserEdit(deep(res.data) || []) }) }, []) return ( { }} >
{t('datasetSettings.title')}
分类管理
setShowAccountSettingModal({ payload: 'type' })}>设置
{ setType(i.value) }} items={options} allowSearch={false} />
{t('datasetSettings.form.name')}
setName(e.target.value)} className='h-9' placeholder={t('datasetSettings.form.namePlaceholder') || ''} />
{t('datasetSettings.form.desc')}