
* #48 - postgreSQL db * #43 - vacation summary for employee (#66) * wip * wip * wip * wip * wip * wip * wip * #5 - bump dependencies * #43 - wip * #43 - add composer script * #43 - fix * #43 - fix * #43 - wip * #43 - ecs fix * #43 - cr fix * #43 - cr fix * #43 - fix Co-authored-by: EwelinaLasowy <ewelina.lasowy@blumilk.pl> * #48 - redis stuff * #48 - user avatars using ui-avatars.com * #48 - fix * #48 - fix * Apply suggestions from code review Co-authored-by: Marcin Tracz <marcin.tracz@blumilk.pl> * #48 - cr fix Co-authored-by: EwelinaLasowy <ewelina.lasowy@blumilk.pl> Co-authored-by: Marcin Tracz <marcin.tracz@blumilk.pl>
46 lines
1.1 KiB
PHP
46 lines
1.1 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Toby\Eloquent\Observers;
|
|
|
|
use Toby\Domain\PolishHolidaysRetriever;
|
|
use Toby\Eloquent\Models\User;
|
|
use Toby\Eloquent\Models\YearPeriod;
|
|
|
|
class YearPeriodObserver
|
|
{
|
|
public function __construct(
|
|
protected PolishHolidaysRetriever $polishHolidaysRetriever,
|
|
) {}
|
|
|
|
public function created(YearPeriod $yearPeriod): void
|
|
{
|
|
$this->createVacationLimitsFor($yearPeriod);
|
|
$this->createHolidaysFor($yearPeriod);
|
|
}
|
|
|
|
protected function createVacationLimitsFor(YearPeriod $yearPeriod): void
|
|
{
|
|
$users = User::all();
|
|
|
|
foreach ($users as $user) {
|
|
$yearPeriod->vacationLimits()->create([
|
|
"user_id" => $user->id,
|
|
]);
|
|
}
|
|
}
|
|
|
|
protected function createHolidaysFor(YearPeriod $yearPeriod): void
|
|
{
|
|
$holidays = $this->polishHolidaysRetriever->getForYearPeriod($yearPeriod);
|
|
|
|
foreach ($holidays as $holiday) {
|
|
$yearPeriod->holidays()->create([
|
|
"name" => $holiday["name"],
|
|
"date" => $holiday["date"],
|
|
]);
|
|
}
|
|
}
|
|
}
|