.codeclimate.yml | ||
.editorconfig | ||
.gitignore | ||
.jscsrc | ||
.npmignore | ||
.travis.yml | ||
CHANGELOG.md | ||
CONTRIBUTING.md | ||
index.js | ||
LICENSE | ||
package.json | ||
README.md | ||
test.js |
Timestring
Parse a human readable time string into a time based value.
Installation
npm install --save timestring
Usage
Overview
var str = '1h 15m';
var time = str.parseTime();
console.log(time); // will log 4500
In the example above str
is just a plain old String
object. A new method is added to the String
objects prototype named parseTime
. This method parses the string and returns a time based value.
By default the returned time value will be in seconds.
The time string can contain as many time groups as needed:
var str = '1d 3h 25m 18s';
var time = str.parseTime();
console.log(time); // will log 98718
and can be as messy as you like:
var str = '1 d 3HOurS 25 min 1 8s';
var time = str.parseTime();
console.log(time); // will log 98718
As well as using the String
objects parseTime
method you can create a Timestring
object and parse the string manually:
var str = '1h 15m';
var time = (new Timestring()).parse(str);
console.log(time); // will log 4500
Keywords
Timestring will parse the following keywords into time values:
s, sec, secs, second, seconds
- will parse to secondsm, min, mins, minute, minutes
- will parse to minutesh, hr, hrs, hour, hours
- will parse to hoursd, day, days
- will parse to daysw, week, weeks
- will parse to weeksmth, mths, month, months
- will parse to monthsy, yr, yrs, year, years
- will parse to years
Keywords can be used interchangeably:
var str = '1day 15h 20minutes 15s';
var time = str.parseTime();
console.log(time); // will log 141615
Return Time Value
By default the return time value will be in seconds. This can be changed by passing one of the following strings as an argument to String.parseTime
or Timestring.parse
:
s
- Secondsm
- Minutesh
- Hoursd
- Daysw
- Weeksmth
- Monthsy
- Years
var str = '22h 16m';
var hours = str.parseTime('h'); // 22.266666666666666
var days = str.parseTime('d'); // 0.9277777777777778
var weeks = str.parseTime('w'); // 0.13253968253968254
// or
var hours = (new Timestring()).parse(str, 'h'); // 22.266666666666666
var days = (new Timestring()).parse(str, 'd'); // 0.9277777777777778
var weeks = (new Timestring()).parse(str, 'w'); // 0.13253968253968254
Optional Configuration
A few assumptions are made by default:
- There are 24 hours per day
- There are 7 days per week
- There are 4 weeks per month
- There are 12 months per year
These options can be changed by passing a options object as an argument to String.parseTime
or to the Timestring
objects constructor.
The following options are configurable:
hoursPerDay
daysPerWeek
weeksPerMonth
monthsPerYear
var str = '1d';
var opts = {
hoursPerDay: 1
}
var time = str.parseTime('h', opts);
// or
var time = (new Timestring(opts)).parse(str, 'h');
console.log(time); // will log 1
In the example above hoursPerDay
is being set to 1
. When the time string is being parsed, the return value is being specified as hours. Normally 1d
would parse to 24
hours (as by default there are 24 hours in a day) but because hoursPerDay
has been set to 1
, 1d
will now only parse to 1
hour.
This would be useful for specific application needs.
Example - Employees of my company work 7.5 hours a day, and only work 5 days a week. In my time tracking app, when they type 1d
i want 7.5 hours to be tracked. When they type 1w
i want 5 days to be tracked etc.
var opts = {
hoursPerDay: 7.5,
daysPerWeek: 5
}
// get time values from form input
var today = document.querySelector('time-input').value, // '1d'
thisWeek = document.querySelector('time-input').value; // '1w'
// parse times
var hoursToday = today.parseTime('h', opts),
daysThisWeek = thisWeek.parseTime('d', opts);
// or
var hoursToday = (new Timestring(opts)).parse(today, 'h'),
daysThisWeek = (new Timestring(opts)).parse(thisWeek, 'd');
console.log(hoursToday); // will log 7.5
console.log(daysThisWeek); // will log 5