7.2 KiB
Contributing to Monochrome
Thank you for your interest in contributing to Monochrome! This guide will help you get started with development, understand our codebase, and follow our contribution workflow.
Table of Contents
- Development Setup
- Code Quality
- Project Structure
- Contributing Workflow
- Commit Message Guidelines
- Deployment
- Questions?
Development Setup
Prerequisites
Quick Start
-
Fork and clone the repository:
git clone https://github.com/YOUR_USERNAME/monochrome.git cd monochrome -
Install dependencies:
bun install # or npm install -
Start the development server:
bun run dev # or npm run dev -
Open your browser: Navigate to
http://localhost:5173/
Code Quality
We maintain high code quality standards. All code must pass our linting checks before being merged.
Our Tool Stack
| Tool | Purpose | Files |
|---|---|---|
| ESLint | JavaScript linting | *.js |
| Stylelint | CSS linting | *.css |
| HTMLHint | HTML validation | *.html |
| Prettier | Code formatting | All |
Available Commands
# Check everything (runs all linters)
bun run lint
# Auto-format all code
bun run format
# Fix JavaScript issues automatically
bun run lint:js -- --fix
# Fix CSS issues automatically
bun run lint:css -- --fix
# Check HTML
bun run lint:html
# Check specific file types
bun run lint:js
bun run lint:css
⚠️ Important: A GitHub Action automatically runs
bun run linton every push and pull request. Please ensure all checks pass before committing.
Project Structure
monochrome/
├── 📁 js/ # Application source code
│ ├── components/ # UI components
│ ├── utils/ # Utility functions
│ ├── api/ # API integration
│ └── ...
├── 📁 public/ # Static assets
│ ├── assets/ # Images, icons, fonts
│ ├── manifest.json # PWA manifest
│ └── instances.json # API instances configuration
├── 📄 index.html # Application entry point
├── 📄 vite.config.js # Build and PWA configuration
├── 📄 package.json # Dependencies and scripts
└── 📄 README.md # Project documentation
Key Directories
-
/js- All JavaScript source code- Keep modules focused and single-purpose
- Use ES6+ features
- Add JSDoc comments for complex functions
-
/public- Static assets copied directly to build- Images should be optimized before adding
- Keep file sizes reasonable
- Use appropriate formats (WebP where possible)
Contributing Workflow
1. Create a Branch
git checkout -b feature/your-feature-name
# or
git checkout -b fix/description-of-fix
2. Make Your Changes
- Follow existing code style
- Write clear, self-documenting code
- Add comments for complex logic
- Update documentation if needed
3. Test Your Changes
# Run all linters
bun run lint
# Test the build
bun run build
4. Commit Your Changes
Follow our commit message guidelines.
git add .
git commit -m "feat(player): add keyboard shortcut for loop toggle"
5. Push and Create a Pull Request
git push origin feature/your-feature-name
Then open a pull request on GitHub with:
- Clear title describing the change
- Detailed description of what changed and why
- Reference any related issues
Commit Message Guidelines
We use Conventional Commits for clear, structured commit messages.
Format
<type>(<scope>): <description>
[optional body]
[optional footer]
Types
| Type | Description |
|---|---|
feat |
New feature |
fix |
Bug fix |
docs |
Documentation changes |
style |
Code style changes (formatting, semicolons, etc.) |
refactor |
Code refactoring without changing behavior |
perf |
Performance improvements |
test |
Adding or updating tests |
chore |
Maintenance tasks (dependencies, build, etc.) |
Scopes
Common scopes in our project:
player- Audio player functionalityui- User interface componentsapi- API integrationlibrary- Library managementplaylists- Playlist functionalitylyrics- Lyrics displaydownloads- Download functionalityauth- Authenticationpwa- Progressive Web App featuressettings- Settings/preferencestheme- Theming system
Examples
# Feature addition
feat(playlists): add shuffle playlist button
# Bug fix
fix(metadata): resolve corrupted Hi-res metadata issue
# Refactoring
refactor(downloads): simplify cancel download logic
# Documentation
docs(README): improve installation instructions
# Maintenance
chore(deps): bump lyrics package to fix vulnerability
# Style changes
style(player): fix indentation in audio controls
Tips
- Use the present tense ("add feature" not "added feature")
- Use imperative mood ("move cursor to..." not "moves cursor to...")
- Don't capitalize the first letter
- No period at the end
- Keep the first line under 72 characters
📋 Cheat Sheet: Conventional Commits Cheat Sheet
Deployment
Deployment is fully automated via Cloudflare Pages.
How It Works
- Push changes to the
mainbranch - Cloudflare automatically builds and deploys
- Changes are live within minutes
Configuration Notes
The project uses a relative base path (./) in vite.config.js. This allows the same build artifact to work on both:
- Cloudflare Pages (served from root)
- GitHub Pages (served from
/monochrome/)
Hash routing is used to ensure compatibility across all hosting platforms.
Manual Deployment
If you need to deploy manually:
# Build for production
bun run build
# The `dist/` folder contains the deployable files
Questions?
- 💬 Join our community discussions
- 🐛 Open an issue for bugs or feature requests
- 📧 Contact the maintainers
Code of Conduct
- Be respectful and inclusive
- Welcome newcomers and help them learn
- Focus on constructive feedback
- Respect different viewpoints and experiences
Thank you for contributing to Monochrome!