Server IP : 185.86.78.101 / Your IP : 216.73.216.124 Web Server : Apache System : Linux 675867-vds-valikoshka1996.gmhost.pp.ua 5.4.0-150-generic #167-Ubuntu SMP Mon May 15 17:35:05 UTC 2023 x86_64 User : www ( 1000) PHP Version : 7.4.33 Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : OFF Directory : /www/wwwroot/mifepriston.org/node_modules/progress/ |
Upload File : |
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