From 77950e48c76f4a3b29d01831d43039caba29888a Mon Sep 17 00:00:00 2001
From: wwf <1971391498@qq.com>
Date: 星期二, 18 十一月 2025 14:12:42 +0800
Subject: [PATCH] 修改
---
app/components/workflow/panel/debug-and-preview/index.tsx | 73 ++++++++++--------------------------
1 files changed, 21 insertions(+), 52 deletions(-)
diff --git a/app/components/workflow/panel/debug-and-preview/index.tsx b/app/components/workflow/panel/debug-and-preview/index.tsx
index b63b7af..d4a3f24 100644
--- a/app/components/workflow/panel/debug-and-preview/index.tsx
+++ b/app/components/workflow/panel/debug-and-preview/index.tsx
@@ -1,19 +1,17 @@
import {
memo,
- useCallback,
- useEffect,
useRef,
useState,
} from 'react'
-
+import { useKeyPress } from 'ahooks'
import { RiCloseLine, RiEqualizer2Line } from '@remixicon/react'
import { useTranslation } from 'react-i18next'
import { useNodes } from 'reactflow'
import {
+ useEdgesInteractions,
+ useNodesInteractions,
useWorkflowInteractions,
} from '../../hooks'
-import { useEdgesInteractionsWithoutSync } from '@/app/components/workflow/hooks/use-edges-interactions-without-sync'
-import { useNodesInteractionsWithoutSync } from '@/app/components/workflow/hooks/use-nodes-interactions-without-sync'
import { BlockEnum } from '../../types'
import type { StartNodeType } from '../../nodes/start/types'
import ChatWrapper from './chat-wrapper'
@@ -23,17 +21,16 @@
import Tooltip from '@/app/components/base/tooltip'
import ActionButton, { ActionButtonState } from '@/app/components/base/action-button'
import { useStore } from '@/app/components/workflow/store'
-import { noop } from 'lodash-es'
export type ChatWrapperRefType = {
handleRestart: () => void
}
const DebugAndPreview = () => {
const { t } = useTranslation()
- const chatRef = useRef({ handleRestart: noop })
+ const chatRef = useRef({ handleRestart: () => { } })
const { handleCancelDebugAndPreviewPanel } = useWorkflowInteractions()
- const { handleNodeCancelRunningStatus } = useNodesInteractionsWithoutSync()
- const { handleEdgeCancelRunningStatus } = useEdgesInteractionsWithoutSync()
+ const { handleNodeCancelRunningStatus } = useNodesInteractions()
+ const { handleEdgeCancelRunningStatus } = useEdgesInteractions()
const varList = useStore(s => s.conversationVariables)
const [expanded, setExpanded] = useState(true)
const nodes = useNodes<StartNodeType>()
@@ -48,54 +45,26 @@
chatRef.current.handleRestart()
}
- const [panelWidth, setPanelWidth] = useState(420)
- const [isResizing, setIsResizing] = useState(false)
-
- const startResizing = useCallback((e: React.MouseEvent) => {
- e.preventDefault()
- setIsResizing(true)
- }, [])
-
- const stopResizing = useCallback(() => {
- setIsResizing(false)
- }, [])
-
- const resize = useCallback((e: MouseEvent) => {
- if (isResizing) {
- const newWidth = window.innerWidth - e.clientX
- if (newWidth > 420 && newWidth < 1024)
- setPanelWidth(newWidth)
- }
- }, [isResizing])
-
- useEffect(() => {
- window.addEventListener('mousemove', resize)
- window.addEventListener('mouseup', stopResizing)
- return () => {
- window.removeEventListener('mousemove', resize)
- window.removeEventListener('mouseup', stopResizing)
- }
- }, [resize, stopResizing])
+ useKeyPress('shift.r', () => {
+ handleRestartChat()
+ }, {
+ exactMatch: true,
+ })
return (
<div
className={cn(
- 'relative flex h-full flex-col rounded-l-2xl border border-r-0 border-components-panel-border bg-chatbot-bg shadow-xl',
+ 'flex flex-col w-[420px] bg-chatbot-bg rounded-l-2xl h-full border border-components-panel-border border-r-0 shadow-xl',
)}
- style={{ width: `${panelWidth}px` }}
>
- <div
- className="absolute bottom-0 left-[3px] top-1/2 z-50 h-6 w-[3px] cursor-col-resize rounded bg-gray-300"
- onMouseDown={startResizing}
- />
- <div className='system-xl-semibold flex shrink-0 items-center justify-between px-4 pb-2 pt-3 text-text-primary'>
+ <div className='shrink-0 flex items-center justify-between px-4 pt-3 pb-2 text-text-primary system-xl-semibold'>
<div className='h-8'>{t('workflow.common.debugAndPreview').toLocaleUpperCase()}</div>
<div className='flex items-center gap-1'>
<Tooltip
popupContent={t('common.operation.refresh')}
>
<ActionButton onClick={() => handleRestartChat()}>
- <RefreshCcw01 className='h-4 w-4' />
+ <RefreshCcw01 className='w-4 h-4' />
</ActionButton>
</Tooltip>
{varList.length > 0 && (
@@ -103,7 +72,7 @@
popupContent={t('workflow.chatVariable.panelTitle')}
>
<ActionButton onClick={() => setShowConversationVariableModal(true)}>
- <BubbleX className='h-4 w-4' />
+ <BubbleX className='w-4 h-4' />
</ActionButton>
</Tooltip>
)}
@@ -113,22 +82,22 @@
popupContent={t('workflow.panel.userInputField')}
>
<ActionButton state={expanded ? ActionButtonState.Active : undefined} onClick={() => setExpanded(!expanded)}>
- <RiEqualizer2Line className='h-4 w-4' />
+ <RiEqualizer2Line className='w-4 h-4' />
</ActionButton>
</Tooltip>
- {expanded && <div className='absolute bottom-[-17px] right-[5px] z-10 h-3 w-3 rotate-45 border-l-[0.5px] border-t-[0.5px] border-components-panel-border-subtle bg-components-panel-on-panel-item-bg' />}
+ {expanded && <div className='absolute z-10 bottom-[-17px] right-[5px] w-3 h-3 bg-components-panel-on-panel-item-bg border-l-[0.5px] border-t-[0.5px] border-components-panel-border-subtle rotate-45'/>}
</div>
)}
- <div className='mx-3 h-3.5 w-[1px] bg-divider-regular'></div>
+ <div className='mx-3 w-[1px] h-3.5 bg-gray-200'></div>
<div
- className='flex h-6 w-6 cursor-pointer items-center justify-center'
+ className='flex items-center justify-center w-6 h-6 cursor-pointer'
onClick={handleCancelDebugAndPreviewPanel}
>
- <RiCloseLine className='h-4 w-4 text-text-tertiary' />
+ <RiCloseLine className='w-4 h-4 text-gray-500' />
</div>
</div>
</div>
- <div className='grow overflow-y-auto rounded-b-2xl'>
+ <div className='grow rounded-b-2xl overflow-y-auto'>
<ChatWrapper
ref={chatRef}
showConversationVariableModal={showConversationVariableModal}
--
Gitblit v1.8.0