mirror of
				https://github.com/langgenius/dify.git
				synced 2025-10-25 07:58:40 +00:00 
			
		
		
		
	 7753ba2d37
			
		
	
	
		7753ba2d37
		
			
		
	
	
	
	
		
			
			Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Yeuoly <admin@srmxy.cn> Co-authored-by: JzoNg <jzongcode@gmail.com> Co-authored-by: StyleZhang <jasonapring2015@outlook.com> Co-authored-by: jyong <jyong@dify.ai> Co-authored-by: nite-knite <nkCoding@gmail.com> Co-authored-by: jyong <718720800@qq.com>
		
			
				
	
	
		
			37 lines
		
	
	
		
			813 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			813 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { memo } from 'react'
 | |
| import type { NodeProps } from 'reactflow'
 | |
| import type { Node } 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 (
 | |
|     <BaseNode { ...props }>
 | |
|       <NodeComponent />
 | |
|     </BaseNode>
 | |
|   )
 | |
| })
 | |
| CustomNode.displayName = 'CustomNode'
 | |
| 
 | |
| export const Panel = memo((props: Node) => {
 | |
|   const nodeData = props.data
 | |
|   const PanelComponent = PanelComponentMap[nodeData.type]
 | |
| 
 | |
|   return (
 | |
|     <BasePanel key={props.id} {...props}>
 | |
|       <PanelComponent />
 | |
|     </BasePanel>
 | |
|   )
 | |
| })
 | |
| 
 | |
| Panel.displayName = 'Panel'
 | |
| 
 | |
| export default memo(CustomNode)
 |