diff options
author | Florrie <towerofnix@gmail.com> | 2020-07-16 14:05:54 -0300 |
---|---|---|
committer | Florrie <towerofnix@gmail.com> | 2020-07-16 14:05:54 -0300 |
commit | 154dd2f631edc9f46ff73e80b54d48f0ccdf049a (patch) | |
tree | b170d47d5f166152a16d83d2584e98ad24da5f1f /ui | |
parent | 7f0579fc6e5771bbcad36591ab54119c4fe66dbd (diff) |
support mixed textAttributes & ANSI format labels
Diffstat (limited to 'ui')
-rw-r--r-- | ui/Label.js | 17 | ||||
-rw-r--r-- | ui/WrapLabel.js | 2 |
2 files changed, 17 insertions, 2 deletions
diff --git a/ui/Label.js b/ui/Label.js index f2cd405..b5828cb 100644 --- a/ui/Label.js +++ b/ui/Label.js @@ -4,6 +4,16 @@ const DisplayElement = require('./DisplayElement') module.exports = class Label extends DisplayElement { // A simple text display. Automatically adjusts size to fit text. + // + // Supports formatted text in two ways: + // 1) Modify the textAttributes to be an array containing the ANSI numerical + // codes for any wanted attributes, and/or + // 2) Supply full ANSI escape codes within the text itself. (The reset + // attributes code, ESC[0m, will be processed to reset to the provided + // values in textAttributes. + // + // Subclasses overriding the writeTextTo function should be sure to call + // processFormatting before actually writing text. constructor(text = '') { super() @@ -32,7 +42,12 @@ module.exports = class Label extends DisplayElement { writeTextTo(writable) { writable.write(ansi.moveCursor(this.absTop, this.absLeft)) - writable.write(this.text) + writable.write(this.processFormatting(this.text)) + } + + processFormatting(text) { + return text.replace(new RegExp(ansi.ESC + '\\[0m', 'g'), + ansi.setAttributes([ansi.A_RESET, ...this.textAttributes])) } set text(newText) { diff --git a/ui/WrapLabel.js b/ui/WrapLabel.js index 7036908..d40b29d 100644 --- a/ui/WrapLabel.js +++ b/ui/WrapLabel.js @@ -20,7 +20,7 @@ module.exports = class WrapLabel extends Label { const lines = this.getWrappedLines() for (let i = 0; i < lines.length; i++) { writable.write(ansi.moveCursor(this.absTop + i, this.absLeft)) - writable.write(lines[i]) + writable.write(this.processFormatting(lines[i])) } } |