Fast & easy time math and time unit conversions.
- Time since date
- Get seconds or any other time unit since
date
,datetime
,timestamp
, orunix timestamp
.
- Get seconds or any other time unit since
- Time until date
- Get seconds or other time unit until
date
,datetime
,timestamp
, orunix timestamp
.
- Get seconds or other time unit until
- Now
- Get current timestamp (now) in seconds or other time unit.
- Now (with offset)`
- Get current timestamp (now) with an offset in the past or future.
- DateTime Parsing
- Parse strings as
DateTime
strings. - Convert to any other time unit.
- Parse strings as
- Unix Timestamps
- Parse
Unix Timstamps
(seconds) & convert to other time units. - Convert
DateTime
strings toUnix Timestamp
.
- Parse
- TypeScript Native
- All types included with package.
- No separate
@types
package eliminates sync issues between types and the library.
- Minimalist
- Small set of library functions for time calculations.
- Get what you need without extra bloat.
- Lightweight
253 kB
unpacked.
- Modern Alternative
- Modern replacement for the excellent
moment.js
(no longer maintained).
- Modern replacement for the excellent
- Tree-Shaking
- Package optimizations helps modern bundlers drop unused code.
@toreda/time
is available as an NPM package.
yarn add @toreda/time
npm install @toreda/time
@toreda/time
source files can be downloaded directly from the public Github repo.
master
branch- Latest release & stable code.
- Use for production builds.
develop
branch- All completed but unreleased features pending release.
- Generally stable, but not guaranteed.
- Not suitable for production builds.
git@github.com:toreda/time.git
https://github.com/toreda/time.git
Download the current master branch as a zip file
https://github.com/toreda/time/archive/refs/heads/master.zip
Create Time object
import type {Time} from '@toreda/time';
import {timeMake} from '@toreda/time';
// Create time object in unit 'seconds' with value 0.
const time = timeMake('s', ,0);
Set Time
// Set time using a Unix Timestamp (in seconds)
time.set(1635577204);
// Set using ISO-8601 string
time.set('2021-10-30T06:13:33+00:00');
Set current time (now)
// Set Time to current time.
time.setNow();
Create unix timestamp
import {unixTimestampNow} from '@toreda/time';
// Returns current unix timestamp in seconds at time of call.
const now = unixTimestampNow();
Set current time using Unix Timestamp
import type {Time} from '@toreda/time';
import {timeMake, unixTimestampNow} from '@toreda/time';
const now = unixTimestampNow();
const time = timeMake('s');
time.set(now);
Check if string is a valid & supported time unit
import {timeUnitSupported} from '@toreda/time';
// Outputs: 'supported: true'
console.info('supported: ' + timeUnitSupported('s'));
// Outputs: 'supported: true'
console.info('supported: ' + timeUnitSupported('w'));
// Outputs: 'supported: false'
console.info('supported: ' + timeUnitSupported());
// Outputs: 'supported: false'
console.info('supported: ' + timeUnitSupported({}));
// Outputs: 'supported: false'
console.info('supported: ' + timeUnitSupported('???'));
Check if object is a Time object
import {timeValid, timeNow} from '@toreda/time';
const now = timeNow();
// Outputs `is valid: true`
console.log('is valid: ' + timeValid(time));
// Outputs `is valid: false`
console.log('is valid: ' + timeValid({}));
// Outputs `is valid: false`
console.log('is valid: ' + timeValid(null));
// Outputs `is valid: false`
console.log('is valid: ' + timeValid(undefined));
@toreda/time
is an open source package provided under the MIT License. Download, clone, or check the complete project source here on Github. We welcome bug reports, comments, and pull requests.
MIT © Toreda, Inc.
Copyright © 2019 - 2022 Toreda, Inc. All Rights Reserved.
Toreda's company website can be found at toreda.com