mirror of
				https://github.com/langgenius/dify.git
				synced 2025-10-24 23:48:40 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			78 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| 'use client'
 | |
| 
 | |
| import type { RefObject } from 'react'
 | |
| import { createContext, useContext } from 'use-context-selector'
 | |
| import type {
 | |
|   Callback,
 | |
|   ChatConfig,
 | |
|   ChatItem,
 | |
|   Feedback,
 | |
| } from '../types'
 | |
| import type { ThemeBuilder } from '../embedded-chatbot/theme/theme-context'
 | |
| import type {
 | |
|   AppConversationData,
 | |
|   AppData,
 | |
|   AppMeta,
 | |
|   ConversationItem,
 | |
| } from '@/models/share'
 | |
| 
 | |
| export type ChatWithHistoryContextValue = {
 | |
|   appInfoError?: any
 | |
|   appInfoLoading?: boolean
 | |
|   appMeta?: AppMeta
 | |
|   appData?: AppData
 | |
|   appParams?: ChatConfig
 | |
|   appChatListDataLoading?: boolean
 | |
|   currentConversationId: string
 | |
|   currentConversationItem?: ConversationItem
 | |
|   appPrevChatList: ChatItem[]
 | |
|   pinnedConversationList: AppConversationData['data']
 | |
|   conversationList: AppConversationData['data']
 | |
|   showConfigPanelBeforeChat: boolean
 | |
|   newConversationInputs: Record<string, any>
 | |
|   handleNewConversationInputsChange: (v: Record<string, any>) => void
 | |
|   inputsForms: any[]
 | |
|   handleNewConversation: () => void
 | |
|   handleStartChat: () => void
 | |
|   handleChangeConversation: (conversationId: string) => void
 | |
|   handlePinConversation: (conversationId: string) => void
 | |
|   handleUnpinConversation: (conversationId: string) => void
 | |
|   handleDeleteConversation: (conversationId: string, callback: Callback) => void
 | |
|   conversationRenaming: boolean
 | |
|   handleRenameConversation: (conversationId: string, newName: string, callback: Callback) => void
 | |
|   handleNewConversationCompleted: (newConversationId: string) => void
 | |
|   chatShouldReloadKey: string
 | |
|   isMobile: boolean
 | |
|   isInstalledApp: boolean
 | |
|   appId?: string
 | |
|   handleFeedback: (messageId: string, feedback: Feedback) => void
 | |
|   currentChatInstanceRef: RefObject<{ handleStop: () => void }>
 | |
|   themeBuilder?: ThemeBuilder
 | |
| }
 | |
| 
 | |
| export const ChatWithHistoryContext = createContext<ChatWithHistoryContextValue>({
 | |
|   currentConversationId: '',
 | |
|   appPrevChatList: [],
 | |
|   pinnedConversationList: [],
 | |
|   conversationList: [],
 | |
|   showConfigPanelBeforeChat: false,
 | |
|   newConversationInputs: {},
 | |
|   handleNewConversationInputsChange: () => {},
 | |
|   inputsForms: [],
 | |
|   handleNewConversation: () => {},
 | |
|   handleStartChat: () => {},
 | |
|   handleChangeConversation: () => {},
 | |
|   handlePinConversation: () => {},
 | |
|   handleUnpinConversation: () => {},
 | |
|   handleDeleteConversation: () => {},
 | |
|   conversationRenaming: false,
 | |
|   handleRenameConversation: () => {},
 | |
|   handleNewConversationCompleted: () => {},
 | |
|   chatShouldReloadKey: '',
 | |
|   isMobile: false,
 | |
|   isInstalledApp: false,
 | |
|   handleFeedback: () => {},
 | |
|   currentChatInstanceRef: { current: { handleStop: () => {} } },
 | |
| })
 | |
| export const useChatWithHistoryContext = () => useContext(ChatWithHistoryContext)
 | 
