window-size
Version:
Reliable way to get the height and width of terminal/console, since it's not calculated or updated the same way on all platforms, environments and node.js versions.
166 lines (106 loc) • 6 kB
Markdown
# window-size [](https://www.npmjs.com/package/window-size) [](https://npmjs.org/package/window-size) [](https://npmjs.org/package/window-size) [](https://travis-ci.org/jonschlinkert/window-size) [](https://ci.appveyor.com/project/jonschlinkert/window-size)
> Reliable way to get the height and width of terminal/console, since it's not calculated or updated the same way on all platforms, environments and node.js versions.
## Install
Install with [npm](https://www.npmjs.com/):
```sh
$ npm install --save window-size
```
## Usage
```js
var size = require('window-size');
```
## CLI
```sh
$ window-size
# height: 40
# width : 145
```
## API
### windowSize
The main export is either an object with `width` and `height` properties, or `undefined` if unable to get width and height.
```js
var size = require('window-size');
console.log(size);
//=> {width: 80, height: 25}
```
### .get
Calls the main function to get the up-to-date window size.
```js
console.log(size.get());
//=> {width: 80, height: 25}
```
**Example**
See [example.js](example.js) for the code used in the below gif.
```js
process.stdout.on('resize', function() {
console.log(size.get());
});
```

**HEADS UP!**
Note that some platforms only provide the initial terminal size, not the actual size after it has been resized by the user.
### .env
Get `process.env.COLUMNS` and `process.env.ROWS`, if defined. Called by the main function if for some reason size was not available from `process.stdout` and `process.stderr`.
```js
console.log(size.env());
```
### .tty
Attempts to get the size from `tty`. Called by the main function if for some reason size was not available from `process.stdout`, `process.stderr` or `process.env`.
```js
console.log(size.tty());
```
### .win
Get the terminal size in Windows 10+.
```js
console.log(size.win());
```
Note that this method calls [execSync](https://nodejs.org/api/child_process.html#child_process_child_process_execsync_command_options) to get the size, and must be called directly, as it **is not** called by the main function.
### .tput
Get the terminal size by calling the unix `$ tput` command.
```js
console.log(size.tput());
```
Note that this method calls [execSync](https://nodejs.org/api/child_process.html#child_process_child_process_execsync_command_options) to get the size, and must be called directly, as it **is not** called by the main function.
### utils
In some environments the main export may not be able to find a window size using the default methods. In this case, `size` will be `undefined` and the functions will not be exported.
Because of this, the functions have been exported in a separate file and can be required directly.
```js
var utils = require('window-size/utils');
console.log(utils.win());
```
## About
### Related projects
* [base-cli](https://www.npmjs.com/package/base-cli): Plugin for base-methods that maps built-in methods to CLI args (also supports methods from a… [more](https://github.com/node-base/base-cli) | [homepage](https://github.com/node-base/base-cli "Plugin for base-methods that maps built-in methods to CLI args (also supports methods from a few plugins, like 'base-store', 'base-options' and 'base-data'.")
* [lint-deps](https://www.npmjs.com/package/lint-deps): CLI tool that tells you when dependencies are missing from package.json and offers you a… [more](https://github.com/jonschlinkert/lint-deps) | [homepage](https://github.com/jonschlinkert/lint-deps "CLI tool that tells you when dependencies are missing from package.json and offers you a choice to install them. Also tells you when dependencies are listed in package.json but are not being used anywhere in your project. Node.js command line tool and API")
* [yargs](https://www.npmjs.com/package/yargs): yargs the modern, pirate-themed, successor to optimist. | [homepage](http://yargs.js.org/ "yargs the modern, pirate-themed, successor to optimist.")
### Contributing
Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new).
### Contributors
| **Commits** | **Contributor** |
| --- | --- |
| 23 | [jonschlinkert](https://github.com/jonschlinkert) |
| 11 | [doowb](https://github.com/doowb) |
| 4 | [bcoe](https://github.com/bcoe) |
| 3 | [icyflame](https://github.com/icyflame) |
| 2 | [derhuerst](https://github.com/derhuerst) |
| 1 | [karliky](https://github.com/karliky) |
### Building docs
_(This project's readme.md is generated by [verb](https://github.com/verbose/verb-generate-readme), please don't edit the readme directly. Any changes to the readme must be made in the [.verb.md](.verb.md) readme template.)_
To generate the readme, run the following command:
```sh
$ npm install -g verbose/verb#dev verb-generate-readme && verb
```
### Running tests
Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command:
```sh
$ npm install && npm test
```
### Author
**Jon Schlinkert**
* [github/jonschlinkert](https://github.com/jonschlinkert)
* [twitter/jonschlinkert](https://twitter.com/jonschlinkert)
### License
Copyright © 2018, [Jon Schlinkert](https://github.com/jonschlinkert).
Released under the [MIT License](LICENSE).
***
_This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.7.0, on July 27, 2018._