Spaces:
Paused
Paused
ragflow
/
web
/src
/pages
/add-knowledge
/components
/knowledge-file
/parsing-action-cell
/index.tsx
import { useShowDeleteConfirm, useTranslate } from '@/hooks/common-hooks'; | |
import { useRemoveDocument } from '@/hooks/document-hooks'; | |
import { IKnowledgeFile } from '@/interfaces/database/knowledge'; | |
import { api_host } from '@/utils/api'; | |
import { downloadFile } from '@/utils/file-util'; | |
import { | |
DeleteOutlined, | |
DownloadOutlined, | |
EditOutlined, | |
ToolOutlined, | |
} from '@ant-design/icons'; | |
import { Button, Dropdown, MenuProps, Space, Tooltip } from 'antd'; | |
import { isParserRunning } from '../utils'; | |
import styles from './index.less'; | |
interface IProps { | |
record: IKnowledgeFile; | |
setCurrentRecord: (record: IKnowledgeFile) => void; | |
showRenameModal: () => void; | |
showChangeParserModal: () => void; | |
} | |
const ParsingActionCell = ({ | |
record, | |
setCurrentRecord, | |
showRenameModal, | |
showChangeParserModal, | |
}: IProps) => { | |
const documentId = record.id; | |
const isRunning = isParserRunning(record.run); | |
const { t } = useTranslate('knowledgeDetails'); | |
const removeDocument = useRemoveDocument(); | |
const showDeleteConfirm = useShowDeleteConfirm(); | |
const onRmDocument = () => { | |
if (!isRunning) { | |
showDeleteConfirm({ onOk: () => removeDocument([documentId]) }); | |
} | |
}; | |
const onDownloadDocument = () => { | |
downloadFile({ | |
url: `${api_host}/document/get/${documentId}`, | |
filename: record.name, | |
}); | |
}; | |
const setRecord = () => { | |
setCurrentRecord(record); | |
}; | |
const onShowRenameModal = () => { | |
setRecord(); | |
showRenameModal(); | |
}; | |
const onShowChangeParserModal = () => { | |
setRecord(); | |
showChangeParserModal(); | |
}; | |
const chunkItems: MenuProps['items'] = [ | |
{ | |
key: '1', | |
label: ( | |
<div> | |
<Button type="link" onClick={onShowChangeParserModal}> | |
{t('chunkMethod')} | |
</Button> | |
</div> | |
), | |
}, | |
]; | |
return ( | |
<Space size={0}> | |
<Dropdown | |
menu={{ items: chunkItems }} | |
trigger={['click']} | |
disabled={isRunning} | |
> | |
<Button type="text" className={styles.iconButton}> | |
<ToolOutlined size={20} /> | |
</Button> | |
</Dropdown> | |
<Tooltip title={t('rename', { keyPrefix: 'common' })}> | |
<Button | |
type="text" | |
disabled={isRunning} | |
onClick={onShowRenameModal} | |
className={styles.iconButton} | |
> | |
<EditOutlined size={20} /> | |
</Button> | |
</Tooltip> | |
<Tooltip title={t('delete', { keyPrefix: 'common' })}> | |
<Button | |
type="text" | |
disabled={isRunning} | |
onClick={onRmDocument} | |
className={styles.iconButton} | |
> | |
<DeleteOutlined size={20} /> | |
</Button> | |
</Tooltip> | |
<Tooltip title={t('download', { keyPrefix: 'common' })}> | |
<Button | |
type="text" | |
disabled={isRunning} | |
onClick={onDownloadDocument} | |
className={styles.iconButton} | |
> | |
<DownloadOutlined size={20} /> | |
</Button> | |
</Tooltip> | |
</Space> | |
); | |
}; | |
export default ParsingActionCell; | |