Spaces:
Sleeping
Sleeping
File size: 2,072 Bytes
149698e | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 | import { useState, useCallback } from 'react';
import { api } from '@/services/api';
export interface ChatMessage {
id: string;
role: 'user' | 'assistant';
content: string;
type?: 'message' | 'scan_started' | 'transactions' | 'stats' | 'scan_history' | 'search_results' | 'error';
data?: any;
timestamp: Date;
}
const WELCOME_MESSAGE: ChatMessage = {
id: 'welcome',
role: 'assistant',
content: "Bonjour! Je suis l'assistant ICC. Je peux scanner vos courriels, afficher les transactions, ou consulter les statistiques. Comment puis-je vous aider?",
type: 'message',
timestamp: new Date(),
};
export function useChatAssistant() {
const [messages, setMessages] = useState<ChatMessage[]>([WELCOME_MESSAGE]);
const [isLoading, setIsLoading] = useState(false);
const sendMessage = useCallback(async (text: string) => {
const userMsg: ChatMessage = {
id: `user_${Date.now()}`,
role: 'user',
content: text,
timestamp: new Date(),
};
setMessages((prev) => [...prev, userMsg]);
setIsLoading(true);
try {
const response = await api.post<{
type: string;
message: string;
data?: any;
}>('/chat/message', { message: text });
const assistantMsg: ChatMessage = {
id: `assistant_${Date.now()}`,
role: 'assistant',
content: response.message,
type: response.type as ChatMessage['type'],
data: response.data,
timestamp: new Date(),
};
setMessages((prev) => [...prev, assistantMsg]);
} catch (error: any) {
const errorMsg: ChatMessage = {
id: `error_${Date.now()}`,
role: 'assistant',
content: error.message || 'Une erreur est survenue. Réessayez.',
type: 'error',
timestamp: new Date(),
};
setMessages((prev) => [...prev, errorMsg]);
} finally {
setIsLoading(false);
}
}, []);
const clearHistory = useCallback(() => {
setMessages([WELCOME_MESSAGE]);
}, []);
return { messages, isLoading, sendMessage, clearHistory };
}
|