Package Data | |
---|---|
Maintainer Username: | yassi |
Package Create Date: | 2018-10-23 |
Package Last Update: | 2024-05-13 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-12-26 15:19:34 |
Package Statistics | |
---|---|
Total Downloads: | 467,936 |
Monthly Downloads: | 2,193 |
Daily Downloads: | 33 |
Total Stars: | 240 |
Total Watchers: | 13 |
Total Forks: | 95 |
Total Open Issues: | 60 |
This package allows you to include your nested relationships' forms into a parent form.
To be more consistent with Nova's other fields, the order of the parameters has changed to become:
NestedForm::make($name, $viaRelationship = null, $class = null),
For instance, this:
NestedForm::make('Posts'),
Is now the same as:
NestedForm::make('Posts', 'posts', Post::class),
Also, translations are now available in your nested field! You just need to add this key in you language file:
"Add a new :resourceSingularName": "Ajouter un(e) :resourceSingularName"
composer require yassi/nova-nested-form
Simply add a NestedForm into your fields. The first parameter must be an existing NovaResource class and the second parameter (optional) must be an existing HasOneOrMany relationship in your model.
namespace App\Nova;
use Laravel\Nova\Fields\ID;
use Illuminate\Http\Request;
use Laravel\Nova\Fields\Text;
use Laravel\Nova\Fields\Gravatar;
use Laravel\Nova\Fields\Password;
// Add use statement here.
use Yassi\NestedForm\NestedForm;
class User extends Resource
{
...
public function fields(Request $request)
{
return [
ID::make()->sortable(),
Gravatar::make(),
Text::make('Name')
->sortable()
->rules('required', 'max:255'),
Text::make('Email')
->sortable()
->rules('required', 'email', 'max:254')
->creationRules('unique:users,email')
->updateRules('unique:users,email,{{resourceId}}'),
Password::make('Password')
->onlyOnForms()
->creationRules('required', 'string', 'min:6')
->updateRules('nullable', 'string', 'min:6'),
// Add NestedForm here.
NestedForm::make('Posts'),
];
}
You can also nest your relationship forms by adding another NestedForm into the fields of your App\Nova\Post.
For instance, if you have to modify a value on the request before the nested form is filled or trigger an event after all relations have been set, you can now simply use this:
NestedForm::make('Posts')
->beforeFill(function ($request, $model, $attribute, $requestAttribute) {
$request->merge(['key' => 'value']);
// or
if (!$model->hasSomeProperty) {
throw new \Exception('You cannot do this.');
}
})
->afterFill(function ($request, $model, $attribute, $requestAttribute, $touched) {
$touched->each(function ($model) {
if ($model->wasRecentlyCreated) {
// do something
}
});
})
For instance, if you want every user to have at least 3 posts and at most 5 posts, simply use:
NestedForm::make('Posts')->min(3)->max(5),
When creating a new user, 3 blank posts will be displayed. If you reach the maximum number of posts, the "Add a new post" button will disappear.
If you want the nested forms to be opened by default, simply use:
NestedForm::make('Posts')->open(true),
You can also decide to open only the first nested form by using:
NestedForm::make('Posts')->open('only first'),
You can modify the default heading using the heading() method. You can use wildcards to add dynamic content to your label such as '{{id}}', '{{index}}' or any attribute present in the form.
NestedForm::make('Posts')->heading('{{index}} // Post - {{title}}'),
You can modify the default index separator using the separator() method when you have nested forms (e.g. 1. Post, 1.1. Comment, 1.1.1. Like).
NestedForm::make('Posts')->separator('\'),