| 
									
										
										
										
											2024-02-04 16:10:46 +08:00
										 |  |  | import { useCallback, useEffect, useMemo } from 'react' | 
					
						
							|  |  |  | import Chat from '../chat' | 
					
						
							|  |  |  | import type { | 
					
						
							|  |  |  |   ChatConfig, | 
					
						
							|  |  |  |   OnSend, | 
					
						
							|  |  |  | } from '../types' | 
					
						
							|  |  |  | import { useChat } from '../chat/hooks' | 
					
						
							|  |  |  | import { useChatWithHistoryContext } from './context' | 
					
						
							|  |  |  | import Header from './header' | 
					
						
							|  |  |  | import ConfigPanel from './config-panel' | 
					
						
							|  |  |  | import { | 
					
						
							|  |  |  |   fetchSuggestedQuestions, | 
					
						
							|  |  |  |   getUrl, | 
					
						
							| 
									
										
										
										
											2024-02-04 18:08:53 +08:00
										 |  |  |   stopChatMessageResponding, | 
					
						
							| 
									
										
										
										
											2024-02-04 16:10:46 +08:00
										 |  |  | } from '@/service/share' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const ChatWrapper = () => { | 
					
						
							|  |  |  |   const { | 
					
						
							|  |  |  |     appParams, | 
					
						
							|  |  |  |     appPrevChatList, | 
					
						
							|  |  |  |     currentConversationId, | 
					
						
							|  |  |  |     currentConversationItem, | 
					
						
							|  |  |  |     inputsForms, | 
					
						
							|  |  |  |     newConversationInputs, | 
					
						
							|  |  |  |     handleNewConversationCompleted, | 
					
						
							|  |  |  |     isMobile, | 
					
						
							|  |  |  |     isInstalledApp, | 
					
						
							|  |  |  |     appId, | 
					
						
							|  |  |  |     appMeta, | 
					
						
							|  |  |  |     handleFeedback, | 
					
						
							|  |  |  |     currentChatInstanceRef, | 
					
						
							| 
									
										
										
										
											2024-06-21 12:51:10 +08:00
										 |  |  |     appData, | 
					
						
							| 
									
										
										
										
											2024-02-04 16:10:46 +08:00
										 |  |  |   } = useChatWithHistoryContext() | 
					
						
							|  |  |  |   const appConfig = useMemo(() => { | 
					
						
							|  |  |  |     const config = appParams || {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return { | 
					
						
							|  |  |  |       ...config, | 
					
						
							|  |  |  |       supportFeedback: true, | 
					
						
							| 
									
										
										
										
											2024-02-12 22:22:57 +08:00
										 |  |  |       opening_statement: currentConversationId ? currentConversationItem?.introduction : (config as any).opening_statement, | 
					
						
							| 
									
										
										
										
											2024-02-04 16:10:46 +08:00
										 |  |  |     } as ChatConfig | 
					
						
							| 
									
										
										
										
											2024-02-12 22:22:57 +08:00
										 |  |  |   }, [appParams, currentConversationItem?.introduction, currentConversationId]) | 
					
						
							| 
									
										
										
										
											2024-02-04 16:10:46 +08:00
										 |  |  |   const { | 
					
						
							|  |  |  |     chatList, | 
					
						
							|  |  |  |     handleSend, | 
					
						
							|  |  |  |     handleStop, | 
					
						
							| 
									
										
										
										
											2024-03-07 10:20:35 +08:00
										 |  |  |     isResponding, | 
					
						
							| 
									
										
										
										
											2024-02-04 16:10:46 +08:00
										 |  |  |     suggestedQuestions, | 
					
						
							|  |  |  |   } = useChat( | 
					
						
							|  |  |  |     appConfig, | 
					
						
							| 
									
										
										
										
											2024-02-12 22:22:57 +08:00
										 |  |  |     { | 
					
						
							|  |  |  |       inputs: (currentConversationId ? currentConversationItem?.inputs : newConversationInputs) as any, | 
					
						
							|  |  |  |       promptVariables: inputsForms, | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-02-04 16:10:46 +08:00
										 |  |  |     appPrevChatList, | 
					
						
							| 
									
										
										
										
											2024-02-04 18:08:53 +08:00
										 |  |  |     taskId => stopChatMessageResponding('', taskId, isInstalledApp, appId), | 
					
						
							| 
									
										
										
										
											2024-02-04 16:10:46 +08:00
										 |  |  |   ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   useEffect(() => { | 
					
						
							|  |  |  |     if (currentChatInstanceRef.current) | 
					
						
							|  |  |  |       currentChatInstanceRef.current.handleStop = handleStop | 
					
						
							|  |  |  |   }, []) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const doSend: OnSend = useCallback((message, files) => { | 
					
						
							|  |  |  |     const data: any = { | 
					
						
							|  |  |  |       query: message, | 
					
						
							|  |  |  |       inputs: currentConversationId ? currentConversationItem?.inputs : newConversationInputs, | 
					
						
							|  |  |  |       conversation_id: currentConversationId, | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (appConfig?.file_upload?.image.enabled && files?.length) | 
					
						
							|  |  |  |       data.files = files | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     handleSend( | 
					
						
							|  |  |  |       getUrl('chat-messages', isInstalledApp, appId || ''), | 
					
						
							|  |  |  |       data, | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |         onGetSuggestedQuestions: responseItemId => fetchSuggestedQuestions(responseItemId, isInstalledApp, appId), | 
					
						
							|  |  |  |         onConversationComplete: currentConversationId ? undefined : handleNewConversationCompleted, | 
					
						
							|  |  |  |         isPublicAPI: !isInstalledApp, | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |   }, [ | 
					
						
							|  |  |  |     appConfig, | 
					
						
							|  |  |  |     currentConversationId, | 
					
						
							|  |  |  |     currentConversationItem, | 
					
						
							|  |  |  |     handleSend, | 
					
						
							|  |  |  |     newConversationInputs, | 
					
						
							|  |  |  |     handleNewConversationCompleted, | 
					
						
							|  |  |  |     isInstalledApp, | 
					
						
							|  |  |  |     appId, | 
					
						
							|  |  |  |   ]) | 
					
						
							|  |  |  |   const chatNode = useMemo(() => { | 
					
						
							|  |  |  |     if (inputsForms.length) { | 
					
						
							|  |  |  |       return ( | 
					
						
							|  |  |  |         <> | 
					
						
							|  |  |  |           <Header | 
					
						
							|  |  |  |             isMobile={isMobile} | 
					
						
							|  |  |  |             title={currentConversationItem?.name || ''} | 
					
						
							|  |  |  |           /> | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             !currentConversationId && ( | 
					
						
							|  |  |  |               <div className={`mx-auto w-full max-w-[720px] ${isMobile && 'px-4'}`}> | 
					
						
							|  |  |  |                 <div className='mb-6' /> | 
					
						
							|  |  |  |                 <ConfigPanel /> | 
					
						
							|  |  |  |                 <div | 
					
						
							|  |  |  |                   className='my-6 h-[1px]' | 
					
						
							|  |  |  |                   style={{ background: 'linear-gradient(90deg, rgba(242, 244, 247, 0.00) 0%, #F2F4F7 49.17%, rgba(242, 244, 247, 0.00) 100%)' }} | 
					
						
							|  |  |  |                 /> | 
					
						
							|  |  |  |               </div> | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         </> | 
					
						
							|  |  |  |       ) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return ( | 
					
						
							|  |  |  |       <Header | 
					
						
							|  |  |  |         isMobile={isMobile} | 
					
						
							|  |  |  |         title={currentConversationItem?.name || ''} | 
					
						
							|  |  |  |       /> | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |   }, [ | 
					
						
							|  |  |  |     currentConversationId, | 
					
						
							|  |  |  |     inputsForms, | 
					
						
							|  |  |  |     currentConversationItem, | 
					
						
							|  |  |  |     isMobile, | 
					
						
							|  |  |  |   ]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <Chat | 
					
						
							| 
									
										
										
										
											2024-06-21 12:51:10 +08:00
										 |  |  |       appData={appData} | 
					
						
							| 
									
										
										
										
											2024-02-04 16:10:46 +08:00
										 |  |  |       config={appConfig} | 
					
						
							|  |  |  |       chatList={chatList} | 
					
						
							| 
									
										
										
										
											2024-03-07 10:20:35 +08:00
										 |  |  |       isResponding={isResponding} | 
					
						
							| 
									
										
										
										
											2024-02-04 16:10:46 +08:00
										 |  |  |       chatContainerInnerClassName={`mx-auto pt-6 w-full max-w-[720px] ${isMobile && 'px-4'}`} | 
					
						
							|  |  |  |       chatFooterClassName='pb-4' | 
					
						
							|  |  |  |       chatFooterInnerClassName={`mx-auto w-full max-w-[720px] ${isMobile && 'px-4'}`} | 
					
						
							|  |  |  |       onSend={doSend} | 
					
						
							|  |  |  |       onStopResponding={handleStop} | 
					
						
							|  |  |  |       chatNode={chatNode} | 
					
						
							|  |  |  |       allToolIcons={appMeta?.tool_icons || {}} | 
					
						
							|  |  |  |       onFeedback={handleFeedback} | 
					
						
							|  |  |  |       suggestedQuestions={suggestedQuestions} | 
					
						
							| 
									
										
										
										
											2024-05-11 13:40:27 +08:00
										 |  |  |       hideProcessDetail | 
					
						
							| 
									
										
										
										
											2024-02-04 16:10:46 +08:00
										 |  |  |     /> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default ChatWrapper |