A collection of opinionated keyboard-driven user interfaces for various built-in Emacs modes.
Find a file
Charles Choi 4f14eac613
Some checks failed
Deploy Casual User Guide to GitHub Pages / deploy (push) Has been cancelled
Bump version to 2.8.3
2025-07-28 13:26:44 -07:00
.github/workflows Configure GitHub action deploy Casual User Guide. 2025-07-17 13:40:48 -07:00
docs Fix binding for kill-compilation in Compile 2025-07-28 13:21:27 -07:00
lisp Bump version to 2.8.3 2025-07-28 13:26:44 -07:00
scripts Updated Copyright to include 2025. 2025-01-03 09:12:17 -08:00
tests Add Casual Elisp 2025-07-25 12:08:47 -07:00
.gitignore Added .gitignore 2024-10-15 13:58:39 -07:00
LICENSE Initial Entry - Casual Package Consolidation 2024-10-15 10:52:00 -07:00
Makefile Configure GitHub action deploy Casual User Guide. 2025-07-17 13:40:48 -07:00
README.org Add Casual Elisp 2025-07-25 12:08:47 -07:00

Casual

Casual is a project to re-imagine the primary user interface for Emacs using keyboard-driven menus.

Emacs has many commands that are easy to forget if not used frequently. Menus are a user interface (UI) affordance that offers discoverability and recognition. While menus are commonly associated with mouse-driven UI, the inclusion of Transient in Emacs core allows for building menus that are keyboard-driven instead. This appeals to users that prefer keyboard-driven workflows.

Casual organizes itself primarily around the different built-in modes Emacs provides. For each mode Casual supports, there is a bespoke designed library of Transient menus for that mode's command set.

Casual has no aims to be a mutually exclusive user interface. All existing user interfaces to commands (keybinding, mini-buffer prompt, mouse menus) are still available to the user.

To learn more about the motivations and design considerations for Casual as well as seeing it at work, please watch the presentation “Re-imagining the Emacs User Experience with Casual Suite” from EmacsConf 2024.

Please refer to the Casual User Guide for detailed information about it. This user guide is available both in Emacs Info and HTML formats.

Asks

As Casual is new, we are looking for early adopters! Your feedback is welcome as it will likely impact Casual's evolution, particularly with regards to UI.

Development

For users who wish to help contribute to Casual or personally customize it for their own usage, please read the developer documentation.

Sponsorship

If you enjoy using Casual, consider making a modest financial contribution to help support its development and maintenance.

/procyberian/casual/media/branch/main/docs/images/default-yellow.png

See Also

While the package casual focuses on user interfaces for built-in Emacs modes, there are other third party packages which receive the “Casual” treatment. Two such packages are:

  • Casual Avy (Elisp package: casual-avy)

    • An interface for the highly capable Avy navigation package.
  • Casual Symbol Overlay (Elisp package: casual-symbol-overlay)

    • An interface for the Symbol Overlay package.

Users interested in getting all current and future Casual interfaces for both built-in and third party packages should install Casual Suite, which includes all of the above packages including casual.

Acknowledgments

A heartfelt thanks to all the contributors to Transient, Magit, Org Mode, and Emacs. This package would not be possible without your efforts.

© 2024-2025 Charles Y. Choi