SurfSense/surfsense_web/hooks/use-chat.ts

44 lines
1.2 KiB
TypeScript
Raw Normal View History

import { useEffect, useState } from "react";
2025-07-27 10:05:37 -07:00
import type { ResearchMode } from "@/components/chat";
import type { Document } from "@/contracts/types/document.types";
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
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,
researchMode,
setResearchMode,
selectedConnectors,
setSelectedConnectors,
selectedDocuments,
setSelectedDocuments,
2025-11-06 13:25:05 -08:00
topK,
setTopK,
2025-07-27 10:05:37 -07:00
};
}