12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- import type { FC } from 'react'
- import {
- memo,
- useCallback,
- useState,
- } from 'react'
- import { useTranslation } from 'react-i18next'
- import {
- RiPlayLargeLine,
- } from '@remixicon/react'
- import {
- useNodeDataUpdate,
- useNodesInteractions,
- useNodesSyncDraft,
- } from '../../../hooks'
- import type { Node } from '../../../types'
- import { canRunBySingle } from '../../../utils'
- import PanelOperator from './panel-operator'
- import {
- Stop,
- } from '@/app/components/base/icons/src/vender/line/mediaAndDevices'
- import TooltipPlus from '@/app/components/base/tooltip-plus'
- type NodeControlProps = Pick<Node, 'id' | 'data'>
- const NodeControl: FC<NodeControlProps> = ({
- id,
- data,
- }) => {
- const { t } = useTranslation()
- const [open, setOpen] = useState(false)
- const { handleNodeDataUpdate } = useNodeDataUpdate()
- const { handleNodeSelect } = useNodesInteractions()
- const { handleSyncWorkflowDraft } = useNodesSyncDraft()
- const handleOpenChange = useCallback((newOpen: boolean) => {
- setOpen(newOpen)
- }, [])
- return (
- <div
- className={`
- hidden group-hover:flex pb-1 absolute right-0 -top-7 h-7
- ${data.selected && '!flex'}
- ${open && '!flex'}
- `}
- >
- <div
- className='flex items-center px-0.5 h-6 bg-white rounded-lg border-[0.5px] border-gray-100 shadow-xs text-gray-500'
- onClick={e => e.stopPropagation()}
- >
- {
- canRunBySingle(data.type) && (
- <div
- className='flex items-center justify-center w-5 h-5 rounded-md cursor-pointer hover:bg-black/5'
- onClick={() => {
- handleNodeDataUpdate({
- id,
- data: {
- _isSingleRun: !data._isSingleRun,
- },
- })
- handleNodeSelect(id)
- if (!data._isSingleRun)
- handleSyncWorkflowDraft(true)
- }}
- >
- {
- data._isSingleRun
- ? <Stop className='w-3 h-3' />
- : (
- <TooltipPlus
- popupContent={t('workflow.panel.runThisStep')}
- >
- <RiPlayLargeLine className='w-3 h-3' />
- </TooltipPlus>
- )
- }
- </div>
- )
- }
- <PanelOperator
- id={id}
- data={data}
- offset={0}
- onOpenChange={handleOpenChange}
- triggerClassName='!w-5 !h-5'
- />
- </div>
- </div>
- )
- }
- export default memo(NodeControl)
|