| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   memo, | 
					
						
							| 
									
										
										
										
											2025-04-03 21:30:04 +08:00
										 |  |  |   useCallback, | 
					
						
							|  |  |  |   useEffect, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   useRef, | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |   useState, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | } from 'react' | 
					
						
							| 
									
										
										
										
											2025-04-18 09:42:08 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  | import { RiCloseLine, RiEqualizer2Line } from '@remixicon/react' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  | import { useNodes } from 'reactflow' | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   useWorkflowInteractions, | 
					
						
							|  |  |  | } from '../../hooks' | 
					
						
							| 
									
										
										
										
											2025-04-19 14:46:10 +08:00
										 |  |  | import { useEdgesInteractionsWithoutSync } from '@/app/components/workflow/hooks/use-edges-interactions-without-sync' | 
					
						
							|  |  |  | import { useNodesInteractionsWithoutSync } from '@/app/components/workflow/hooks/use-nodes-interactions-without-sync' | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  | import { BlockEnum } from '../../types' | 
					
						
							|  |  |  | import type { StartNodeType } from '../../nodes/start/types' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import ChatWrapper from './chat-wrapper' | 
					
						
							| 
									
										
										
										
											2024-07-09 15:05:40 +08:00
										 |  |  | import cn from '@/utils/classnames' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { RefreshCcw01 } from '@/app/components/base/icons/src/vender/line/arrows' | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  | import { BubbleX } from '@/app/components/base/icons/src/vender/line/others' | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  | import Tooltip from '@/app/components/base/tooltip' | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  | import ActionButton, { ActionButtonState } from '@/app/components/base/action-button' | 
					
						
							|  |  |  | import { useStore } from '@/app/components/workflow/store' | 
					
						
							| 
									
										
										
										
											2025-04-06 17:56:08 +08:00
										 |  |  | import { noop } from 'lodash-es' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export type ChatWrapperRefType = { | 
					
						
							|  |  |  |   handleRestart: () => void | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | const DebugAndPreview = () => { | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							| 
									
										
										
										
											2025-04-06 17:56:08 +08:00
										 |  |  |   const chatRef = useRef({ handleRestart: noop }) | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |   const { handleCancelDebugAndPreviewPanel } = useWorkflowInteractions() | 
					
						
							| 
									
										
										
										
											2025-04-19 14:46:10 +08:00
										 |  |  |   const { handleNodeCancelRunningStatus } = useNodesInteractionsWithoutSync() | 
					
						
							|  |  |  |   const { handleEdgeCancelRunningStatus } = useEdgesInteractionsWithoutSync() | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |   const varList = useStore(s => s.conversationVariables) | 
					
						
							|  |  |  |   const [expanded, setExpanded] = useState(true) | 
					
						
							|  |  |  |   const nodes = useNodes<StartNodeType>() | 
					
						
							|  |  |  |   const startNode = nodes.find(node => node.data.type === BlockEnum.Start) | 
					
						
							|  |  |  |   const variables = startNode?.data.variables || [] | 
					
						
							| 
									
										
										
										
											2025-05-21 13:52:21 +08:00
										 |  |  |   const visibleVariables = variables.filter(v => v.hide !== true) | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   const [showConversationVariableModal, setShowConversationVariableModal] = useState(false) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |   const handleRestartChat = () => { | 
					
						
							|  |  |  |     handleNodeCancelRunningStatus() | 
					
						
							|  |  |  |     handleEdgeCancelRunningStatus() | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     chatRef.current.handleRestart() | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-03 21:30:04 +08:00
										 |  |  |   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]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   return ( | 
					
						
							|  |  |  |     <div | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |       className={cn( | 
					
						
							| 
									
										
										
										
											2025-04-03 21:30:04 +08:00
										 |  |  |         'relative flex h-full flex-col rounded-l-2xl border border-r-0 border-components-panel-border bg-chatbot-bg shadow-xl', | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |       )} | 
					
						
							| 
									
										
										
										
											2025-04-03 21:30:04 +08:00
										 |  |  |       style={{ width: `${panelWidth}px` }} | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     > | 
					
						
							| 
									
										
										
										
											2025-04-03 21:30:04 +08:00
										 |  |  |       <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} | 
					
						
							|  |  |  |       /> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |       <div className='system-xl-semibold flex shrink-0 items-center justify-between px-4 pb-2 pt-3 text-text-primary'> | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |         <div className='h-8'>{t('workflow.common.debugAndPreview').toLocaleUpperCase()}</div> | 
					
						
							|  |  |  |         <div className='flex items-center gap-1'> | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |           <Tooltip | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |             popupContent={t('common.operation.refresh')} | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |           > | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |             <ActionButton onClick={() => handleRestartChat()}> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |               <RefreshCcw01 className='h-4 w-4' /> | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |             </ActionButton> | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |           </Tooltip> | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |           {varList.length > 0 && ( | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |             <Tooltip | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |               popupContent={t('workflow.chatVariable.panelTitle')} | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |             > | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |               <ActionButton onClick={() => setShowConversationVariableModal(true)}> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |                 <BubbleX className='h-4 w-4' /> | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |               </ActionButton> | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |             </Tooltip> | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |           )} | 
					
						
							| 
									
										
										
										
											2025-05-21 13:52:21 +08:00
										 |  |  |           {visibleVariables.length > 0 && ( | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |             <div className='relative'> | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |               <Tooltip | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |                 popupContent={t('workflow.panel.userInputField')} | 
					
						
							|  |  |  |               > | 
					
						
							|  |  |  |                 <ActionButton state={expanded ? ActionButtonState.Active : undefined} onClick={() => setExpanded(!expanded)}> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |                   <RiEqualizer2Line className='h-4 w-4' /> | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |                 </ActionButton> | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |               </Tooltip> | 
					
						
							| 
									
										
										
										
											2025-04-19 14:46:10 +08:00
										 |  |  |               {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' />} | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |             </div> | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |           )} | 
					
						
							| 
									
										
										
										
											2025-04-10 17:15:48 +08:00
										 |  |  |           <div className='mx-3 h-3.5 w-[1px] bg-divider-regular'></div> | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |           <div | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |             className='flex h-6 w-6 cursor-pointer items-center justify-center' | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |             onClick={handleCancelDebugAndPreviewPanel} | 
					
						
							|  |  |  |           > | 
					
						
							| 
									
										
										
										
											2025-04-10 17:15:48 +08:00
										 |  |  |             <RiCloseLine className='h-4 w-4 text-text-tertiary' /> | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |           </div> | 
					
						
							|  |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:41:03 +08:00
										 |  |  |       <div className='grow overflow-y-auto rounded-b-2xl'> | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |         <ChatWrapper | 
					
						
							|  |  |  |           ref={chatRef} | 
					
						
							|  |  |  |           showConversationVariableModal={showConversationVariableModal} | 
					
						
							|  |  |  |           onConversationModalHide={() => setShowConversationVariableModal(false)} | 
					
						
							|  |  |  |           showInputsFieldsPanel={expanded} | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  |           onHide={() => setExpanded(false)} | 
					
						
							| 
									
										
										
										
											2024-08-13 14:44:10 +08:00
										 |  |  |         /> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |       </div> | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default memo(DebugAndPreview) |