import { useQuery } from '@tanstack/react-query'

export type ChatMode = 'enhanced-hermes' | 'portable' | 'disconnected'

interface GatewayStatus {
  capabilities: Record<string, boolean>
  hermesUrl: string
}

function deriveChatMode(capabilities: Record<string, boolean>): ChatMode {
  if (capabilities.sessions) return 'enhanced-hermes'
  if (capabilities.chatCompletions || capabilities.health) return 'portable'
  return 'disconnected'
}

export function useChatMode(): ChatMode {
  const { data } = useQuery({
    queryKey: ['gateway-status'],
    queryFn: async () => {
      const res = await fetch('/api/gateway-status')
      if (!res.ok) return null
      return (await res.json()) as GatewayStatus
    },
    staleTime: 60_000,
    refetchInterval: 60_000,
  })

  if (!data?.capabilities) return 'disconnected'
  return deriveChatMode(data.capabilities)
}
