The CLI prompt library you didnât realize youâve been desperate for.
Itâs blazing-fast, type-safe, and has built-in crash resilienceâso your command-line app can look slick without bursting into flames. Forget boilerplate-heavy setupsâthis library makes CLI development smooth and effortless.
- Docs: docs.reliverse.org/reliverse/prompts
- NPM: npmjs.com/package/@reliverse/prompts
- GitHub: github.com/reliverse/prompts
- Discord: discord.gg/3GawfWfAPe
bun add @reliverse/prompts
# Or npm/pnpm/yarn if thatâs your style
# (deno with jsr support soonâ˘)
Pro Tip: Make sure you have Bun, Node.js, and Git installed.
This thing is blazing fast, type-safe, and basically a bulletproof vest for your CLI.
No more spaghetti prompt code. Just shiny, stable, next-gen developer bliss.
- Better typed validation, bigger ASCII art, more interactive goodies, and next-level color theming.
- Because you deserve better than âjust good enough.â
- TypeScript-first: So your TypeScript dev heart can flutter in peace. Enjoy IntelliSense and zero guesswork.
- Flexible Prompt Types: Text, confirm, select, multiselect, password, number, spinner, toggle, and many more⌠you do you.
- Schema-driven Validations: Easily integrates with TypeBox, Zod, or your own thing. No more âhope it worksâ solutions.
- Accessibility: Terminal-size awareness, WCAG AA color contrast, the whole enchilada.
- Crash-safe: Ctrl+C or random cosmic rays? It shrugs them off.
Consider it your brand-new sports car, while your old CLI prompt library was a rusty lawnmower. Also, itâs a feature-packed replacement for Inquirer, Enquirer, Clack, Terkelg, Terminal-Kit, and a bunch more.
- Full Cross-Platform ESM: Seamlessly works with the Node.js and Bun environments.
- Extensible UI: Because color, typography, animations, and more matter to your terminal fashion sense.
- Built for DX: Minimal dependencies, clean API, full validation baked in, and more.
- Mono Component: Perfect for rapid prototyping. Or if youâre feeling lazy.
import { inputPrompt } from "@reliverse/prompts";
await startPrompt({
clearConsole: true,
titleColor: "inverse",
packageName: "@reliverse/cli",
packageVersion: "1.0.0",
terminalSizeOptions: {
minWidth: 100,
minHeight: 16,
// đ´ Oops! Terminal width is too small. Expected >100 | Current: 97
},
});
const username = await inputPrompt({
id: "username",
title: "Welcome to @reliverse/prompts Demo!",
content: "What's your name?",
});
console.log(`Hey there, ${username}!`);
The library provides a powerful task management system with built-in verification steps, spinners, and error handling:
- Spinner and progress bars that actually move: Progress tracking with current/total counts and status messages
- Task priorities (because some stuff is more important): Critical, high, normal, low
- Built-in stats, error handling, and cancellation: Task timing and statistics, built-in error handling and cancellation support
- Customizable spinners to keep your eyes happy: Customizable spinners and progress indicators
- Nested subtasks and task groups: Group tasks and subtasks for better organization
- Automatic verification steps with customizable delays
- Simple error handling with proper formatting
- Progress tracking for long-running operations
- Custom validation and business logic support
Visit docs to learn more and see examples.
git clone https://github.com/reliverse/prompts.git
cd prompts
bun i
bun dev
Check out examples/launcher.ts
for a smorgasbord of demos (including a quiz). Who says CLIs canât be fun?
- 1-main.ts: A powerhouse CLI example with all the trimmings, with advanced styling and all prompts.
- 2-mono.ts: A single
prompt()
for multiple componentsâperfect for CLI where performance doesn't matter. - 3-simple.ts: Less code, more speed.
- 4-args-a.ts + 5-args-b.ts: Turn sub-commands into a more headless experience.
You donât want a one-size-fits-all library. We got you:
const basicConfig = {
titleColor: "cyanBright",
titleTypography: "bold",
borderColor: "dim",
} satisfies PromptOptions;
const extendedConfig = {
...basicConfig,
contentTypography: "italic",
contentColor: "dim",
} satisfies PromptOptions;
const username = await inputPrompt({
id: "username",
title: "Testing out our fancy library!",
content: "What's your username?",
...extendedConfig,
});
If youâre lazy (like the rest of us), in a hurry, or just want everything jammed together, the Mono Component wraps up all prompt types in a single import.
export const IDs = {
start: "start",
username: "username",
// ...
};
Weâre not shy. We lined up @reliverse/prompts against Inquirer, Clack, Terminal-Kit, etc. Our goal? Turn every feature dot green. Check out the epic chart
You canât build an amazing CLI without argument parsing. Weâve got a built-in fast parser that typecasts your things automatically.
@reliverse/prompts is more than just pretty and fast promptsâitâs a full-blown CLI builder with customizable designs and robust typing. Itâs built to slot seamlessly into Reliverseâs ecosystem, but even if youâre rolling your own thing, youâll appreciate the minimal boilerplate and fancy visuals.
- CLI builder with style & resilience
- Customizable design and color theming
- Zero guesswork with TypeScript integrations
- Minimal boilerplate with maximum results
@inquirer/prompts, @terkelg/prompts, @clack/prompts, @unjs/citty, and many more other open-source legends. You built the shoulders we stand on.
MIT Š Nazarii Korniienko
Stop reading. Start coding.
If youâre serious about CLIsâdonât just buildâReliverse it with
@reliverse/prompts
.