import React, { useCallback, useMemo, useState } from 'react' import { RiFileUploadLine } from '@remixicon/react' import Divider from '../../base/divider' import { useTranslation } from 'react-i18next' import CreateFromDSLModal, { CreateFromDSLModalTab } from './create-options/create-from-dsl-modal' import { useRouter, useSearchParams } from 'next/navigation' import { useResetDatasetList } from '@/service/knowledge/use-dataset' const Footer = () => { const { t } = useTranslation() const [showImportModal, setShowImportModal] = useState(false) const searchParams = useSearchParams() const { replace } = useRouter() const dslUrl = searchParams.get('remoteInstallUrl') || undefined const resetDatasetList = useResetDatasetList() const activeTab = useMemo(() => { if (dslUrl) return CreateFromDSLModalTab.FROM_URL return undefined }, [dslUrl]) const openImportFromDSL = useCallback(() => { setShowImportModal(true) }, []) const onCloseImportModal = useCallback(() => { setShowImportModal(false) if (dslUrl) replace('/datasets/create-from-pipeline') }, [dslUrl, replace]) const onImportFromDSLSuccess = useCallback(() => { resetDatasetList() }, [resetDatasetList]) return (
) } export default React.memo(Footer)