From a430284aa21e3ae1f0d5654e55b2ad2852519cc2 Mon Sep 17 00:00:00 2001 From: wwf <yearningwang@iqtogether.com> Date: 星期三, 04 六月 2025 15:17:49 +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