mirror of
https://github.com/infiniflow/ragflow.git
synced 2025-12-26 17:16:52 +08:00
### What problem does this PR solve? Put the knowledge base list related hooks into use-knowledge-request.ts #3221 ### Type of change - [x] New Feature (non-breaking change which adds functionality)
54 lines
1.5 KiB
TypeScript
54 lines
1.5 KiB
TypeScript
import { useSetModalState } from '@/hooks/common-hooks';
|
|
import { useUpdateKnowledge } from '@/hooks/use-knowledge-request';
|
|
import { IKnowledge } from '@/interfaces/database/knowledge';
|
|
import { omit } from 'lodash';
|
|
import { useCallback, useState } from 'react';
|
|
|
|
export const useRenameDataset = () => {
|
|
const [dataset, setDataset] = useState<IKnowledge>({} as IKnowledge);
|
|
const {
|
|
visible: datasetRenameVisible,
|
|
hideModal: hideDatasetRenameModal,
|
|
showModal: showDatasetRenameModal,
|
|
} = useSetModalState();
|
|
const { saveKnowledgeConfiguration, loading } = useUpdateKnowledge(true);
|
|
|
|
const onDatasetRenameOk = useCallback(
|
|
async (name: string) => {
|
|
const ret = await saveKnowledgeConfiguration({
|
|
...omit(dataset, [
|
|
'id',
|
|
'update_time',
|
|
'nickname',
|
|
'tenant_avatar',
|
|
'tenant_id',
|
|
]),
|
|
kb_id: dataset.id,
|
|
name,
|
|
});
|
|
|
|
if (ret.code === 0) {
|
|
hideDatasetRenameModal();
|
|
}
|
|
},
|
|
[saveKnowledgeConfiguration, dataset, hideDatasetRenameModal],
|
|
);
|
|
|
|
const handleShowDatasetRenameModal = useCallback(
|
|
async (record: IKnowledge) => {
|
|
setDataset(record);
|
|
showDatasetRenameModal();
|
|
},
|
|
[showDatasetRenameModal],
|
|
);
|
|
|
|
return {
|
|
datasetRenameLoading: loading,
|
|
initialDatasetName: dataset?.name,
|
|
onDatasetRenameOk,
|
|
datasetRenameVisible,
|
|
hideDatasetRenameModal,
|
|
showDatasetRenameModal: handleShowDatasetRenameModal,
|
|
};
|
|
};
|