Files
worldcup/lib/graphql/hooks.ts
T
valknar 58b4114159 feat: initial commit — World Cup stats app with pnpm, Traefik, Docker
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>
2026-06-14 15:36:44 +02:00

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'