From 779ed6a7d64f796510e7c46d365f82f470307646 Mon Sep 17 00:00:00 2001 From: dhanabalan Date: Sat, 3 Jan 2026 12:39:24 +0530 Subject: [PATCH] Added filter options in product characteristics master resource --- .../ProductCharacteristicsMasterResource.php | 193 +++++++++++++++++- 1 file changed, 192 insertions(+), 1 deletion(-) diff --git a/app/Filament/Resources/ProductCharacteristicsMasterResource.php b/app/Filament/Resources/ProductCharacteristicsMasterResource.php index badf207..79c14d2 100644 --- a/app/Filament/Resources/ProductCharacteristicsMasterResource.php +++ b/app/Filament/Resources/ProductCharacteristicsMasterResource.php @@ -6,6 +6,7 @@ use App\Filament\Exports\ProductCharacteristicsMasterExporter; use App\Filament\Imports\ProductCharacteristicsMasterImporter; use App\Filament\Resources\ProductCharacteristicsMasterResource\Pages; use App\Filament\Resources\ProductCharacteristicsMasterResource\RelationManagers; +use App\Models\Item; use App\Models\Line; use App\Models\Machine; use App\Models\Plant; @@ -22,6 +23,10 @@ use Illuminate\Database\Eloquent\Builder; use Illuminate\Database\Eloquent\SoftDeletingScope; use Filament\Tables\Actions\ImportAction; use Filament\Tables\Actions\ExportAction; +use Filament\Forms\Components\DateTimePicker; +use Filament\Tables\Filters\Filter; +use Filament\Forms\Components\Select; +use Filament\Forms\Components\TextInput; class ProductCharacteristicsMasterResource extends Resource { @@ -302,9 +307,195 @@ class ProductCharacteristicsMasterResource extends Resource ->sortable() ->toggleable(isToggledHiddenByDefault: true), ]) + // ->filters([ + // Tables\Filters\TrashedFilter::make(), + // ]) ->filters([ - Tables\Filters\TrashedFilter::make(), + + Tables\Filters\TrashedFilter::make(), + Filter::make('advanced_filters') + ->label('Advanced Filters') + ->form([ + Select::make('Plant') + ->label('Select Plant') + ->nullable() + ->options(function (callable $get) { + $userHas = Filament::auth()->user()->plant_id; + return ($userHas && strlen($userHas) > 0) ? Plant::where('id', $userHas)->pluck('name', 'id')->toArray() : Plant::pluck('name', 'id')->toArray(); + }) + ->reactive() + ->afterStateUpdated(function ($state, callable $set, callable $get) { + $set('Item', null); + }), + Select::make('Line') + ->label('Select Line') + ->nullable() + ->options(function (callable $get) { + $plantId = $get('Plant'); + + if(empty($plantId)) { + return []; + } + + return Line::where('plant_id', $plantId)->pluck('name', 'id'); + + //return $plantId ? Item::where('plant_id', $plantId)->pluck('code', 'id') : []; + }) + ->reactive() + ->afterStateUpdated(function ($state, callable $set, callable $get) { + $set('Item', null); + }), + Select::make('Item') + ->label('Item Code') + ->nullable() + ->searchable() + ->options(function (callable $get) { + $plantId = $get('Plant'); + + if(empty($plantId)) { + return []; + } + + return Item::where('plant_id', $plantId)->pluck('code', 'id'); + + //return $plantId ? Item::where('plant_id', $plantId)->pluck('code', 'id') : []; + }) + ->reactive() + ->afterStateUpdated(function ($state, callable $set, callable $get) { + $set('process_order', null); + }), + Select::make('work_group_master') + ->label('Select Work Group Master') + ->nullable() + ->options(function (callable $get) { + $plantId = $get('Plant'); + + if(empty($plantId)) { + return []; + } + + return WorkGroupMaster::where('plant_id', $plantId)->pluck('name', 'id'); + + //return $plantId ? Item::where('plant_id', $plantId)->pluck('code', 'id') : []; + }) + ->reactive() + ->afterStateUpdated(function ($state, callable $set, callable $get) { + $set('Machine', null); + }), + Select::make('Machine') + ->label('Select Machine') + ->nullable() + ->options(function (callable $get) { + $plantId = $get('Plant'); + $lineId = $get('Line'); + + if(empty($plantId) || empty($lineId)) { + return []; + } + + return Machine::where('plant_id', $plantId)->where('line_id', $lineId)->pluck('work_center', 'id'); + + //return $plantId ? Item::where('plant_id', $plantId)->pluck('code', 'id') : []; + }) + ->reactive(), + // ->afterStateUpdated(function ($state, callable $set, callable $get) { + // $set('process_order', null); + // }), + // TextInput::make('process_order') + // ->label('Process Order') + // ->placeholder('Enter Process Order'), + // TextInput::make('coil_number') + // ->label('Coil Number') + // ->placeholder(placeholder: 'Enter Coil Number'), + // Select::make('status') + // ->label('Status') + // ->options([ + // 'Ok' => 'OK', + // 'NotOk' => 'Not Ok' + // ]), + DateTimePicker::make(name: 'created_from') + ->label('Created From') + ->placeholder(placeholder: 'Select From DateTime') + ->reactive() + ->native(false), + DateTimePicker::make('created_to') + ->label('Created To') + ->placeholder(placeholder: 'Select To DateTime') + ->reactive() + ->native(false), + ]) + ->query(function ($query, array $data) { + // Hide all records initially if no filters are applied + if (empty($data['Plant']) && empty($data['Line']) && empty($data['Item']) && empty($data['work_group_master']) && empty($data['Machine']) && empty($data['created_from']) && empty($data['created_to'])) { + return $query->whereRaw('1 = 0'); + } + + if (!empty($data['Plant'])) { + $query->where('plant_id', $data['Plant']); + } + + if (!empty($data['Line'])) { + $query->where('line_id', $data['Line']); + } + + if (!empty($data['Item'])) { + $query->where('item_id', $data['Item']); + } + + if (!empty($data['work_group_master'])) { + $query->where('work_group_master_id', $data['work_group_master']); + } + + if (!empty($data['Machine'])) { + $query->where('machine_id', $data['Machine']); + } + + if (!empty($data['created_from'])) { + $query->where('created_at', '>=', $data['created_from']); + } + + if (!empty($data['created_to'])) { + $query->where('created_at', '<=', $data['created_to']); + } + + + //$query->orderBy('created_at', 'asc'); + }) + ->indicateUsing(function (array $data) { + $indicators = []; + + if (!empty($data['Plant'])) { + $indicators[] = 'Plant: ' . Plant::where('id', $data['Plant'])->value('name'); + } + + if (!empty($data['Line'])) { + $indicators[] = 'Line: ' . Line::where('id', $data['Line'])->value('name'); + } + + if (!empty($data['Item'])) { + $indicators[] = 'Item: ' . Item::where('id', $data['Item'])->value('code'); + } + + if (!empty($data['work_group_master'])) { + $indicators[] = 'Work Group Master: ' . WorkGroupMaster::where('id', $data['work_group_master'])->value('name'); + } + + if (!empty($data['Machine'])) { + $indicators[] = 'Machine: ' . Machine::where('id', $data['Machine'])->value('work_center'); + } + + if (!empty($data['created_from'])) { + $indicators[] = 'From: ' . $data['created_from']; + } + + if (!empty($data['created_to'])) { + $indicators[] = 'To: ' . $data['created_to']; + } + + return $indicators; + }) ]) + ->filtersFormMaxHeight('280px') ->actions([ Tables\Actions\ViewAction::make(), Tables\Actions\EditAction::make(), -- 2.49.1