Skip to content

novius/filament-relation-nested

Repository files navigation

Laravel Filament Relation Nested

Novius CI Packagist Release License: AGPL v3

Introduction

This Laravel Filament package allows you to manage relation that uses the kalnoy/nestedset in your Laravel Filament admin panel.

Requirements

  • PHP >= 8.2
  • Laravel Filament >= 3.3
  • Laravel Framework >= 11.0

Installation

composer require novius/filament-relation-nested

Publish Filament assets

php artisan filament:assets

Usage

Relation Manager

First create a RelationManager for your filament resource that have a relation to a model that uses nestedset package:

use Filament\Tables\Actions\CreateAction;
use Filament\Tables\Actions\DeleteAction;
use Filament\Tables\Actions\EditAction;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
use Illuminate\Database\Eloquent\Model;
use Novius\FilamentRelationNested\Filament\Resources\RelationManagers\TreeRelationManager;
use Novius\FilamentRelationNested\Filament\Tables\Actions\FixTreeAction;

class MenuItemsTreeRelationManager extends TreeRelationManager
{
    // Define the relationship name
    protected static string $relationship = 'items';

    public function table(Table $table): Table
    {
        return $table
            ->columns([
                TextColumn::make('title'),
            ])
            ->pluralModelLabel('Menu items')
            ->recordTitleAttribute('title')
            ->headerActions([
                CreateAction::make(),
                    
                // Add the FixTreeAction if you want an action that fix the nestedset tree 
                FixTreeAction::make(),
            ])
            ->actions([
                EditAction::make(),
                DeleteAction::make(),
            ]);
    }
}

Then add it to your resource

class MenuResource extends Resource
{
    public static function getRelations(): array
    {
        return [
            // ...
            MenuItemsTreeRelationManager::class,
        ];
    }
}

TreeColumn

You can use this column in a filament table on a model that uses the nestedset package. This will display a column which, when sorting is this column, will give an idea of the tree.

use CodeWithDennis\FilamentSelectTree\SelectTree;
use Exception;
use Filament\Forms\Components\Checkbox;
use Filament\Forms\Components\Grid;
use Filament\Forms\Components\Hidden;
use Filament\Forms\Components\Select;
use Filament\Forms\Components\TextInput;
use Filament\Forms\Form;
use Filament\Forms\Get;
use Filament\Forms\Set;
use Filament\Resources\Resource;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Model;
use Novius\FilamentRelationNested\Filament\Tables\Columns\TreeColumn;
use Novius\LaravelFilamentMenu\Enums\LinkType;
use Novius\LaravelFilamentMenu\Facades\MenuManager;
use Novius\LaravelFilamentMenu\Filament\Resources\MenuItemResource\Pages\CreateMenuItem;
use Novius\LaravelFilamentMenu\Filament\Resources\MenuItemResource\Pages\EditMenuItem;
use Novius\LaravelFilamentMenu\Filament\Resources\MenuItemResource\RelationManagers\MenuItemsRelationManager;
use Novius\LaravelFilamentMenu\Models\Menu;
use Novius\LaravelFilamentMenu\Models\MenuItem;
use Novius\LaravelLinkable\Filament\Forms\Components\Linkable;
use Wiebenieuwenhuis\FilamentCodeEditor\Components\CodeEditor;

class MenuItemResource extends Resource
{
    public static function table(Table $table): Table
    {
        return $table
            // This will disable the pagination when the table is sorted by the _lft field
            ->paginated(fn (Table $table) => ! empty($table->getSortColumn()) && $table->getSortColumn() !== '_lft')
            // This will default sort the table on the _lft field
            ->defaultSort('_lft')
            ->columns([
                TreeColumn::make('_lft'),

                // ....
            ]);
    }
}

Lint

Run php-cs with:

composer run-script lint

Contributing

Contributions are welcome! Leave an issue on Github, or create a Pull Request.

Licence

This package is under GNU Affero General Public License v3 or (at your option) any later version.

About

A filament package to manage relationships that use the NestedSet model.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published