From 4b4228f4f061966bb7fa5cf86267805533f6e438 Mon Sep 17 00:00:00 2001 From: alexPopaCode4 <156655986+alexPopaCode4@users.noreply.github.com> Date: Mon, 8 Apr 2024 13:08:13 +0300 Subject: [PATCH] Resource filters for category/ subcategory/ type (#163) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Resource filters for category/ subcategory/ type * fixes --------- Co-authored-by: Andrei Ioniță --- app/Filament/Filters/ResourceTreeFilter.php | 26 ++++++++++++++++--- .../ResourcesRelationManager.php | 17 ++++-------- 2 files changed, 27 insertions(+), 16 deletions(-) diff --git a/app/Filament/Filters/ResourceTreeFilter.php b/app/Filament/Filters/ResourceTreeFilter.php index 28c8aea..a713c22 100644 --- a/app/Filament/Filters/ResourceTreeFilter.php +++ b/app/Filament/Filters/ResourceTreeFilter.php @@ -5,9 +5,11 @@ namespace App\Filament\Filters; use App\Models\Resource\Category; +use Cache; use Closure; use Filament\Forms\Components\Select; use Filament\Tables\Filters\BaseFilter; +use Illuminate\Database\Eloquent\Builder; class ResourceTreeFilter extends BaseFilter { @@ -29,9 +31,13 @@ protected function setUp(): void { parent::setUp(); - $categories = Category::query() - ->with('subcategories.types') - ->get(); + $categories = Cache::driver('array') + ->rememberForever( + 'resource-tree-filter-categories', + fn () => Category::query() + ->with('subcategories.types') + ->get() + ); $this->form(fn () => [ Select::make('category') @@ -61,6 +67,18 @@ protected function setUp(): void ->pluck('name', 'id') ) ->hidden(fn (Select $component) => empty($component->getOptions())), - ]); + ]) + ->query(function (Builder $query, array $data) use ($categories) { + $subcategory = $categories->firstWhere('id', $data['category']) + ?->subcategories + ->firstWhere('id', $data['subcategory']); + + $type = $subcategory?->types + ->firstWhere('id', $data['type']); + + return $query->when($data['category'], fn (Builder $query, $value) => $query->where('category_id', $value)) + ->when($subcategory?->id, fn (Builder $query, $value) => $query->where('subcategory_id', $value)) + ->when($type?->id, fn (Builder $query, $value) => $query->whereRelation('types', 'type_id', $value)); + }); } } diff --git a/app/Filament/Resources/OrganisationResource/RelationManagers/ResourcesRelationManager.php b/app/Filament/Resources/OrganisationResource/RelationManagers/ResourcesRelationManager.php index 1e76db5..ca65852 100644 --- a/app/Filament/Resources/OrganisationResource/RelationManagers/ResourcesRelationManager.php +++ b/app/Filament/Resources/OrganisationResource/RelationManagers/ResourcesRelationManager.php @@ -4,6 +4,7 @@ namespace App\Filament\Resources\OrganisationResource\RelationManagers; +use App\Filament\Filters\ResourceTreeFilter; use App\Filament\Forms\FieldGroups; use App\Filament\Resources\ResourceResource; use App\Filament\Tables\Actions\ExportAction; @@ -145,22 +146,14 @@ public static function table(Table $table): Table ->toggleable(), ]) ->filters([ - SelectFilter::make('category') - ->label(__('resource.fields.category')) - ->relationship('category', 'name'), - - SelectFilter::make('subcategory') - ->relationship('subcategory', 'name') - ->label(__('resource.fields.subcategory')), - - SelectFilter::make('type') - ->label(__('resource.fields.type')) - ->relationship('types', 'name'), - SelectFilter::make('county') ->label(__('general.county')) ->relationship('county', 'name'), + ResourceTreeFilter::make('cat') + ->columns(3) + ->columnSpan(3), + ]) ->headerActions([ ExportAction::make(),