diff --git a/app/Filament/Resources/PalletValidationResource.php b/app/Filament/Resources/PalletValidationResource.php index 71d817d99..998d805d3 100644 --- a/app/Filament/Resources/PalletValidationResource.php +++ b/app/Filament/Resources/PalletValidationResource.php @@ -254,218 +254,218 @@ class PalletValidationResource extends Resource ->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('serial_number', null); - $set('pallet_status', null); - $set('locator_number', null); - $set('locator_quantity', 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('pallet_number') - ->label('Pallet Number') - ->options(function (callable $get) { - $plantId = $get('Plant'); - if (!$plantId) { - return []; - } - return PalletValidation::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(), - TextInput::make('serial_number') - ->label('Serial Number') - ->placeholder(placeholder: 'Enter Serial Number'), - Select::make('pallet_status') - ->label('Pallet Status') - ->options([ - 'Completed' => 'Completed', - ]), - Select::make('locator_number') - ->label('Locator Number') - ->options(function (callable $get) { - $plantId = $get('Plant'); - if (!$plantId) { - return []; - } - return PalletValidation::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('locator_quantity') - ->label('Locator Quantity') - ->options([ - 0 => 0, - 1 => 1, - 2 => 2, - ]) - ->reactive(), - 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['pallet_number']) && empty($data['serial_number']) && empty($data['pallet_status']) && empty($data['locator_number']) && $data['locator_quantity'] == null && 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'); - } + ->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('serial_number', null); + $set('pallet_status', null); + $set('locator_number', null); + $set('locator_quantity', 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('pallet_number') + ->label('Pallet Number') + ->options(function (callable $get) { + $plantId = $get('Plant'); + if (!$plantId) { + return []; + } + return PalletValidation::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(), + TextInput::make('serial_number') + ->label('Serial Number') + ->placeholder(placeholder: 'Enter Serial Number'), + Select::make('pallet_status') + ->label('Pallet Status') + ->options([ + 'Completed' => 'Completed', + ]), + Select::make('locator_number') + ->label('Locator Number') + ->options(function (callable $get) { + $plantId = $get('Plant'); + if (!$plantId) { + return []; + } + return PalletValidation::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('locator_quantity') + ->label('Locator Quantity') + ->options([ + 0 => 0, + 1 => 1, + 2 => 2, + ]) + ->reactive(), + 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['pallet_number']) && empty($data['serial_number']) && empty($data['pallet_status']) && empty($data['locator_number']) && $data['locator_quantity'] == null && 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['Plant'])) { //$plant = $data['Plant'] ?? null + $query->where('plant_id', $data['Plant']); + } - if (!empty($data['pallet_number'])) { - $query->where('pallet_number', $data['pallet_number']); - } + if (!empty($data['pallet_number'])) { + $query->where('pallet_number', $data['pallet_number']); + } - if (!empty($data['serial_number'])) { - $query->where('serial_number', $data['serial_number']); - } + if (!empty($data['serial_number'])) { + $query->where('serial_number', $data['serial_number']); + } - if (!empty($data['pallet_status'])) { - $query->where('pallet_status', $data['pallet_status']); - } + if (!empty($data['pallet_status'])) { + $query->where('pallet_status', $data['pallet_status']); + } - if (!empty($data['locator_number'])) { - $query->where('locator_number', $data['locator_number']); - } + if (!empty($data['locator_number'])) { + $query->where('locator_number', $data['locator_number']); + } - // if (!empty($data['locator_quantity'])) { - // $query->where('locator_quantity', $data['locator_quantity']); - // } + // if (!empty($data['locator_quantity'])) { + // $query->where('locator_quantity', $data['locator_quantity']); + // } - if ($data['locator_quantity'] != null && $data['locator_quantity'] != '') { //isset($data['locator_quantity']) && - $query->where('locator_quantity', $data['locator_quantity']);//(int) - } + if ($data['locator_quantity'] != null && $data['locator_quantity'] != '') { //isset($data['locator_quantity']) && + $query->where('locator_quantity', $data['locator_quantity']);//(int) + } - if (!empty($data['created_from'])) { - $query->where('created_at', '>=', $data['created_from']); - } + 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_to'])) { + $query->where('created_at', '<=', $data['created_to']); + } - if (!empty($data['created_by'])) { - $query->where('created_by', $data['created_by']); - } + 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_from'])) { + $query->where('scanned_at', '>=', $data['scanned_from']); + } - if (!empty($data['scanned_to'])) { - $query->where('scanned_at', '<=', $data['scanned_to']); - } + 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['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['Plant'])) { + $indicators[] = 'Plant: ' . Plant::where('id', $data['Plant'])->value('name'); + } - if (!empty($data['pallet_number'])) { - $indicators[] = 'Pallet Number: ' . $data['pallet_number']; - } + if (!empty($data['pallet_number'])) { + $indicators[] = 'Pallet Number: ' . $data['pallet_number']; + } - if (!empty($data['serial_number'])) { - $indicators[] = 'Serial Number: ' . $data['serial_number']; - } + if (!empty($data['serial_number'])) { + $indicators[] = 'Serial Number: ' . $data['serial_number']; + } - if (!empty($data['pallet_status'])) { - $indicators[] = 'Pallet Status: ' . $data['pallet_status']; - } + if (!empty($data['pallet_status'])) { + $indicators[] = 'Pallet Status: ' . $data['pallet_status']; + } - if (!empty($data['locator_number'])) { - $indicators[] = 'Locator Number: ' . $data['locator_number']; - } + if (!empty($data['locator_number'])) { + $indicators[] = 'Locator Number: ' . $data['locator_number']; + } - // if (!empty($data['locator_quantity'])) { - // $indicators[] = 'Locator Quantity: ' . $data['locator_quantity']; - // } - if (isset($data['locator_quantity']) && $data['locator_quantity'] !== '') { - $indicators[] = 'Locator Quantity: ' . $data['locator_quantity']; - } + // if (!empty($data['locator_quantity'])) { + // $indicators[] = 'Locator Quantity: ' . $data['locator_quantity']; + // } + if ($data['locator_quantity'] != null && $data['locator_quantity'] != '') { //isset($data['locator_quantity']) && + $indicators[] = 'Locator Quantity: ' . $data['locator_quantity']; + } - if (!empty($data['created_from'])) { - $indicators[] = 'From: ' . $data['created_from']; - } + if (!empty($data['created_from'])) { + $indicators[] = 'From: ' . $data['created_from']; + } - if (!empty($data['created_to'])) { - $indicators[] = 'To: ' . $data['created_to']; - } + 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']; - } + 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; - }) + return $indicators; + }) ]) ->filtersFormMaxHeight('280px') ->actions([ @@ -484,38 +484,37 @@ class PalletValidationResource extends Resource Tables\Actions\Action::make('reprint_pallet') ->label('Re-Print Pallet QR') ->form([ - Forms\Components\Section::make() - ->schema([ - Forms\Components\Select::make('plant') - ->label('Select Plant') - ->options(Plant::pluck('name', 'id')->toArray()) - ->required() - ->reactive() - ->columnSpan(2), + Forms\Components\Section::make() + ->schema([ + Forms\Components\Select::make('plant') + ->label('Select Plant') + ->options(Plant::pluck('name', 'id')->toArray()) + ->required() + ->reactive() + ->columnSpan(2), + Forms\Components\Select::make('pallet_list') + ->label('Select Pallet') + ->searchable() + ->required() + ->reactive() + ->columnSpan(1) + ->options(function (callable $get) { + $plantId = $get('plant'); - Forms\Components\Select::make('pallet_list') - ->label('Select Pallet') - ->searchable() - ->required() - ->reactive() - ->columnSpan(1) - ->options(function (callable $get) { - $plantId = $get('plant'); + if (!$plantId) { + return []; + } - if (!$plantId) { - return []; - } - - return PalletValidation::query() - ->where('plant_id', $plantId) - ->whereNotNull('pallet_number') - ->where('pallet_number', '!=', '') - ->select('pallet_number') - ->distinct() - ->orderBy('pallet_number') - ->pluck('pallet_number', 'pallet_number') - ->toArray(); - }), + return PalletValidation::query() + ->where('plant_id', $plantId) + ->whereNotNull('pallet_number') + ->where('pallet_number', '!=', '') + ->select('pallet_number') + ->distinct() + ->orderBy('pallet_number') + ->pluck('pallet_number', 'pallet_number') + ->toArray(); + }), ]) ->columns(['default' => 1, 'sm' => 3]), ])