| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   memo, | 
					
						
							|  |  |  |   useState, | 
					
						
							|  |  |  | } from 'react' | 
					
						
							|  |  |  | import useSWR from 'swr' | 
					
						
							|  |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							| 
									
										
										
										
											2024-04-24 04:07:28 +00:00
										 |  |  | import { useShallow } from 'zustand/react/shallow' | 
					
						
							| 
									
										
										
										
											2024-06-20 11:05:08 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   RiCheckboxCircleLine, | 
					
						
							|  |  |  |   RiCloseLine, | 
					
						
							|  |  |  |   RiErrorWarningLine, | 
					
						
							|  |  |  | } from '@remixicon/react' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   useIsChatMode, | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |   useNodesInteractions, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   useWorkflow, | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |   useWorkflowInteractions, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   useWorkflowRun, | 
					
						
							|  |  |  | } from '../hooks' | 
					
						
							| 
									
										
										
										
											2024-08-19 18:11:11 +08:00
										 |  |  | import { ControlMode, WorkflowRunningStatus } from '../types' | 
					
						
							| 
									
										
										
										
											2024-07-09 15:05:40 +08:00
										 |  |  | import cn from '@/utils/classnames' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   PortalToFollowElem, | 
					
						
							|  |  |  |   PortalToFollowElemContent, | 
					
						
							|  |  |  |   PortalToFollowElemTrigger, | 
					
						
							|  |  |  | } from '@/app/components/base/portal-to-follow-elem' | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  | import Tooltip from '@/app/components/base/tooltip' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { useStore as useAppStore } from '@/app/components/app/store' | 
					
						
							|  |  |  | import { | 
					
						
							|  |  |  |   ClockPlay, | 
					
						
							|  |  |  |   ClockPlaySlim, | 
					
						
							|  |  |  | } from '@/app/components/base/icons/src/vender/line/time' | 
					
						
							| 
									
										
										
										
											2024-06-20 11:05:08 +08:00
										 |  |  | import { AlertTriangle } from '@/app/components/base/icons/src/vender/line/alertsAndFeedback' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { | 
					
						
							| 
									
										
										
										
											2024-09-08 12:14:11 +07:00
										 |  |  |   fetchChatRunHistory, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   fetchWorkflowRunHistory, | 
					
						
							|  |  |  | } from '@/service/workflow' | 
					
						
							|  |  |  | import Loading from '@/app/components/base/loading' | 
					
						
							|  |  |  | import { | 
					
						
							|  |  |  |   useStore, | 
					
						
							|  |  |  |   useWorkflowStore, | 
					
						
							|  |  |  | } from '@/app/components/workflow/store' | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  | type ViewHistoryProps = { | 
					
						
							|  |  |  |   withText?: boolean | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | const ViewHistory = ({ | 
					
						
							|  |  |  |   withText, | 
					
						
							|  |  |  | }: ViewHistoryProps) => { | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   const { t } = useTranslation() | 
					
						
							|  |  |  |   const isChatMode = useIsChatMode() | 
					
						
							|  |  |  |   const [open, setOpen] = useState(false) | 
					
						
							|  |  |  |   const { formatTimeFromNow } = useWorkflow() | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |   const { | 
					
						
							|  |  |  |     handleNodesCancelSelected, | 
					
						
							|  |  |  |   } = useNodesInteractions() | 
					
						
							|  |  |  |   const { | 
					
						
							|  |  |  |     handleCancelDebugAndPreviewPanel, | 
					
						
							|  |  |  |   } = useWorkflowInteractions() | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   const workflowStore = useWorkflowStore() | 
					
						
							| 
									
										
										
										
											2024-08-19 18:11:11 +08:00
										 |  |  |   const setControlMode = useStore(s => s.setControlMode) | 
					
						
							| 
									
										
										
										
											2024-04-24 04:07:28 +00:00
										 |  |  |   const { appDetail, setCurrentLogItem, setShowMessageLogModal } = useAppStore(useShallow(state => ({ | 
					
						
							|  |  |  |     appDetail: state.appDetail, | 
					
						
							|  |  |  |     setCurrentLogItem: state.setCurrentLogItem, | 
					
						
							|  |  |  |     setShowMessageLogModal: state.setShowMessageLogModal, | 
					
						
							|  |  |  |   }))) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   const historyWorkflowData = useStore(s => s.historyWorkflowData) | 
					
						
							|  |  |  |   const { handleBackupDraft } = useWorkflowRun() | 
					
						
							|  |  |  |   const { data: runList, isLoading: runListLoading } = useSWR((appDetail && !isChatMode && open) ? `/apps/${appDetail.id}/workflow-runs` : null, fetchWorkflowRunHistory) | 
					
						
							| 
									
										
										
										
											2024-09-08 12:14:11 +07:00
										 |  |  |   const { data: chatList, isLoading: chatListLoading } = useSWR((appDetail && isChatMode && open) ? `/apps/${appDetail.id}/advanced-chat/workflow-runs` : null, fetchChatRunHistory) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   const data = isChatMode ? chatList : runList | 
					
						
							|  |  |  |   const isLoading = isChatMode ? chatListLoading : runListLoading | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     ( | 
					
						
							|  |  |  |       <PortalToFollowElem | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |         placement={withText ? 'bottom-start' : 'bottom-end'} | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |         offset={{ | 
					
						
							|  |  |  |           mainAxis: 4, | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |           crossAxis: withText ? -8 : 10, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |         }} | 
					
						
							|  |  |  |         open={open} | 
					
						
							|  |  |  |         onOpenChange={setOpen} | 
					
						
							|  |  |  |       > | 
					
						
							|  |  |  |         <PortalToFollowElemTrigger onClick={() => setOpen(v => !v)}> | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |           { | 
					
						
							|  |  |  |             withText && ( | 
					
						
							|  |  |  |               <div className={cn( | 
					
						
							|  |  |  |                 'flex items-center px-3 h-8 rounded-lg border-[0.5px] border-gray-200 bg-white shadow-xs', | 
					
						
							|  |  |  |                 'text-[13px] font-medium text-primary-600 cursor-pointer', | 
					
						
							|  |  |  |                 open && '!bg-primary-50', | 
					
						
							|  |  |  |               )}> | 
					
						
							|  |  |  |                 <ClockPlay | 
					
						
							|  |  |  |                   className={'mr-1 w-4 h-4'} | 
					
						
							|  |  |  |                 /> | 
					
						
							|  |  |  |                 {t('workflow.common.showRunHistory')} | 
					
						
							|  |  |  |               </div> | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             !withText && ( | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |               <Tooltip | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |                 popupContent={t('workflow.common.viewRunHistory')} | 
					
						
							|  |  |  |               > | 
					
						
							|  |  |  |                 <div | 
					
						
							| 
									
										
										
										
											2024-07-22 15:29:39 +08:00
										 |  |  |                   className={cn('group flex items-center justify-center w-7 h-7 rounded-md hover:bg-state-accent-hover cursor-pointer', open && 'bg-state-accent-hover')} | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |                   onClick={() => { | 
					
						
							|  |  |  |                     setCurrentLogItem() | 
					
						
							|  |  |  |                     setShowMessageLogModal(false) | 
					
						
							|  |  |  |                   }} | 
					
						
							|  |  |  |                 > | 
					
						
							| 
									
										
										
										
											2024-07-22 15:29:39 +08:00
										 |  |  |                   <ClockPlay className={cn('w-4 h-4 group-hover:text-components-button-secondary-accent-text', open ? 'text-components-button-secondary-accent-text' : 'text-components-button-ghost-text')} /> | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |                 </div> | 
					
						
							| 
									
										
										
										
											2024-08-26 13:00:02 +08:00
										 |  |  |               </Tooltip> | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |             ) | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |         </PortalToFollowElemTrigger> | 
					
						
							|  |  |  |         <PortalToFollowElemContent className='z-[12]'> | 
					
						
							|  |  |  |           <div | 
					
						
							|  |  |  |             className='flex flex-col ml-2 w-[240px] bg-white border-[0.5px] border-gray-200 shadow-xl rounded-xl overflow-y-auto' | 
					
						
							|  |  |  |             style={{ | 
					
						
							|  |  |  |               maxHeight: 'calc(2 / 3 * 100vh)', | 
					
						
							|  |  |  |             }} | 
					
						
							|  |  |  |           > | 
					
						
							|  |  |  |             <div className='sticky top-0 bg-white flex items-center justify-between px-4 pt-3 text-base font-semibold text-gray-900'> | 
					
						
							|  |  |  |               <div className='grow'>{t('workflow.common.runHistory')}</div> | 
					
						
							|  |  |  |               <div | 
					
						
							|  |  |  |                 className='shrink-0 flex items-center justify-center w-6 h-6 cursor-pointer' | 
					
						
							|  |  |  |                 onClick={() => { | 
					
						
							|  |  |  |                   setCurrentLogItem() | 
					
						
							|  |  |  |                   setShowMessageLogModal(false) | 
					
						
							|  |  |  |                   setOpen(false) | 
					
						
							|  |  |  |                 }} | 
					
						
							|  |  |  |               > | 
					
						
							| 
									
										
										
										
											2024-06-20 11:05:08 +08:00
										 |  |  |                 <RiCloseLine className='w-4 h-4 text-gray-500' /> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |               </div> | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |               isLoading && ( | 
					
						
							|  |  |  |                 <div className='flex items-center justify-center h-10'> | 
					
						
							|  |  |  |                   <Loading /> | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |               ) | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |               !isLoading && ( | 
					
						
							|  |  |  |                 <div className='p-2'> | 
					
						
							|  |  |  |                   { | 
					
						
							|  |  |  |                     !data?.data.length && ( | 
					
						
							|  |  |  |                       <div className='py-12'> | 
					
						
							|  |  |  |                         <ClockPlaySlim className='mx-auto mb-2 w-8 h-8 text-gray-300' /> | 
					
						
							|  |  |  |                         <div className='text-center text-[13px] text-gray-400'> | 
					
						
							|  |  |  |                           {t('workflow.common.notRunning')} | 
					
						
							|  |  |  |                         </div> | 
					
						
							|  |  |  |                       </div> | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |                   } | 
					
						
							|  |  |  |                   { | 
					
						
							|  |  |  |                     data?.data.map(item => ( | 
					
						
							|  |  |  |                       <div | 
					
						
							|  |  |  |                         key={item.id} | 
					
						
							|  |  |  |                         className={cn( | 
					
						
							|  |  |  |                           'flex mb-0.5 px-2 py-[7px] rounded-lg hover:bg-primary-50 cursor-pointer', | 
					
						
							|  |  |  |                           item.id === historyWorkflowData?.id && 'bg-primary-50', | 
					
						
							|  |  |  |                         )} | 
					
						
							|  |  |  |                         onClick={() => { | 
					
						
							|  |  |  |                           workflowStore.setState({ | 
					
						
							|  |  |  |                             historyWorkflowData: item, | 
					
						
							|  |  |  |                             showInputsPanel: false, | 
					
						
							| 
									
										
										
										
											2024-07-22 15:29:39 +08:00
										 |  |  |                             showEnvPanel: false, | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                           }) | 
					
						
							|  |  |  |                           handleBackupDraft() | 
					
						
							|  |  |  |                           setOpen(false) | 
					
						
							| 
									
										
										
										
											2024-04-28 17:09:56 +08:00
										 |  |  |                           handleNodesCancelSelected() | 
					
						
							|  |  |  |                           handleCancelDebugAndPreviewPanel() | 
					
						
							| 
									
										
										
										
											2024-08-19 18:11:11 +08:00
										 |  |  |                           setControlMode(ControlMode.Hand) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                         }} | 
					
						
							|  |  |  |                       > | 
					
						
							|  |  |  |                         { | 
					
						
							|  |  |  |                           !isChatMode && item.status === WorkflowRunningStatus.Stopped && ( | 
					
						
							|  |  |  |                             <AlertTriangle className='mt-0.5 mr-1.5 w-3.5 h-3.5 text-[#F79009]' /> | 
					
						
							|  |  |  |                           ) | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         { | 
					
						
							|  |  |  |                           !isChatMode && item.status === WorkflowRunningStatus.Failed && ( | 
					
						
							| 
									
										
										
										
											2024-06-20 11:05:08 +08:00
										 |  |  |                             <RiErrorWarningLine className='mt-0.5 mr-1.5 w-3.5 h-3.5 text-[#F04438]' /> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                           ) | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         { | 
					
						
							|  |  |  |                           !isChatMode && item.status === WorkflowRunningStatus.Succeeded && ( | 
					
						
							| 
									
										
										
										
											2024-06-20 11:05:08 +08:00
										 |  |  |                             <RiCheckboxCircleLine className='mt-0.5 mr-1.5 w-3.5 h-3.5 text-[#12B76A]' /> | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |                           ) | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         <div> | 
					
						
							|  |  |  |                           <div | 
					
						
							|  |  |  |                             className={cn( | 
					
						
							|  |  |  |                               'flex items-center text-[13px] font-medium leading-[18px]', | 
					
						
							|  |  |  |                               item.id === historyWorkflowData?.id && 'text-primary-600', | 
					
						
							|  |  |  |                             )} | 
					
						
							|  |  |  |                           > | 
					
						
							|  |  |  |                             {`Test ${isChatMode ? 'Chat' : 'Run'}#${item.sequence_number}`} | 
					
						
							|  |  |  |                           </div> | 
					
						
							|  |  |  |                           <div className='flex items-center text-xs text-gray-500 leading-[18px]'> | 
					
						
							|  |  |  |                             {item.created_by_account.name} · {formatTimeFromNow((item.finished_at || item.created_at) * 1000)} | 
					
						
							|  |  |  |                           </div> | 
					
						
							|  |  |  |                         </div> | 
					
						
							|  |  |  |                       </div> | 
					
						
							|  |  |  |                     )) | 
					
						
							|  |  |  |                   } | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |               ) | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |         </PortalToFollowElemContent> | 
					
						
							|  |  |  |       </PortalToFollowElem> | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default memo(ViewHistory) |