| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   useCallback, | 
					
						
							|  |  |  |   useEffect, | 
					
						
							|  |  |  |   useMemo, | 
					
						
							|  |  |  |   useRef, | 
					
						
							|  |  |  |   useState, | 
					
						
							|  |  |  | } from 'react' | 
					
						
							|  |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							|  |  |  | import useSWR from 'swr' | 
					
						
							|  |  |  | import { useLocalStorageState } from 'ahooks' | 
					
						
							|  |  |  | import produce from 'immer' | 
					
						
							|  |  |  | import type { | 
					
						
							|  |  |  |   ChatConfig, | 
					
						
							|  |  |  |   Feedback, | 
					
						
							|  |  |  | } from '../types' | 
					
						
							|  |  |  | import { CONVERSATION_ID_INFO } from '../constants' | 
					
						
							| 
									
										
										
										
											2024-09-22 03:15:11 +08:00
										 |  |  | import { getPrevChatList, getProcessedInputsFromUrlParams } from '../utils' | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   fetchAppInfo, | 
					
						
							|  |  |  |   fetchAppMeta, | 
					
						
							|  |  |  |   fetchAppParams, | 
					
						
							|  |  |  |   fetchChatList, | 
					
						
							|  |  |  |   fetchConversations, | 
					
						
							|  |  |  |   generationConversationName, | 
					
						
							|  |  |  |   updateFeedback, | 
					
						
							|  |  |  | } from '@/service/share' | 
					
						
							|  |  |  | import type { | 
					
						
							|  |  |  |   // AppData,
 | 
					
						
							|  |  |  |   ConversationItem, | 
					
						
							|  |  |  | } from '@/models/share' | 
					
						
							|  |  |  | import { useToastContext } from '@/app/components/base/toast' | 
					
						
							|  |  |  | import { changeLanguage } from '@/i18n/i18next-config' | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  | import { InputVarType } from '@/app/components/workflow/types' | 
					
						
							|  |  |  | import { TransferMethod } from '@/types/app' | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export const useEmbeddedChatbot = () => { | 
					
						
							|  |  |  |   const isInstalledApp = false | 
					
						
							|  |  |  |   const { data: appInfo, isLoading: appInfoLoading, error: appInfoError } = useSWR('appInfo', fetchAppInfo) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const appData = useMemo(() => { | 
					
						
							|  |  |  |     return appInfo | 
					
						
							|  |  |  |   }, [appInfo]) | 
					
						
							|  |  |  |   const appId = useMemo(() => appData?.app_id, [appData]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   useEffect(() => { | 
					
						
							|  |  |  |     if (appInfo?.site.default_language) | 
					
						
							|  |  |  |       changeLanguage(appInfo.site.default_language) | 
					
						
							|  |  |  |   }, [appInfo]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const [conversationIdInfo, setConversationIdInfo] = useLocalStorageState<Record<string, string>>(CONVERSATION_ID_INFO, { | 
					
						
							|  |  |  |     defaultValue: {}, | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  |   const currentConversationId = useMemo(() => conversationIdInfo?.[appId || ''] || '', [appId, conversationIdInfo]) | 
					
						
							|  |  |  |   const handleConversationIdInfoChange = useCallback((changeConversationId: string) => { | 
					
						
							|  |  |  |     if (appId) { | 
					
						
							|  |  |  |       setConversationIdInfo({ | 
					
						
							|  |  |  |         ...conversationIdInfo, | 
					
						
							|  |  |  |         [appId || '']: changeConversationId, | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, [appId, conversationIdInfo, setConversationIdInfo]) | 
					
						
							|  |  |  |   const [showConfigPanelBeforeChat, setShowConfigPanelBeforeChat] = useState(true) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const [newConversationId, setNewConversationId] = useState('') | 
					
						
							|  |  |  |   const chatShouldReloadKey = useMemo(() => { | 
					
						
							|  |  |  |     if (currentConversationId === newConversationId) | 
					
						
							|  |  |  |       return '' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return currentConversationId | 
					
						
							|  |  |  |   }, [currentConversationId, newConversationId]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const { data: appParams } = useSWR(['appParams', isInstalledApp, appId], () => fetchAppParams(isInstalledApp, appId)) | 
					
						
							|  |  |  |   const { data: appMeta } = useSWR(['appMeta', isInstalledApp, appId], () => fetchAppMeta(isInstalledApp, appId)) | 
					
						
							|  |  |  |   const { data: appPinnedConversationData } = useSWR(['appConversationData', isInstalledApp, appId, true], () => fetchConversations(isInstalledApp, appId, undefined, true, 100)) | 
					
						
							|  |  |  |   const { data: appConversationData, isLoading: appConversationDataLoading, mutate: mutateAppConversationData } = useSWR(['appConversationData', isInstalledApp, appId, false], () => fetchConversations(isInstalledApp, appId, undefined, false, 100)) | 
					
						
							|  |  |  |   const { data: appChatListData, isLoading: appChatListDataLoading } = useSWR(chatShouldReloadKey ? ['appChatList', chatShouldReloadKey, isInstalledApp, appId] : null, () => fetchChatList(chatShouldReloadKey, isInstalledApp, appId)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-22 03:15:11 +08:00
										 |  |  |   const appPrevChatList = useMemo( | 
					
						
							|  |  |  |     () => (currentConversationId && appChatListData?.data.length) | 
					
						
							|  |  |  |       ? getPrevChatList(appChatListData.data) | 
					
						
							|  |  |  |       : [], | 
					
						
							|  |  |  |     [appChatListData, currentConversationId], | 
					
						
							|  |  |  |   ) | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   const [showNewConversationItemInList, setShowNewConversationItemInList] = useState(false) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const pinnedConversationList = useMemo(() => { | 
					
						
							|  |  |  |     return appPinnedConversationData?.data || [] | 
					
						
							|  |  |  |   }, [appPinnedConversationData]) | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							|  |  |  |   const newConversationInputsRef = useRef<Record<string, any>>({}) | 
					
						
							|  |  |  |   const [newConversationInputs, setNewConversationInputs] = useState<Record<string, any>>({}) | 
					
						
							| 
									
										
										
										
											2024-07-18 21:54:16 +08:00
										 |  |  |   const [initInputs, setInitInputs] = useState<Record<string, any>>({}) | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |   const handleNewConversationInputsChange = useCallback((newInputs: Record<string, any>) => { | 
					
						
							|  |  |  |     newConversationInputsRef.current = newInputs | 
					
						
							|  |  |  |     setNewConversationInputs(newInputs) | 
					
						
							|  |  |  |   }, []) | 
					
						
							|  |  |  |   const inputsForms = useMemo(() => { | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  |     return (appParams?.user_input_form || []).filter((item: any) => !item.external_data_tool).map((item: any) => { | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |       if (item.paragraph) { | 
					
						
							| 
									
										
										
										
											2024-07-18 21:54:16 +08:00
										 |  |  |         let value = initInputs[item.paragraph.variable] | 
					
						
							|  |  |  |         if (value && item.paragraph.max_length && value.length > item.paragraph.max_length) | 
					
						
							|  |  |  |           value = value.slice(0, item.paragraph.max_length) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |         return { | 
					
						
							|  |  |  |           ...item.paragraph, | 
					
						
							| 
									
										
										
										
											2024-07-18 21:54:16 +08:00
										 |  |  |           default: value || item.default, | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |           type: 'paragraph', | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (item.number) { | 
					
						
							| 
									
										
										
										
											2024-07-18 21:54:16 +08:00
										 |  |  |         const convertedNumber = Number(initInputs[item.number.variable]) ?? undefined | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |         return { | 
					
						
							|  |  |  |           ...item.number, | 
					
						
							| 
									
										
										
										
											2024-07-18 21:54:16 +08:00
										 |  |  |           default: convertedNumber || item.default, | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |           type: 'number', | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (item.select) { | 
					
						
							| 
									
										
										
										
											2024-07-18 21:54:16 +08:00
										 |  |  |         const isInputInOptions = item.select.options.includes(initInputs[item.select.variable]) | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |         return { | 
					
						
							|  |  |  |           ...item.select, | 
					
						
							| 
									
										
										
										
											2024-07-18 21:54:16 +08:00
										 |  |  |           default: (isInputInOptions ? initInputs[item.select.variable] : undefined) || item.default, | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |           type: 'select', | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  |       if (item['file-list']) { | 
					
						
							|  |  |  |         return { | 
					
						
							|  |  |  |           ...item['file-list'], | 
					
						
							|  |  |  |           type: 'file-list', | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (item.file) { | 
					
						
							|  |  |  |         return { | 
					
						
							|  |  |  |           ...item.file, | 
					
						
							|  |  |  |           type: 'file', | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-18 21:54:16 +08:00
										 |  |  |       let value = initInputs[item['text-input'].variable] | 
					
						
							|  |  |  |       if (value && item['text-input'].max_length && value.length > item['text-input'].max_length) | 
					
						
							|  |  |  |         value = value.slice(0, item['text-input'].max_length) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |       return { | 
					
						
							|  |  |  |         ...item['text-input'], | 
					
						
							| 
									
										
										
										
											2024-07-18 21:54:16 +08:00
										 |  |  |         default: value || item.default, | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |         type: 'text-input', | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }) | 
					
						
							| 
									
										
										
										
											2024-09-22 03:15:11 +08:00
										 |  |  |   }, [initInputs, appParams]) | 
					
						
							| 
									
										
										
										
											2024-07-18 21:54:16 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   useEffect(() => { | 
					
						
							|  |  |  |     // init inputs from url params
 | 
					
						
							|  |  |  |     setInitInputs(getProcessedInputsFromUrlParams()) | 
					
						
							|  |  |  |   }, []) | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |   useEffect(() => { | 
					
						
							|  |  |  |     const conversationInputs: Record<string, any> = {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     inputsForms.forEach((item: any) => { | 
					
						
							|  |  |  |       conversationInputs[item.variable] = item.default || '' | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |     handleNewConversationInputsChange(conversationInputs) | 
					
						
							|  |  |  |   }, [handleNewConversationInputsChange, inputsForms]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const { data: newConversation } = useSWR(newConversationId ? [isInstalledApp, appId, newConversationId] : null, () => generationConversationName(isInstalledApp, appId, newConversationId), { revalidateOnFocus: false }) | 
					
						
							|  |  |  |   const [originConversationList, setOriginConversationList] = useState<ConversationItem[]>([]) | 
					
						
							|  |  |  |   useEffect(() => { | 
					
						
							|  |  |  |     if (appConversationData?.data && !appConversationDataLoading) | 
					
						
							|  |  |  |       setOriginConversationList(appConversationData?.data) | 
					
						
							|  |  |  |   }, [appConversationData, appConversationDataLoading]) | 
					
						
							|  |  |  |   const conversationList = useMemo(() => { | 
					
						
							|  |  |  |     const data = originConversationList.slice() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (showNewConversationItemInList && data[0]?.id !== '') { | 
					
						
							|  |  |  |       data.unshift({ | 
					
						
							|  |  |  |         id: '', | 
					
						
							|  |  |  |         name: t('share.chat.newChatDefaultName'), | 
					
						
							|  |  |  |         inputs: {}, | 
					
						
							|  |  |  |         introduction: '', | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return data | 
					
						
							|  |  |  |   }, [originConversationList, showNewConversationItemInList, t]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   useEffect(() => { | 
					
						
							|  |  |  |     if (newConversation) { | 
					
						
							|  |  |  |       setOriginConversationList(produce((draft) => { | 
					
						
							|  |  |  |         const index = draft.findIndex(item => item.id === newConversation.id) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (index > -1) | 
					
						
							|  |  |  |           draft[index] = newConversation | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |           draft.unshift(newConversation) | 
					
						
							|  |  |  |       })) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, [newConversation]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const currentConversationItem = useMemo(() => { | 
					
						
							|  |  |  |     let conversationItem = conversationList.find(item => item.id === currentConversationId) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!conversationItem && pinnedConversationList.length) | 
					
						
							|  |  |  |       conversationItem = pinnedConversationList.find(item => item.id === currentConversationId) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return conversationItem | 
					
						
							|  |  |  |   }, [conversationList, currentConversationId, pinnedConversationList]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const { notify } = useToastContext() | 
					
						
							|  |  |  |   const checkInputsRequired = useCallback((silent?: boolean) => { | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  |     let hasEmptyInput = '' | 
					
						
							|  |  |  |     let fileIsUploading = false | 
					
						
							|  |  |  |     const requiredVars = inputsForms.filter(({ required }) => required) | 
					
						
							|  |  |  |     if (requiredVars.length) { | 
					
						
							|  |  |  |       requiredVars.forEach(({ variable, label, type }) => { | 
					
						
							|  |  |  |         if (hasEmptyInput) | 
					
						
							|  |  |  |           return | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (fileIsUploading) | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |           return | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (!newConversationInputsRef.current[variable] && !silent) | 
					
						
							|  |  |  |           hasEmptyInput = label as string | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ((type === InputVarType.singleFile || type === InputVarType.multiFiles) && newConversationInputsRef.current[variable] && !silent) { | 
					
						
							|  |  |  |           const files = newConversationInputsRef.current[variable] | 
					
						
							|  |  |  |           if (Array.isArray(files)) | 
					
						
							|  |  |  |             fileIsUploading = files.find(item => item.transferMethod === TransferMethod.local_file && !item.uploadedId) | 
					
						
							|  |  |  |           else | 
					
						
							|  |  |  |             fileIsUploading = files.transferMethod === TransferMethod.local_file && !files.uploadedId | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  |       }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (hasEmptyInput) { | 
					
						
							|  |  |  |       notify({ type: 'error', message: t('appDebug.errorMessage.valueOfVarRequired', { key: hasEmptyInput }) }) | 
					
						
							|  |  |  |       return false | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (fileIsUploading) { | 
					
						
							|  |  |  |       notify({ type: 'info', message: t('appDebug.errorMessage.waitForFileUpload') }) | 
					
						
							|  |  |  |       return | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return true | 
					
						
							|  |  |  |   }, [inputsForms, notify, t]) | 
					
						
							|  |  |  |   const handleStartChat = useCallback(() => { | 
					
						
							|  |  |  |     if (checkInputsRequired()) { | 
					
						
							|  |  |  |       setShowConfigPanelBeforeChat(false) | 
					
						
							|  |  |  |       setShowNewConversationItemInList(true) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, [setShowConfigPanelBeforeChat, setShowNewConversationItemInList, checkInputsRequired]) | 
					
						
							|  |  |  |   const currentChatInstanceRef = useRef<{ handleStop: () => void }>({ handleStop: () => { } }) | 
					
						
							|  |  |  |   const handleChangeConversation = useCallback((conversationId: string) => { | 
					
						
							|  |  |  |     currentChatInstanceRef.current.handleStop() | 
					
						
							|  |  |  |     setNewConversationId('') | 
					
						
							|  |  |  |     handleConversationIdInfoChange(conversationId) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (conversationId === '' && !checkInputsRequired(true)) | 
					
						
							|  |  |  |       setShowConfigPanelBeforeChat(true) | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       setShowConfigPanelBeforeChat(false) | 
					
						
							|  |  |  |   }, [handleConversationIdInfoChange, setShowConfigPanelBeforeChat, checkInputsRequired]) | 
					
						
							|  |  |  |   const handleNewConversation = useCallback(() => { | 
					
						
							|  |  |  |     currentChatInstanceRef.current.handleStop() | 
					
						
							|  |  |  |     setNewConversationId('') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (showNewConversationItemInList) { | 
					
						
							|  |  |  |       handleChangeConversation('') | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else if (currentConversationId) { | 
					
						
							|  |  |  |       handleConversationIdInfoChange('') | 
					
						
							|  |  |  |       setShowConfigPanelBeforeChat(true) | 
					
						
							|  |  |  |       setShowNewConversationItemInList(true) | 
					
						
							|  |  |  |       handleNewConversationInputsChange({}) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, [handleChangeConversation, currentConversationId, handleConversationIdInfoChange, setShowConfigPanelBeforeChat, setShowNewConversationItemInList, showNewConversationItemInList, handleNewConversationInputsChange]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const handleNewConversationCompleted = useCallback((newConversationId: string) => { | 
					
						
							|  |  |  |     setNewConversationId(newConversationId) | 
					
						
							|  |  |  |     handleConversationIdInfoChange(newConversationId) | 
					
						
							|  |  |  |     setShowNewConversationItemInList(false) | 
					
						
							|  |  |  |     mutateAppConversationData() | 
					
						
							|  |  |  |   }, [mutateAppConversationData, handleConversationIdInfoChange]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const handleFeedback = useCallback(async (messageId: string, feedback: Feedback) => { | 
					
						
							|  |  |  |     await updateFeedback({ url: `/messages/${messageId}/feedbacks`, body: { rating: feedback.rating } }, isInstalledApp, appId) | 
					
						
							|  |  |  |     notify({ type: 'success', message: t('common.api.success') }) | 
					
						
							|  |  |  |   }, [isInstalledApp, appId, t, notify]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return { | 
					
						
							|  |  |  |     appInfoError, | 
					
						
							|  |  |  |     appInfoLoading, | 
					
						
							|  |  |  |     isInstalledApp, | 
					
						
							|  |  |  |     appId, | 
					
						
							|  |  |  |     currentConversationId, | 
					
						
							|  |  |  |     currentConversationItem, | 
					
						
							|  |  |  |     handleConversationIdInfoChange, | 
					
						
							|  |  |  |     appData, | 
					
						
							|  |  |  |     appParams: appParams || {} as ChatConfig, | 
					
						
							|  |  |  |     appMeta, | 
					
						
							|  |  |  |     appPinnedConversationData, | 
					
						
							|  |  |  |     appConversationData, | 
					
						
							|  |  |  |     appConversationDataLoading, | 
					
						
							|  |  |  |     appChatListData, | 
					
						
							|  |  |  |     appChatListDataLoading, | 
					
						
							|  |  |  |     appPrevChatList, | 
					
						
							|  |  |  |     pinnedConversationList, | 
					
						
							|  |  |  |     conversationList, | 
					
						
							|  |  |  |     showConfigPanelBeforeChat, | 
					
						
							|  |  |  |     setShowConfigPanelBeforeChat, | 
					
						
							|  |  |  |     setShowNewConversationItemInList, | 
					
						
							|  |  |  |     newConversationInputs, | 
					
						
							| 
									
										
										
										
											2024-10-21 10:32:37 +08:00
										 |  |  |     newConversationInputsRef, | 
					
						
							| 
									
										
										
										
											2024-06-14 08:42:41 +08:00
										 |  |  |     handleNewConversationInputsChange, | 
					
						
							|  |  |  |     inputsForms, | 
					
						
							|  |  |  |     handleNewConversation, | 
					
						
							|  |  |  |     handleStartChat, | 
					
						
							|  |  |  |     handleChangeConversation, | 
					
						
							|  |  |  |     handleNewConversationCompleted, | 
					
						
							|  |  |  |     newConversationId, | 
					
						
							|  |  |  |     chatShouldReloadKey, | 
					
						
							|  |  |  |     handleFeedback, | 
					
						
							|  |  |  |     currentChatInstanceRef, | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } |