npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

package-timer

v0.0.2

Published

Package-timer is an NPM package that provides a simple and flexible way to implement a timer functionality into your Node.js project. With this package, you can easily create, start, pause, resume, stop, restart, extend, shorten and get the remaining time

Downloads

30

Readme

package-timer

The packageTimer is a simple Node.js module that can be used to track the duration of a certain event or task. It allows you to start, pause, resume, stop, restart, extend, and shorten a timer. It also provides methods to get the remaining time and duration of the timer, as well as to check whether the timer is paused ot running.

Contents

Installation

You can install packageTimer via:


npm install package-timer

Usage

You can use packageTimer by requiring it in your Node.js application:


const packageTimer = require('package-timer')

Then, you create a new timer by calling the packageTimer function:


const timer = packageTimer()

Start

You can start the timer by calling the start method and passing in the duration of the timer in milliseconds:


timer.start(5000)

This will start timer for 5 seconds (5000 milliseconds) and emit a start event with the durution of the timer as an argument.

Pause

To pause the timer, call the pause() method:


timer.pause()

This will pause the timer and return the remaining time in milliseconds.

Resume

To resume the timer agter pausing it , call the resume() method:


timer.resume()

This will resume the timer and return the remaining time in milliseconds.

Stop

To stop the timer, call the stop() method:


timer.stop()

This will stop timer and reset all its properties.

Restart

To restart the timer, call the restart() method and pass in the duration of the timer in milliseconds:


timer.restart(10000)

This will stop the current timer (if running), reset its properties, and start a new timer for 10 seconds (10000 milliseconds).

Extend

To extend the timer, call the extend(time) method and pass in the duration you want to add to the remaining time in milliseconds:


timer.extend(5000)

This will add 5 seconds to the remaining time of the timer.

Shorten

To shorten the timer, call the shorten(time) method and pass in the duration you want to subtract from the remaining time in milliseconds:


timer.shorten(2000)

This will subtract 2 seconds (2000 milliseconds) from the remaining time of the timer.

getRemainingTime

To get the remaining time of the timer, call the getRemainingTime() method:


const remainingTime = timer.getRemainingTime()

This will return the remaining time of the timer in milliseconds.

getDuration

To get the duration of the timer, call the getDuration() method:


const duration = timer.getDuration()

This will return the duration of the timer in milliseconds.

isPaused

To check if the timer is paused, call the isPaused() method:


const paused = timer.isPaused()

This will return true if the timer is paused, and false otherwise.

isRunning

To check if the timer is running, call the isRunning() method:


const running = timer.isRunning()

This will return true if the timer is running, and false otherwise.

Events

The packageTimer object is an instance of Node.js's built-in EventEmitter class and emits the following events:

  • start(duration: number) - Emits when the timer is started. The duration parameter is the total time (in milliseconds) that the timer will run.
  • timeout - Emits when the timer has timed out.
  • pause(remainingTime: number) - Emits when the timer is paused. The remainingTime parameter is the remaining time (in milliseconds) on the timer when it was paused.
  • resume(remainingTime: number) - Emits when the timer is resumed. The remainingTime parameter is the remaining time (in milliseconds) on the timer when it was resumed.
  • stop - Emits when the timer is stopped. ..* restart(duration: number) - Emits when the timer is restarted. The duration parameter is the new total time (in milliseconds) that the timer will run.
  • extend(duration: number) - Emits when the timer is extended. The duration parameter is the new total time (in milliseconds) that the timer will run.
  • shorten(duration: number) - Emits when the timer is shortened. The duration parameter is the new total time (in milliseconds) that the timer will run.

You can listen to these events using the on, once, and off methods inherited from EventEmitter.


const packageTimer = require('package-timer')

const timer = packageTimer()

timer.on('start', (duration) => {
  console.log(`Timer started for ${duration}ms`)
})

timer.once('timeout', () => {
  console.log('Time\'s up!')
})

timer.on('pause', (remainingTime) => {
  console.log(`Timer paused with ${remainingTime}ms remaining`)
})

timer.on('resume', (remainingTime) => {
  console.log(`Timer resumed with ${remainingTime}ms remaining`)
})

timer.on('stop', () => {
  console.log('Timer stopped')
})

timer.on('restart', (duration) => {
  console.log(`Timer restarted for ${duration}ms`)
})

timer.on('extend', (duration) => {
  console.log(`Timer extended for ${duration}ms`)
})

timer.on('shorten', (duration) => {
  console.log(`Timer shortened for ${duration}ms`)
})

Examples

Here are some examples of how to use packageTimer:


const packageTimer = require('package-timer')

// Create a new timer with a duration of 5 seconds
const timer = packageTimer()

// Start the timer
timer.start(5000)

// Pause the timer after 3 seconds
setTimeout(() => {
  timer.pause()
}, 3000)

// Resume the timer after 2 seconds
setTimeout(() => {
  timer.resume()
}, 5000)

// Stop the timer after 8 seconds
setTimeout(() => {
  timer.stop()
}, 8000)

License

This package is licensed under the MIT License

Contributing

contributions are welcome! if you find a bug want to add a feature, please Open an issue

Contact

If you have any questions or comments about this package, please feel free to contract the author via email at [email protected]