SurfSense/surfsense_web/hooks/use-chat.ts

49 lines
1.4 KiB
TypeScript
Raw Normal View History

2025-07-27 10:05:37 -07:00
import type { Message } from "@ai-sdk/react";
2025-07-27 10:44:27 -07:00
import { useCallback, useEffect, useState } from "react";
2025-10-23 19:48:10 +02:00
import type { ChatDetails } from "@/app/dashboard/[search_space_id]/chats/chats-client";
2025-07-27 10:05:37 -07:00
import type { ResearchMode } from "@/components/chat";
import type { Document } from "@/hooks/use-documents";
import { getBearerToken } from "@/lib/auth-utils";
interface UseChatStateProps {
2025-07-27 10:05:37 -07:00
search_space_id: string;
chat_id?: string;
}
2025-07-27 10:44:27 -07:00
export function useChatState({ chat_id }: UseChatStateProps) {
2025-07-27 10:05:37 -07:00
const [token, setToken] = useState<string | null>(null);
const [isLoading, setIsLoading] = useState(false);
const [currentChatId, setCurrentChatId] = useState<string | null>(chat_id || null);
// Chat configuration state
2025-11-06 13:25:05 -08:00
const [searchMode, setSearchMode] = useState<"DOCUMENTS" | "CHUNKS">("DOCUMENTS");
2025-07-27 10:05:37 -07:00
const [researchMode, setResearchMode] = useState<ResearchMode>("QNA");
const [selectedConnectors, setSelectedConnectors] = useState<string[]>([]);
const [selectedDocuments, setSelectedDocuments] = useState<Document[]>([]);
2025-11-06 13:25:05 -08:00
const [topK, setTopK] = useState<number>(5);
2025-07-27 10:05:37 -07:00
useEffect(() => {
const bearerToken = getBearerToken();
2025-07-27 10:05:37 -07:00
setToken(bearerToken);
}, []);
return {
token,
setToken,
isLoading,
setIsLoading,
currentChatId,
setCurrentChatId,
searchMode,
setSearchMode,
researchMode,
setResearchMode,
selectedConnectors,
setSelectedConnectors,
selectedDocuments,
setSelectedDocuments,
2025-11-06 13:25:05 -08:00
topK,
setTopK,
2025-07-27 10:05:37 -07:00
};
}