51 lines
1.1 KiB
TypeScript
Raw Normal View History

import type { FC } from 'react'
import { memo } from 'react'
import { useNodes } from 'reactflow'
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
}
}
const Panel: FC<PanelProps> = ({
components,
}) => {
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)
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
}
{
showEnvPanel && (
<EnvPanel />
)
}
</div>
)
}
export default memo(Panel)