From 4a8802060a27f341ae4d45430dd0404dbbdeb8eb Mon Sep 17 00:00:00 2001 From: dhanabalan Date: Wed, 2 Jul 2025 11:03:12 +0530 Subject: [PATCH] Added filter functionality in locator invoice validation page --- .../LocatorInvoiceValidationResource.php | 226 +++++++++++++++++- 1 file changed, 225 insertions(+), 1 deletion(-) diff --git a/app/Filament/Resources/LocatorInvoiceValidationResource.php b/app/Filament/Resources/LocatorInvoiceValidationResource.php index daba71c9b..5eb1b45cf 100644 --- a/app/Filament/Resources/LocatorInvoiceValidationResource.php +++ b/app/Filament/Resources/LocatorInvoiceValidationResource.php @@ -31,6 +31,9 @@ use Filament\Tables\Actions\ExportAction; use Filament\Tables\Actions\ImportAction; use Storage; use Str; +use Filament\Forms\Components\DateTimePicker; +use Filament\Tables\Filters\Filter; +use Filament\Forms\Components\TextInput; class LocatorInvoiceValidationResource extends Resource { @@ -654,9 +657,230 @@ class LocatorInvoiceValidationResource extends Resource }), ]) - ->filters([ + // ->filters([ + // Tables\Filters\TrashedFilter::make(), + // ]) + + ->filters([ Tables\Filters\TrashedFilter::make(), + Filter::make('advanced_filters') + ->label('Advanced Filters') + ->form([ + Select::make('Plant') + ->label('Select Plant') + ->nullable() + ->options(function () { + return Plant::pluck('name', 'id'); + }) + ->reactive() + ->afterStateUpdated(function ($state, callable $set, callable $get): void { + $set('pallet_number', null); + $set('invoice_number', null); + $set('serial_number', null); + $set('scanned_status', null); + $set('locator_number', null); + $set('created_from', null); + $set('created_to', null); + $set('created_by', null); + $set('scanned_from', null); + $set('scanned_to', null); + $set('scanned_by', null); + }), + Select::make('invoice_number') + ->label('Invoice Number') + ->options(function (callable $get) { + $plantId = $get('Plant'); + if (!$plantId) { + return []; + } + return LocatorInvoiceValidation::where('plant_id', $plantId) + ->whereNotNull('invoice_number') + ->where('invoice_number','!=', '') + ->orderBy('invoice_number', 'asc') + ->get() + ->unique('invoice_number') + ->pluck('invoice_number', 'invoice_number') + ->toArray(); + }) + ->searchable() + ->reactive(), + TextInput::make('serial_number') + ->label('Serial Number') + ->placeholder(placeholder: 'Enter Serial Number'), + + Select::make('pallet_number') + ->label('Pallet Number') + ->options(function (callable $get) { + $plantId = $get('Plant'); + if (!$plantId) { + return []; + } + return LocatorInvoiceValidation::where('plant_id', $plantId) + ->whereNotNull('pallet_number') + ->where('pallet_number','!=', '') + ->orderBy('pallet_number', 'asc') + ->get() + ->unique('pallet_number') + ->pluck('pallet_number', 'pallet_number') + ->toArray(); + }) + ->searchable() + ->reactive(), + Select::make('locator_number') + ->label('Locator Number') + ->options(function (callable $get) { + $plantId = $get('Plant'); + if (!$plantId) { + return []; + } + return LocatorInvoiceValidation::where('plant_id', $plantId) + ->whereNotNull('locator_number') + ->where('locator_number','!=', '') + ->orderBy('locator_number', 'asc') + ->get() + ->unique('locator_number') + ->pluck('locator_number', 'locator_number') + ->toArray(); + }) + ->searchable() + ->reactive(), + Select::make('scanned_status') + ->label('Scanned Status') + ->options([ + 'Scanned' => 'Scanned', + ]), + 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), + TextInput::make('created_by') + ->label('Created By') + ->placeholder(placeholder: 'Enter Created By'), + DateTimePicker::make(name: 'scanned_from') + ->label('Scanned From') + ->placeholder(placeholder: 'Select From DateTime') + ->reactive() + ->native(false), + DateTimePicker::make('scanned_to') + ->label('Scanned To') + ->placeholder(placeholder: 'Select To DateTime') + ->reactive() + ->native(false), + TextInput::make('scanned_by') + ->label('Scanned By') + ->placeholder(placeholder: 'Enter Scanned By'), + ]) + ->query(function ($query, array $data) { + // Hide all records initially if no filters are applied + if (empty($data['Plant']) && empty($data['invoice_number']) && empty($data['serial_number']) && empty($data['pallet_number']) && empty($data['locator_number']) && empty($data['scanned_status']) && empty($data['created_from']) && empty($data['created_to']) && empty($data['created_by']) && empty($data['scanned_from']) && empty($data['scanned_to']) && empty($data['scanned_by'])) { + return $query->whereRaw('1 = 0'); + } + + if (!empty($data['Plant'])) { //$plant = $data['Plant'] ?? null + $query->where('plant_id', $data['Plant']); + } + + if (!empty($data['invoice_number'])) { + $query->where('invoice_number', $data['invoice_number']); + } + + if (!empty($data['serial_number'])) { + $query->where('serial_number', $data['serial_number']); + } + + if (!empty($data['pallet_number'])) { + $query->where('pallet_number', $data['pallet_number']); + } + + if (!empty($data['locator_number'])) { + $query->where('locator_number', $data['locator_number']); + } + if (!empty($data['scanned_status'])) { + $query->where('scanned_status', $data['scanned_status']); + } + + if (!empty($data['created_from'])) { + $query->where('created_at', '>=', $data['created_from']); + } + + if (!empty($data['created_to'])) { + $query->where('created_at', '<=', $data['created_to']); + } + + if (!empty($data['created_by'])) { + $query->where('created_by', $data['created_by']); + } + + if (!empty($data['scanned_from'])) { + $query->where('scanned_at', '>=', $data['scanned_from']); + } + + if (!empty($data['scanned_to'])) { + $query->where('scanned_at', '<=', $data['scanned_to']); + } + + if (!empty($data['scanned_by'])) { + $query->where('scanned_by', $data['scanned_by']); + } + }) + ->indicateUsing(function (array $data) { + $indicators = []; + + if (!empty($data['Plant'])) { + $indicators[] = 'Plant: ' . Plant::where('id', $data['Plant'])->value('name'); + } + + if (!empty($data['invoice_number'])) { + $indicators[] = 'Invoice Number: ' . $data['invoice_number']; + } + + if (!empty($data['serial_number'])) { + $indicators[] = 'Serial Number: ' . $data['serial_number']; + } + + if (!empty($data['pallet_number'])) { + $indicators[] = 'Pallet Number: ' . $data['pallet_number']; + } + + if (!empty($data['locator_number'])) { + $indicators[] = 'Locator Number: ' . $data['locator_number']; + } + + if (!empty($data['scanned_status'])) { + $indicators[] = 'Scanned Status: ' . $data['scanned_status']; + } + + if (!empty($data['created_from'])) { + $indicators[] = 'From: ' . $data['created_from']; + } + + if (!empty($data['created_to'])) { + $indicators[] = 'To: ' . $data['created_to']; + } + + if (!empty($data['created_by'])) { + $indicators[] = 'Created By: ' . $data['created_by']; + } + if (!empty($data['scanned_from'])) { + $indicators[] = 'Scanned From: ' . $data['scanned_from']; + } + if (!empty($data['scanned_to'])) { + $indicators[] = 'Scanned To: ' . $data['scanned_to']; + } + if (!empty($data['scanned_by'])) { + $indicators[] = 'Scanned By: ' . $data['scanned_by']; + } + + return $indicators; + }) ]) + ->filtersFormMaxHeight('280px') ->actions([ Tables\Actions\ViewAction::make(), Tables\Actions\EditAction::make(),