# Owl
[data:image/s3,"s3://crabby-images/f3285/f3285696f73d52e2c4ac3117c455b913be2c3b8b" alt="CI Status"](https://github.com/fuelen/owl/actions)
[data:image/s3,"s3://crabby-images/3e88d/3e88d069e883296f052ba408e8245b89c3aac75a" alt="Hex.pm"](https://hex.pm/packages/owl)
[data:image/s3,"s3://crabby-images/50da3/50da381c96bab38496cddf83ce4922f3c9ae3387" alt="Hex.pm Downloads"](https://hex.pm/packages/owl)
[data:image/s3,"s3://crabby-images/466af/466afc0709a57f1548f379ed9c070337f7587e22" alt="Coverage Status"](https://coveralls.io/github/fuelen/owl?branch=main)
```
,_,
{o,o}
/) )
---"-"--
```
Owl is a toolkit for writing command-line user interfaces in Elixir.
It provides a convenient interface for
* colorizing text using tags
* input control with validations and casting to various data types
* select/multiselect controls, inspired by AUR package managers
* tables
* editing text in `ELIXIR_EDITOR`
* wrapping multiline colorized data into ASCII boxes
* printing palette colors
* progress bars and spinners, multiple bars/spinners at the same time are supported as well
* live-updating of multiline blocks
* working with virtual device which partially implements
[The Erlang I/O Protocol](https://www.erlang.org/doc/apps/stdlib/io_protocol.html) and doesn't conflict with live blocks.
## Demo
[data:image/s3,"s3://crabby-images/7610d/7610dcef1b23971012338bfb9dfc07b9788c0bd5" alt="asciicast"](https://asciinema.org/a/vOL2PtAEWB88S9G93Iojwprj2)
The code can be found in [examples](https://github.com/fuelen/owl/tree/main/examples) directory.
## Installation
The package can be installed by adding `owl` to your list of dependencies in `mix.exs`:
```elixir
def deps do
[
{:owl, "~> 0.12"},
# ucwidth is an optional dependency, uncomment it for multibyte characters support (emoji, etc)
# {:ucwidth, "~> 0.2"}
]
end
```
Documentation can be found at [https://hexdocs.pm/owl](https://hexdocs.pm/owl).