File size: 2,636 Bytes
4304c6d
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
import type { FC } from 'react'
import { memo } from 'react'
import { useNodes } from 'reactflow'
import cn from 'classnames'
import { useShallow } from 'zustand/react/shallow'
import type { CommonNodeType } from '../types'
import { Panel as NodePanel } from '../nodes'
import { useStore } from '../store'
import {
  useIsChatMode,
  useWorkflow,
} from '../hooks'
import DebugAndPreview from './debug-and-preview'
import Record from './record'
import WorkflowPreview from './workflow-preview'
import ChatRecord from './chat-record'
import { useStore as useAppStore } from '@/app/components/app/store'
import MessageLogModal from '@/app/components/base/message-log-modal'

const Panel: FC = () => {
  const nodes = useNodes<CommonNodeType>()
  const isChatMode = useIsChatMode()
  const selectedNode = nodes.find(node => node.data.selected)
  const historyWorkflowData = useStore(s => s.historyWorkflowData)
  const showDebugAndPreviewPanel = useStore(s => s.showDebugAndPreviewPanel)
  const isRestoring = useStore(s => s.isRestoring)
  const {
    enableShortcuts,
    disableShortcuts,
  } = useWorkflow()
  const { currentLogItem, setCurrentLogItem, showMessageLogModal, setShowMessageLogModal } = useAppStore(useShallow(state => ({
    currentLogItem: state.currentLogItem,
    setCurrentLogItem: state.setCurrentLogItem,
    showMessageLogModal: state.showMessageLogModal,
    setShowMessageLogModal: state.setShowMessageLogModal,
  })))

  return (
    <div

      tabIndex={-1}

      className={cn(

        'absolute top-14 right-0 bottom-2 flex z-10 outline-none',

      )}

      onFocus={disableShortcuts}

      onBlur={enableShortcuts}

      key={`${isRestoring}`}

    >

      {

        showMessageLogModal && (

          <MessageLogModal

            fixedWidth

            width={400}

            currentLogItem={currentLogItem}

            onCancel={() => {

              setCurrentLogItem()

              setShowMessageLogModal(false)

            }}

          />

        )

      }

      {

        !!selectedNode && (

          <NodePanel {...selectedNode!} />

        )

      }

      {

        historyWorkflowData && !isChatMode && (

          <Record />

        )

      }

      {

        historyWorkflowData && isChatMode && (

          <ChatRecord />

        )

      }

      {

        showDebugAndPreviewPanel && isChatMode && (

          <DebugAndPreview />

        )

      }

      {

        showDebugAndPreviewPanel && !isChatMode && (

          <WorkflowPreview />

        )

      }

    </div>
  )
}

export default memo(Panel)