From 88e08bbe802596fea948c9c58b7216011920ec68 Mon Sep 17 00:00:00 2001 From: Rafael Gonzaga Date: Mon, 26 Feb 2024 06:55:57 -0300 Subject: [PATCH] util: add styleText API to text formatting Co-Authored-By: Hemanth HM PR-URL: https://github.com/nodejs/node/pull/51850 Reviewed-By: Matteo Collina Reviewed-By: Adrian Estrada Reviewed-By: Marco Ippolito Reviewed-By: Antoine du Hamel Reviewed-By: Moshe Atlow Reviewed-By: Geoffrey Booth --- doc/api/util.md | 37 ++++++++++++++++++++++++++++ lib/util.js | 16 ++++++++++++ test/parallel/test-util-styletext.js | 35 ++++++++++++++++++++++++++ 3 files changed, 88 insertions(+) create mode 100644 test/parallel/test-util-styletext.js diff --git a/doc/api/util.md b/doc/api/util.md index ed05dfebaf5384..f937d7272a7436 100644 --- a/doc/api/util.md +++ b/doc/api/util.md @@ -1792,6 +1792,42 @@ console.log(util.stripVTControlCharacters('\u001B[4mvalue\u001B[0m')); // Prints "value" ``` +## `util.styleText(format, text)` + +> Stability: 1.1 - Active development + + + +* `format` {string} A text format defined in `util.inspect.colors`. +* `text` {string} The text to to be formatted. + +This function returns a formatted text considering the `format` passed. + +```mjs +import { styleText } from 'node:util'; +const errorMessage = styleText('red', 'Error! Error!'); +console.log(errorMessage); +``` + +```cjs +const { styleText } = require('node:util'); +const errorMessage = styleText('red', 'Error! Error!'); +console.log(errorMessage); +``` + +`util.inspect.colors` also provides text formats such as `italic`, and +`underline` and you can combine both: + +```cjs +console.log( + util.styleText('underline', util.styleText('italic', 'My italic underlined message')), +); +``` + +The full list of formats can be found in [modifiers][]. + ## Class: `util.TextDecoder`