2013-07-18 17:56:05 -05:00
var blessed = require ( '../' )
2013-07-28 14:29:07 -05:00
, screen ;
screen = blessed . screen ( {
2015-01-29 20:08:23 -08:00
dump : _ _dirname + '/logs/widget.log' ,
2015-03-14 16:35:17 -07:00
title : 'widget test' ,
2015-03-19 23:49:26 -07:00
resizeTimeout : 300 ,
cursor : {
artificial : true ,
shape : 'line' ,
blink : true ,
color : null
2015-03-31 02:25:18 -07:00
} ,
debug : true
2013-07-28 14:29:07 -05:00
} ) ;
2013-07-03 23:15:09 -05:00
2015-04-01 19:46:08 -07:00
screen . _debugLog . parseTags = true ;
require ( './tail' ) ( _ _dirname + '/logs/widget.log' ) . on ( 'line' , function ( line ) {
if ( ! screen . _debugLog . hidden ) return ;
screen . debug ( line ) ;
} ) ;
2015-03-31 02:25:18 -07:00
2013-07-18 17:56:05 -05:00
screen . append ( blessed . text ( {
2013-06-06 04:03:25 -05:00
top : 0 ,
left : 2 ,
2013-06-13 04:14:14 -05:00
width : '100%' ,
2013-06-16 04:21:57 -05:00
//bg: 'blue',
content : '{green-fg}Welcome{/green-fg} to my {red-fg,ul}program{/red-fg,ul}' ,
2013-07-14 06:57:15 -05:00
bg : '#0000ff' ,
2013-07-23 05:04:04 -05:00
// bg: blessed.colors.match('#0000ff'),
2013-06-13 20:21:41 -05:00
tags : true ,
2013-06-13 04:14:14 -05:00
align : 'center'
2013-06-06 04:03:25 -05:00
} ) ) ;
2013-07-18 17:56:05 -05:00
screen . append ( blessed . line ( {
2013-06-06 04:03:25 -05:00
orientation : 'horizontal' ,
top : 1 ,
left : 0 ,
right : 0
} ) ) ;
2013-07-18 17:56:05 -05:00
var list = blessed . list ( {
2013-06-13 04:14:14 -05:00
align : 'center' ,
2013-06-06 05:39:44 -05:00
mouse : true ,
2013-06-13 02:16:32 -05:00
fg : 'blue' ,
bg : 'default' ,
2015-02-26 15:37:01 -08:00
label : ' My list ' ,
2013-06-01 02:06:04 -05:00
border : {
type : 'ascii' ,
2013-06-13 02:16:32 -05:00
fg : 'default' ,
bg : 'default'
2013-06-01 02:06:04 -05:00
} ,
width : '50%' ,
height : '50%' ,
top : 'center' ,
left : 'center' ,
2013-06-13 02:16:32 -05:00
selectedBg : 'green' ,
2013-06-01 02:06:04 -05:00
items : [
2013-06-02 22:29:26 -05:00
'one' ,
'two' ,
'three' ,
'four' ,
'five' ,
'six' ,
'seven' ,
'eight' ,
'nine' ,
'ten'
2013-07-19 01:57:17 -05:00
] ,
scrollbar : {
ch : ' ' ,
2013-07-27 06:58:50 -05:00
track : {
bg : 'yellow'
} ,
style : {
inverse : true
}
2013-07-19 01:57:17 -05:00
}
2013-06-06 04:03:25 -05:00
} ) ;
2013-06-01 02:06:04 -05:00
2013-06-06 04:03:25 -05:00
screen . append ( list ) ;
2013-06-09 08:33:23 -05:00
list . select ( 0 ) ;
2013-06-06 04:03:25 -05:00
2015-02-13 01:18:20 -08:00
list . items . forEach ( function ( item ) {
item . setHover ( item . getText ( ) . trim ( ) ) ;
} ) ;
2013-06-06 04:03:25 -05:00
list . on ( 'keypress' , function ( ch , key ) {
2013-06-09 08:33:23 -05:00
if ( key . name === 'up' || key . name === 'k' ) {
2013-06-06 04:03:25 -05:00
list . up ( ) ;
2013-06-01 05:47:18 -05:00
screen . render ( ) ;
return ;
2013-06-09 08:33:23 -05:00
} else if ( key . name === 'down' || key . name === 'j' ) {
2013-06-06 04:03:25 -05:00
list . down ( ) ;
2013-06-01 05:47:18 -05:00
screen . render ( ) ;
return ;
}
2013-06-06 04:03:25 -05:00
} ) ;
2015-02-26 15:37:01 -08:00
list . on ( 'select' , function ( item , select ) {
list . setLabel ( ' ' + item . getText ( ) + ' ' ) ;
screen . render ( ) ;
} ) ;
2013-07-18 17:56:05 -05:00
var progress = blessed . progressbar ( {
2013-06-13 02:16:32 -05:00
fg : 'blue' ,
bg : 'default' ,
barBg : 'default' ,
barFg : 'blue' ,
2013-06-06 04:03:25 -05:00
border : {
type : 'ascii' ,
2013-06-13 02:16:32 -05:00
fg : 'default' ,
bg : 'default'
2013-06-06 04:03:25 -05:00
} ,
ch : ':' ,
2013-06-12 04:18:47 -05:00
//orientation: 'vertical',
//height: 10,
//width: 3,
2013-06-06 04:03:25 -05:00
width : '50%' ,
height : 3 ,
right : 0 ,
bottom : 0 ,
filled : 50
} ) ;
screen . append ( progress ) ;
2013-06-06 07:57:50 -05:00
var lorem = 'Lorem ipsum \x1b[41mdolor sit amet, \nconsectetur adipisicing elit, \x1b[43msed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.' ;
2013-06-06 04:03:25 -05:00
2013-06-09 20:41:25 -05:00
var lorem = require ( 'fs' ) . readFileSync ( _ _dirname + '/git.diff' , 'utf8' ) ;
2013-06-06 09:24:03 -05:00
2013-06-09 08:33:23 -05:00
//lorem = lorem.replace(/\x1b[^m]*m/g, '');
2013-07-18 17:56:05 -05:00
var stext = blessed . scrollabletext ( {
2013-06-13 19:02:02 -05:00
//padding: 1,
2013-06-06 05:39:44 -05:00
mouse : true ,
2013-06-06 04:03:25 -05:00
content : lorem ,
2013-06-13 02:16:32 -05:00
fg : 'blue' ,
2013-07-28 10:52:13 -05:00
bg : 'black' ,
2013-06-06 04:03:25 -05:00
border : {
type : 'ascii' ,
2013-06-13 02:16:32 -05:00
fg : 'default' ,
bg : 'default'
2013-06-06 04:03:25 -05:00
} ,
width : '50%' ,
2013-06-06 09:24:03 -05:00
//height: 4,
height : 6 ,
2013-06-06 04:03:25 -05:00
left : 0 ,
2013-07-21 05:31:24 -05:00
bottom : 0 ,
scrollbar : {
inverse : true
}
2013-06-06 04:03:25 -05:00
} ) ;
screen . append ( stext ) ;
stext . on ( 'keypress' , function ( ch , key ) {
2013-06-09 08:33:23 -05:00
if ( key . name === 'up' || key . name === 'k' ) {
2013-06-06 04:03:25 -05:00
stext . scroll ( - 1 ) ;
screen . render ( ) ;
return ;
2013-06-09 08:33:23 -05:00
} else if ( key . name === 'down' || key . name === 'j' ) {
2013-06-06 04:03:25 -05:00
stext . scroll ( 1 ) ;
screen . render ( ) ;
return ;
}
} ) ;
2013-07-31 19:52:25 -05:00
screen . on ( 'element focus' , function ( cur , old ) {
2013-07-16 17:50:02 -05:00
if ( old . border ) old . style . border . fg = 'default' ;
if ( cur . border ) cur . style . border . fg = 'green' ;
2013-06-06 04:03:25 -05:00
screen . render ( ) ;
} ) ;
2013-07-18 17:56:05 -05:00
var input = blessed . textbox ( {
2013-06-09 15:02:12 -05:00
label : ' My Input ' ,
2013-06-09 13:14:42 -05:00
content : '' ,
2013-06-13 02:16:32 -05:00
fg : 'blue' ,
bg : 'default' ,
barBg : 'default' ,
barFg : 'blue' ,
2013-06-09 13:14:42 -05:00
border : {
type : 'ascii' ,
2013-06-13 02:16:32 -05:00
fg : 'default' ,
bg : 'default'
2013-06-09 13:14:42 -05:00
} ,
width : '30%' ,
height : 3 ,
right : 0 ,
2013-07-29 15:49:25 -05:00
top : 2 ,
keys : true ,
vi : true ,
mouse : true
//inputOnFocus: true
2013-06-09 13:14:42 -05:00
} ) ;
2013-07-29 15:49:25 -05:00
input . on ( 'submit' , function ( value ) {
if ( value ) screen . children [ 0 ] . setContent ( value ) ;
2013-07-18 22:49:06 -05:00
input . clearInput ( ) ;
2013-07-29 15:49:25 -05:00
screen . render ( ) ;
2013-07-18 22:49:06 -05:00
} ) ;
2013-06-09 13:14:42 -05:00
screen . append ( input ) ;
2013-07-31 19:21:10 -05:00
var button = blessed . button ( {
2013-06-16 04:21:57 -05:00
//content: 'Click me!',
content : 'Click\nme!' ,
shrink : true ,
2013-07-31 19:21:10 -05:00
mouse : true ,
2013-06-16 04:21:57 -05:00
border : {
type : 'ascii'
} ,
fg : 'red' ,
bg : 'blue' ,
//height: 3,
right : 4 ,
//bottom: 6,
bottom : 2 ,
padding : 0
} ) ;
button . on ( 'press' , function ( ) {
button . setContent ( 'Clicked!' ) ;
2013-07-29 15:49:25 -05:00
screen . render ( ) ;
2013-06-16 04:21:57 -05:00
} ) ;
screen . append ( button ) ;
2013-06-09 13:14:42 -05:00
screen . on ( 'keypress' , function ( ch , key ) {
2013-06-06 04:03:25 -05:00
if ( key . name === 'tab' ) {
return key . shift
2013-07-29 15:49:25 -05:00
? screen . focusPrevious ( )
2013-06-06 04:03:25 -05:00
: screen . focusNext ( ) ;
}
2013-06-01 00:29:31 -05:00
if ( key . name === 'escape' || key . name === 'q' ) {
2013-06-01 02:06:04 -05:00
return process . exit ( 0 ) ;
2013-06-01 00:29:31 -05:00
}
} ) ;
2013-07-14 10:06:28 -05:00
screen . key ( 'C-z' , function ( ) {
screen . sigtstp ( ) ;
} ) ;
2013-06-06 04:03:25 -05:00
list . focus ( ) ;
2013-06-01 00:29:31 -05:00
screen . render ( ) ;
2013-06-06 04:03:25 -05:00
2013-06-06 05:38:30 -05:00
setInterval ( function ( ) {
2013-06-09 15:21:58 -05:00
progress . toggle ( ) ;
2013-06-09 11:47:02 -05:00
screen . render ( ) ;
2013-06-09 15:21:58 -05:00
} , 2000 ) ;
2013-06-06 05:38:30 -05:00
2013-06-06 04:03:25 -05:00
( function fill ( ) {
2013-06-09 14:32:29 -05:00
if ( progress . filled === 100 ) {
progress . reset ( ) ;
}
2013-06-06 04:03:25 -05:00
progress . progress ( 2 ) ;
screen . render ( ) ;
setTimeout ( fill , 300 ) ;
2015-03-29 04:17:59 -07:00
progress . atop -= 2 ;
2013-06-06 04:03:25 -05:00
} ) ( ) ;