reinbier / laravel-holiday
Holidays in Laravel, the right way.
Requires
- php: ^8.1
- cmixin/business-day: ^1.16
- illuminate/contracts: ^9.0|^10.0|^11.0
- spatie/laravel-package-tools: ^1.14.0
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^6.0
- nunomaduro/larastan: ^2.0.1
- orchestra/testbench: ^7.0
- pestphp/pest: ^1.21
- pestphp/pest-plugin-laravel: ^1.1
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
- phpunit/phpunit: ^9.5
README
This package helps by providing a Holiday model in your project with all the holidays for a specific year.
By storing them in the database and automatically injected into Carbon via the
BusinessDay
package, you can simply see if a given Carbon instance
represents a holiday, via $carbon->isHoliday()
.
The benefits of the model are that you can easily add your own holidays. On top of that, the package can generate holidays for the current locale.
Use cases
An example would be when you want to show your store's opening hours. When echoing your opening hours for each day, you can check whether the given date is a holiday and say that you're closed this day.
Installation
You can install the package via composer:
composer require reinbier/laravel-holiday
You should publish and run the migrations:
php artisan vendor:publish --tag="holiday-migrations"
php artisan migrate
Optionally, you can publish the config file with:
php artisan vendor:publish --tag="holiday-config"
This is the contents of the published config file:
return [ /** * The name of the table to use. You can adjust this to suit your needs. */ 'table_name' => 'holidays', /** * If you want to use a different locale to generate holidays for, * you can set it here. For now, a sensible default is set. */ 'locale' => config('app.locale', 'nl'), /** * When true, sets the holidays for Carbon in the service container. */ 'enable_carbon' => false, ];
Usage
To generate local holidays for the current and next year, execute the command.
php artisan holiday:generate
Subsequently, you could schedule this command to run yearly so your table will always hold data when working with the Holiday model.
To do that, place the following line into your Console/Kernel.php 'schedule' method:
protected function schedule(Schedule $schedule) { // ... $schedule->command('holiday:generate')->yearly(); }
Using the Facade
The LaravelHoliday
Facade gets automatically registered in the service container.
The facade is a singleton and will hold the current year's Holiday model.
It will set global holidays throughout your application so that you can check
any date for whether it's treated as a holiday according to your model.
The facade also provides you with a couple of methods:
use Reinbier\LaravelHoliday\Facades\LaravelHoliday; // The Holiday model of the current year $holiday = LaravelHoliday::model(); // All holiday-dates in a Collection $holidays = LaravelHoliday::getHolidays(); // Set the Holiday model and chain methods LaravelHoliday::forYear(2023) ->addHoliday('2023-06-07', 'boss-birthday') ->getHolidays(); // Simply add multiple holidays by chaining LaravelHoliday::forYear(2023) ->addHoliday('2023-06-07', 'boss-birthday') ->addHoliday('2023-10-10', 'anniversary') -> ...
Future holidays
If you don't want to be limited to only the current year's holidays, you can
fetch all future holidays as well using the helper method on the facade: getFutureHolidays()
.
use Reinbier\LaravelHoliday\Facades\LaravelHoliday; $future_holidays = LaravelHoliday::getFutureHolidays(); // You may optionally specify a year, until when to retrieve holidays $future_holidays = LaravelHoliday::getFutureHolidays(2035);
Enable holidays in Carbon
The package can automatically apply your stored holidays to Carbon instances,
so that, whenever you need to check a date to be a holiday, you can
call ->isHoliday()
on that Carbon instance.
This setting is disabled by default. To enable this, set the value in the config holiday.php
.
'enable_carbon' => true,
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Security Vulnerabilities
If you discover any security related issues, please email support@reinbier.nl instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.