58b4114159
Full-stack World Cup web app (1930–2026): - Next.js 16 + TailwindCSS 4 + GraphQL Yoga + Apollo Client 4 + Drizzle + PostgreSQL 16 - 23 tournaments synced from openfootball/worldcup.json (matches, goals, teams, stadiums, squads, standings) - Pages: home (live), groups, stats, history, search, /tournaments/[year], /teams/[slug], /players/[name] - Live match detection via isLive() + Apollo 60 s poll - pnpm with node-linker=hoisted for Docker compatibility - docker-compose.yml with Traefik labels (HTTPS redirect, TLS, security middleware) - docker-compose.dev.yml for local dev (DB only, port 5432 exposed) - Dockerfile: multi-stage pnpm build, standalone Next.js output, sync script bundled - .env.example with all required variables documented - Comprehensive README with local dev, deployment, schema, and GraphQL API reference Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
13 lines
534 B
TypeScript
13 lines
534 B
TypeScript
'use client'
|
|
/* Apollo Client v4 defaults TData to unknown — wrap to restore convenient any typing */
|
|
import { useQuery as _useQuery } from '@apollo/client/react'
|
|
import type { DocumentNode } from '@apollo/client/core'
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
export function useQuery(query: DocumentNode, options?: Record<string, unknown>) {
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
return _useQuery<Record<string, any>>(query, options)
|
|
}
|
|
|
|
export { gql } from '@apollo/client/core'
|