mirror of
https://git.mirrors.martin98.com/https://github.com/langgenius/dify.git
synced 2025-05-14 04:28:17 +08:00

Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Patryk Garstecki <patryk20120@yahoo.pl> Co-authored-by: Sebastian.W <thiner@gmail.com> Co-authored-by: 呆萌闷油瓶 <253605712@qq.com> Co-authored-by: takatost <takatost@users.noreply.github.com> Co-authored-by: rechardwang <wh_goodjob@163.com> Co-authored-by: Nite Knite <nkCoding@gmail.com> Co-authored-by: Chenhe Gu <guchenhe@gmail.com> Co-authored-by: Joshua <138381132+joshua20231026@users.noreply.github.com> Co-authored-by: Weaxs <459312872@qq.com> Co-authored-by: Ikko Eltociear Ashimine <eltociear@gmail.com> Co-authored-by: leejoo0 <81673835+leejoo0@users.noreply.github.com> Co-authored-by: JzoNg <jzongcode@gmail.com> Co-authored-by: sino <sino2322@gmail.com> Co-authored-by: Vikey Chen <vikeytk@gmail.com> Co-authored-by: wanghl <Wang-HL@users.noreply.github.com> Co-authored-by: Haolin Wang-汪皓临 <haolin.wang@atlaslovestravel.com> Co-authored-by: Zixuan Cheng <61724187+Theysua@users.noreply.github.com> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: Bowen Liang <bowenliang@apache.org> Co-authored-by: Bowen Liang <liangbowen@gf.com.cn> Co-authored-by: fanghongtai <42790567+fanghongtai@users.noreply.github.com> Co-authored-by: wxfanghongtai <wxfanghongtai@gf.com.cn> Co-authored-by: Matri <qjp@bithuman.io> Co-authored-by: Benjamin <benjaminx@gmail.com>
50 lines
1.2 KiB
TypeScript
50 lines
1.2 KiB
TypeScript
import type { FC } from 'react'
|
|
import {
|
|
memo,
|
|
useEffect,
|
|
} from 'react'
|
|
import {
|
|
Background,
|
|
useNodesInitialized,
|
|
useViewport,
|
|
} from 'reactflow'
|
|
import cn from 'classnames'
|
|
import { useNodeIterationInteractions } from './use-interactions'
|
|
import type { IterationNodeType } from './types'
|
|
import AddBlock from './add-block'
|
|
import type { NodeProps } from '@/app/components/workflow/types'
|
|
|
|
const Node: FC<NodeProps<IterationNodeType>> = ({
|
|
id,
|
|
data,
|
|
}) => {
|
|
const { zoom } = useViewport()
|
|
const nodesInitialized = useNodesInitialized()
|
|
const { handleNodeIterationRerender } = useNodeIterationInteractions()
|
|
|
|
useEffect(() => {
|
|
if (nodesInitialized)
|
|
handleNodeIterationRerender(id)
|
|
}, [nodesInitialized, id, handleNodeIterationRerender])
|
|
|
|
return (
|
|
<div className={cn(
|
|
'relative min-w-[258px] min-h-[118px] w-full h-full rounded-2xl bg-[#F0F2F7]/90',
|
|
)}>
|
|
<Background
|
|
id={`iteration-background-${id}`}
|
|
className='rounded-2xl !z-0'
|
|
gap={[14 / zoom, 14 / zoom]}
|
|
size={2 / zoom}
|
|
color='#E4E5E7'
|
|
/>
|
|
<AddBlock
|
|
iterationNodeId={id}
|
|
iterationNodeData={data}
|
|
/>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default memo(Node)
|