Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rafaelrinaldi/loading-indicator
:vertical_traffic_light: Simple and customizable command line loading indicator
https://github.com/rafaelrinaldi/loading-indicator
cli emoji indicator loading spinner
Last synced: 2 months ago
JSON representation
:vertical_traffic_light: Simple and customizable command line loading indicator
- Host: GitHub
- URL: https://github.com/rafaelrinaldi/loading-indicator
- Owner: rafaelrinaldi
- License: mit
- Created: 2015-08-04T23:53:33.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2017-10-27T05:31:45.000Z (about 7 years ago)
- Last Synced: 2024-10-26T13:26:05.370Z (3 months ago)
- Topics: cli, emoji, indicator, loading, spinner
- Language: JavaScript
- Homepage:
- Size: 124 KB
- Stars: 19
- Watchers: 3
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# loading-indicator [![Build Status](https://semaphoreci.com/api/v1/projects/aa124d8d-865f-4a05-ac30-1b47c246ddbe/681927/badge.svg)](https://semaphoreci.com/rafaelrinaldi/loading-indicator)
> Simple and customizable command line loading indicator
## Install
**Warning: `v2.0.0` is a complete rewrite of the previous implementation.**
```sh
$ npm install loading-indicator --save
```## Usage
```js
import loading from 'loading-indicator';// Initialize the loading animation and saves the timer id
const timer = loading.start();// 1500ms later, stop the loading animation passing along the timer id
setTimeout(() => {
loading.stop(timer);
}, 1500);
```![demo-default](./demo-default.gif)
### Presets
```js
import loading from 'loading-indicator';
// Import available presets
import presets from 'loading-indicator/presets';// Use an available preset (or simply provides an array with your custom preset)
const timer = loading.start(null, {
frames: presets.arrows
});
```![demo-presets](./demo-presets.gif)
### Custom text
```js
import loading from 'loading-indicator';// Setup a custom loading text
const timer = loading.start('Loading...');
```![demo-custom-text](./demo-custom-text.gif)
## API
## `loading.start([text], [options])`
Returns a `number` with the id that is used to reset the render interval (later referenced as _timer_).
### `text`
Type: `string`
Default: `null`Text do append to the indicator symbol.
### `options`
Type: `object`
Available options.
#### `options.delay`
Type: `number` _(milliseconds)_
Default: `100`Delay for the render to be triggered.
#### `options.frames`
Type: `array`
Default: [`presets.spinner`](./presets.js#L2)Frames for the loading animation sequence.
Available presets are:
* [`spinner`](./presets.js#L2) (default)
* [`circle`](./presets.js#3)
* [`dots`](./presets.js#4)
* [`bullets`](./presets.js#5)
* [`arrows`](./presets.js#11)
* [`clock`](./presets.js#19)## `loading.stop(timer, [shouldKeepOutput])`
### `timer`
_Required_
Type: `number` _(integer)_Id of the render function interval.
### `shouldKeepOutput`
Type: `boolean`
Default: `false`Whether or not to keep the output when `loading.stop()` is called.
## License
MIT :copyright: [Rafael Rinaldi](http://rinaldi.io)