Form actions
You're browsing the documentation for an old version of MoonShine. Consider upgrading your project to MoonShine 2.x.
-
Sections
By default, forms in the MoonShine panel contain only 1 action - saving. But you can add your own custom actions
namespace MoonShine\Resources; use MoonShine\Models\MoonshineUser;use MoonShine\FormActions\FormAction; class PostResource extends Resource{ public static string $model = App\Models\Post::class; public static string $title = 'Articles'; //... public function formActions(): array { return [ FormAction::make('Delete', function (Model $item) { $item->delete(); }, 'Removed')->icon('delete') ]; } //...}
data:image/s3,"s3://crabby-images/29d1e/29d1e4f4a49e00744b8c99a5df66c4c2e2f6e4c1" alt=""
# Display method
To display actions as a dropdown list, you can use the showInDropdown
method
use MoonShine\FormActions\FormAction; //...public function formActions(): array{ return [ FormAction::make('Deactivation', function (Model $item) { $item->update(['active' => false]); }, 'Deactivated') ->showInDropdown() ];}//...
This display method is used by default
data:image/s3,"s3://crabby-images/d5b44/d5b4416e8274e1a2ed1a06cce1db18a2cbf927c8" alt=""
To display actions as a horizontal list, you can use the showInLine
method
use MoonShine\FormActions\FormAction; //...public function formActions(): array{ return [ FormAction::make('Deactivation', function (Model $item) { $item->update(['active' => false]); }, 'Deactivated') ->showInLine() ];}//...
data:image/s3,"s3://crabby-images/fc4b9/fc4b91fecf14493029a74859937eebe579c6cb6a" alt=""
# Confirm the action
To confirm the action, you must use the withConfirm
method
use MoonShine\FormActions\FormAction; //...public function formActions(): array{ return [ FormAction::make('Deactivation', function (Model $item) { $item->update(['active' => false]); }, 'Deactivated') ->withConfirm() ];}//...
data:image/s3,"s3://crabby-images/8874d/8874d893ce90dffe3cda2a299a1cbf1bed1b7c3d" alt=""
The withConfirm()
method can be passed the title and text for the modal window, as well as the title
for confirmation button
use MoonShine\FormActions\FormAction; //...public function formActions(): array{ return [ FormAction::make('Deactivation', function (Model $item) { $item->update(['active' => false]); }, 'Deactivated') ->withConfirm('Title', 'Modal content', 'Accept') ];}//...
The errorMessage()
method allows you to set the text of the error message
use MoonShine\FormActions\FormAction; //...public function formActions(): array{ return [ FormAction::make('Deactivation', function (Model $item) { $item->update(['active' => false]); }, 'Deactivated') ->withConfirm('Title', 'Modal content', 'Accept') ->errorMessage('Fail') ];}//...