#tui #terminal-text #user-interface #terminal #ansi-codes #colored-text #color-printing

termint

Library for colored printing and Terminal User Interfaces

11 releases (4 breaking)

0.5.2 Oct 30, 2024
0.5.1 Oct 6, 2024
0.5.0 Aug 4, 2024
0.4.2 Apr 11, 2024
0.1.1 Jan 27, 2024

#148 in GUI

Download history 79/week @ 2024-07-29 40/week @ 2024-08-05 7/week @ 2024-08-12 15/week @ 2024-09-16 9/week @ 2024-09-23 102/week @ 2024-09-30 63/week @ 2024-10-07 123/week @ 2024-10-28 5/week @ 2024-11-04

131 downloads per month

Custom license

180KB
4.5K SLoC

termint

Crates.io Version docs.rs Crates.io Total Downloads

Rust library for colored printing and Terminal User Interfaces

Table of Contents

Installation

This library is available on crates.io. You can add it to your projects using cargo:

cargo add termint

Examples

Printing colored text

Printing colored text is really easy, you can do it like this:

// Using Span widget
println!("{}", "Cyan text".fg(Color::Cyan));
println!("{}", "Cyan text on white".fg(Color::Cyan).bg(Color::White));
println!("{}", "Bold red text".fg(Color::Red).modifier(Modifier::BOLD));
println!("{}", "Text with RGB value".fg(Color::Rgb(0, 249, 210)));

image

You can see all the colors and modifiers in the documentation.

More complex layout

You can also create TUIs using this library. This example shows how you can use Block widget and add children to it and creating Layout:

// Creates main block and sets its properties
let mut main = Block::horizontal()
    .title("Termint")
    .border_type(BorderType::Double);

// Creates block1 and adds span as its child
let mut block1 = Block::vertical().title("Sub block");
let span1 = "I like it!".fg(Color::Green).bg(Color::Yellow);
block1.add_child(span1, Constraint::Percent(100));
// Adds block1 as child of main block
main.add_child(block1, Constraint::Min(0));

// Create block2 and adds span as its child
let mut block2 = Block::vertical().title("Another");
let span2 = "This is really cool, right?".fg(Color::Blue);
block2.add_child(span2, Constraint::Percent(100));
// Adds block2 as child of main block
main.add_child(block2, Constraint::Fill);

// Renders the main block which renders all the children using Buffer
let mut buffer = Buffer::empty(Rect::new(1, 1, 30, 8));
main.render(&mut buffer);
buffer.render();

image

Usage

Code blocks above are just examples of the usage. To see more about functions, Widgets and more, please visit the documentation.

Technologies

Obviously this library was created in Rust, but I also used library called term_size to get terminal size.

Dependencies

~230KB