What is ansi-align?
The ansi-align npm package is used to align text within the terminal using ANSI escape codes. It allows for centering, right-aligning, or left-aligning strings within a given width, which is useful for creating visually appealing command-line interfaces.
What are ansi-align's main functionalities?
Center alignment
This feature centers the text within a specified width. The code sample demonstrates how to center the text 'Centered Text' within a width of 20 characters.
const ansiAlign = require('ansi-align');
console.log(ansiAlign.center('Centered Text', {width: 20}));
Right alignment
This feature right-aligns the text within a specified width. The code sample demonstrates how to right-align the text 'Right Aligned' within a width of 20 characters.
const ansiAlign = require('ansi-align');
console.log(ansiAlign.right('Right Aligned', {width: 20}));
Left alignment
This feature left-aligns the text within a specified width. The code sample demonstrates how to left-align the text 'Left Aligned' within a width of 20 characters.
const ansiAlign = require('ansi-align');
console.log(ansiAlign.left('Left Aligned', {width: 20}));
Other packages similar to ansi-align
text-table
The text-table package is used to create a text-based table with aligned columns. It can align text within each column of the table. While ansi-align focuses on aligning individual lines of text, text-table is more suited for aligning text in a tabular format.
string-width
The string-width package is designed to calculate and return the visual width of a string in the terminal, considering ANSI escape codes. It does not provide direct alignment features but can be used in conjunction with other packages to align text properly, taking into account the visual width of ANSI-colored strings.
ansi-align
align-text with ANSI support for CLIs
Easily center- or right- align a block of text, carefully ignoring ANSI escape codes.
E.g. turn this:
Into this:
Install
npm install --save ansi-align
var ansiAlign = require('ansi-align')
API
ansiAlign(text, [opts])
Align the given text per the line with the greatest string-width
, returning a new string (or array).
Arguments
-
text
: required, string or array
The text to align. If a string is given, it will be split using either the opts.split
value or '\n'
by default. If an array is given, a different array of modified strings will be returned.
-
opts
: optional, object
Options to change behavior, see below.
Options
-
opts.align
: string, default 'center'
The alignment mode. Use 'center'
for center-alignment, 'right'
for right-alignment, or 'left'
for left-alignment. Note that the given text
is assumed to be left-aligned already, so specifying align: 'left'
just returns the text
as is (no-op).
-
opts.split
: string or RegExp, default '\n'
The separator to use when splitting the text. Only used if text is given as a string.
-
opts.pad
: string, default ' '
The value used to left-pad (prepend to) lines of lesser width. Will be repeated as necessary to adjust alignment to the line with the greatest width.
ansiAlign.center(text)
Alias for ansiAlign(text, { align: 'center' })
.
ansiAlign.right(text)
Alias for ansiAlign(text, { align: 'right' })
.
ansiAlign.left(text)
Alias for ansiAlign(text, { align: 'left' })
, which is a no-op.
Similar Packages
center-align
: Very close to this package, except it doesn't support ANSI codes.left-pad
: Great for left-padding but does not support center alignment or ANSI codes.- Pretty much anything by the chalk team
License
ISC © Contributors