Skip to content

pejalo/top-of-second-ticker

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 

Repository files navigation

top-of-second-ticker

Schedule your callback function to be run every second, close to when the system clock changes.

This relies on the setTimeout() global function.

Install

npm install top-of-second-ticker --save

Summary

This package exposes a single class with five methods: start(callback), pause(), resume(), stop(), getIsRunning().

Example

import TopOfSecondTicker from 'top-of-second-ticker'

const ticker = new TopOfSecondTicker()

// start immediately
ticker.start((scheduledDate) => {
    console.log('ran', schdeuledDate)
})

// stop after ten seconds
setTimeout(ticker.stop, 10 * 1000)

// pause when the browser becomes inactive
document.addEventListener('visibilitychange', (_) => {
    if (document.visibilityState === 'visible')
        ticker.resume()
    else
        ticker.pause()
})

Guide

  • Constructor takes no arguments.

  • .start(callback, shouldExecuteCallbackImmediately = true)

    callback is your function to be executed repeatedly. It will be passed one argument: a Date object for when this class intended to execute the callback (at the top of the second). Thus, the date's .valueOf() (in milliseconds) will be divisible by 1000. If shouldExecuteCallbackImmediately is true (the default, see explanation below), the first time callback is executed, its date will be undefined.

    Note: The actual exact time that callback is executed will be some number of milliseconds after the intended Date. If your code runs smoothly, this delay should be imperceptible to the user. For reference, see setTimeout()'s Reasons for delays longer than specified

    If shouldExecuteCallbackImmediately is false, callback will not be executed until the top of the next second.

    If .start(...) is called multiple times on the same ticker instance, the previous callbacks are forgotten. Only the most recent callback will continue to execute repeatedly.

  • .pause() takes no arguments.

    When paused, the most recent callback is still remembered, so you can easily call .resume() again to continue execution.

  • .resume(shouldExecuteCallbackImmediately = true)

    shouldExecuteCallbackImmediately behaves just like the argument to .start(...) above.

    This returns true if a callback was still remembered and either just executed (immediately), or will execute at the top of the next second.

  • .stop() takes no arguments.

    Once stopped, the callback is forgotten, and resume() has no effect (until you call .start(...) again).

  • .getIsRunning() will return false if stopped or paused.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published