|
import { memo } from 'react' |
|
import { useTranslation } from 'react-i18next' |
|
import type { NodeProps } from 'reactflow' |
|
import { RiHome5Fill } from '@remixicon/react' |
|
import Tooltip from '@/app/components/base/tooltip' |
|
import { NodeSourceHandle } from '@/app/components/workflow/nodes/_base/components/node-handle' |
|
|
|
const IterationStartNode = ({ id, data }: NodeProps) => { |
|
const { t } = useTranslation() |
|
|
|
return ( |
|
<div className='group flex nodrag items-center justify-center w-11 h-11 mt-1 rounded-2xl border border-workflow-block-border bg-white'> |
|
<Tooltip popupContent={t('workflow.blocks.iteration-start')} asChild={false}> |
|
<div className='flex items-center justify-center w-6 h-6 rounded-full border-[0.5px] border-components-panel-border-subtle bg-util-colors-blue-brand-blue-brand-500'> |
|
<RiHome5Fill className='w-3 h-3 text-text-primary-on-surface' /> |
|
</div> |
|
</Tooltip> |
|
<NodeSourceHandle |
|
id={id} |
|
data={data} |
|
handleClassName='!top-1/2 !-right-[9px] !-translate-y-1/2' |
|
handleId='source' |
|
/> |
|
</div> |
|
) |
|
} |
|
|
|
export const IterationStartNodeDumb = () => { |
|
const { t } = useTranslation() |
|
|
|
return ( |
|
<div className='relative left-[17px] top-[21px] flex nodrag items-center justify-center w-11 h-11 rounded-2xl border border-workflow-block-border bg-white z-[11]'> |
|
<Tooltip popupContent={t('workflow.blocks.iteration-start')} asChild={false}> |
|
<div className='flex items-center justify-center w-6 h-6 rounded-full border-[0.5px] border-components-panel-border-subtle bg-util-colors-blue-brand-blue-brand-500'> |
|
<RiHome5Fill className='w-3 h-3 text-text-primary-on-surface' /> |
|
</div> |
|
</Tooltip> |
|
</div> |
|
) |
|
} |
|
|
|
export default memo(IterationStartNode) |
|
|