# progress

Flexible ascii progress bar.

### Installation

```bash
$ npm install progress
```

### Usage

First we create a `ProgressBar`, giving it a format string as well as the `total`, telling the progress bar when it will be considered complete. After that all we need to do is `tick()` appropriately.

```javascript
var ProgressBar = require('progress');

var bar = new ProgressBar(':bar', { total: 10 });
var timer = setInterval(function () {
  bar.tick();
  if (bar.complete) {
    console.log('\ncomplete\n');
    clearInterval(timer);
  }
}, 100);
```

#### Options

These are keys in the options object you can pass to the progress bar along with `total` as seen in the example above.

* `curr` current completed index
* `total` total number of ticks to complete
* `width` the displayed width of the progress bar defaulting to total
* `stream` the output stream defaulting to stderr
* `head` head character defaulting to complete character
* `complete` completion character defaulting to "="
* `incomplete` incomplete character defaulting to "-"
* `renderThrottle` minimum time between updates in milliseconds defaulting to 16
* `clear` option to clear the bar on completion defaulting to false
* `callback` optional function to call when the progress bar completes

#### Tokens

These are tokens you can use in the format of your progress bar.

* `:bar` the progress bar itself
* `:current` current tick number
* `:total` total ticks
* `:elapsed` time elapsed in seconds
* `:percent` completion percentage
* `:eta` estimated completion time in seconds
* `:rate` rate of ticks per second

#### Custom Tokens

You can define custom tokens by adding a `{'name': value}` object parameter to your method (`tick()`, `update()`, etc.) calls.

```javascript
var bar = new ProgressBar(':current: :token1 :token2', { total: 3 })
bar.tick({
  'token1': "Hello",
  'token2': "World!\n"
})
bar.tick(2, {
  'token1': "Goodbye",
  'token2': "World!"
})
```

The above example would result in the output below.

```
1: Hello World!
3: Goodbye World!
```

### Examples

#### Download

In our download example each tick has a variable influence, so we pass the chunk length which adjusts the progress bar appropriately relative to the total length.

```javascript
var ProgressBar = require('progress');
var https = require('https');

var req = https.request({
  host: 'download.github.com',
  port: 443,
  path: '/visionmedia-node-jscoverage-0d4608a.zip'
});

req.on('response', function(res){
  var len = parseInt(res.headers['content-length'], 10);

  console.log();
  var bar = new ProgressBar('  downloading [:bar] :rate/bps :percent :etas', {
    complete: '=',
    incomplete: ' ',
    width: 20,
    total: len
  });

  res.on('data', function (chunk) {
    bar.tick(chunk.length);
  });

  res.on('end', function () {
    console.log('\n');
  });
});

req.end();
```

The above example result in a progress bar like the one below.

```
downloading [=====             ] 39/bps 29% 3.7s
```

#### Interrupt

To display a message during progress bar execution, use `interrupt()`

```javascript
var ProgressBar = require('progress');

var bar = new ProgressBar(':bar :current/:total', { total: 10 });
var timer = setInterval(function () {
  bar.tick();
  if (bar.complete) {
    clearInterval(timer);
  } else if (bar.curr === 5) {
      bar.interrupt('this message appears above the progress bar\ncurrent progress is ' + bar.curr + '/' + bar.total);
  }
}, 1000);
```

You can see more examples in the `examples` folder.

### License

MIT
