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>
20 lines
583 B
TypeScript
20 lines
583 B
TypeScript
'use client'
|
|
import { ApolloClient, InMemoryCache, HttpLink } from '@apollo/client/core'
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
let client: InstanceType<typeof ApolloClient> | null = null
|
|
|
|
function createClient() {
|
|
return new ApolloClient({
|
|
link: new HttpLink({ uri: '/api/graphql' }),
|
|
cache: new InMemoryCache(),
|
|
defaultOptions: { watchQuery: { fetchPolicy: 'cache-and-network' } },
|
|
})
|
|
}
|
|
|
|
export function getApolloClient() {
|
|
if (typeof window === 'undefined') return createClient()
|
|
if (!client) client = createClient()
|
|
return client
|
|
}
|