https://github.com/abusoww/tuxmate
THE MISSING BULK APP INSTALLER FOR LINUX
https://github.com/abusoww/tuxmate
arch debian flatpa linux nix package-manager tool ubuntu web
Last synced: 10 days ago
JSON representation
THE MISSING BULK APP INSTALLER FOR LINUX
- Host: GitHub
- URL: https://github.com/abusoww/tuxmate
- Owner: abusoww
- License: gpl-3.0
- Created: 2025-12-24T03:35:39.000Z (3 months ago)
- Default Branch: main
- Last Pushed: 2026-02-22T00:52:36.000Z (17 days ago)
- Last Synced: 2026-02-22T01:12:09.337Z (17 days ago)
- Topics: arch, debian, flatpa, linux, nix, package-manager, tool, ubuntu, web
- Language: TypeScript
- Homepage: https://tuxmate.com
- Size: 3.86 MB
- Stars: 1,721
- Watchers: 4
- Forks: 78
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- definitive-opensource - TuxMate
README




[](https://github.com/abusoww/tuxmate/issues)
[](https://github.com/abusoww/tuxmate/stargazers)
[](https://github.com/abusoww/tuxmate/blob/main/LICENSE)
## π§ The only Mate you need for setup
**TuxMate** is a simple web tool that generates install scripts for any Linux distro. Pick your apps, copy the command, done.
Fresh install? New machine? Can't remember every package name? We've all been there.
## π¦ Supported Package Managers
- Ubuntu / Debian (apt)
- Arch Linux (pacman + AUR)
- Fedora (dnf)
- openSUSE (zypper)
- Nix (declarative config)
- Flatpak
- Snap
- Homebrew (macOS + Linux)
## β¨ Features
### **Application Catalog**
180+ applications across 15 categories: browsers, communication, dev tools, terminals, media, creative software, gaming, office, VPN/network, security, and more.
### **Smart Script Generation**
- Detects already-installed packages
- Handles AUR packages automatically on Arch
- **Nix Unfree Detection**: Warns compliant configuration for unfree packages (Discord, Spotify, etc.)
- Homebrew formula/cask separation for macOS
- Parallel installation for Flatpak
- Network retry with exponential backoff
- Progress bars with ETA
- Colored output and summary reports
## πΈ Screenshots



π» Development
```bash
npm install
npm run dev
```
Open [http://localhost:3000](http://localhost:3000)
### Build
```bash
npm run build
npm start
```
ποΈ Project Structure
```
src/
βββ app/ # Next.js app router
β βββ page.tsx # Main page component
β βββ layout.tsx # Root layout with meta tags
β βββ globals.css # Tailwind styles
β βββ error.tsx # Error boundary
β βββ favicon.ico # Site favicon
βββ components/
β βββ app/ # App cards & categories
β βββ command/ # Command footer & AUR settings
β βββ common/ # Tooltips, loading states
β βββ distro/ # Distribution selector
β βββ header/ # Header links & info
β βββ search/ # Search overlay
β βββ ui/ # Theme toggle
βββ hooks/ # React hooks
β βββ useLinuxInit.ts # Main app state management
β βββ useKeyboardNavigation.ts
β βββ useTheme.tsx
β βββ useTooltip.ts
β βββ useDelayedTooltip.ts
βββ lib/
β βββ apps/ # JSON application files by category
β βββ data.ts # Categories, distros, and app unifier
β βββ aur.ts # AUR package detection
β βββ analytics.ts # Umami tracking
β βββ utils.ts # Utility functions
β βββ generateInstallScript.ts
β βββ scripts/ # Per-distro script generators
βββ __tests__/ # Vitest unit tests
```
π³ Docker Deployment
### Quick Start with Docker
```bash
# Build the Docker image
docker build -t tuxmate:latest .
# Run the container
docker run -p 3000:3000 tuxmate:latest
```
### Using Pre-built Images
Pre-built Docker images are automatically published to GitHub Container Registry:
```bash
# Pull and run the latest image
docker pull ghcr.io/abusoww/tuxmate:latest
docker run -p 3000:3000 ghcr.io/abusoww/tuxmate:latest
# Or use a specific version
docker pull ghcr.io/abusoww/tuxmate:v1.0.0
docker run -p 3000:3000 ghcr.io/abusoww/tuxmate:v1.0.0
```
### Using Docker Compose (Recommended)
```bash
# Start the application
docker-compose up -d
# View logs
docker-compose logs -f
# Stop the application
docker-compose down
```
Open [http://localhost:3000](http://localhost:3000)
### Configuration
The Docker container exposes port 3000 by default. You can customize the port mapping:
```bash
docker run -p 8080:3000 tuxmate:latest
```
### Environment Variables
The following environment variables are configured by default:
- `NODE_ENV=production` - Run in production mode
- `PORT=3000` - Application port
- `NEXT_TELEMETRY_DISABLED=1` - Disable Next.js anonymous telemetry
You can override these when running the container:
```bash
docker run -p 3000:3000 \
-e PORT=3000 \
-e NEXT_TELEMETRY_DISABLED=1 \
tuxmate:latest
```
π οΈ Tech Stack
- [Next.js](https://nextjs.org/) 16 (App Router)
- [React](https://react.dev/) 19
- [TypeScript](https://www.typescriptlang.org/)
- [Tailwind CSS](https://tailwindcss.com/) 4
- [Framer Motion](https://www.framer.com/motion/)
- [GSAP](https://gsap.com/)
- [Vitest](https://vitest.dev/) (testing)
- [Lucide React](https://lucide.dev/) (icons)
### β¨οΈ Keyboard Shortcuts
| Key | Action |
|-----|--------|
| `β` `β` `β` `β` / `h` `j` `k` `l` | Navigate apps |
| `Space` | Toggle app selection |
| `Esc` | Clear focus |
| `/` | Focus search |
| `y` | Copy command |
| `d` | Download script |
| `t` | Toggle theme |
| `c` | Clear all selections |
| `Tab` | Toggle preview drawer |
## π€ Contribution
See [CONTRIBUTING.md](CONTRIBUTING.md) for contribution guidelines.
## π― Roadmap
### Completed
- [x] Multi-distro support (Ubuntu, Debian, Arch, Fedora, openSUSE)
- [x] Nix, Flatpak & Snap universal package support
- [x] 180+ applications across 15 categories
- [x] Smart script generation with error handling
- [x] Dark / Light theme toggle with smooth animations
- [x] Copy command & Download script
- [x] Custom domain
- [x] Docker support
- [x] CI/CD shortcuts & workflow
- [x] Search & filter applications (Real-time)
- [x] AUR Helper selection (yay/paru) + Auto-detection
- [x] Keyboard navigation (Vim keys, Arrows, Space, Esc, Enter)
- [x] Package availability indicators (including AUR badges)
- [x] Homebrew support (macOS + Linux)
- [x] PWA support for offline use
- [x] Nix configuration.nix download with unfree package detection
### Planned
- [ ] Winget support (Windows)
- [ ] Custom presets / profiles
- [ ] Share configurations via URL
- [ ] More distros (FreeBSD, Gentoo, Void, Alpine)
- [ ] i18n / Multi-language support
- [ ] Companion CLI tool
- [ ] Expand application catalog (200+)
- [ ] Dotfiles integration
- [ ] Declarative NixOS options support (programs.*) [Issue #36]
π Related Projects
- **[LinuxToys](https://github.com/psygreg/linuxtoys)** β User-friendly collection of tools for Linux with an intuitive interface
- **[Nixite](https://github.com/aspizu/nixite)** β Generates bash scripts to install Linux software, inspired by Ninite
- **[tuxmate-cli](https://github.com/Gururagavendra/tuxmate-cli)** β CLI companion for tuxmate, uses tuxmate's package database
π³ Monetary Contributions
No tips jar here. Iβm happy just knowing youβre using Linux.
If you want to earn some real life karma points, consider donating to the following organizations:
* [KDE e.V.](https://kde.org/community/donations/)
* [Gnome Foundation](https://www.gnome.org/donate/)
* [Arch Linux](https://archlinux.org/donate/)
* [The Tor Project](https://donate.torproject.org/)
Comments, suggestions, bug reports and contributions are welcome.
## π License
Licensed under the [GPL-3.0 License](LICENSE)
Free software β you can redistribute and modify it under the terms of the GNU General Public License.