25 releases
0.3.5 | Sep 12, 2024 |
---|---|
0.3.2 | Jul 8, 2024 |
0.1.13 | Feb 27, 2024 |
0.1.10 | Dec 20, 2023 |
0.1.6 | Jul 23, 2023 |
#39 in Command-line interface
22,323 downloads per month
Used in 32 crates
(30 directly)
255KB
2K
SLoC
data:image/s3,"s3://crabby-images/4bb46/4bb461054f91b8bf9c9a22ab9a84722ab80b8d3f" alt="CliClack Logo"
Effortlessly build beautiful command-line apps with Rust 🦀✨
Beautiful, minimal, opinionated CLI prompts inspired by the
@clack/prompts npm
package.
cargo add cliclack
cliclack
in action
cargo run --example basic
cargo run --example log
data:image/s3,"s3://crabby-images/64e37/64e37b9a6047fb2e554849210beffe87c20eead5" alt="CliClack Example"
💎 Fancy minimal UI
✅ Simple API
🎨 Theme support
Setup
The intro
and outro
/outro_cancel
functions will
print a message to begin and end a prompt session respectively.
use cliclack::{intro, outro};
intro("create-my-app")?;
// Do stuff
outro("You're all set!")?;
Input
The input prompt accepts a single line of text trying to parse it into a target type.
Multiline input can be enabled using the multiline()
switch.
use cliclack::input;
let path: String = input("Where should we create your project?")
.placeholder("./sparkling-solid")
.validate(|input: &String| {
if input.is_empty() {
Err("Please enter a path.")
} else if !input.starts_with("./") {
Err("Please enter a relative path")
} else {
Ok(())
}
})
.interact()?;
🎨 Theme
A custom theme can be applied for UI rendering. An example of theme customization:
cargo run --example theme
data:image/s3,"s3://crabby-images/20579/20579321325849ad748b5603d6bb77b859dccaaa" alt="CliClack Magenta Theme"
🚥 Progress Bar
Starting from cliclack = "0.2.3"
, progress bars and multi-progress bars are supported.
data:image/s3,"s3://crabby-images/daef6/daef659f070922f005af63aa91bdd3c805203482" alt="CliClack Multi Progress Bar"
See more
Dependencies
~3–10MB
~102K SLoC