mirror of
https://github.com/theoludwig/theoludwig.git
synced 2025-10-14 20:23:25 +02:00
2.1 KiB
2.1 KiB
Contributing
Thanks a lot for your interest in contributing to theoludwig.fr!
Types of contributions
- Reporting a bug.
- Suggest a new feature idea.
- Correct spelling errors, improvements or additions to documentation files (README, CONTRIBUTING...).
- Improve structure/format/performance/refactor/tests of the code.
Pull Requests
-
Please first discuss the change you wish to make via issue before making a change. It might avoid a waste of your time.
-
Ensure your code respect linting.
-
Make sure your code passes the tests.
If you're adding new features to theoludwig.fr, please include tests.
Commits
The commit message guidelines adheres to Conventional Commits and Semantic Versioning for releases.
Getting Started
Prerequisites
- Node.js >= v24.0.0 (
nvm install 24
) - pnpm v10.18.2 (
npm install --global corepack@0.34.0 && corepack enable
) - Docker
Installation
# Clone the repository
git clone git@github.com:theoludwig/theoludwig.git
# Go to the project root
cd theoludwig
# Configure environment variables
cp .env.example .env
cp apps/website/.env.example apps/website/.env
# Install dependencies
pnpm install --frozen-lockfile
# Install Playwright browser binaries and their dependencies (tests)
pnpm exec playwright install --with-deps
Development
# Start the development server
node --run dev
# Lint
node --run lint:editorconfig
node --run lint:markdown
node --run lint:typescript
node --run lint:eslint
node --run lint:prettier
# Tests
node --run test
# Build
node --run build
# To execute a command in a specific package (e.g: packages/utils)
cd packages/utils
node --run test
Production environment with Docker
# Setup and run all the services for you
VERSION=$(git describe --tags) docker compose up --build --detach
Services started
theoludwig
: http://localhost:3000