A comprehensive Escape from Tarkov progress tracker built with Nuxt 4, featuring team collaboration, dual game mode support (PvP/PvE), and real-time synchronization via Supabase.
- Dual Game Mode Support: Track progress separately for PvP and PvE modes
- Team Collaboration: Share progress with teammates in real-time
- Task Tracking: Monitor quest completions and objectives
- Hideout Progress: Track module upgrades and parts
- Player Level Progress: Monitor leveling across different factions
- Real-time Sync: Automatic synchronization via Supabase
- Multi-language Support: Available in English, German, Spanish, French, Russian, Ukrainian, and Chinese
- Framework: Nuxt 4 (SPA mode)
- UI: Nuxt UI component library
- Styling: Tailwind CSS v4
- State Management: Pinia with three-store architecture
- Backend: Supabase (authentication, database, real-time)
- API: Nuxt server-side proxy to tarkov.dev GraphQL API
- Deployment: Cloudflare Pages
Install dependencies:
npm installCopy .env.example to .env and fill in your values:
# Required for login/sync features
VITE_SUPABASE_URL=your_supabase_project_url
VITE_SUPABASE_ANON_KEY=your_supabase_anonymous_key
# Optional: API gateway URLs (for team features)
# NUXT_PUBLIC_TEAM_GATEWAY_URL=
# NUXT_PUBLIC_TOKEN_GATEWAY_URL=
# Optional: App configuration
# NUXT_PUBLIC_APP_URL=http://localhost:3000
# NUXT_PUBLIC_GA_MEASUREMENT_ID=G-XXXXXXXXXX
# NUXT_PUBLIC_CLARITY_PROJECT_ID=xxxxxxxxxxNUXT_PUBLIC_APP_URL only sets the public app/canonical URL. NUXT_PUBLIC_GA_MEASUREMENT_ID
and NUXT_PUBLIC_CLARITY_PROJECT_ID only enable the Google Analytics and Microsoft Clarity
integration codepaths; they do not start tracking by themselves. Tracking stays disabled until the
user explicitly opts in through the analytics consent banner or footer "Analytics Preferences"
control. That opt-in state is managed in app/composables/useAnalyticsConsent.ts, and
app/plugins/03.analytics-consent-mode.client.ts keeps analytics consent mode denied until the
user accepts.
The project uses two Cloudflare Workers, each with a Durable Object binding for rate limiting:
workers/api-gateway— API request gatewayAPI_GATEWAY_LIMITER(Durable Object)
workers/team-gateway— Team feature gatewayTEAM_GATEWAY_LIMITER(Durable Object)
app/server/api/team/members.tsuses in-memory Maps for response caching and rate limiting.app/server/api/profile/[userId]/[mode].get.tsuses in-memory MapssharedProfileRateLimiterandsharedProfileCache.- In-memory Maps are local to each running instance and are not shared across serverless/horizontal deployments.
- For production-wide consistency across both endpoints, use a distributed backend (for example Redis or Cloudflare KV) for rate limiting and caching.
Start the development server:
npm run devThe application will be available at http://localhost:3000.
# Format code (Prettier + ESLint)
npm run format
# Lint code
npm run lint
# Run tests
npm test
# Type check
npm run typecheck
# Check for dependency updates
npm run depsBuild for production:
npm run buildPreview production build locally:
npm run previewapp/- Main application source directoryapp/features/- Feature-specific components organized by domainapp/components/- Global/shared UI componentsapp/stores/- Pinia stores for state managementapp/composables/- Reusable composition functionsapp/pages/- File-based routingapp/server/api/- Nuxt server routes for API proxyingworkers/- Cloudflare Workers (api-gateway, team-gateway)docs/- Project documentation and migration guides
For detailed development guidelines, architecture references, and migration progress, see the files in the docs/ directory.
This repository includes both contribution workflow guidance and technical documentation.
How to Contribute (Issues, Branches, PR Process): Open or pick an issue, get assigned, create a focused branch, Use the PR template, and link the issue.
Important
Each pull request must address one change only — a single fix, update, documentation improvement, or new feature.
Pull requests that bundle unrelated changes may be asked to split or be closed.
Label System: Issue Types define the kind of work being done, while labels communicate scope, priority, ownership, and status throughout the lifecycle of the issue.
GitHub Project Board: Issues progress through the board from backlog to completion, with transitions driven by issue and pull request activity.
Note
If you’re new to the project, look for issues labeled good-first-issue. These are intentionally scoped to be approachable and are the best way to get familiar with the codebase, contribution process, and review expectations.
This project remains licensed under the GNU General Public License v3.0. See LICENSE.md for the full license text.