An i3status implementation in Node.js
const { Block, Status } = require('node-i3status');
/** An example block that shows the date every second */
class ExampleBlock extends Block {
/** The constructor */
constructor() {
super('example');
this.n = 0;
// update the block every second
setInterval(() => this.update(), 1000);
this.on('mouse-LEFT', ev => {
// can also use numbers, eg mouse-1
this.n++;
this.update();
});
}
/**
* The render function
* @return {String}
*/
render() {
return {
full_text: `${(new Date()).toString()} ${this.n}`,
color: '#ffff00'
};
}
}
let status = new Status();
let b = new ExampleBlock();
// add the block to the status
status.addBlock(b);
// bind the status display to stdin/stdout
status.outStream.pipe(process.stdout);
process.stdin.pipe(status.inStream);
// remove it after 10 seconds
setTimeout(() => status.deleteBlock(b), 10000);
In ~/.config/i3/status
:
bar {
status_command /path/to/your/script.js
}
See examples folder for examples of more complex blocks.
Represents the status display. The Status
object consists of many different
Block
objects.
Sends the text of the current blocks to i3bar
block
<string>
|<Block>
The block to render
Render a single block
Render all the blocks
block
<Block>
The block to addindex
<integer>
Where to add the block
Add a block to the status display. If index
is not specified, add the block to
the end.
block
<Block>
The block to remove
Remove a block from the status display.
Represents a part of the status display.
name
<String>
The name of the block
Create a new block. The name isn't currently used, besides to give to i3bar.
event
<Object>
A click event from i3
Emitted whenever there is input on the block, for example, if a user clicks it. See here for more information on the format which is used.
event
<Object>
A click event from i3
Emitted for a specific mouse event on the block. Both button names and button
numbers can be used. See the input
event for details and
src/mouse-buttons.json
for the names of the buttons.
Tells the status display to update the block. Will call render() to get an updated display of the contents of the block.
- Returns:
<string>
Update function. Will be called by the Status
object to obtain the latest
information provided by this block. See
here for details
about the format which should be used.
Yes.