61 lines
1.6 KiB
TypeScript
Raw Normal View History

import type { FC } from 'react'
import { memo } from 'react'
import { useNodes } from 'reactflow'
2025-05-08 18:27:15 +08:00
import type { VersionHistoryPanelProps } from '@/app/components/workflow/panel/version-history-panel'
import VersionHistoryPanel from '@/app/components/workflow/panel/version-history-panel'
import type { CommonNodeType } from '../types'
import { Panel as NodePanel } from '../nodes'
import { useStore } from '../store'
import EnvPanel from './env-panel'
import cn from '@/utils/classnames'
2025-04-18 13:59:12 +08:00
export type PanelProps = {
components?: {
left?: React.ReactNode
right?: React.ReactNode
}
2025-05-08 18:27:15 +08:00
versionHistoryPanelProps?: VersionHistoryPanelProps
2025-04-18 13:59:12 +08:00
}
const Panel: FC<PanelProps> = ({
components,
2025-05-08 18:27:15 +08:00
versionHistoryPanelProps,
2025-04-18 13:59:12 +08:00
}) => {
const nodes = useNodes<CommonNodeType>()
const selectedNode = nodes.find(node => node.data.selected)
const showEnvPanel = useStore(s => s.showEnvPanel)
2024-04-24 13:05:33 +08:00
const isRestoring = useStore(s => s.isRestoring)
2025-05-08 18:27:15 +08:00
const showWorkflowVersionHistoryPanel = useStore(s => s.showWorkflowVersionHistoryPanel)
return (
2024-04-25 14:02:06 +08:00
<div
tabIndex={-1}
className={cn('absolute bottom-2 right-0 top-14 z-10 flex outline-none')}
2024-04-25 14:02:06 +08:00
key={`${isRestoring}`}
>
{
2025-04-18 13:59:12 +08:00
components?.left
}
{
!!selectedNode && (
<NodePanel {...selectedNode!} />
)
}
{
2025-04-18 13:59:12 +08:00
components?.right
}
2025-05-08 18:27:15 +08:00
{
showWorkflowVersionHistoryPanel && (
<VersionHistoryPanel {...versionHistoryPanelProps} />
)
}
{
showEnvPanel && (
<EnvPanel />
)
}
</div>
)
}
export default memo(Panel)