'use client' import { useMemo, useState } from 'react' import { useTranslation } from 'react-i18next' import { useContext } from 'use-context-selector' import { RiAddLine, } from '@remixicon/react' import type { CustomCollectionBackend } from '../types' import I18n from '@/context/i18n' import { getLanguage } from '@/i18n/language' import { BookOpen01 } from '@/app/components/base/icons/src/vender/line/education' import { ArrowUpRight } from '@/app/components/base/icons/src/vender/line/arrows' import EditCustomToolModal from '@/app/components/tools/edit-custom-collection-modal' import { createCustomCollection } from '@/service/tools' import Toast from '@/app/components/base/toast' import { useAppContext } from '@/context/app-context' type Props = { onRefreshData: () => void } const Contribute = ({ onRefreshData }: Props) => { const { t } = useTranslation() const { locale } = useContext(I18n) const language = getLanguage(locale) const { isCurrentWorkspaceManager } = useAppContext() const linkUrl = useMemo(() => { if (language.startsWith('zh_')) return 'https://docs.dify.ai/zh-hans/guides/tools#ru-he-chuang-jian-zi-ding-yi-gong-ju' return 'https://docs.dify.ai/guides/tools#how-to-create-custom-tools' }, [language]) const [isShowEditCollectionToolModal, setIsShowEditCustomCollectionModal] = useState(false) const doCreateCustomToolCollection = async (data: CustomCollectionBackend) => { await createCustomCollection(data) Toast.notify({ type: 'success', message: t('common.api.actionSuccess'), }) setIsShowEditCustomCollectionModal(false) onRefreshData() } return ( <> {isCurrentWorkspaceManager && (
setIsShowEditCustomCollectionModal(true)}>
{t('tools.createCustomTool')}
{t('tools.customToolTip')}
)} {isShowEditCollectionToolModal && ( setIsShowEditCustomCollectionModal(false)} onAdd={doCreateCustomToolCollection} /> )} ) } export default Contribute