Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/kmonad/kmonad

An advanced keyboard manager
https://github.com/kmonad/kmonad

Last synced: about 19 hours ago
JSON representation

An advanced keyboard manager

Awesome Lists containing this project

README

        


KMonad

The Onion of Keyboard Management Tools, available on GNU/Linux, Windows, and MacOS!


Features
Installation
Configuration
Troubleshooting
Disclaimer

## Introduction

KMonad is an advanced tool that lets you infinitely customize and extend the functionalities of almost any keyboard. For a detailed list of features, see [here](#features).

If you want to get started with the latest, stable binary release, please check out the master branch, if you are interested in the latest additions and tweaks, switch on over to develop and compile your own binary.

Additionally, if you need any help or just want to say hi,
you can join our [Matrix space](https://matrix.to/#/#Kmonad:matrix.org) or
jump into our [IRC channel](https://web.libera.chat/#kmonad).
There is also an unofficial [Discord server](https://discord.gg/3tFfWmnahN), and a [KMonad Subreddit](https://www.reddit.com/r/Kmonad/).

## Features

KMonad offers advanced customization features such as **layers**, **multi-tap**, **tap-hold**, and much more. These features are usually available at the hardware level on the QMK-firmware enabled keyboards. However, KMonad allows you to enjoy such features in virtually any keyboard by low-level system manipulations.

For a good introduction to KMonad, have a look at [this YouTube video](https://www.youtube.com/watch?v=Dhj1eauljwU).

#### Key Customizations

KMonad lets you map any keyboard button to any keymap. Want to swap the useless **Caps Lock** key with the **Escape** key? Want to have your modifiers such as **Shift** and **Control** on your home row, without breaking your normal typing flow? Want a modifier that is combination of **Alt + Ctrl + Super + Shift**? You can do all of those and much more!

#### Layers

A layer is a set of keymaps assigned to your keyboard's buttons. You can have as many layers on top of your base layer as you want. For instance, you can have your regular QWERTY layout, a Colemak/Dvorak layout, a numbers and symbols layer, a function keys layer, a layer for mouse navigation and system controls --- all in a 60% keyboard. When a particular layer is active, any keypress is interpreted according to the layout defined in that layer. With proper configurations, you can jump to a specific layer or switch to one for the next keypress, or do various other complex manipulations.

#### Multi-Use and Multi-Tap Buttons

Multi-Use Buttons are one of the distinguishing features of KMonad. You can have a single button do different things based on whether it is pressed quickly in succession, or pressed once, or held. For example, you can configure the **Caps Lock** key to act as an **Escape** button when pressed once and released, a **Ctrl** modifier when held-down, and a button to jump to a layer when pressed twice quickly in succession. You can make the left and right **Shift** keys to act like left and right parentheses (like the Space Cadet Shift keys) when tapped once, and regular **Shift** keys when held down. The possibilities are infinite!

#### Command Buttons

With Command Buttons you can trigger shell commands with a tap of any button.

#### And More!

There are many more exciting features of KMonad that you can find in the [configuration tutorial](keymap/tutorial.kbd).

## Installation
For more information on how to install KMonad, please refer to:
- [installation](doc/installation.md)

## Configuration

For information on how to configure KMonad, please refer you to:
- [the configuration tutorial](keymap/tutorial.kbd)
- [quick reference](doc/quick-reference.md)
- [user configurations](https://github.com/kmonad/kmonad-contrib)

Want to add your own keyboard configuration to [kmonad-contrib]? Just
fork the repository, create a new subdirectory using your GitHub
username and submit a pull request!

[kmonad-contrib]: https://github.com/kmonad/kmonad-contrib

### Editor Support for the Configuration Language
- [Emacs](https://github.com/kmonad/kbd-mode)
- [Vim](https://github.com/kmonad/kmonad-vim)
- [VSCode](https://github.com/canadaduane/vscode-kmonad)

### Startup
- There are startup scripts available for different init systems in [`startup/`](startup/).
- A [GNOME Shell extension](https://extensions.gnome.org/extension/6069/kmonad-toggle/)
is available.

## Troubleshooting
For several commonly asked questions regarding various configuration issues, please see:
- [the FAQ](doc/faq.md)

## Disclaimer
The core maintainer is currently chronically ill with debilitating autoimmune
symptoms. They come and go, but when they are there they very much get in the
way of concentrated work. It is very much his intent to keep working on KMonad
until it is very, very good. But please be aware that he might be gone for weeks
on end, not out of a lack of interest, but out of a lack of capacity. You are
always free to reach out to him by email.