jpmurray / laravel-countdown
Provide an easy class easy way to get the time difference between two dates, with an extra bonus trait for eloquent
Fund package maintenance!
jpmurray
Installs: 3 761
Dependents: 0
Suggesters: 0
Security: 0
Stars: 83
Watchers: 3
Forks: 12
Open Issues: 2
Requires
- php: ^7.0
- ext-bcmath: *
- illuminate/support: 6.* || 7.* || 8.*
- nesbot/carbon: ^2.0
Requires (Dev)
- mockery/mockery: dev-master@dev
- nesbot/carbon: ^2.0
- orchestra/testbench: ~3.0
- phpunit/phpunit: ~4.0||~5.0
- squizlabs/php_codesniffer: ^2.3
README
The jpmurray/laravel-countdown
and easy way to get the time difference between two dates, with an extra bonus trait for eloquent.
I needed to get the diffrence of time, and while the very good Carbon gives me helper to retreive difference in time in different time unit (hours, minutes, etc), there is no method to calculate it all at the same time. Carbon's diffForHumans
is pretty close, but there is no control over how it displays information, and what information it displays.
Install
You can install this package via composer:
$ composer require jpmurray/laravel-countdown
Usage with Laravel <= 5.5
You should be using versions of this package that are <= 3.0.0.
If you are using a version of Laravel that doesn't support package autodiscovery, you will have to add the service provider and facade to your config/app.php
file.
Edit file: config/app.php
'providers' => [ // ... jpmurray\LaravelCountdown\CountdownServiceProvider::class, // ... ]; // ... 'aliases' => [ // ... 'Countdown' => jpmurray\LaravelCountdown\Facades\CountdownFacade::class, // ... ];
Usage
use jpmurray\LaravelCountdown\Countdown; // To get time from 5 years ago until now, you can do the following. // Note that you can send a string to the from and to methods, we will // try to parse it with Carbon behind the scene $now = Carbon::now(); $countdown = Countdown::from($now->copy()->subYears(5)) ->to($now)->get(); // The above will return the Countdown class where you can access the following values. // Those mean that from 5 years ago to now, there is 5 years, 1 week, 1 day, 2 hours 15 minutes and 23 seconds $countdown->years; // 5 $countdown->weeks; // 1 $countdown->days; // 1 $countdown->hours; // 2 $countdown->minutes; // 15 $countdown->seconds; // 23 // It will of course, also work in reverse order of time. // This will get the time between now and some future date $countdown = Countdown::from($now) ->to($now->copy()->addYears(5)) ->get(); // To return to humans string $countdown->toHuman(); // 18 years, 33 weeks, 2 days, 18 hours, 4 minutes and 35 seconds // You to can pass custom string to parse in method toHuman, like this: $countdown->toHuman('{days} days, {hours} hours and {minutes} minutes'); // 2 days, 18 hours, 4 minutes
Eloquent Trait
// For convenience, we provide a trait that you can add to any model in your Laravel app that provides // quick methods to get the values of time between dates. For example: use jpmurray\LaravelCountdown\Traits\CalculateTimeDiff; class User extends Authenticatable { use Notifiable, CalculateTimeDiff; //... }
Example to use Trait:
// This enables the following: // You should have casted your attributes to dates beforehand $user = User::find(1); $user->elapsed('trial_ends_at'); // get the time elapsed between the date in attribute trial_ends_at to now $user->until('trial_ends_at'); // get the time from now until the date in attribute trial_ends_at
Tests
composer run test
Change log
Please see CHANGELOG for more information on what has changed recently.
Credits
License
The MIT License (MIT). Please see License File for more information.