rag pipeline main
parent
97cf6b2d65
commit
076924bbd6
@ -0,0 +1,39 @@
|
|||||||
|
import {
|
||||||
|
useMemo,
|
||||||
|
} from 'react'
|
||||||
|
import { WorkflowWithInnerContext } from '@/app/components/workflow'
|
||||||
|
import type { WorkflowProps } from '@/app/components/workflow'
|
||||||
|
import RagPipelineChildren from './rag-pipeline-children'
|
||||||
|
import {
|
||||||
|
useAvailableNodesMetaData,
|
||||||
|
} from '../hooks'
|
||||||
|
|
||||||
|
type RagPipelineMainProps = Pick<WorkflowProps, 'nodes' | 'edges' | 'viewport'>
|
||||||
|
const RagPipelineMain = ({
|
||||||
|
nodes,
|
||||||
|
edges,
|
||||||
|
viewport,
|
||||||
|
}: RagPipelineMainProps) => {
|
||||||
|
const availableNodesMetaData = useAvailableNodesMetaData()
|
||||||
|
|
||||||
|
const hooksStore = useMemo(() => {
|
||||||
|
return {
|
||||||
|
availableNodesMetaData,
|
||||||
|
}
|
||||||
|
}, [
|
||||||
|
availableNodesMetaData,
|
||||||
|
])
|
||||||
|
|
||||||
|
return (
|
||||||
|
<WorkflowWithInnerContext
|
||||||
|
nodes={nodes}
|
||||||
|
edges={edges}
|
||||||
|
viewport={viewport}
|
||||||
|
hooksStore={hooksStore as any}
|
||||||
|
>
|
||||||
|
<RagPipelineChildren />
|
||||||
|
</WorkflowWithInnerContext>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default RagPipelineMain
|
||||||
@ -0,0 +1 @@
|
|||||||
|
export * from './use-available-nodes-meta-data'
|
||||||
@ -0,0 +1,47 @@
|
|||||||
|
import { useMemo } from 'react'
|
||||||
|
import { useTranslation } from 'react-i18next'
|
||||||
|
import { useGetLanguage } from '@/context/i18n'
|
||||||
|
import { WORKFLOW_COMMON_NODES } from '@/app/components/workflow/constants/node'
|
||||||
|
import type { AvailableNodesMetaData } from '@/app/components/workflow/hooks-store/store'
|
||||||
|
|
||||||
|
export const useAvailableNodesMetaData = () => {
|
||||||
|
const { t } = useTranslation()
|
||||||
|
const language = useGetLanguage()
|
||||||
|
|
||||||
|
const mergedNodesMetaData = useMemo(() => [
|
||||||
|
...WORKFLOW_COMMON_NODES,
|
||||||
|
], [])
|
||||||
|
|
||||||
|
const prefixLink = useMemo(() => {
|
||||||
|
if (language === 'zh_Hans')
|
||||||
|
return 'https://docs.dify.ai/zh-hans/guides/workflow/node/'
|
||||||
|
|
||||||
|
return 'https://docs.dify.ai/guides/workflow/node/'
|
||||||
|
}, [language])
|
||||||
|
|
||||||
|
const availableNodesMetaData = useMemo(() => mergedNodesMetaData.map((node) => {
|
||||||
|
return {
|
||||||
|
...node,
|
||||||
|
defaultValue: {
|
||||||
|
...node.defaultValue,
|
||||||
|
type: node.type,
|
||||||
|
},
|
||||||
|
title: t(`workflow.blocks.${node.type}`),
|
||||||
|
description: t(`workflow.blocksAbout.${node.type}`),
|
||||||
|
helpLinkUri: `${prefixLink}${node.helpLinkUri}`,
|
||||||
|
|
||||||
|
}
|
||||||
|
}), [mergedNodesMetaData, t, prefixLink])
|
||||||
|
|
||||||
|
const availableNodesMetaDataMap = useMemo(() => availableNodesMetaData.reduce((acc, node) => {
|
||||||
|
acc![node.type] = node
|
||||||
|
return acc
|
||||||
|
}, {} as AvailableNodesMetaData['nodesMap']), [availableNodesMetaData])
|
||||||
|
|
||||||
|
return useMemo(() => {
|
||||||
|
return {
|
||||||
|
nodes: availableNodesMetaData,
|
||||||
|
nodesMap: availableNodesMetaDataMap,
|
||||||
|
}
|
||||||
|
}, [availableNodesMetaData, availableNodesMetaDataMap])
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue