
Security News
n8n Tops 2025 JavaScript Rising Stars as Workflow Platforms Gain Momentum
n8n led JavaScript Rising Stars 2025 by a wide margin, with workflow platforms seeing the largest growth across categories.
@opentf/cli-styles
Advanced tools
Style your CLI text using ANSI escape sequences.
24-Bit colors only (True Color)
Nested styles
Auto detects CLI color support
Supports RGB & Hex color modes
Respects NO_COLOR & FORCE_COLOR
✔️ GNOME Terminal
✔️ Konsole
✔️ xfce4-terminal
✔️ MATE Terminal
✔️ iTerm2
✔️ VS Code
✔️ Tabby
✔️ Hyper
✔️ Alacritty
✔️ Contour
✔️ kitty
✔️ WezTerm
✔️ Windows Terminal
❌ Terminal.app
*Missing your favorite terminal emulators here? Please give a PR or file an issue in Github.
npm install @opentf/cli-styles
yarn add @opentf/cli-styles
pnpm add @opentf/cli-styles
style(str: string, options?: { color: boolean }): string;
import { style } from '@opentf/cli-styles';
style('$key[.key...]{Text}');
Using foreground color
style(
'🍊 - An $o{orange} is a fruit of various citrus species in the family Rutaceae.'
);

Using multiple colors
style(
'$bgy.bl{The $r.bol{R}$g.bol{G}$b.bol{B} color model is an additive color model in which the $r.bol{red}, $g.bol{green} and $b.bol{blue} primary colors of light are added together in various ways to reproduce a broad array of colors.}'
);

Nested colors
style(
"$bgbl.b{THE QUICK $g{BROWN $r.bol{CAT} JUMPED} OVER THE LAZY $r.bol{DOG}'S BACK}"
);

Composing different styles
style('$bol.w.bgg{ PASS }');

Inverse colors
style('$inv.r.bgw.bol{ FAILED }');

Normal vs Bold vs Dim text
style('Normal text | $bol{Bold text} | $dim{Dimmed text}');

Italic fonts
style(
'$ita.fuchsia.bol.bgw{"This poem is endless,\n the odds against us are endless,\n our chances of being alive together statistically nonexistent;\n still we have made it"}'
);

Underlined texts
style('Highlighted fruits: $und{Apple}, cat, $und{Banana}');

Strikethrough text
style('Price: $str.r{\\$75.00} $g{\\$50.00}');

Code Highlighting:
import { style } from '@opentf/cli-styles';
import hljs from 'highlight.js';
import { decode } from 'html-entities';
function highlight(code) {
let html = hljs.highlight(code, {
language: 'js',
}).value;
html = html.replaceAll('<span class="hljs-keyword">', '$fuchsia{');
html = html.replaceAll('<span class="hljs-variable language_">', '$b{');
html = html.replaceAll('<span class="hljs-title function_">', '$lime{');
html = html.replaceAll('<span class="hljs-string">', '$y{');
html = html.replaceAll('<span class="hljs-params"></span>', '');
html = html.replaceAll('<span class="hljs-comment">', '$gr.dim{');
html = html.replaceAll('</span>', '}');
html = decode(html);
return style(html);
}
const code = `
// Comment
function greet() {
console.log('Hello World!');
}
`;
console.log(highlight(code));

Using Template Literals:
const cpu = 90;
const ram = 40;
const disk = 70;
const getColor = (n) => (n <= 50 ? 'g' : n > 50 && n <= 70 ? 'y' : 'r');
style(`
CPU: $${getColor(cpu)}{${cpu}%}
RAM: $${getColor(ram)}{${ram}%}
DISK: $${getColor(disk)}{${disk}%}
`);

Escape characters:
Use double back slashes to escape a character in a string.
style(
`<$hex(#39CCCC){input} name=$y{"price"} value=$y{"\\$\\{ Cost + Tax \\}.00"} />`
);

Blinking Text:
style('$g.bol{SALE! -} $blk.r.bol{50% OFFER}');

