-
-
Notifications
You must be signed in to change notification settings - Fork 97
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Feature: Added ...transitionArgs to default transition constructor ca…
…ll to allow arguments use for custom default transition
- Loading branch information
1 parent
56e6207
commit 82b4f6f
Showing
4 changed files
with
112 additions
and
1 deletion.
There are no files selected for viewing
78 changes: 78 additions & 0 deletions
78
docs/working-with-transitions/06-custom-default-transition-class.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
--- | ||
title: Custom default transition class | ||
weight: 6 | ||
--- | ||
|
||
When working with state transitions, you may need to pass additional contextual data to your `StateChanged` event | ||
listeners. While custom transitions allow this for specific state changes, sometimes you need this functionality for all | ||
transitions. To handle such scenarios `DefaultTransition` class can be extended. | ||
|
||
The following example uses different logic depending on how `transitionTo` is called. | ||
|
||
Creating custom default transition class: | ||
|
||
```php | ||
use Spatie\ModelStates\DefaultTransition; | ||
use Spatie\ModelStates\State; | ||
|
||
class CustomDefaultTransitionWithAttributes extends DefaultTransition | ||
{ | ||
public function __construct($model, string $field, State $newState, public bool $silent = false) | ||
{ | ||
parent::__construct($model, $field, $newState); | ||
} | ||
} | ||
``` | ||
|
||
Register your custom transition class in `config/model-states.php`: | ||
|
||
```php | ||
return [ | ||
'default_transition' => CustomDefaultTransitionWithAttributes::class | ||
]; | ||
``` | ||
|
||
Implement your state change listener to use the custom parameter: | ||
|
||
```php | ||
use Spatie\ModelStates\Events\StateChanged; | ||
|
||
class OrderStateChangedListener | ||
{ | ||
public function handle(StateChanged $event): void | ||
{ | ||
$isSilent = $event->transition->silent; | ||
|
||
$this->processOrderState($event->model); | ||
|
||
if (! $isSilent) { | ||
$this->notifyUser($event->model); | ||
} | ||
} | ||
} | ||
``` | ||
|
||
Now we can pass additional parameter to `transitionTo` method, to omit notification logic: | ||
|
||
```php | ||
class OrderService { | ||
public function markAsPaid(Order $order): void | ||
{ | ||
// Will trigger notification | ||
$order->state->transitionTo(PaidState::class); | ||
// Also can be specified explicitly | ||
$order->state->transitionTo(PaidState::class, false); | ||
} | ||
|
||
public function markAsPaidSilently(Order $order): void | ||
{ | ||
// Will not trigger notification | ||
$order->state->transitionTo(PaidState::class, true); | ||
} | ||
} | ||
``` | ||
|
||
Important notes: | ||
|
||
- Custom parameters are only available within the context of the event listeners | ||
- Parameters must be serializable if you plan to queue your state change listeners |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
14 changes: 14 additions & 0 deletions
14
tests/Dummy/Transitions/CustomDefaultTransitionWithAttributes.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
<?php | ||
|
||
namespace Spatie\ModelStates\Tests\Dummy\Transitions; | ||
|
||
use Spatie\ModelStates\DefaultTransition; | ||
use Spatie\ModelStates\State; | ||
|
||
class CustomDefaultTransitionWithAttributes extends DefaultTransition | ||
{ | ||
public function __construct($model, string $field, State $newState, public bool $silent = false) | ||
{ | ||
parent::__construct($model, $field, $newState); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters