mirror of
https://github.com/langgenius/dify.git
synced 2026-04-24 00:59:19 +08:00
62 lines
1.7 KiB
TypeScript
62 lines
1.7 KiB
TypeScript
import { memo } from 'react'
|
|
import type { NodeProps } from 'reactflow'
|
|
import {
|
|
Handle,
|
|
Position,
|
|
} from 'reactflow'
|
|
import type { SelectedNode } from '../types'
|
|
import { BlockEnum } from '../types'
|
|
import {
|
|
NodeComponentMap,
|
|
PanelComponentMap,
|
|
} from './constants'
|
|
import BaseNode from './_base/node'
|
|
import BasePanel from './_base/panel'
|
|
|
|
const CustomNode = memo((props: NodeProps) => {
|
|
const nodeData = props.data
|
|
const NodeComponent = NodeComponentMap[nodeData.type]
|
|
|
|
return (
|
|
<>
|
|
<Handle
|
|
type='target'
|
|
position={Position.Left}
|
|
className={`
|
|
!top-[17px] !left-0 !w-4 !h-4 !bg-transparent !rounded-none !outline-none !border-none !translate-y-0 z-[1]
|
|
after:absolute after:w-0.5 after:h-2 after:-left-0.5 after:top-1 after:bg-primary-500
|
|
${nodeData.type === BlockEnum.Start && 'opacity-0'}
|
|
`}
|
|
isConnectable={nodeData.type !== BlockEnum.Start}
|
|
/>
|
|
<BaseNode { ...props }>
|
|
<NodeComponent />
|
|
</BaseNode>
|
|
<Handle
|
|
type='source'
|
|
position={Position.Right}
|
|
className={`
|
|
!top-[17px] !right-0 !w-4 !h-4 !bg-transparent !rounded-none !outline-none !border-none !translate-y-0 z-[1]
|
|
after:absolute after:w-0.5 after:h-2 after:-right-0.5 after:top-1 after:bg-primary-500
|
|
`}
|
|
/>
|
|
</>
|
|
)
|
|
})
|
|
CustomNode.displayName = 'CustomNode'
|
|
|
|
export const Panel = memo((props: SelectedNode) => {
|
|
const nodeData = props.data
|
|
const PanelComponent = PanelComponentMap[nodeData.type]
|
|
|
|
return (
|
|
<BasePanel {...props}>
|
|
<PanelComponent />
|
|
</BasePanel>
|
|
)
|
|
})
|
|
|
|
Panel.displayName = 'Panel'
|
|
|
|
export default memo(CustomNode)
|