| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import type { FC } from 'react' | 
					
						
							|  |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  | import { useCallback, useEffect, useRef, useState } from 'react' | 
					
						
							|  |  |  | import { useBoolean, useClickAway } from 'ahooks' | 
					
						
							| 
									
										
										
										
											2024-06-20 11:05:08 +08:00
										 |  |  | import { RiCloseLine } from '@remixicon/react' | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  | import IterationResultPanel from '../../workflow/run/iteration-result-panel' | 
					
						
							| 
									
										
										
										
											2024-07-09 15:05:40 +08:00
										 |  |  | import cn from '@/utils/classnames' | 
					
						
							| 
									
										
										
										
											2024-06-24 12:29:14 +08:00
										 |  |  | import type { IChatItem } from '@/app/components/base/chat/chat/type' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import Run from '@/app/components/workflow/run' | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  | import type { NodeTracing } from '@/types/workflow' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | type MessageLogModalProps = { | 
					
						
							|  |  |  |   currentLogItem?: IChatItem | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |   defaultTab?: string | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   width: number | 
					
						
							|  |  |  |   fixedWidth?: boolean | 
					
						
							|  |  |  |   onCancel: () => void | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | const MessageLogModal: FC<MessageLogModalProps> = ({ | 
					
						
							|  |  |  |   currentLogItem, | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |   defaultTab = 'DETAIL', | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   width, | 
					
						
							|  |  |  |   fixedWidth, | 
					
						
							|  |  |  |   onCancel, | 
					
						
							|  |  |  | }) => { | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							|  |  |  |   const ref = useRef(null) | 
					
						
							|  |  |  |   const [mounted, setMounted] = useState(false) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   useClickAway(() => { | 
					
						
							|  |  |  |     if (mounted) | 
					
						
							|  |  |  |       onCancel() | 
					
						
							|  |  |  |   }, ref) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   useEffect(() => { | 
					
						
							|  |  |  |     setMounted(true) | 
					
						
							|  |  |  |   }, []) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |   const [iterationRunResult, setIterationRunResult] = useState<NodeTracing[][]>([]) | 
					
						
							|  |  |  |   const [isShowIterationDetail, { | 
					
						
							|  |  |  |     setTrue: doShowIterationDetail, | 
					
						
							|  |  |  |     setFalse: doHideIterationDetail, | 
					
						
							|  |  |  |   }] = useBoolean(false) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const handleShowIterationDetail = useCallback((detail: NodeTracing[][]) => { | 
					
						
							|  |  |  |     setIterationRunResult(detail) | 
					
						
							|  |  |  |     doShowIterationDetail() | 
					
						
							|  |  |  |   }, [doShowIterationDetail]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   if (!currentLogItem || !currentLogItem.workflow_run_id) | 
					
						
							|  |  |  |     return null | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <div | 
					
						
							|  |  |  |       className={cn('relative flex flex-col py-3 bg-white border-[0.5px] border-gray-200 rounded-xl shadow-xl z-10')} | 
					
						
							|  |  |  |       style={{ | 
					
						
							| 
									
										
										
										
											2024-04-17 10:30:52 +08:00
										 |  |  |         width: fixedWidth ? width : 480, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |         ...(!fixedWidth | 
					
						
							|  |  |  |           ? { | 
					
						
							|  |  |  |             position: 'fixed', | 
					
						
							|  |  |  |             top: 56 + 8, | 
					
						
							| 
									
										
										
										
											2024-04-17 10:30:52 +08:00
										 |  |  |             left: 8 + (width - 480), | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |             bottom: 16, | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           : { | 
					
						
							|  |  |  |             marginRight: 8, | 
					
						
							|  |  |  |           }), | 
					
						
							|  |  |  |       }} | 
					
						
							|  |  |  |       ref={ref} | 
					
						
							|  |  |  |     > | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |       {isShowIterationDetail | 
					
						
							|  |  |  |         ? ( | 
					
						
							|  |  |  |           <IterationResultPanel | 
					
						
							|  |  |  |             list={iterationRunResult} | 
					
						
							|  |  |  |             onHide={doHideIterationDetail} | 
					
						
							|  |  |  |             onBack={doHideIterationDetail} | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |         : ( | 
					
						
							|  |  |  |           <> | 
					
						
							|  |  |  |             <h1 className='shrink-0 px-4 py-1 text-md font-semibold text-gray-900'>{t('appLog.runDetail.title')}</h1> | 
					
						
							|  |  |  |             <span className='absolute right-3 top-4 p-1 cursor-pointer z-20' onClick={onCancel}> | 
					
						
							| 
									
										
										
										
											2024-06-20 11:05:08 +08:00
										 |  |  |               <RiCloseLine className='w-4 h-4 text-gray-500' /> | 
					
						
							| 
									
										
										
										
											2024-05-27 21:57:08 +08:00
										 |  |  |             </span> | 
					
						
							|  |  |  |             <Run | 
					
						
							|  |  |  |               hideResult activeTab={defaultTab as any} | 
					
						
							|  |  |  |               runID={currentLogItem.workflow_run_id} | 
					
						
							|  |  |  |               onShowIterationDetail={handleShowIterationDetail} | 
					
						
							|  |  |  |             /> | 
					
						
							|  |  |  |           </> | 
					
						
							|  |  |  |         )} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     </div> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default MessageLogModal |