Generate Badges for your CLI.
NOTE: It is recommended to update pre-exisiting versions of this module to ^v0.1.0
as there are many breaking changes from this release in the API.
- Make Beautiful Badges for CLI 🤩
- Works across all terminals 🦄
- Link support 🔗
- Variety of colors to choose from 🎨
- Written in TS with Deno 🦕
Warning
⚠️ : If your terminal has a custom theme then the colors will blend according to your configuration which can cause unwanted results.
Showcases failed
, success
and skipped
badge on the terminal
import { badge } from "https://deno.land/x/cli_badges@v0.1.1/mod.ts";
console.log(badge("failed", "2", { msgBg: "red" }));
console.log(badge("success", "2", { msgBg: "green" }));
console.log(badge("skipped", "2", { msgBg: "yellow" }));
The hyperlink will only work if supported.
import { badge } from "https://deno.land/x/cli_badges@v0.1.1/mod.ts";
console.log(badge('❤️ donate', 'ko-fi', { hyper_link: 'https://ko-fi.com/logginjs',
}));
For more usages, see examples.
badge
function accepts the following arguments:
label
: label of the badgemsg
: message of the badgeopts
: accepts an interface ofBadgeOptions
interface BadgeOptions {
msgBg: string; // default is blue
labelBg: string; // default is brightBlack
msgColor: string; // default is white
labelColor: string; // default is white
msgStyle?: string; // default is null
labelStyle?: string; // default is null
msgWidth?: number; // default is msg length + 2
labelWidth?: number; // default is label length + 2
is_8bit?: boolean; // default is false as it uses 24 bits
hyper_link?: string; // hyperlink for the badge
}
black
red
blue
green
yellow
magenta
cyan
white
brightBlack
brightRed
brightBlue
brightGreen
brightYellow
brightMagenta
brightCyan
brightWhite
black
red
blue
green
yellow
magenta
cyan
white
brightBlack
brightRed
brightBlue
brightGreen
brightYellow
brightMagenta
brightCyan
brightWhite
Custom Colors are available and can be used for msgBg
, labelmsg
, msgColor
and labelColor
only. There are options to make 8 bit
and 24 bit
colors respectively. Set is_8bit
to true if you want custom 8 bit RGB colors else it will be set to 24 bit RBG colors by default.
NOTE: 24 bit
Colors must be in a range of 0x000000
and 0xffffff
and 8 bit
Colors must in a range of 0x0
and 0xFF
.
bold
italic
inverse
dim
strike
underline
Hyperlink is only supported on some terminals.
I thank the author of nombrekeff/cli-badges for his original implementation in JS wth Node and also helped me with some Deno issues and giving me guidance on this project as this is my first project written in TS and Deno.
Licensed under MIT.