@@ -7,7 +7,7 @@ namespace Toby\Domain\Enums;
|
||||
enum VacationRequestState: string
|
||||
{
|
||||
case Created = "created";
|
||||
case Canceled = "canceled";
|
||||
case Cancelled = "cancelled";
|
||||
case Rejected = "rejected";
|
||||
case Approved = "approved";
|
||||
case WaitingForTechnical = "waiting_for_technical";
|
||||
@@ -40,7 +40,7 @@ enum VacationRequestState: string
|
||||
{
|
||||
return [
|
||||
self::Rejected,
|
||||
self::Canceled,
|
||||
self::Cancelled,
|
||||
];
|
||||
}
|
||||
|
||||
|
20
app/Domain/Events/VacationRequestCancelled.php
Normal file
20
app/Domain/Events/VacationRequestCancelled.php
Normal file
@@ -0,0 +1,20 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Toby\Domain\Events;
|
||||
|
||||
use Illuminate\Foundation\Events\Dispatchable;
|
||||
use Illuminate\Queue\SerializesModels;
|
||||
use Toby\Eloquent\Models\VacationRequest;
|
||||
|
||||
class VacationRequestCancelled
|
||||
{
|
||||
use Dispatchable;
|
||||
use SerializesModels;
|
||||
|
||||
public function __construct(
|
||||
public VacationRequest $vacationRequest,
|
||||
) {
|
||||
}
|
||||
}
|
@@ -5,16 +5,10 @@ declare(strict_types=1);
|
||||
namespace Toby\Domain\Listeners;
|
||||
|
||||
use Toby\Domain\Events\VacationRequestApproved;
|
||||
use Toby\Domain\VacationTypeConfigRetriever;
|
||||
use Toby\Infrastructure\Jobs\SendVacationRequestDaysToGoogleCalendar;
|
||||
|
||||
class HandleApprovedVacationRequest
|
||||
{
|
||||
public function __construct(
|
||||
protected VacationTypeConfigRetriever $configRetriever,
|
||||
) {
|
||||
}
|
||||
|
||||
public function handle(VacationRequestApproved $event): void
|
||||
{
|
||||
SendVacationRequestDaysToGoogleCalendar::dispatch($event->vacationRequest);
|
||||
|
16
app/Domain/Listeners/HandleCancelledVacationRequest.php
Normal file
16
app/Domain/Listeners/HandleCancelledVacationRequest.php
Normal file
@@ -0,0 +1,16 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Toby\Domain\Listeners;
|
||||
|
||||
use Toby\Domain\Events\VacationRequestCancelled;
|
||||
use Toby\Infrastructure\Jobs\ClearVacationRequestDaysInGoogleCalendar;
|
||||
|
||||
class HandleCancelledVacationRequest
|
||||
{
|
||||
public function handle(VacationRequestCancelled $event): void
|
||||
{
|
||||
ClearVacationRequestDaysInGoogleCalendar::dispatch($event->vacationRequest);
|
||||
}
|
||||
}
|
@@ -10,6 +10,7 @@ use Toby\Domain\Enums\VacationRequestState;
|
||||
use Toby\Domain\Events\VacationRequestAcceptedByAdministrative;
|
||||
use Toby\Domain\Events\VacationRequestAcceptedByTechnical;
|
||||
use Toby\Domain\Events\VacationRequestApproved;
|
||||
use Toby\Domain\Events\VacationRequestCancelled;
|
||||
use Toby\Domain\Events\VacationRequestCreated;
|
||||
use Toby\Eloquent\Models\VacationRequest;
|
||||
|
||||
@@ -42,7 +43,9 @@ class VacationRequestStateManager
|
||||
|
||||
public function cancel(VacationRequest $vacationRequest): void
|
||||
{
|
||||
$this->changeState($vacationRequest, VacationRequestState::Canceled);
|
||||
$this->changeState($vacationRequest, VacationRequestState::Cancelled);
|
||||
|
||||
$this->dispatcher->dispatch(new VacationRequestCancelled($vacationRequest));
|
||||
}
|
||||
|
||||
public function acceptAsTechnical(VacationRequest $vacationRequest): void
|
||||
|
Reference in New Issue
Block a user