2013-06-11 14:20:09 +00:00
|
|
|
var blessed = require('blessed')
|
2013-06-11 15:07:04 +00:00
|
|
|
, program = blessed()
|
|
|
|
, assert = require('assert');
|
2013-06-11 14:20:09 +00:00
|
|
|
|
2013-06-11 16:48:37 +00:00
|
|
|
// My terminal size at the time of writing these tests:
|
|
|
|
program.cols = 154;
|
|
|
|
program.rows = 19;
|
|
|
|
|
2013-06-11 14:20:09 +00:00
|
|
|
var screen = new blessed.Screen({
|
|
|
|
program: program
|
|
|
|
});
|
|
|
|
|
|
|
|
var main = new blessed.Box({
|
2013-06-11 15:07:04 +00:00
|
|
|
//width: '75%',
|
|
|
|
//height: '75%',
|
|
|
|
width: 115,
|
|
|
|
height: 14,
|
2013-06-11 14:20:09 +00:00
|
|
|
bg: 3,
|
|
|
|
top: 2,
|
|
|
|
left: 2,
|
|
|
|
content: 'Welcome to my program'
|
|
|
|
});
|
|
|
|
|
|
|
|
screen.append(main);
|
|
|
|
|
|
|
|
var inner = new blessed.Box({
|
|
|
|
width: '50%',
|
|
|
|
height: '50%',
|
2013-06-11 15:07:04 +00:00
|
|
|
//width: 57,
|
|
|
|
//height: 7,
|
2013-06-11 14:20:09 +00:00
|
|
|
bg: 4,
|
|
|
|
top: 2,
|
|
|
|
left: 2,
|
|
|
|
content: 'Hello'
|
|
|
|
});
|
|
|
|
|
|
|
|
main.append(inner);
|
|
|
|
|
|
|
|
inner.setContent(inner.content + '\n' + JSON.stringify({
|
|
|
|
left: inner.left,
|
|
|
|
right: inner.right,
|
|
|
|
top: inner.top,
|
|
|
|
bottom: inner.bottom,
|
|
|
|
width: inner.width,
|
|
|
|
height: inner.height,
|
|
|
|
rleft: inner.rleft,
|
|
|
|
rright: inner.rright,
|
|
|
|
rtop: inner.rtop,
|
|
|
|
rbottom: inner.rbottom
|
|
|
|
}));
|
|
|
|
|
2013-06-11 15:07:04 +00:00
|
|
|
assert.equal(inner.width, 57);
|
|
|
|
assert.equal(inner.height, 7);
|
|
|
|
|
|
|
|
assert.equal(inner.left, 4);
|
|
|
|
assert.equal(inner.right, 93);
|
|
|
|
assert.equal(inner.top, 4);
|
|
|
|
assert.equal(inner.bottom, 8);
|
|
|
|
|
|
|
|
assert.equal(inner.rleft, 2);
|
|
|
|
assert.equal(inner.rright, 56);
|
|
|
|
assert.equal(inner.rtop, 2);
|
|
|
|
assert.equal(inner.rbottom, 5);
|
|
|
|
|
|
|
|
// Change left to half of the parent width.
|
|
|
|
inner.rleft = '50%';
|
|
|
|
assert.equal(inner.left, 59);
|
|
|
|
|
|
|
|
// Change left to half of the screen width.
|
|
|
|
inner.left = '50%';
|
|
|
|
assert.equal(inner.left, screen.width / 2 | 0);
|
|
|
|
|
|
|
|
// Test implied height/width.
|
|
|
|
reset(inner, {
|
|
|
|
top: 5,
|
|
|
|
bottom: 5,
|
|
|
|
left: 5,
|
|
|
|
right: 5
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.equal(inner.width, 105);
|
|
|
|
assert.equal(inner.height, 4);
|
|
|
|
|
|
|
|
// Demonstrate the difference between `left: 5`, and `.left = 5` (relative vs. absolute):
|
|
|
|
inner.top = inner.bottom = inner.left = inner.right = 5;
|
|
|
|
|
|
|
|
assert.equal(inner.width, 144);
|
|
|
|
assert.equal(inner.height, 9);
|
|
|
|
|
2013-06-11 16:48:37 +00:00
|
|
|
// Test center keyword
|
|
|
|
reset(inner, {
|
|
|
|
width: '50%',
|
|
|
|
height: '50%',
|
|
|
|
left: 'center',
|
|
|
|
top: 'center'
|
|
|
|
});
|
|
|
|
|
|
|
|
assert.equal(inner.rleft, 29);
|
|
|
|
assert.equal(inner.rtop, 4);
|
|
|
|
|
2013-06-11 15:07:04 +00:00
|
|
|
// TODO: Start storing position.left, etc. as absolute?
|
|
|
|
|
2013-06-11 14:20:09 +00:00
|
|
|
screen.on('keypress', function(ch, key) {
|
|
|
|
if (key.name === 'escape' || key.name === 'q') {
|
|
|
|
return process.exit(0);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
screen.render();
|
2013-06-11 15:07:04 +00:00
|
|
|
|
|
|
|
function reset(el, pos) {
|
2013-06-11 16:48:37 +00:00
|
|
|
pos = pos || {};
|
2013-06-11 15:07:04 +00:00
|
|
|
el.position.width = el.options.width = pos.width;
|
|
|
|
el.position.height = el.options.height = pos.height;
|
|
|
|
el.position.left = el.options.left = pos.left;
|
|
|
|
el.position.right = el.options.right = pos.right;
|
|
|
|
el.position.top = el.options.top = pos.top;
|
|
|
|
el.position.bottom = el.options.bottom = pos.bottom;
|
|
|
|
}
|