Component Template
Features
- Uses tokio for async events
- Start and stop key events to shell out to another TUI like vim
- Supports suspend signal hooks
- Logs using tracing
- better-panic
- color-eyre
- human-panic
- clap for command line argument parsing
Component
trait withHome
andFps
components as examples
Usage
You can start by using cargo-generate
:
You can also use a
template.toml
file to skip the prompts:
Run
Show help
Show version
Without direnv variables:
With direnv variables:
Documentation
Read documentation on design decisions in the template here: https://ratatui.rs/templates/component/
Background
ratatui
is a Rust library to build rich terminal user
interfaces (TUIs) and dashboards. It is a community fork of the original
tui-rs
created to maintain and improve the project.
The source code of this project is an
opinionated template for getting up and running with ratatui
. You can pick and choose the pieces
of this template to suit your needs and sensibilities. This rest of this documentation is a
walk-through of why the code is structured the way it is, so that you are aided in modifying it as
you require.
ratatui
is based on the principle of immediate rendering with intermediate buffers. This means
that at each new frame you have to build all widgets that are supposed to be part of the UI. In
short, the ratatui
library is largely handles just drawing to the terminal.
Additionally, the library does not provide any input handling nor any event system. The responsibility of getting keyboard input events, modifying the state of your application based on those events and figuring out which widgets best reflect the view of the state of your application is on you.
The ratatui
project has added a template that covers the basics, and you find that here:
https://github.com/ratatui/templates/tree/main/simple.
I wanted to take another stab at a template, one that uses tokio
and organizes the code a little
differently. This is an opinionated view on how to organize a ratatui
project.
This project also adds commonly used dependencies like logging, command line arguments, configuration options, etc.
As part of this documentation, we’ll walk through some of the different ways you may choose to organize your code and project in order to build a functioning terminal user interface. You can pick and choose the parts you like.
You may also want to check out the following links (roughly in order of increasing complexity):
- https://github.com/ratatui/ratatui/tree/main/examples: Simple one-off examples to illustrate
various widgets and features in
ratatui
. - https://github.com/ratatui/templates/tree/main/simple: Starter kit for using
ratatui
- https://github.com/ratatui/templates/tree/main/simple-async: Starter kit for using
ratatui
withasync
usingtokio
- https://github.com/ratatui/ratatui-website/tree/main/code/tutorials/json-editor: Tutorial project that the user a simple interface to enter key-value pairs, which will printed in json.
- https://github.com/ratatui/templates/tree/main/component: Async tokio crossterm based
opinionated starter kit with “components” for using
ratatui
. - https://github.com/veeso/tui-realm/: A framework for
tui.rs
to simplify the implementation of terminal user interfaces adding the possibility to work with re-usable components with properties and states.