moondial
v0.1.4
Published
A tiny stopwatch, chronometer, and countdown timer library with millisecond precision built in TypeScript
Downloads
19
Maintainers
Readme
Moondial Timer
A tiny stopwatch, chronometer, and countdown timer library with millisecond precision built in TypeScript. Support for state change events implemented via RxJs. Use it in the browser or NodeJs.
See the docs for live examples of the library in action: http://moondial.siliconcosmos.com
Project Setup
Build the project:
> npm run build
# OR
> npm run watch
Run a demo of the project with:
> npm run demo
This demo is equivalent to the live demo in the docs.
Usage
Install the Library
> npm install moondial
Import the Library
ES Modules:
import { Clock, Duration } from "moondial.js";
Require statement:
var { Clock, Duration } = require("moondial.js");
Quickstart Example
Setup a new clock with some basic configuration.
let c = new Clock({
mode: 'countdown',
initial: Duration.of(20, 'seconds')
});
This creates a new countdown clock with an inital time of 20 seconds. If we set no configuration the mode would default to 'stopwatch' and initial time would default to 0 seconds.
We can start the clock...
c.start();
pause the clock...
c.pause();
and stop the clock. Stopping the clock will cause it to revert to initial on next start.
c.stop();
We can also reconfigure the clock later.
c.configure({
mode: 'countdown',
initial: Duration.of(10, 'minutes'),
interval: Duration.of(100, 'milliseconds')
});
The update interval would otherwise default to 500ms.
When the clock is running (or any other phase, really) we can fetch the state.
const cState = c.state;
// Which returns:
{
phase: 'running',
time: {} //some Duration object
}
We can access the time in a particular unit.
cState.time.as('milliseconds'); // e.g. 9845
OR convert the time to a nice clock style string
import { Clockify } from "moondial.js";
Clockify.duration(cState.time, ['hours', 'minutes', 'seconds']);
// Which returns:
// 00:09:57
The units are not mandatory and would default to ['minutes', 'seconds']
. We can also clockify other things.
// all Duration params are optional
Clockify.durationParams({ days: 1, hours: 3, minutes: 30, seconds: 10, milliseconds: 0 });
// optional separator character results in - 04;40
Clockify.seconds(280, [['minutes', 'seconds'], ';']);
// 00:10
Clockify.milliseconds(10000);
OR we could subscribe to clock updated events and do any of these things in the callback.
c.events.subscribe('updated', (state:ClockState) => {
console.log(state.phase);
console.log(state.time.as('milliseconds'));
console.log(Clockify.duration(state.time));
});
The library also contains typescript definitions with doc comments for editors which support hinting.
See the docs for more examples and API details: http://moondial.siliconcosmos.com