Skip to content

tarkovtracker-org/TarkovTracker

Repository files navigation

TarkovTracker

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.

Features

  • 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, and Ukrainian

Tech Stack

  • 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

Setup

Install dependencies:

npm install

Environment Variables

Create a .env file with the following variables:

VITE_SUPABASE_URL=your_supabase_project_url
VITE_SUPABASE_ANON_KEY=your_supabase_anonymous_key

Cloudflare Workers (API Gateway)

The workers/api-gateway Worker uses a Durable Object binding for rate limiting:

  • API_GATEWAY_LIMITER (Durable Object)

Development

Start the development server:

npm run dev

The application will be available at http://localhost:3000.

Code Quality

# Lint code
npx eslint .

# Run tests
npx vitest

Production

Build for production:

npm run build

Preview production build locally:

npm run preview

Project Structure

  • app/ - Main application source directory
  • app/features/ - Feature-specific components organized by domain
  • app/components/ - Global/shared UI components
  • app/stores/ - Pinia stores for state management
  • app/composables/ - Reusable composition functions
  • app/pages/ - File-based routing
  • app/server/api/ - Nuxt server routes for API proxying
  • docs/ - Project documentation and migration guides

Documentation

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.

Where to start (new contributors)

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.

License

This project remains licensed under the GNU General Public License v3.0. See LICENSE.md for the full license text.

About

Rewrite of TarkovTracker.org in Nuxt.

Resources

License

Contributing

Stars

Watchers

Forks

Contributors 10