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

timestamp-range

v0.0.6

Published

An object representing 2 timestamps - i.e. a 'gap' in time

Downloads

16

Readme

timestamp-range

Build status

An object representing 2 timestamps - i.e. a 'gap' in time

installation

$ npm install timestamp-range

usage

Give a start and end date and get back an object with some useful functions:

var timestamprange = require('timestamp-range');

// took a coupla mins to make some tea
var make_cuppa_tea = timestamprange(
	new Date('05/12/2014 11:10:45'),
	new Date('05/12/2014 11:16:23')
)

// took a coupla years to write a book
var write_book = timestamprange(
	new Date('02/12/2012 11:10:45'),
	new Date('03/26/2014 23:46:23'),
)

// 'minute'
var tea_res = make_cuppa_tea.resolution

// the number of minutes to make some tea (float)
var tea_len = make_cuppa_tea.length

// the number of milliseconds to make some tea (int)
var tea_ms = make_cuppa_tea.ms

// 'year'
var book_res = write_book.resolution

// the number of minutes to make write a book (float)
var book_len = write_book.length

// the number of milliseconds to write a book (int)
var book_ms = write_book.ms

api

var range = timestamprange(startdate, enddate);

create a new timestamp-range.

startdate and enddate can be Dates or timestamps

// create with date objects
var range = timestamprange(
	new Date('05/12/2014 11:10:45'),
	new Date('05/12/2014 11:16:23')
)


// create with timestamps
var range = timestamprange(
	1394616600000,
	1394647200000
)

var resolution = range.resolution

get a string that describes the resolution of the range.

this is decided by if there is more than 1 of the given amount.

So - 59 seconds is resolution 'minute' and length 59

66 seconds is resolution 'minute' and length 1.1

The resolution is a string one of:

  • millisecond
  • second
  • minute
  • hour
  • day

Month and years are not consistent when it comes to length and so its best to not make things complicated and just leave them out.

var length = range.length

the float that is the number of 'resolution' in the gap.

So - a gap of 90 seconds would be resolution 'minute' and length 1.5

var ms = range.ms

the number of milliseconds in a given range

license

MIT