Files
automaker/apps/ui/src/hooks/queries/use-sessions.ts
Shirone 2bc931a8b0 feat(ui): add React Query hooks for data fetching
- Add useFeatures, useFeature, useAgentOutput for feature data
- Add useGitHubIssues, useGitHubPRs, useGitHubValidations, useGitHubIssueComments
- Add useClaudeUsage, useCodexUsage with polling intervals
- Add useRunningAgents, useRunningAgentsCount
- Add useWorktrees, useWorktreeInfo, useWorktreeStatus, useWorktreeDiffs
- Add useGlobalSettings, useProjectSettings, useCredentials
- Add useAvailableModels, useCodexModels, useOpencodeModels
- Add useSessions, useSessionHistory, useSessionQueue
- Add useIdeationPrompts, useIdeas
- Add CLI status queries (claude, cursor, codex, opencode, github)
- Add useCursorPermissionsQuery, useWorkspaceDirectories
- Add usePipelineConfig, useSpecFile, useSpecRegenerationStatus

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-15 16:20:24 +01:00

87 lines
2.5 KiB
TypeScript

/**
* Sessions Query Hooks
*
* React Query hooks for fetching session data.
*/
import { useQuery } from '@tanstack/react-query';
import { getElectronAPI } from '@/lib/electron';
import { queryKeys } from '@/lib/query-keys';
import { STALE_TIMES } from '@/lib/query-client';
import type { SessionListItem } from '@/types/electron';
/**
* Fetch all sessions
*
* @param includeArchived - Whether to include archived sessions
* @returns Query result with sessions array
*
* @example
* ```tsx
* const { data: sessions, isLoading } = useSessions(false);
* ```
*/
export function useSessions(includeArchived = false) {
return useQuery({
queryKey: queryKeys.sessions.all(includeArchived),
queryFn: async (): Promise<SessionListItem[]> => {
const api = getElectronAPI();
const result = await api.sessions.list(includeArchived);
if (!result.success) {
throw new Error(result.error || 'Failed to fetch sessions');
}
return result.sessions ?? [];
},
staleTime: STALE_TIMES.SESSIONS,
});
}
/**
* Fetch session history
*
* @param sessionId - ID of the session
* @returns Query result with session messages
*/
export function useSessionHistory(sessionId: string | undefined) {
return useQuery({
queryKey: queryKeys.sessions.history(sessionId ?? ''),
queryFn: async () => {
if (!sessionId) throw new Error('No session ID');
const api = getElectronAPI();
const result = await api.agent.getHistory(sessionId);
if (!result.success) {
throw new Error(result.error || 'Failed to fetch session history');
}
return {
messages: result.messages ?? [],
isRunning: result.isRunning ?? false,
};
},
enabled: !!sessionId,
staleTime: STALE_TIMES.FEATURES, // Session history changes during conversations
});
}
/**
* Fetch session message queue
*
* @param sessionId - ID of the session
* @returns Query result with queued messages
*/
export function useSessionQueue(sessionId: string | undefined) {
return useQuery({
queryKey: queryKeys.sessions.queue(sessionId ?? ''),
queryFn: async () => {
if (!sessionId) throw new Error('No session ID');
const api = getElectronAPI();
const result = await api.agent.queueList(sessionId);
if (!result.success) {
throw new Error(result.error || 'Failed to fetch queue');
}
return result.queue ?? [];
},
enabled: !!sessionId,
staleTime: STALE_TIMES.RUNNING_AGENTS, // Queue changes frequently during use
});
}