The Node.js TTY module contains tty.ReadStream and tty.WriteStream classes. In most cases, there is no need to use this module directly.
You have to use require ('tty') to access this module.
Syntax:
var tty = require('tty');
When Node.js discovers that it is being run inside a TTY context, then:
To check that if Node.js is running in a TTY context, use the following command:
node -p -e "Boolean(process.stdout.isTTY)"
It contains a net.Socket subclass that represents the readable portion of a tty. In normal circumstances,the tty.ReadStream has the only instance named process.stdin in any Node.js program (only when isatty(0) is true).
rs.isRaw: It is a Boolean that is initialized to false. It specifies the current "raw" state of the tty.ReadStream instance.
rs.setRawMode(mode): It should be true or false. It is used to set the properties of the tty.ReadStream to act either as a raw device or default. isRaw will be set to the resulting mode.
It contains a net.Socket subclass that represents the writable portion of a tty. In normal circumstances, the tty.WriteStream has the only instance named process.stdout in any Node.js program (only when isatty(1) is true).
Resize event: This event is used when either of the columns or rows properties has changed.
Syntax:
process.stdout.on('resize', () => { console.log('screen size has changed!'); console.log(`${process.stdout.columns}x${process.stdout.rows}`); });
ws.columns: It is used to give the number of columns the TTY currently has. This property gets updated on 'resize' events.
ws.rows: It is used to give the number of rows the TTY currently has. This property gets updated on 'resize' events.
File: tty.js
var tty = require('tty'); process.stdin.setRawMode(true); process.stdin.resume(); console.log('I am leaving now'); process.stdin.on('keypress', function(char, key) { if (key && key.ctrl && key.name == 'c') { process.exit() } });
Output: