UNPKG

styled-string-builder

Version:

String Styler class based on a builder design pattern

441 lines (437 loc) 27 kB
/** * @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(" ")); } export { AnsiReset, BrightBackgroundColors, BrightForegroundColors, StandardBackgroundColors, StandardForegroundColors, StyledString, applyStyle, clear, colorize256, colorizeANSI, colorizeRGB, raw, style, styles }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"styled-string-builder.esm.cjs","sources":["../src/constants.ts","../src/colors.ts","../src/strings.ts"],"sourcesContent":[null,null,null],"names":[],"mappings":"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"}