- Features
- Themes
- Requirements
- Installation
- Quick Start
- Usage
- Keybindings
- Components
- Customization
- Structure
- Troubleshooting
- Uninstallation
- Credits
- One-command theming — Switch entire desktop look with
hyprluggage switch - Dynamic colors — Matugen extracts palette from any wallpaper
- 12 themes — 11 handcrafted + 1 dynamic (Dark, cozy, and aesthetic)
- Everything synced — Terminal, bar, launcher, notifications, apps
- Rofi menus — App launcher, emoji picker, clipboard, wallpaper selector, power profiles
- Dual mode — Vibe (animations + blur) or Focus (minimal + fast)
- Music integration — MPD + RMPC + Cava visualizer
Dual Mode System
Sometimes you want your desktop to look good. Other times you just need to get work done.
Vibe Mode
The default look — animations, blur, transparency, gaps. Makes everything feel smooth and polished.
Focus Mode
Strips it all down. No animations, minimal borders, transparency off. Just you and your work.
Toggle between them with Super + Ctrl + Backspace
Dynamic |
Catppuccin |
Coffee |
Everforest |
Gruvbox |
Jade |
Kanagawa |
Monochrome |
Nordic |
Octarine |
Rosé Pine |
Tokyo Night |
Dynamic - Colors generated from wallpaper using Matugen
Catppuccin - Soothing pastel theme (Mocha variant)
Coffee - Warm, earthy brown tones inspired by coffee
Everforest - Green-based, warm-toned color scheme
Gruvbox - Retro groove color scheme with warm, muted tones
Jade - Cool, serene green palette with elegant tones
Kanagawa - Inspired by Japanese woodblock prints, warm and artistic
Monochrome - Minimalist black and white aesthetic
Nordic - Cool, clean blue tones inspired by Nordic design
Octarine - The eighth color of magic (fluorescent greenish-yellow purple) from Discworld
Rosé Pine - Soft, muted rose and pine color scheme
Tokyo Night - Dark theme with vibrant neon accents
Each theme includes multiple wallpapers and can be previewed using hyprluggage tui or hyprluggage browse.
HyprLuggage comes with a complete desktop environment setup:
Rofi Menus - Powerful launcher with multiple menus:
- App launcher (
Super + Space) - Emoji picker (
Alt + .) - Clipboard manager (
Alt + ,) - Wallpaper selector (
Super + Alt + Space) - Power profiles (
Super + Ctrl + B) - Power menu (
Super + Escape)
Hyprlock - Customizable lock screen with theme integration. Lock with Super + Shift + L.
Neovim - Pre-configured Neovim with theme integration. All themes include Neovim color schemes that sync automatically.
Music Integration - Complete music setup:
- MPD - Music Player Daemon for background playback
- RMPC - Terminal-based music player (
Alt + M) - Cava - Audio visualizer (
Super + Shift + C)
Notifications - Mako notification daemon with theme-aware styling.
- Distribution: CachyOS or Arch Linux (CachyOS preferred)
- RAM: At least 4GB (8GB recommended)
- Storage: ~5GB free space for packages and configs
- Internet: Required for installation
- Access: Root/sudo privileges
- Display: Wayland-compatible graphics
This setup works best on CachyOS or Arch Linux. While CachyOS is preferred, you can use either distribution.
-
Bootloader and Filesystem
You can use whatever bootloader (GRUB, systemd-boot, rEFInd, etc.) and filesystem (ext4, btrfs, zfs, etc.) you prefer. HyprLuggage works with any combination.
-
Choose "No Desktop" during installation
When installing CachyOS, select "No Desktop" from the desktop environment list. This ensures a clean base system without any desktop environment pre-configured.
-
Uncheck "CachyOS shell configuration" in the packages step
In the packages selection screen, make sure to uncheck "CachyOS shell configuration" to prevent the installer from configuring your shell. This allows HyprLuggage to set up your shell configuration instead.
-
Install Git and Stow after base system is finished installing
Reboot your system and at the prompt install git and stow for package management and stowing dotfiles (if not installed already)
sudo pacman -S git stow
curl -fsSL https://raw.githubusercontent.com/Jmartgraphix/hyprluggage/master/boot.sh | bashOr manually:
git clone https://github.com/Jmartgraphix/hyprluggage ~/hyprluggage
cd ~/hyprluggage && ./install.shWant just the themes without the full setup? See install/themes/README.md
The installer will:
-
Install core packages:
- Hyprland compositor and related tools (hypridle, hyprlock, hyprpicker)
- Desktop components (Waybar, Rofi, Mako, swww)
- Terminal emulators (Kitty, Alacritty)
- Shell and tools (Fish, Starship, tmux)
- File managers (Thunar, Yazi)
- Editor (Neovim)
- Music stack (MPD, RMPC, Cava)
- And many more utilities
-
Install optional applications:
- Browsers (Brave, Firefox, Chromium, Zen)
- Editors (VS Code, Zed, Obsidian)
- Communication (Discord, Vesktop)
- And other productivity apps
-
Set up system services:
- MPD (music daemon)
- Greetd (display manager)
- User services for autostart
-
Deploy dotfiles:
- Symlink all configs to
~/.config/ - Set up desktop entries
- Configure shell (Fish with Starship)
- Symlink all configs to
-
Install theme system:
- Set up Hyprluggage theme manager
- Install all 12 themes
After installation:
- Log out and log back in (or reboot) to start Hyprland
- Choose your first theme:
Or press
hyprluggage switch
Super + Ctrl + Shift + Spacefor the interactive picker - Explore keybindings: Press
Super + Kto see all available shortcuts - Customize: Edit configs in
~/.config/- they won't be overwritten - Switch themes anytime: Use
hyprluggage switchor the TUI (Super + I)
hyprluggage switch # interactive picker
hyprluggage switch rose-pine # direct switch
hyprluggage list # show all themes
hyprluggage reload # re-apply current
hyprluggage current # show current theme
hyprluggage fix # fix broken symlinks
hyprluggage browse # browse & import Omarchy themes
hyprluggage import <url> # import theme from GitHub
hyprluggage tui # interactive theme browser
hyprluggage remove <theme> # delete a theme
hyprluggage uninstall # remove Hyprluggage
hyprluggage help # show helpOr press Super + Ctrl + Shift + Space for the theme picker.
Applications
| Key | Action |
|---|---|
Super + Return |
Terminal |
Super + B |
Browser |
Super + E |
File Manager (Thunar) |
Super + M |
Spotify |
Super + D |
Discord |
Super + O |
Obsidian |
Super + C |
VS Code |
Alt + M |
RMPC |
Alt + N |
Neovim |
Alt + Q |
Yazi |
Alt + / |
Btop |
Rofi Menus
| Key | Action |
|---|---|
Super + Space |
App Launcher |
Alt + , |
Clipboard |
Alt + . |
Emoji Picker |
Super + Ctrl + B |
Power Profiles |
Super + Ctrl + Space |
Matugen Theme |
Super + Alt + Space |
Wallpaper Picker |
Super + Ctrl + Shift + Space |
Theme Switcher |
Super + I |
Hyprluggage TUI |
Super + Alt + I |
Browse Themes |
Window Management
| Key | Action |
|---|---|
Super + Q |
Close Window |
Super + K |
Show All Keybindings |
Super + Shift + K |
Kill Application |
Super + Arrow |
Move Focus |
Super + Shift + Arrow |
Move Window |
Super + Ctrl + Arrow |
Resize Window |
Super + 1-9 |
Switch Workspace |
Super + Shift + 1-9 |
Move to Workspace |
Super + F |
Fullscreen |
Super + Shift + V |
Toggle Floating |
Super + Shift + O |
Pop Window (Float & Pin) |
System
| Key | Action |
|---|---|
Super + L |
Screensaver |
Super + Shift + L |
Lock Screen |
Super + Escape |
Power Menu |
Super + N |
Notifications |
Super + Backspace |
Toggle Transparency |
Super + Ctrl + Backspace |
Toggle Focus/Vibe Mode |
Screenshots & Recording
| Key | Action |
|---|---|
Super + P |
Screenshot |
Super + R |
Screen Record |
Super + Shift + R |
Record with Mic |
Super + Shift + P |
Color Picker |
Wallpapers
| Key | Action |
|---|---|
Ctrl + Alt + Space |
Random Wallpaper + Colors |
Super + Alt + Left/Right |
Cycle Wallpapers |
See .config/hypr/bindings.conf for full list.
| Component | Tool | Description |
|---|---|---|
| Compositor | Hyprland | Wayland compositor with smooth animations and window management |
| Bar | Waybar | Highly customizable status bar with modules for system info, workspaces, and more |
| Launcher | Rofi | Application launcher and menu system with multiple modes |
| Terminal | Kitty / Alacritty / Ghostty | GPU-accelerated terminal emulators (Kitty & Alacritty installed by default) |
| File Manager | Thunar (GUI) / Yazi (CLI) | Dual file managers for GUI and terminal workflows |
| Notifications | Mako | Lightweight notification daemon with theme support |
| Lock screen | Hyprlock | Secure lock screen integrated with Hyprland |
| Theme engine | Matugen | Material You color palette generator from wallpapers |
| Music | MPD + RMPC | Music Player Daemon with terminal client for music playback |
| Visualizer | Cava | Audio spectrum visualizer for terminal |
| Editor | Neovim | Modern Vim fork with LSP support and theme integration |
| Shell | Fish + Starship | User-friendly shell with fast, customizable prompt |
All configuration files are located in ~/.config/. You can edit them directly—they won't be overwritten by theme switches.
Key customization locations:
- Keybindings:
~/.config/hypr/bindings.conf- Modify or add shortcuts - Hyprland settings:
~/.config/hypr/- Window rules, animations, monitors - Waybar:
~/.config/waybar/- Status bar modules and styling - Rofi:
~/.config/rofi/- Launcher appearance and scripts - Terminal:
~/.config/kitty/or~/.config/alacritty/- Terminal settings - Shell:
~/.config/fish/- Fish shell configuration
Theme customization:
- Each theme's configs are in
~/hyprluggage/themes/<theme-name>/.config/ - Copy a theme to create your own:
cp -r themes/monochrome themes/my-theme - Edit colors, wallpapers, and configs in your custom theme
Note: Theme switches only update colors and wallpapers. Your custom config edits are preserved.
~/hyprluggage/
├── .config/
│ ├── hypr/ # Hyprland (compositor, bindings, animations)
│ ├── waybar/ # Status bar
│ ├── rofi/ # Launcher & menus
│ ├── mako/ # Notifications
│ ├── kitty/ # Terminal
│ ├── ghostty/ # Terminal (alt)
│ ├── alacritty/ # Terminal (alt)
│ ├── nvim/ # Neovim
│ ├── fish/ # Shell
│ ├── tmux/ # Terminal multiplexer
│ ├── yazi/ # File manager (CLI)
│ ├── gtk-3.0/ # GTK theme (Thunar, etc.)
│ ├── gtk-4.0/ # GTK theme (Thunar, etc.)
│ ├── btop/ # System monitor
│ ├── rmpc/ # Music player
│ ├── matugen/ # Theme generator templates
│ └── lazygit/ # Git UI
├── themes/ # Theme configs (colors, wallpapers)
├── scripts/ # Utility scripts
└── install/ # Installer
├── packages.sh # Package lists
├── stow.sh # Dotfile deployment
├── services.sh # Systemd services
└── themes/ # Hyprluggage theme system
Colors not updating?
hyprluggage reloadSymlinks broken?
hyprluggage fixTheme not applying?
- Check that
~/.config/hyprluggage/currentexists and is a symlink - Verify the theme exists:
hyprluggage list - Try reloading:
hyprluggage reload
Installation issues?
- Ensure you have internet connection
- Check you have sudo/root access
- Verify you're on Arch Linux or CachyOS
- See install/themes/README.md for theme-specific issues
Hyprland not starting?
- Check logs:
journalctl -u greetdor~/.local/share/hyprland/hyprland.log - Verify graphics drivers are installed
- Ensure you're using a Wayland-compatible setup
Keybindings not working?
- Check
~/.config/hypr/bindings.conffor conflicts - Reload Hyprland config:
hyprctl reload - Verify the keybinding syntax is correct
Need more help?
- Check the full keybindings list
- Run
hyprluggage helpfor command reference - Report a bug
To remove HyprLuggage:
cd ~/hyprluggage && ./uninstall.shThe uninstaller will:
- Remove all symlinks from your home directory
- Restore any backed-up configs (from
~/dotfiles-backup*) - Optionally remove installed packages (you choose which ones)
- Clean up shell configuration
- Remove desktop entries
Note: Your custom edits in ~/.config/ will be preserved if they weren't symlinks. Backups are created during installation in ~/dotfiles-backup*.
Inspiration: HyprLuggage is inspired by Terry Pratchett's Discworld series, specifically The Luggage—a magical, multi-legged chest made of Sapient Pearwood that is fiercely loyal to its owner.
Learned a lot from these projects:
Wallpapers: Jmartgraphix/Wallpapers












