pwa / time-elapsed
A class to print the elapsed time between two DateTime objects in a nice (and highly modifiable) format
Installs: 4 863
Dependents: 1
Suggesters: 0
Security: 0
Stars: 4
Watchers: 3
Forks: 0
Open Issues: 0
Requires
- php: >=5.3.0
This package is not auto-updated.
Last update: 2025-01-18 17:02:07 UTC
README
pwa/time-elapsed
A PHP class to print the elapsed time between two DateTime objects in a nice (and highly modifiable) format.
Setup
To add this package as a local, per-project dependency to your project, simply add a
dependency on pwa/time-elapsed
to your project's composer.json
file.
{ "require": { "pwa/time-elapsed": "dev-master" } }
Because this class uses namespacing, when instantiating the object, you need to use the fully qualified namespace:
$elapsed = new \Pwa\TimeElapsed($start);
Usage
This class prints the elapsed time, between two DateTime objects, in a formatted way determined by the anonymous functions found in src/localization.php. E.g. this function will be called if elapsed time is >= 1 week and < 1 month:
'weeks_ago' => function ($weeks) { if (floor($weeks) == 1) { return 'a week ago'; } else { return floor($weeks) . ' weeks ago'; } },
You can easily pass your own localization functions to the TimeElapsed class, to override default localization/format:
$timezone = new \DateTimeZone("Europe/Stockholm"); $date = new \DateTime('2015-01-01 15:00:00', $timezone); $elapsed = new TimeElapsed($date); echo $elapsed->getElapsedTime(); // Between $date and $now = DateTime(null, $timezone); // Output: a week ago $localization = '/path/to/my_localization.php'; $elapsed->setLocalization($localization); echo $elapsed->getElapsedTime(); // Output: one week ago $localization = '/path/to/my_french_localization.php'; $elapsed->setLocalization($localization); echo $elapsed->getElapsedTime(); // Output: Il ya 1 semaine
You may also pass an end date when instantianting the object:
$start = new \DateTime('2015-01-01 15:00:00', $timezone); $end = new \DateTime('2015-01-01 15:00:05', $timezone); $elapsed = new TimeElapsed($start, end); echo $elapsed->getElapsedTime(); // Output: a few seconds ago
License
This software is free software and carries a MIT license.