msa1 / front /src /context /ChatContext.tsx
zouhairk's picture
init front
b681a44
raw
history blame
905 Bytes
import React, { createContext, useContext, useState } from 'react';
interface Message {
id: number;
text: string;
isArabic?: boolean;
isFrench?: boolean;
timestamp: Date;
}
interface ChatContextType {
messages: Message[];
addMessage: (message: Message) => void;
}
const ChatContext = createContext<ChatContextType | undefined>(undefined);
export function ChatProvider({ children }: { children: React.ReactNode }) {
const [messages, setMessages] = useState<Message[]>([]);
const addMessage = (message: Message) => {
setMessages(prev => [...prev, message]);
};
return (
<ChatContext.Provider value={{ messages, addMessage }}>
{children}
</ChatContext.Provider>
);
}
export function useChat() {
const context = useContext(ChatContext);
if (context === undefined) {
throw new Error('useChat must be used within a ChatProvider');
}
return context;
}