@involvex/youtube-music-cli
v0.0.46
Published
- A Commandline music player for youtube-music
Maintainers
Readme
🎵 youtube-music-cli
A powerful Terminal User Interface (TUI) music player for YouTube Music
Features • Installation • Usage • Plugins • Documentation
Features
- 🎨 Beautiful TUI - Rich terminal interface built with React and Ink
- 🔍 Search - Find songs, albums, artists, and playlists
- 📋 Queue Management - Build and manage your playback queue
- 🔀 Shuffle & Repeat - Multiple playback modes
- 🎚️ Volume Control - Fine-grained volume adjustment
- 💡 Smart Suggestions - Discover related tracks
- 🎨 Themes - Dark, Light, Midnight, Matrix themes
- 🔌 Plugin System - Extend functionality with plugins
- ⌨️ Keyboard-Driven - Efficient vim-style navigation
- 🖥️ Headless Mode - Run without TUI for scripting
- 💾 Downloads - Save tracks/playlists/artists with
Shift+D - 🏷️ Metadata Tagging - Auto-tag title/artist/album with optional cover art
- ⚡️ Shell Completions -
ymc completions <bash|zsh|powershell|fish>emits scripts you can source or save so the CLI (also available asymc) tab-completes subcommands and flags
Roadmap
Visit SUGGESTIONS.md for the full backlog and use docs/roadmap.md to understand the current implementation focus (crossfade + gapless playback) and the next steps planned for equalizer/enhancements. The roadmap doc also explains how to pick up work so reviewers and contributors remain aligned.
Prerequisites
Required:
Installing Prerequisites
# With Scoop
scoop install mpv yt-dlp
# With Chocolatey
choco install mpv yt-dlpbrew install mpv yt-dlp# Ubuntu/Debian
sudo apt install mpv
pip install yt-dlp
# Arch Linux
sudo pacman -S mpv yt-dlp
# Fedora
sudo dnf install mpv yt-dlpInstallation
npm (Recommended)
npm install -g @involvex/youtube-music-cliBun
bun install -g @involvex/youtube-music-cliHomebrew
brew tap involvex/youtube-music-cli https://github.com/involvex/youtube-music-cli.git
brew install youtube-music-cliGitHub Releases
https://github.com/involvex/youtube-music-cli/releasesInstall Script (bash)
curl -fssl https://raw.githubusercontent.com/involvex/youtube-music-cli/main/scripts/install.sh | bashInstall Script (PowerShell)
iwr https://raw.githubusercontent.com/involvex/youtube-music-cli/main/scripts/install.ps1 | iexFrom Source
git clone https://github.com/involvex/youtube-music-cli.git
cd youtube-music-cli
bun install
bun run build
bun linkUsage
Interactive Mode
Launch the TUI:
youtube-music-cliCLI Commands
# Play a specific track
youtube-music-cli play <video-id|youtube-url>
# Search for music
youtube-music-cli search "artist or song name"
# Play a playlist
youtube-music-cli playlist <playlist-id>
# Get suggestions based on current track
youtube-music-cli suggestions
# Playback control
youtube-music-cli pause
youtube-music-cli resume
youtube-music-cli skip
youtube-music-cli backShell completions
Generate shell completion helpers through the lightweight ymc alias that ships with the CLI. Run ymc completions <bash|zsh|powershell|fish> to print the completion script for your shell, then source it or persist it in your profile:
# Bash
source <(ymc completions bash)
ymc completions bash >> ~/.bash_completion
# Zsh
source <(ymc completions zsh)
# PowerShell
ymc completions powershell | Out-File -Encoding utf8 $PROFILE
Invoke-Expression (ymc completions powershell)
# Fish
ymc completions fish > ~/.config/fish/completions/ymc.fishIf you installed the CLI globally with an alias or script name, make sure ymc points at the same binary before generating completions so that the script matches your install path.
Options
| Flag | Short | Description |
| ------------ | ----- | -------------------------------------------- |
| --theme | -t | Theme: dark, light, midnight, matrix |
| --volume | -v | Initial volume (0-100) |
| --shuffle | -s | Enable shuffle mode |
| --repeat | -r | Repeat mode: off, all, one |
| --headless | | Run without TUI |
| --help | -h | Show help |
Examples
# Launch with matrix theme at 80% volume
youtube-music-cli --theme=matrix --volume=80
# Search and play in headless mode
youtube-music-cli search "lofi beats" --headless
# Play with shuffle enabled
youtube-music-cli play dQw4w9WgXcQ --shuffleKeyboard Shortcuts
Global
| Key | Action |
| ----- | --------------- |
| ? | Show help |
| / | Search |
| p | Plugins manager |
| g | Suggestions |
| , | Settings |
| Esc | Go back |
| q | Quit |
Playback
| Key | Action |
| --------- | ----------------- |
| Space | Play / Pause |
| n / → | Next track |
| b / ← | Previous track |
| Shift+→ | Seek forward 10s |
| Shift+← | Seek backward 10s |
| = | Volume up |
| - | Volume down |
| s | Toggle shuffle |
| r | Cycle repeat mode |
Navigation
| Key | Action |
| --------- | --------- |
| ↑ / k | Move up |
| ↓ / j | Move down |
| Enter | Select |
| Esc | Back |
Downloads
| Key | Action |
| --------- | ------------------------------------------------------- |
| Shift+D | Download selected song/artist/playlist or playlist view |
Plugins
Extend youtube-music-cli with plugins!
Managing Plugins
TUI Mode: Press p to open the plugins manager.
CLI Mode:
# List installed plugins
youtube-music-cli plugins list
# Install from default repository
youtube-music-cli plugins install adblock
# Install from GitHub URL
youtube-music-cli plugins install https://github.com/user/my-plugin
# Enable/disable
youtube-music-cli plugins enable my-plugin
youtube-music-cli plugins disable my-plugin
# Update
youtube-music-cli plugins update my-plugin
# Remove
youtube-music-cli plugins remove my-pluginAvailable Plugins
| Plugin | Description |
| --------------- | --------------------------------------- |
| adblock | Block ads and sponsored content |
| lyrics | Display synchronized lyrics |
| scrobbler | Scrobble to Last.fm |
| discord-rpc | Discord Rich Presence integration |
| notifications | Desktop notifications for track changes |
Developing Plugins
See Plugin Development Guide and Plugin API Reference.
# Start from a template
cp -r templates/plugin-basic my-plugin
cd my-plugin
# Edit plugin.json and index.ts
# Install for testing
youtube-music-cli plugins install /path/to/my-pluginConfiguration
Config is stored in ~/.youtube-music-cli/config.json:
{
"theme": "dark",
"volume": 70,
"shuffle": false,
"repeat": "off",
"streamQuality": "high",
"downloadsEnabled": false,
"downloadDirectory": "D:/Music/youtube-music-cli",
"downloadFormat": "mp3"
}Stream Quality
| Quality | Description |
| -------- | ----------------------- |
| low | 64kbps - Save bandwidth |
| medium | 128kbps - Balanced |
| high | 256kbps+ - Best quality |
Download Settings
- Enable/disable downloads in Settings (
,). - Set your download directory in Settings → Download Folder.
- Choose format in Settings → Download Format (
mp3orm4a). - Downloads are saved as:
<downloadDirectory>/<artist>/<album>/<title>.mp3(or.m4a)
- MP3/M4A files are tagged with metadata (
title,artist,album) and include cover art when available.
Troubleshooting
mpv not found
Ensure mpv is installed and in your PATH:
mpv --versionOn startup, the CLI now checks for mpv and yt-dlp. In interactive terminals it can prompt to run an install command automatically (with explicit confirmation first).
No audio
- Check volume isn't muted (
=to increase) - Verify yt-dlp is working:
yt-dlp --version - Try a different track
TUI rendering issues
If rendering looks wrong, try resizing your terminal window or restarting the app.
Plugin not loading
- Check
plugin.jsonsyntax is valid - Verify the plugin is enabled:
youtube-music-cli plugins list - Check logs for errors
Contributing
Contributions are welcome!
- Fork the repository
- Create a feature branch:
git checkout -b feature/my-feature - Make your changes
- Run tests:
bun run test - Commit:
git commit -m 'feat: add my feature' - Push:
git push origin feature/my-feature - Open a Pull Request
Development
# Install dependencies
bun install
# Run in development mode
bun run dev
# Build
bun run build
# Lint and format
bun run lint:fix
bun run format
# Type check
bun run typecheckTech Stack
- Runtime: Bun / Node.js
- UI Framework: Ink (React for CLI)
- Language: TypeScript
- Audio: mpv + yt-dlp
- API: YouTube Music Innertube API
License
MIT © Involvex
Documentation • Report Bug • Request Feature
Made with ❤️ for music lovers
