2024-03-28 18:21:41 -07:00
|
|
|
## RMenu
|
2023-01-04 01:07:57 -07:00
|
|
|
|
|
|
|
Another customizable Application-Launcher written in Rust
|
2023-08-08 18:52:41 -07:00
|
|
|
|
|
|
|
### Features
|
|
|
|
|
2024-03-28 18:21:41 -07:00
|
|
|
- Blazingly Fast 🔥
|
|
|
|
- Simple and Easy to Use
|
|
|
|
- Customizable (Configuration and CSS-Styling)
|
|
|
|
- Plugin Support
|
|
|
|
- Dmenu-Like Stdin Menu Generation
|
2023-08-08 18:52:41 -07:00
|
|
|
|
|
|
|
### Installation
|
|
|
|
|
2024-04-03 13:47:36 -07:00
|
|
|
##### Nix
|
|
|
|
|
2024-03-29 11:53:41 -07:00
|
|
|
RMenu now has Nix support thanks to
|
|
|
|
[@LordGrimmauld](https://github.com/LordGrimmauld)!
|
|
|
|
|
2024-04-03 13:47:36 -07:00
|
|
|
Try it on nix directly via
|
|
|
|
|
|
|
|
```bash
|
|
|
|
nix run github:imgurbot12/rmenu -- -r drun
|
|
|
|
```
|
|
|
|
|
2024-04-07 02:51:35 -07:00
|
|
|
Rmenu v1.2.0 is now in nix unstable!
|
|
|
|
Install it via:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo nix-channel --add https://nixos.org/channels/nixpkgs-unstable unstable
|
|
|
|
sudo nix-channel --update
|
|
|
|
sudo nix-env -iA unstable.rmenu
|
|
|
|
```
|
|
|
|
|
|
|
|
|
2024-04-03 13:47:36 -07:00
|
|
|
##### Other Platforms:
|
|
|
|
|
2024-03-28 18:21:41 -07:00
|
|
|
Install Dependencies (Ubuntu)
|
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo apt install pkg-config libglib2.0-dev libghc-gi-gdk-dev libsoup-3.0-dev libjavascriptcoregtk-4.1-dev libwebkit2gtk-4.1-dev libnm-dev
|
|
|
|
```
|
|
|
|
|
|
|
|
Compile and Install Binaries/Config-Files
|
|
|
|
|
2023-08-08 18:52:41 -07:00
|
|
|
```bash
|
|
|
|
$ make install
|
|
|
|
```
|
|
|
|
|
|
|
|
### Usage
|
|
|
|
|
2024-04-03 13:47:36 -07:00
|
|
|
View all available options with the built-in help:
|
2023-08-08 18:52:41 -07:00
|
|
|
|
|
|
|
```bash
|
2023-08-20 19:45:20 -07:00
|
|
|
$ rmenu --help
|
2023-08-08 18:52:41 -07:00
|
|
|
```
|
|
|
|
|
2024-04-03 13:47:36 -07:00
|
|
|
##### Plugins
|
|
|
|
|
2023-08-20 19:45:20 -07:00
|
|
|
RMenu Comes with a few default plugins.
|
|
|
|
|
2024-03-28 18:21:41 -07:00
|
|
|
| Name | Description |
|
2023-08-20 19:45:20 -07:00
|
|
|
| :-------: | ------------------------------------------------------- |
|
2024-03-28 18:21:41 -07:00
|
|
|
| run | Execute a program in $PATH |
|
|
|
|
| drun | Run a Configured Free-Desktop Application |
|
|
|
|
| audio | Select and Set-Default PulseAudio Sink using `pactl` |
|
|
|
|
| network | Wi-Fi Login/Connection Tool using Network-Manager |
|
|
|
|
| window | Simple Window Switcher (Currently Only Support Sway) |
|
2023-08-20 19:45:20 -07:00
|
|
|
| powermenu | Simple Power/Logout Tool (Currently Only Supports Sway) |
|
|
|
|
|
|
|
|
Run a plugin by passing the `-r` flag like one of the following:
|
2023-08-08 18:52:41 -07:00
|
|
|
|
|
|
|
```bash
|
2023-08-20 19:45:20 -07:00
|
|
|
$ rmenu -r run
|
2023-08-08 18:52:41 -07:00
|
|
|
$ rmenu -r drun
|
2023-08-20 19:45:20 -07:00
|
|
|
$ rmenu -r audio
|
|
|
|
```
|
|
|
|
|
|
|
|
Or even run plugins in combination if you'd like:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ rmenu -r run -r drun
|
2023-08-08 18:52:41 -07:00
|
|
|
```
|
|
|
|
|
2024-04-03 13:47:36 -07:00
|
|
|
##### Direct Input
|
|
|
|
|
|
|
|
Custom Menus can also be passed via `/dev/stdin` or as an input file. The schema
|
|
|
|
follows a standard as defined in [rmenu-plugin](./rmenu-plugin)
|
2023-08-08 18:52:41 -07:00
|
|
|
|
|
|
|
```bash
|
2024-04-03 13:47:36 -07:00
|
|
|
$ ./examples/rmenu-build.sh > input.json
|
2023-08-08 18:52:41 -07:00
|
|
|
$ rmenu -i input.json
|
|
|
|
```
|
|
|
|
|
2024-03-28 18:21:41 -07:00
|
|
|
When neither a plugin nor an input are specified, rmenu defaults to reading from
|
|
|
|
stdin.
|
2023-08-08 18:52:41 -07:00
|
|
|
|
|
|
|
```bash
|
2024-04-03 13:47:36 -07:00
|
|
|
$ ./examples/rmenu-build.sh | rmenu
|
2023-08-08 18:52:41 -07:00
|
|
|
```
|
|
|
|
|
2024-04-03 13:47:36 -07:00
|
|
|
##### Supported Formats
|
|
|
|
|
|
|
|
RMenu has two supported input formats: dmenu-like and JSON. JSON is the default
|
|
|
|
provided by rmenu and allows for rich configuration and controls for dynamically
|
|
|
|
generated menus. You can switch between supported formats with `-f`:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ printf 'foo\nbar\nbaz' | rmenu -f dmenu
|
|
|
|
```
|
|
|
|
|
|
|
|
Check the [examples](./examples) folder for more examples.
|
|
|
|
|
2023-08-08 18:52:41 -07:00
|
|
|
### Configuration
|
|
|
|
|
2024-03-28 18:21:41 -07:00
|
|
|
Customize RMenu Behavior and Appearal in a
|
|
|
|
[single config](./rmenu/public/config.yaml)
|
2023-08-08 18:52:41 -07:00
|
|
|
|
2024-03-28 18:21:41 -07:00
|
|
|
Customize the entire app's appearance with CSS. A few
|
|
|
|
[Example Themes](./themes/) are available as reference. To try them out use:
|
|
|
|
`rmenu --css <my-css-theme>` or move the css file to
|
|
|
|
`$HOME/.config/rmenu/style.css`
|
2023-08-08 18:52:41 -07:00
|
|
|
|
2023-08-20 19:45:20 -07:00
|
|
|
### Scripting
|
|
|
|
|
2024-03-28 18:21:41 -07:00
|
|
|
RMenu plugins and imports communicate using JSON messages defined in
|
|
|
|
`rmenu-plugin`. Writing JSON in shell is painful, so rmenu provides another
|
|
|
|
cli-tool to help build messages quickly and easily while still retaining the
|
|
|
|
flexibility of JSON.
|
2023-08-20 19:45:20 -07:00
|
|
|
|
2024-03-28 18:21:41 -07:00
|
|
|
After Installing. Use the following command, and look at
|
|
|
|
[other-plugins](./other-plugins) for example uses.
|
2023-08-20 19:45:20 -07:00
|
|
|
|
|
|
|
```
|
|
|
|
$ rmenu-build --help
|
|
|
|
```
|
|
|
|
|
2023-08-20 19:09:23 -07:00
|
|
|
### Example Screenshots
|
|
|
|
|
|
|
|
#### Launchpad
|
2024-03-28 18:21:41 -07:00
|
|
|
|
2023-08-20 19:09:23 -07:00
|
|
|

|
|
|
|
|
|
|
|
#### Nord
|
2024-03-28 18:21:41 -07:00
|
|
|
|
2023-08-20 19:09:23 -07:00
|
|
|

|
|
|
|
|
|
|
|
#### Dark
|
2024-03-28 18:21:41 -07:00
|
|
|
|
2023-08-20 19:09:23 -07:00
|
|
|

|
2023-08-08 18:52:41 -07:00
|
|
|
|
2023-08-20 19:09:23 -07:00
|
|
|
#### Solarized
|
2024-03-28 18:21:41 -07:00
|
|
|
|
2023-08-20 19:09:23 -07:00
|
|
|

|
2023-08-20 19:13:12 -07:00
|
|
|
|
|
|
|
#### PowerMenu
|
2024-03-28 18:21:41 -07:00
|
|
|
|
2023-08-20 19:13:12 -07:00
|
|
|

|