mirror of
https://github.com/langgenius/dify.git
synced 2026-05-13 08:57:28 +08:00
Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: jyong <718720800@qq.com> Co-authored-by: Yansong Zhang <916125788@qq.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: hj24 <mambahj24@gmail.com> Co-authored-by: hj24 <huangjian@dify.ai> Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Stephen Zhou <38493346+hyoban@users.noreply.github.com> Co-authored-by: CodingOnStar <hanxujiang@dify.com> Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: 非法操作 <hjlarry@163.com> Co-authored-by: Ayush Baluni <73417844+aayushbaluni@users.noreply.github.com> Co-authored-by: yyh <92089059+lyzno1@users.noreply.github.com> Co-authored-by: jimcody1995 <jjimcody@gmail.com> Co-authored-by: James <63717587+jamesrayammons@users.noreply.github.com> Co-authored-by: Yunlu Wen <yunlu.wen@dify.ai> Co-authored-by: Stephen Zhou <hi@hyoban.cc> Co-authored-by: Coding On Star <447357187@qq.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: jerryzai <jerryzh8710@protonmail.com> Co-authored-by: NVIDIAN <speedy.hpc@hotmail.com> Co-authored-by: ai-hpc <ai-hpc@users.noreply.github.com> Co-authored-by: Asuka Minato <i@asukaminato.eu.org> Co-authored-by: Junghwan <70629228+shaun0927@users.noreply.github.com> Co-authored-by: HeYinKazune <70251095+HeYin-OS@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: yyh <yuanyouhuilyz@gmail.com> Co-authored-by: Jingyi <jingyi.qi@dify.ai> Co-authored-by: Claude Sonnet 4.6 <noreply@anthropic.com> Co-authored-by: sxxtony <166789813+sxxtony@users.noreply.github.com>
67 lines
2.6 KiB
TypeScript
67 lines
2.6 KiB
TypeScript
'use client'
|
|
import type { ToolWithProvider } from '@/app/components/workflow/types'
|
|
import {
|
|
RiAddCircleFill,
|
|
RiArrowRightUpLine,
|
|
RiBookOpenLine,
|
|
} from '@remixicon/react'
|
|
import { useMemo, useState } from 'react'
|
|
import { useTranslation } from 'react-i18next'
|
|
import { useAppContext } from '@/context/app-context'
|
|
import { useDocLink } from '@/context/i18n'
|
|
import { useCreateMCP } from '@/service/use-tools'
|
|
import MCPModal from './modal'
|
|
|
|
type Props = {
|
|
handleCreate: (provider: ToolWithProvider) => void
|
|
}
|
|
|
|
const NewMCPCard = ({ handleCreate }: Props) => {
|
|
const { t } = useTranslation()
|
|
const docLink = useDocLink()
|
|
const { isCurrentWorkspaceManager } = useAppContext()
|
|
|
|
const { mutateAsync: createMCP } = useCreateMCP()
|
|
|
|
const create = async (info: any) => {
|
|
const provider = await createMCP(info)
|
|
handleCreate(provider)
|
|
}
|
|
|
|
const linkUrl = useMemo(() => docLink('/use-dify/build/mcp'), [docLink])
|
|
|
|
const [showModal, setShowModal] = useState(false)
|
|
|
|
return (
|
|
<>
|
|
{isCurrentWorkspaceManager && (
|
|
<div className="col-span-1 flex min-h-[108px] cursor-pointer flex-col rounded-xl bg-background-default-dimmed transition-all duration-200 ease-in-out">
|
|
<div className="group grow rounded-t-xl" onClick={() => setShowModal(true)}>
|
|
<div className="flex shrink-0 items-center p-4 pb-3">
|
|
<div className="flex h-10 w-10 items-center justify-center rounded-lg border border-dashed border-divider-deep group-hover:border-solid group-hover:border-state-accent-hover-alt group-hover:bg-state-accent-hover">
|
|
<RiAddCircleFill className="h-4 w-4 text-text-quaternary group-hover:text-text-accent" />
|
|
</div>
|
|
<div className="ml-3 system-md-semibold text-text-secondary group-hover:text-text-accent">{t('mcp.create.cardTitle', { ns: 'tools' })}</div>
|
|
</div>
|
|
</div>
|
|
<div className="rounded-b-xl border-t-[0.5px] border-divider-subtle px-4 py-3 text-text-tertiary hover:text-text-accent">
|
|
<a href={linkUrl} target="_blank" rel="noopener noreferrer" className="flex items-center space-x-1">
|
|
<RiBookOpenLine className="h-3 w-3 shrink-0" />
|
|
<div className="grow truncate system-xs-regular" title={t('mcp.create.cardLink', { ns: 'tools' }) || ''}>{t('mcp.create.cardLink', { ns: 'tools' })}</div>
|
|
<RiArrowRightUpLine className="h-3 w-3 shrink-0" />
|
|
</a>
|
|
</div>
|
|
</div>
|
|
)}
|
|
{showModal && (
|
|
<MCPModal
|
|
show={showModal}
|
|
onConfirm={create}
|
|
onHide={() => setShowModal(false)}
|
|
/>
|
|
)}
|
|
</>
|
|
)
|
|
}
|
|
export default NewMCPCard
|