nevadskiy / nova-collection-field
Collection fields for Laravel Nova.
0.3.0
2023-12-09 15:42 UTC
Requires
- php: ^8.0
Suggests
- nevadskiy/laravel-many-to-morph: Required to use ManyToMorphCollection field.
This package is auto-updated.
Last update: 2024-11-09 17:40:34 UTC
README
Usage
HasManyCollection
FaqSection resource:
namespace App\Nova; use App\Models\FaqSection as FaqSectionModel; use App\Nova\Resource; use Laravel\Nova\Fields\ID; use Laravel\Nova\Fields\Text; use Laravel\Nova\Http\Requests\NovaRequest; use Nevadskiy\Nova\Collection\HasManyCollection; class FaqSection extends Resource { public static string $model = FaqSectionModel::class; public static $title = 'heading'; public static $search = [ 'heading', ]; public function fields(NovaRequest $request): array { return [ ID::make(), Text::make('Heading'), HasManyCollection::make('Questions', 'items', FaqItem::class) ->sortBy('position') ->stacked() ->fullWidth() ]; } }
FaqSection model:
namespace App\Models; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Relations\HasMany; class FaqSection extends Model { public function items(): HasMany { return $this->hasMany(FaqItem::class); } }
MorphToManyCollection
Usage example for a Page
model that has defined Many-To-Many (Polymorphic) relations.
Page resource:
namespace App\Nova; use App\Models\Page as PageModel; use Laravel\Nova\Fields\ID; use Laravel\Nova\Fields\Text; use Laravel\Nova\Http\Requests\NovaRequest; use Nevadskiy\Nova\Collection\MorphToManyCollection; class Page extends Resource { public static string $model = PageModel::class; public function fields(NovaRequest $request): array { return [ ID::make(), Text::make('Title'), MorphToManyCollection::make('Components') ->resources([ 'heroSections' => HeroSection::class, 'demoSections' => DemoSection::class, 'faqSections' => FaqSection::class, ]) ->sortBy('position') ->attachable() ->collapsable() ->stacked() ->fullWidth(), ]; } }
Page model:
namespace App\Models; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Relations\MorphToMany; class Page extends Model { public function heroSections(): MorphToMany { return $this->morphedByMany(HeroSection::class, 'page_component') ->withPivot('position'); } public function demoSections(): MorphToMany { return $this->morphedByMany(DemoSection::class, 'page_component') ->withPivot('position'); } public function faqSections(): MorphToMany { return $this->morphedByMany(FaqSection::class, 'page_component') ->withPivot('position'); } }
ManyToMorphCollection
If you do not want to define a separate relation for each model type, you can use ManyToMorphCollection
field that requires a separate ManyToMorph relation.
Usage example for a Page
model that has defined the Many-To-Morph relation.
Page resource:
namespace App\Nova; use App\Models\Page as PageModel; use Laravel\Nova\Fields\ID; use Laravel\Nova\Fields\Text; use Laravel\Nova\Http\Requests\NovaRequest; use Nevadskiy\Nova\Collection\MorphToManyCollection; class Page extends Resource { public static string $model = PageModel::class; public function fields(NovaRequest $request): array { return [ ID::make(), Text::make('Title'), ManyToMorphCollection::make('Components') ->resources([ HeroSection::class, DemoSection::class, FaqSection::class, ]) ->sortBy('position') ->attachable() ->collapsable() ->stacked() ->fullWidth(), ]; } }
Page
model:
namespace App\Models; use Illuminate\Database\Eloquent\Model; use Nevadskiy\ManyToMorph\HasManyToMorph; use Nevadskiy\ManyToMorph\ManyToMorph; class Page extends Model { use HasManyToMorph; public function components(): ManyToMorph { return $this->manyToMorph('page_component'); } }
To-Do List
- validation
- detail view
- delete with detach when is not used attachable mode