From 6c910fd3a2c3433fb302dcd7c01f63ef1da929f7 Mon Sep 17 00:00:00 2001 From: "Pedro X." Date: Fri, 1 Mar 2024 12:52:13 +0000 Subject: [PATCH] update form operation docs --- 6.x/crud-operations.md | 27 +++++++++++++++++++++------ 1 file changed, 21 insertions(+), 6 deletions(-) diff --git a/6.x/crud-operations.md b/6.x/crud-operations.md index b54cb754..459b393c 100644 --- a/6.x/crud-operations.md +++ b/6.x/crud-operations.md @@ -976,10 +976,18 @@ The button makes one call for all entries, and only triggers one notification. I #### Creating a New Operation With a Form -Say we want to create a ```Comment``` operation. Click the Comment button on an entry, and it brings up a form with a textarea. Submit the form and you're back to the list view. What we need to do is: +Say we want to create a ```Comment``` operation. Click the Comment button on an entry, and it brings up a form with a textarea. Submit the form and you're back to the list view. Let's get started. What we need to do is: +**Step 0.** Install ```backpack/generators``` if you haven't yet. [https://github.com/Laravel-Backpack/Generators](https://github.com/Laravel-Backpack/Generators). We have built a set of commands to help you create a new form operation easy peasy. You can use it like this: + +```bash +php artisan backpack:crud-operation Comment # will create a form for the entries in your list view, with the id in the URL + +php artisan backpack:crud-operation Comment --no-id # will create a form, without the id in the URL (generators v4.0.4+) +``` -**Step 1.** Generate the operation trait, by running `php artisan backpack:crud-form-operation Comment`. This will create a new trait, `CommentOperation` that should look very similar to this: + +**Step 1.** Back to our goal, lets generate the operation trait, by running `php artisan backpack:crud-form-operation Comment`. This will create a new trait, `CommentOperation` that should look very similar to this: ```php formDefaults( operationName: 'comment', - // buttonStack: 'line', // alternatives: top, bottom + buttonStack: 'line', // alternatives: top, bottom // buttonMeta: [ // 'icon' => 'la la-home', // 'label' => 'Comment', @@ -1034,7 +1042,7 @@ trait CommentOperation * @param int $id * @return \Illuminate\Contracts\View\View */ - public function getCommentForm(int $id = null) + public function getCommentForm(int $id) { $this->crud->hasAccessOrFail('comment'); @@ -1051,7 +1059,7 @@ trait CommentOperation { $this->crud->hasAccessOrFail('comment'); - return $this->formAction($id, function ($inputs, $entry) { + return $this->formAction(id: $id, formLogic: function ($inputs, $entry) { // You logic goes here... // dd('got to ' . __METHOD__, $inputs, $entry); @@ -1103,6 +1111,10 @@ public function setupCommentOperation(): void { $this->crud->field('message')->type('textarea'); $this->crud->field('rating')->type('number'); + + // if you want to add a FormRequest to validate the fields you do it here. + // later when you handle the form submission, the request will be automatically validated + $this->crud->setValidation(CommentRequest::class); // this file is not automatically created. You have to create it yourself. } ``` @@ -1114,12 +1126,15 @@ public function setupCommentOperation(): void { $this->crud->hasAccessOrFail('comment'); - return $this->formAction($id, function ($inputs, $entry) { + return $this->formAction(id: $id, formLogic: function ($inputs, $entry) { // You logic goes here... // You can validate the inputs using the Laravel Validator, eg: // $valid = Validator::make($inputs, ['message' => 'required'])->validated(); + // alternatively if you set a FormRequest in the setupCommentOperation() method, + // the request will be validated here already + // and then save it to database // $entry->comments()->create($valid);