styled-string-builder
Version:
String Styler class based on a builder design pattern
462 lines (456 loc) • 29.5 kB
JavaScript
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :
typeof define === 'function' && define.amd ? define(['exports'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["styled-string-builder"] = {}));
})(this, (function (exports) { 'use strict';
/**
* @description ANSI escape code for resetting text formatting.
* @summary This constant holds the ANSI escape sequence used to reset all text formatting to default.
* @const AnsiReset
* @memberOf module:StyledString
*/
const AnsiReset = "\x1b[0m";
/**
* @description Standard foreground color codes for ANSI text formatting.
* @summary This object maps color names to their corresponding ANSI color codes for standard foreground colors.
* @const StandardForegroundColors
* @property {number} black - ANSI code for black text (30).
* @property {number} red - ANSI code for red text (31).
* @property {number} green - ANSI code for green text (32).
* @property {number} yellow - ANSI code for yellow text (33).
* @property {number} blue - ANSI code for blue text (34).
* @property {number} magenta - ANSI code for magenta text (35).
* @property {number} cyan - ANSI code for cyan text (36).
* @property {number} white - ANSI code for white text (37).
* @memberOf module:StyledString
*/
const StandardForegroundColors = {
black: 30,
red: 31,
green: 32,
yellow: 33,
blue: 34,
magenta: 35,
cyan: 36,
white: 37,
};
/**
* @description Bright foreground color codes for ANSI text formatting.
* @summary This object maps color names to their corresponding ANSI color codes for bright foreground colors.
* @const BrightForegroundColors
* @property {number} black - ANSI code for bright black text (90).
* @property {number} red - ANSI code for bright red text (91).
* @property {number} green - ANSI code for bright green text (92).
* @property {number} yellow - ANSI code for bright yellow text (93).
* @property {number} blue - ANSI code for bright blue text (94).
* @property {number} magenta - ANSI code for bright magenta text (95).
* @property {number} cyan - ANSI code for bright cyan text (96).
* @property {number} white - ANSI code for bright white text (97).
* @memberOf module:@StyledString
*/
const BrightForegroundColors = {
brightBlack: 90,
brightRed: 91,
brightGreen: 92,
brightYellow: 93,
brightBlue: 94,
brightMagenta: 95,
brightCyan: 96,
brightWhite: 97,
};
/**
* @description Standard background color codes for ANSI text formatting.
* @summary This object maps color names to their corresponding ANSI color codes for standard background colors.
* @const StandardBackgroundColors
* @property {number} bgBlack - ANSI code for black background (40).
* @property {number} bgRed - ANSI code for red background (41).
* @property {number} bgGreen - ANSI code for green background (42).
* @property {number} bgYellow - ANSI code for yellow background (43).
* @property {number} bgBlue - ANSI code for blue background (44).
* @property {number} bgMagenta - ANSI code for magenta background (45).
* @property {number} bgCyan - ANSI code for cyan background (46).
* @property {number} bgWhite - ANSI code for white background (47).
* @memberOf module:@StyledString
*/
const StandardBackgroundColors = {
bgBlack: 40,
bgRed: 41,
bgGreen: 42,
bgYellow: 43,
bgBlue: 44,
bgMagenta: 45,
bgCyan: 46,
bgWhite: 47,
};
/**
* @description Bright background color codes for ANSI text formatting.
* @summary This object maps color names to their corresponding ANSI color codes for bright background colors.
* @const BrightBackgroundColors
* @property {number} bgBrightBlack - ANSI code for bright black background (100).
* @property {number} bgBrightRed - ANSI code for bright red background (101).
* @property {number} bgBrightGreen - ANSI code for bright green background (102).
* @property {number} bgBrightYellow - ANSI code for bright yellow background (103).
* @property {number} bgBrightBlue - ANSI code for bright blue background (104).
* @property {number} bgBrightMagenta - ANSI code for bright magenta background (105).
* @property {number} bgBrightCyan - ANSI code for bright cyan background (106).
* @property {number} bgBrightWhite - ANSI code for bright white background (107).
* @memberOf module:@StyledString
*/
const BrightBackgroundColors = {
bgBrightBlack: 100,
bgBrightRed: 101,
bgBrightGreen: 102,
bgBrightYellow: 103,
bgBrightBlue: 104,
bgBrightMagenta: 105,
bgBrightCyan: 106,
bgBrightWhite: 107,
};
/**
* @description Text style codes for ANSI text formatting.
* @summary This object maps style names to their corresponding ANSI codes for various text styles.
* @const styles
* @property {number} reset - ANSI code to reset all styles (0).
* @property {number} bold - ANSI code for bold text (1).
* @property {number} dim - ANSI code for dim text (2).
* @property {number} italic - ANSI code for italic text (3).
* @property {number} underline - ANSI code for underlined text (4).
* @property {number} blink - ANSI code for blinking text (5).
* @property {number} inverse - ANSI code for inverse colors (7).
* @property {number} hidden - ANSI code for hidden text (8).
* @property {number} strikethrough - ANSI code for strikethrough text (9).
* @property {number} doubleUnderline - ANSI code for double underlined text (21).
* @property {number} normalColor - ANSI code to reset color to normal (22).
* @property {number} noItalicOrFraktur - ANSI code to turn off italic (23).
* @property {number} noUnderline - ANSI code to turn off underline (24).
* @property {number} noBlink - ANSI code to turn off blink (25).
* @property {number} noInverse - ANSI code to turn off inverse (27).
* @property {number} noHidden - ANSI code to turn off hidden (28).
* @property {number} noStrikethrough - ANSI code to turn off strikethrough (29).
* @memberOf module:@StyledString
*/
const styles = {
reset: 0,
bold: 1,
dim: 2,
italic: 3,
underline: 4,
blink: 5,
inverse: 7,
hidden: 8,
strikethrough: 9,
doubleUnderline: 21,
normalColor: 22,
noItalicOrFraktur: 23,
noUnderline: 24,
noBlink: 25,
noInverse: 27,
noHidden: 28,
noStrikethrough: 29,
};
/**
* @description Applies a basic ANSI color code to text.
* @summary This function takes a string, an ANSI color code number, and an optional background flag.
* It returns the text wrapped in the appropriate ANSI escape codes for either foreground or background coloring.
* This function is used for basic 16-color ANSI formatting.
*
* @param {string} text - The text to be colored.
* @param {number} n - The ANSI color code number.
* @param {boolean} [bg=false] - If true, applies the color to the background instead of the foreground.
* @return {string} The text wrapped in ANSI color codes.
*
* @function colorizeANSI
* @memberOf module:@StyledString
*/
function colorizeANSI(text, n, bg = false) {
if (isNaN(n)) {
console.warn(`Invalid color number on the ANSI scale: ${n}. ignoring...`);
return text;
}
if (bg && ((n > 30 && n <= 40)
|| (n > 90 && n <= 100))) {
n = n + 10;
}
return `\x1b[${n}m${text}${AnsiReset}`;
}
/**
* @description Applies a 256-color ANSI code to text.
* @summary This function takes a string and a color number (0-255) and returns the text
* wrapped in ANSI escape codes for either foreground or background coloring.
*
* @param {string} text - The text to be colored.
* @param {number} n - The color number (0-255).
* @param {boolean} [bg=false] - If true, applies the color to the background instead of the foreground.
* @return {string} The text wrapped in ANSI color codes.
*
* @function colorize256
* @memberOf module:@StyledString
*/
function colorize256(text, n, bg = false) {
if (isNaN(n)) {
console.warn(`Invalid color number on the 256 scale: ${n}. ignoring...`);
return text;
}
if (n < 0 || n > 255) {
console.warn(`Invalid color number on the 256 scale: ${n}. ignoring...`);
return text;
}
return `\x1b[${bg ? 48 : 38};5;${n}m${text}${AnsiReset}`;
}
/**
* @description Applies an RGB color ANSI code to text.
* @summary This function takes a string and RGB color values (0-255 for each component)
* and returns the text wrapped in ANSI escape codes for either foreground or background coloring.
*
* @param {string} text - The text to be colored.
* @param {number} r - The red component of the color (0-255).
* @param {number} g - The green component of the color (0-255).
* @param {number} b - The blue component of the color (0-255).
* @param {boolean} [bg=false] - If true, applies the color to the background instead of the foreground.
* @return {string} The text wrapped in ANSI color codes.
*
* @function colorizeRGB
* @memberOf module:StyledString
*/
function colorizeRGB(text, r, g, b, bg = false) {
if (isNaN(r) || isNaN(g) || isNaN(b)) {
console.warn(`Invalid RGB color values: r=${r}, g=${g}, b=${b}. Ignoring...`);
return text;
}
if ([r, g, b].some(v => v < 0 || v > 255)) {
console.warn(`Invalid RGB color values: r=${r}, g=${g}, b=${b}. Ignoring...`);
return text;
}
return `\x1b[${bg ? 48 : 38};2;${r};${g};${b}m${text}${AnsiReset}`;
}
/**
* @description Applies an ANSI style code to text.
* @summary This function takes a string and a style code (either a number or a key from the styles object)
* and returns the text wrapped in the appropriate ANSI escape codes for that style.
*
* @param {string} text - The text to be styled.
* @param {number | string} n - The style code or style name.
* @return {string} The text wrapped in ANSI style codes.
*
* @function applyStyle
* @memberOf module:StyledString
*/
function applyStyle(text, n) {
const styleCode = typeof n === "number" ? n : styles[n];
return `\x1b[${styleCode}m${text}${AnsiReset}`;
}
/**
* @description Removes all ANSI formatting codes from text.
* @summary This function takes a string that may contain ANSI escape codes for formatting
* and returns a new string with all such codes removed, leaving only the plain text content.
* It uses a regular expression to match and remove ANSI escape sequences.
*
* @param {string} text - The text potentially containing ANSI formatting codes.
* @return {string} The input text with all ANSI formatting codes removed.
*
* @function clear
* @memberOf module:StyledString
*/
function clear(text) {
// Regular expression to match ANSI escape codes
// eslint-disable-next-line no-control-regex
const ansiRegex = /\x1B(?:[@-Z\\-_]|\[[0-?]*[ -/]*[@-~])/g;
return text.replace(ansiRegex, '');
}
/**
* @description Applies raw ANSI escape codes to text.
* @summary This function takes a string and a raw ANSI escape code, and returns the text
* wrapped in the provided raw ANSI code and the reset code. This allows for applying custom
* or complex ANSI formatting that may not be covered by other utility functions.
*
* @param {string} text - The text to be formatted.
* @param {string} raw - The raw ANSI escape code to be applied.
* @return {string} The text wrapped in the raw ANSI code and the reset code.
*
* @function raw
* @memberOf module:StyledString
*/
function raw(text, raw) {
return `${raw}${text}${AnsiReset}`;
}
/**
* @class StyledString
* @description A class that extends string functionality with ANSI color and style options.
* @summary StyledString provides methods to apply various ANSI color and style options to text strings.
* It implements the ColorizeOptions interface and proxies native string methods to the underlying text.
* This class allows for chaining of styling methods and easy application of colors and styles to text.
*
* @implements {ColorizeOptions}
* @param {string} text - The initial text string to be styled.
*/
class StyledString {
constructor(text) {
this.text = text;
// Basic colors
Object.entries(StandardForegroundColors).forEach(([name, code]) => {
Object.defineProperty(this, name, {
get: () => this.foreground(code),
});
});
Object.entries(BrightForegroundColors).forEach(([name, code]) => {
Object.defineProperty(this, name, {
get: () => this.foreground(code),
});
});
// Background colors
Object.entries(StandardBackgroundColors).forEach(([name, code]) => {
Object.defineProperty(this, name, {
get: () => this.background(code),
});
});
Object.entries(BrightBackgroundColors).forEach(([name, code]) => {
Object.defineProperty(this, name, {
get: () => this.background(code),
});
});
// Styles
Object.entries(styles).forEach(([name, code]) => {
Object.defineProperty(this, name, {
get: () => this.style(code),
});
});
}
/**
* @description Clears all styling from the text.
* @summary Removes all ANSI color and style codes from the text.
* @return {StyledString} The StyledString instance with cleared styling.
*/
clear() {
this.text = clear(this.text);
return this;
}
/**
* @description Applies raw ANSI codes to the text.
* @summary Allows direct application of ANSI escape sequences to the text.
* @param {string} rawAnsi - The raw ANSI escape sequence to apply.
* @return {StyledString} The StyledString instance with the raw ANSI code applied.
*/
raw(rawAnsi) {
this.text = raw(this.text, rawAnsi);
return this;
}
/**
* @description Applies a foreground color to the text.
* @summary Sets the text color using ANSI color codes.
* @param {number} n - The ANSI color code for the foreground color.
* @return {StyledString} The StyledString instance with the foreground color applied.
*/
foreground(n) {
this.text = colorizeANSI(this.text, n);
return this;
}
/**
* @description Applies a background color to the text.
* @summary Sets the background color of the text using ANSI color codes.
* @param {number} n - The ANSI color code for the background color.
* @return {StyledString} The StyledString instance with the background color applied.
*/
background(n) {
this.text = colorizeANSI(this.text, n, true);
return this;
}
/**
* @description Applies a text style to the string.
* @summary Sets text styles such as bold, italic, or underline using ANSI style codes.
* @param {number | string} n - The style code or key from the styles object.
* @return {StyledString} The StyledString instance with the style applied.
*/
style(n) {
if (typeof n === "string" && !(n in styles)) {
console.warn(`Invalid style: ${n}`);
return this;
}
this.text = applyStyle(this.text, n);
return this;
}
/**
* @description Applies a 256-color foreground color to the text.
* @summary Sets the text color using the extended 256-color palette.
* @param {number} n - The color number from the 256-color palette.
* @return {StyledString} The StyledString instance with the 256-color foreground applied.
*/
color256(n) {
this.text = colorize256(this.text, n);
return this;
}
/**
* @description Applies a 256-color background color to the text.
* @summary Sets the background color using the extended 256-color palette.
* @param {number} n - The color number from the 256-color palette.
* @return {StyledString} The StyledString instance with the 256-color background applied.
*/
bgColor256(n) {
this.text = colorize256(this.text, n, true);
return this;
}
/**
* @description Applies an RGB foreground color to the text.
* @summary Sets the text color using RGB values.
* @param {number} r - The red component (0-255).
* @param {number} g - The green component (0-255).
* @param {number} b - The blue component (0-255).
* @return {StyledString} The StyledString instance with the RGB foreground color applied.
*/
rgb(r, g, b) {
this.text = colorizeRGB(this.text, r, g, b);
return this;
}
/**
* @description Applies an RGB background color to the text.
* @summary Sets the background color using RGB values.
* @param {number} r - The red component (0-255).
* @param {number} g - The green component (0-255).
* @param {number} b - The blue component (0-255).
* @return {StyledString} The StyledString instance with the RGB background color applied.
*/
bgRgb(r, g, b) {
this.text = colorizeRGB(this.text, r, g, b, true);
return this;
}
/**
* @description Converts the StyledString to a regular string.
* @summary Returns the underlying text with all applied styling.
* @return {string} The styled text as a regular string.
*/
toString() {
return this.text;
}
}
/**
* @description Applies styling to a given text string.
* @summary This function takes a string and returns a StyledString object, which is an enhanced
* version of the original string with additional methods for applying various ANSI color and style
* options. It sets up a mapper object with methods for different styling operations and then
* defines properties on the text string to make these methods accessible.
*
* @param {string[]} t The input text to be styled.
* @return {StyledString} A StyledString object with additional styling methods.
*
* @function style
*
* @memberOf StyledString
*/
function style(...t) {
return new StyledString(t.join(" "));
}
exports.AnsiReset = AnsiReset;
exports.BrightBackgroundColors = BrightBackgroundColors;
exports.BrightForegroundColors = BrightForegroundColors;
exports.StandardBackgroundColors = StandardBackgroundColors;
exports.StandardForegroundColors = StandardForegroundColors;
exports.StyledString = StyledString;
exports.applyStyle = applyStyle;
exports.clear = clear;
exports.colorize256 = colorize256;
exports.colorizeANSI = colorizeANSI;
exports.colorizeRGB = colorizeRGB;
exports.raw = raw;
exports.style = style;
exports.styles = styles;
}));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"styled-string-builder.cjs","sources":["../src/constants.ts","../src/colors.ts","../src/strings.ts"],"sourcesContent":[null,null,null],"names":[],"mappings":"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"}