Stars: 1811
Forks: 248
Pull Requests: 227
Issues: 119
Watchers: 49
Last Updated: 2021-02-03 15:21:00
🗓 A library to help you work with dates in multiple languages, based on Carbon.
License: MIT License
Languages: PHP
This date library extends Carbon with multi-language support. Methods such as format
, diffForHumans
, parse
, createFromFormat
and the new timespan
, will now be translated based on your locale.
All translations made by contributors have been moved to the Carbon 2 package. This package now uses the Carbon translations to provide you with better multi-language support. Translation issues should be reported on the Carbon repository. Please also check out the original documentation here.
Install using composer:
composer require jenssegers/date
There is a service provider included for integration with the Laravel framework. This provider will get the application locale setting and use this for translations. This service will be automatically registered if you use Laravel 5.5+ using the auto-discovery. Else to register the service provider, add the following to the providers array in config/app.php
:
Jenssegers\Date\DateServiceProvider::class,
You can also add it as a Facade in config/app.php
:
'Date' => Jenssegers\Date\Date::class,
This package contains language files for the following languages (https://carbon.nesbot.com/docs/#supported-locales):
The Date class extends the Carbon methods such as format
and diffForHumans
, and translates them based on your locale:
use Jenssegers\Date\Date;
Date::setLocale('nl');
echo Date::now()->format('l j F Y H:i:s'); // zondag 28 april 2013 21:58:16
echo Date::parse('-1 day')->diffForHumans(); // 1 dag geleden
The Date class also added some aliases and additional methods such as: ago
which is an alias for diffForHumans
, and the timespan
method:
echo $date->timespan(); // 3 months, 1 week, 1 day, 3 hours, 20 minutes
Methods such as parse
and createFromFormat
also support "reverse translations". When calling these methods with translated input, it will try to translate it to English before passing it to DateTime:
$date = Date::createFromFormat('l d F Y', 'zaterdag 21 maart 2015');
Carbon is the library the Date class is based on. All of the original Carbon operations are still available, check out https://carbon.nesbot.com/docs for more information. Here are some of the available methods:
You can create Date objects just like the DateTime object (http://www.php.net/manual/en/datetime.construct.php):
$date = new Date();
$date = new Date('2000-01-31');
$date = new Date('2000-01-31 12:00:00');
// With time zone
$date = new Date('2000-01-31', new DateTimeZone('Europe/Brussels'));
You can skip the creation of a DateTimeZone object:
$date = new Date('2000-01-31', 'Europe/Brussels');
Create Date objects from a relative format (http://www.php.net/manual/en/datetime.formats.relative.php):
$date = new Date('now');
$date = new Date('today');
$date = new Date('+1 hour');
$date = new Date('next monday');
This is also available using these static methods:
$date = Date::parse('now');
$date = Date::now();
Creating a Date from a timestamp:
$date = new Date(1367186296);
Or from an existing date or time:
$date = Date::createFromDate(2000, 1, 31);
$date = Date::createFromTime(12, 0, 0);
$date = Date::create(2000, 1, 31, 12, 0, 0);
You can format a Date object like the DateTime object (http://www.php.net/manual/en/function.date.php):
echo Date::now()->format('Y-m-d'); // 2000-01-31
The Date object can be cast to a string:
echo Date::now(); // 2000-01-31 12:00:00
Get a human readable output (alias for diffForHumans):
echo $date->ago(); // 5 days ago
Calculate a timespan:
$date = new Date('+1000 days');
echo Date::now()->timespan($date);
// 2 years, 8 months, 3 weeks, 5 days
// or even
echo Date::now()->timespan('+1000 days');
Get years since date:
$date = new Date('-10 years');
echo $date->age; // 10
$date = new Date('+10 years');
echo $date->age; // -10
You can manipulate by using the add and sub methods, with relative intervals (http://www.php.net/manual/en/datetime.formats.relative.php):
$yesterday = Date::now()->sub('1 day');
$tomorrow = Date::now()->add('1 day');
// ISO 8601
$date = Date::now()->add('P2Y4DT6H8M');
You can access and modify all date attributes as an object:
$date->year = 2013:
$date->month = 1;
$date->day = 31;
$date->hour = 12;
$date->minute = 0;
$date->second = 0;
Language contributions should made to https://github.com/briannesbitt/Carbon.
Laravel Date is licensed under The MIT License (MIT).
To report a security vulnerability, follow these steps.