From 7246902f77fffe387d26f912e8960e671e5a3e7b Mon Sep 17 00:00:00 2001 From: "Tim A. Conner" Date: Sun, 22 Apr 2018 21:22:50 -0500 Subject: [PATCH] feat: add resetOutput method (#57) --- README.md | 4 ++++ index.js | 6 +++++- test/cliui.js | 59 +++++++++++++++++++++++++++++---------------------- 3 files changed, 43 insertions(+), 26 deletions(-) diff --git a/README.md b/README.md index 3ad2119..eb3e264 100644 --- a/README.md +++ b/README.md @@ -108,3 +108,7 @@ options: Similar to `div`, except the next row will be appended without a new line being created. + +### cliui.resetOutput() + +Resets the UI elements of the current cliui instance. Wrapping and width that would normally be reset when creating a new cliui instance by using the constructor are not reset. \ No newline at end of file diff --git a/index.js b/index.js index 55abdee9..b42d982 100644 --- a/index.js +++ b/index.js @@ -21,6 +21,10 @@ UI.prototype.span = function () { cols.span = true } +UI.prototype.resetOutput = function () { + this.rows = [] +} + UI.prototype.div = function () { if (arguments.length === 0) this.div('') if (this.wrap && this._shouldApplyLayoutDSL.apply(this, arguments)) { @@ -209,7 +213,7 @@ UI.prototype._rasterize = function (row) { row.forEach(function (col, c) { // leave room for left and right padding. col.width = widths[c] - if (_this.wrap) wrapped = wrap(col.text, _this._negatePadding(col), {hard: true}).split('\n') + if (_this.wrap) wrapped = wrap(col.text, _this._negatePadding(col), { hard: true }).split('\n') else wrapped = col.text.split('\n') if (col.border) { diff --git a/test/cliui.js b/test/cliui.js index 76ae366..a7e3d82 100644 --- a/test/cliui.js +++ b/test/cliui.js @@ -10,6 +10,15 @@ var cliui = require('../') var stripAnsi = require('strip-ansi') describe('cliui', function () { + describe('resetOutput', function () { + it('should set lines to empty', function () { + var ui = cliui() + ui.div('i am a value that would be in a line') + ui.resetOutput() + ui.toString().length.should.be.equal(0) + }) + }) + describe('div', function () { it("wraps text at 'width' if a single column is given", function () { var ui = cliui({ @@ -29,7 +38,7 @@ describe('cliui', function () { }) ui.div( - {text: 'i am a string that should be wrapped', width: 15}, + { text: 'i am a string that should be wrapped', width: 15 }, 'i am a second string that should be wrapped', 'i am a third string that should be wrapped' ) @@ -82,7 +91,7 @@ describe('cliui', function () { var ui = cliui({ width: 40 }) - var widths = ui._columnWidths([{width: 20}, {}, {}]) + var widths = ui._columnWidths([{ width: 20 }, {}, {}]) widths[0].should.equal(20) widths[1].should.equal(10) @@ -93,7 +102,7 @@ describe('cliui', function () { var ui = cliui({ width: 40 }) - var widths = ui._columnWidths([{}, {width: 10}, {}]) + var widths = ui._columnWidths([{}, { width: 10 }, {}]) widths[0].should.equal(15) widths[1].should.equal(10) @@ -104,7 +113,7 @@ describe('cliui', function () { var ui = cliui({ width: 40 }) - var widths = ui._columnWidths([{width: 20}, {width: 12}, {}]) + var widths = ui._columnWidths([{ width: 20 }, { width: 12 }, {}]) widths[0].should.equal(20) widths[1].should.equal(12) @@ -115,7 +124,7 @@ describe('cliui', function () { var ui = cliui({ width: 40 }) - var widths = ui._columnWidths([{width: 30}, {width: 30}, {padding: [0, 2, 0, 1]}]) + var widths = ui._columnWidths([{ width: 30 }, { width: 30 }, { padding: [0, 2, 0, 1] }]) widths[0].should.equal(30) widths[1].should.equal(30) @@ -131,7 +140,7 @@ describe('cliui', function () { ui.div( 'i am a string', - {text: 'i am a second string', align: 'right'}, + { text: 'i am a second string', align: 'right' }, 'i am a third string that should be wrapped' ) @@ -153,7 +162,7 @@ describe('cliui', function () { ui.div( 'i am a string', - {text: 'i am a second string', align: 'center', padding: [0, 2, 0, 2]}, + { text: 'i am a second string', align: 'center', padding: [0, 2, 0, 2] }, 'i am a third string that should be wrapped' ) @@ -175,9 +184,9 @@ describe('cliui', function () { }) ui.div( - {text: 'i have padding on my left', padding: [0, 0, 0, 4]}, - {text: 'i have padding on my right', padding: [0, 2, 0, 0], align: 'center'}, - {text: 'i have no padding', padding: [0, 0, 0, 0]} + { text: 'i have padding on my left', padding: [0, 0, 0, 4] }, + { text: 'i have padding on my right', padding: [0, 2, 0, 0], align: 'center' }, + { text: 'i have no padding', padding: [0, 0, 0, 0] } ) // it should add left/right padding to columns. @@ -198,8 +207,8 @@ describe('cliui', function () { ui.div( 'i am a string', - {text: 'i am a second string', padding: [2, 0, 0, 0]}, - {text: 'i am a third string that should be wrapped', padding: [0, 0, 1, 0]} + { text: 'i am a second string', padding: [2, 0, 0, 0] }, + { text: 'i am a third string that should be wrapped', padding: [0, 0, 1, 0] } ) // it should add top/bottom padding to second @@ -239,8 +248,8 @@ describe('cliui', function () { }) ui.div( - {text: 'i am a first string', padding: [0, 0, 0, 0], border: true}, - {text: 'i am a second string', padding: [1, 0, 0, 0], border: true} + { text: 'i am a first string', padding: [0, 0, 0, 0], border: true }, + { text: 'i am a second string', padding: [1, 0, 0, 0], border: true } ) var expected = [ @@ -262,9 +271,9 @@ describe('cliui', function () { }) ui.div( - {text: 'i am a string', padding: [0, 1, 0, 0]}, - {text: 'i am a second string', padding: [0, 2, 0, 0]}, - {text: 'i am a third string that should not be wrapped', padding: [0, 0, 0, 2]} + { text: 'i am a string', padding: [0, 1, 0, 0] }, + { text: 'i am a second string', padding: [0, 2, 0, 0] }, + { text: 'i am a third string that should not be wrapped', padding: [0, 0, 0, 2] } ) ui.toString().should.equal('i am a string i am a second string i am a third string that should not be wrapped') @@ -278,11 +287,11 @@ describe('cliui', function () { }) ui.span( - {text: 'i am a string that will be wrapped', width: 30} + { text: 'i am a string that will be wrapped', width: 30 } ) ui.div( - {text: ' [required] [default: 99]', align: 'right'} + { text: ' [required] [default: 99]', align: 'right' } ) var expected = [ @@ -299,11 +308,11 @@ describe('cliui', function () { }) ui.span( - {text: 'i am a string that will be wrapped', width: 30} + { text: 'i am a string that will be wrapped', width: 30 } ) ui.div( - {text: 'i am a second row', align: 'left'} + { text: 'i am a second row', align: 'left' } ) var expected = [ @@ -322,11 +331,11 @@ describe('cliui', function () { }) ui.span( - {text: 'i am a string that will be wrapped', width: 30} + { text: 'i am a string that will be wrapped', width: 30 } ) ui.div( - {text: 'i am a second row', align: 'left', padding: [0, 0, 0, 3]} + { text: 'i am a second row', align: 'left', padding: [0, 0, 0, 3] } ) ui.div('a third line') @@ -345,11 +354,11 @@ describe('cliui', function () { }) ui.span( - {text: chalk.green('i am a string that will be wrapped'), width: 30} + { text: chalk.green('i am a string that will be wrapped'), width: 30 } ) ui.div( - {text: chalk.blue(' [required] [default: 99]'), align: 'right'} + { text: chalk.blue(' [required] [default: 99]'), align: 'right' } ) var expected = [