| Key | Description |
|---|---|
| r | Red - rgb(255,65,54) |
| g | Green - rgb(46,204,64) |
| b | Blue - rgb(0,116,217) |
| o | Orange - rgb(255,133,27) |
| y | Yellow - rgb(255,220,0) |
| w | White - rgb(255,255,255) |
| bl | Black - rgb(17,17,17) |
| gr | Grey - rgb(170,170,170) |
| navy | Navy - rgb(0,31,63) |
| aqua | Aqua - rgb(127,219,255) |
| teal | Teal - rgb(57,204,204) |
| purple | Purple - rgb(177,13,201) |
| fuchsia | Fuchsia - rgb(240,18,190) |
| maroon | Maroon - rgb(133,20,75) |
| olive | Olive - rgb(61,153,112) |
| lime | Lime - rgb(1,255,112) |
| silver | Silver - rgb(221,221,221) |
| rgb(red, green, blue) | The RGB colors, Eg: rgb(255,0,0) for red color |
| hex(#------) | The 6-digit Hex colors, Eg: hex(#00ff00) for green color |
| bg* | The background colors can be applied with prefix bg to any color keys.Eg: bgw for white bg bgrgb(0,0,0) for black bg bghex(#0000FF) for blue bg |
| Key | Description |
|---|---|
| res | Reset all attributes to normal |
| nor | Normal intensity Neither bold nor dim |
| bol | Bold or increased intensity text |
| dim | Dimmed or decreased intensity text |
| ita | Italic text |
| und | Underlined text |
| inv | Swap foreground and background colors |
| str | Strikethrough text |
| hid | Hidden text |
| dun | Double underlined text |
| ovl | Overlined text |
| blk | Blinking text |
You can disable colors/styles by the following methods:
Pass color option false to the style function.
Pass --no-color or --color=false to the process arguments.
Set FORCE_COLOR=0 in enviroment variables.
You can force enable colors/styles by setting FORCE_COLOR=3 in enviroment variables.
| Key | Supported Terminals |
|---|---|
| res | ✅ Gnome Terminal ✅ Konsole ✅ xfce4-terminal ✅ MATE Terminal ✅ iTerm2 ✅ VS Code ✅ Tabby ✅ Hyper ✅ Alacritty ✅ Contour ✅ kitty ✅ WezTerm ✅ Windows Terminal |
| nor | ✅ Gnome Terminal ✅ Konsole ✅ xfce4-terminal ✅ MATE Terminal ✅ VS Code ✅ Tabby ✅ Hyper ✅ Contour ✅ kitty ✅ WezTerm ✅ Windows Terminal ✅ iTerm2 ✅ Alacritty |
| bol | ✅ Gnome Terminal ✅ Konsole ✅ xfce4-terminal ✅ MATE Terminal ✅ VS Code ✅ Tabby ✅ Hyper ✅ Contour ✅ kitty ✅ WezTerm ✅ Windows Terminal ✅ iTerm2 ✅ Alacritty |
| dim | ✅ Gnome Terminal ✅ Konsole ✅ xfce4-terminal ✅ MATE Terminal ✅ VS Code ✅ Tabby ✅ Hyper ✅ Contour ✅ kitty ✅ WezTerm ✅ Windows Terminal ✅ iTerm2 ✅ Alacritty |
| ita | ✅ Gnome Terminal ✅ Konsole ✅ xfce4-terminal ✅ MATE Terminal ✅ VS Code ✅ Tabby ✅ Hyper ✅ Contour ❌ kitty ✅ WezTerm ✅ Windows Terminal ✅ iTerm2 ✅ Alacritty |
| und | ✅ Gnome Terminal ✅ Konsole ✅ xfce4-terminal ✅ MATE Terminal ✅ VS Code ✅ Tabby ✅ Hyper ✅ Contour ✅ kitty ✅ WezTerm ✅ Windows Terminal ✅ iTerm2 ✅ Alacritty |
| inv | ✅ Gnome Terminal ✅ Konsole ✅ xfce4-terminal ✅ MATE Terminal ✅ VS Code ✅ Tabby ✅ Hyper ✅ Contour ✅ kitty ✅ WezTerm ✅ Windows Terminal ✅ iTerm2 ✅ Alacritty |
| str | ✅ Gnome Terminal ✅ Konsole ✅ xfce4-terminal ✅ MATE Terminal ✅ VS Code ✅ Tabby ✅ Hyper ✅ Contour ✅ kitty ✅ WezTerm ✅ Windows Terminal ✅ iTerm2 ✅ Alacritty |
| hid | ✅ Gnome Terminal ✅ Konsole ✅ xfce4-terminal ✅ MATE Terminal ✅ VS Code ✅ Tabby ✅ Hyper ✅ Contour ❌ kitty ✅ WezTerm ✅ Windows Terminal ❌ iTerm2 ✅ Alacritty |
| dun | ✅ Gnome Terminal ❌ Konsole ✅ xfce4-terminal ✅ MATE Terminal ✅ VS Code ✅ Tabby ❌ Hyper ✅ Contour ✅ kitty ✅ WezTerm ✅ Windows Terminal ❌ iTerm2 ❌ Alacritty |
| ovl | ✅ Gnome Terminal ✅ Konsole ✅ xfce4-terminal ✅ MATE Terminal ✅ VS Code ❌ Tabby ❌ Hyper ✅ Contour ❌ kitty ✅ WezTerm ✅ Windows Terminal ❌ iTerm2 ❌ Alacritty |
| blk | ✅ Gnome Terminal ✅ Konsole ✅ xfce4-terminal ✅ MATE Terminal ❌ VS Code ❌ Tabby ❌ Hyper ✅ Contour ❌ kitty ✅ WezTerm ✅ Windows Terminal ❌ iTerm2 ❌ Alacritty |
https://en.wikipedia.org/wiki/ANSI_escape_code
https://github.com/termstandard/colors
https://nodejs.org/api/cli.html#force_color1-2-3
https://developer.chrome.com/docs/devtools/console/format-style/
@opentf/utils - A collection of JavaScript utility functions.
@opentf/cli-pbar - CLI progress bar.
Copyright (c) 2022, Thanga Ganapathy (MIT License).
FAQs
Style your CLI text using ANSI escape sequences.
The npm package @opentf/cli-styles receives a total of 1,320 weekly downloads. As such, @opentf/cli-styles popularity was classified as popular.
We found that @opentf/cli-styles demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
n8n led JavaScript Rising Stars 2025 by a wide margin, with workflow platforms seeing the largest growth across categories.

Security News
The U.S. government is rolling back software supply chain mandates, shifting from mandatory SBOMs and attestations to a risk-based approach.

Security News
crates.io adds a Security tab backed by RustSec advisories and narrows trusted publishing paths to reduce common CI publishing risks.