tiny-timer
Version:
Small countdown timer and stopwatch module.
73 lines (51 loc) • 1.91 kB
Markdown
# tiny-timer
[](https://npm.im/tiny-timer)
[](https://travis-ci.com/mathiasvr/tiny-timer)

[](https://david-dm.org/mathiasvr/tiny-timer)
[](https://mvr.mit-license.org)
Small countdown timer and stopwatch module.
## Installation
npm:
```shell
$ npm install tiny-timer
```
Yarn:
```shell
$ yarn add tiny-timer
```
## Example
```javascript
const Timer = require('tiny-timer')
const timer = new Timer()
timer.on('tick', (ms) => console.log('tick', ms))
timer.on('done', () => console.log('done!'))
timer.on('statusChanged', (status) => console.log('status:', status))
timer.start(5000) // run for 5 seconds
```
## Usage
### `timer = new Timer({ interval: 1000, stopwatch: false })`
Optionally set the refresh `interval` in ms, or `stopwatch` mode instead of countdown.
### `timer.start(duration [, interval])` {
Starts timer running for a `duration` specified in ms.
Optionally override the default refresh `interval` in ms.
### `timer.stop()`
Stops timer.
### `timer.pause()`
Pauses timer.
### `timer.resume()`
Resumes timer.
## Events
### `timer.on('tick', (ms) => {})`
Event emitted every `interval` with the current time in ms.
### `timer.on('done', () => {})`
Event emitted when the timer reaches the `duration` set by calling `timer.start()`.
### `timer.on('statusChanged', (status) => {})`
Event emitted when the timer status changes.
## Properties
### `timer.time`
Gets the current time in ms.
### `timer.duration`
Gets the total `duration` the timer is running for in ms.
### `timer.status`
Gets the current status of the timer as a string: `running`, `paused` or `stopped`.