diff --git a/app/Filament/Resources/CharacteristicValueResource.php b/app/Filament/Resources/CharacteristicValueResource.php index f3a0925..5f04806 100644 --- a/app/Filament/Resources/CharacteristicValueResource.php +++ b/app/Filament/Resources/CharacteristicValueResource.php @@ -5,26 +5,25 @@ namespace App\Filament\Resources; use App\Filament\Exports\CharacteristicValueExporter; use App\Filament\Imports\CharacteristicValueImporter; use App\Filament\Resources\CharacteristicValueResource\Pages; -use App\Filament\Resources\CharacteristicValueResource\RelationManagers; use App\Models\CharacteristicValue; use App\Models\Item; use App\Models\Line; use App\Models\Machine; use App\Models\Plant; +use Filament\Facades\Filament; use Filament\Forms; +use Filament\Forms\Components\DateTimePicker; +use Filament\Forms\Components\Select; +use Filament\Forms\Components\TextInput; use Filament\Forms\Form; use Filament\Resources\Resource; use Filament\Tables; +use Filament\Tables\Actions\ExportAction; +use Filament\Tables\Actions\ImportAction; +use Filament\Tables\Filters\Filter; use Filament\Tables\Table; use Illuminate\Database\Eloquent\Builder; use Illuminate\Database\Eloquent\SoftDeletingScope; -use Filament\Facades\Filament; -use Filament\Forms\Components\DateTimePicker; -use Filament\Tables\Filters\Filter; -use Filament\Forms\Components\Select; -use Filament\Forms\Components\TextInput; -use Filament\Tables\Actions\ExportAction; -use Filament\Tables\Actions\ImportAction; class CharacteristicValueResource extends Resource { @@ -65,7 +64,7 @@ class CharacteristicValueResource extends Resource Forms\Components\Select::make('line_id') ->label('Line') ->options(function (callable $get) { - if (!$get('plant_id')) { + if (! $get('plant_id')) { return []; } @@ -86,7 +85,7 @@ class CharacteristicValueResource extends Resource Forms\Components\Select::make('item_id') ->label('Item') ->options(function (callable $get) { - if (!$get('plant_id') || !$get('line_id')) { + if (! $get('plant_id') || ! $get('line_id')) { return []; } @@ -107,7 +106,7 @@ class CharacteristicValueResource extends Resource Forms\Components\Select::make('machine_id') ->label('Machine') ->options(function (callable $get) { - if (!$get('plant_id') || !$get('line_id') || !$get('item_id')) { + if (! $get('plant_id') || ! $get('line_id') || ! $get('item_id')) { return []; } @@ -192,7 +191,7 @@ class CharacteristicValueResource extends Resource ->label('Status') ->options([ 'Ok' => 'OK', - 'NotOk' => 'Not Ok' + 'NotOk' => 'Not Ok', ]) ->reactive() ->required(), @@ -287,186 +286,198 @@ class CharacteristicValueResource extends Resource // ]) ->filters([ - 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) { + 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)) { + if (empty($plantId)) { return []; } return Line::where('plant_id', $plantId)->pluck('name', 'id'); - //return $plantId ? 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('Item', null); - }), - Select::make('Item') - ->label('Item Code') - ->nullable() - ->searchable() - ->options(function (callable $get) { + ->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)) { + if (empty($plantId)) { return []; } return Item::where('plant_id', $plantId)->pluck('code', 'id'); - //return $plantId ? 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('Machine') - ->label('Select Machine') - ->nullable() - ->options(function (callable $get) { + ->reactive() + ->afterStateUpdated(function ($state, callable $set, callable $get) { + $set('process_order', null); + }), + Select::make('Machine') + ->label('Select Machine') + ->nullable() + ->options(function (callable $get) { $plantId = $get('Plant'); $lineId = $get('Line'); - if(empty($plantId) || empty($lineId)) { + 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') : []; + // 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['Machine']) && empty($data['process_order']) && empty($data['coil_number']) && empty($data['status']) && empty($data['created_from']) && empty($data['created_to'])) { - return $query->whereRaw('1 = 0'); - } + ->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['Machine']) && empty($data['process_order']) && empty($data['coil_number']) && empty($data['status']) && 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['Plant'])) { + $query->where('plant_id', $data['Plant']); + } else { + $userHas = Filament::auth()->user()->plant_id; - if (!empty($data['Line'])) { - $query->where('line_id', $data['Line']); - } + if ($userHas && strlen($userHas) > 0) { + return $query->whereRaw('1 = 0'); + } + } - if (!empty($data['Item'])) { - $query->where('item_id', $data['Item']); - } + if (! empty($data['Line'])) { + $query->where('line_id', $data['Line']); + } - if (!empty($data['Machine'])) { - $query->where('machine_id', $data['Machine']); - } + if (! empty($data['Item'])) { + $query->where('item_id', $data['Item']); + } - if (!empty($data['process_order'])) { - $query->where('process_order', $data['process_order']); - } + if (! empty($data['Machine'])) { + $query->where('machine_id', $data['Machine']); + } - if (!empty($data['coil_number'])) { - $query->where('coil_number', $data['coil_number']); - } + if (! empty($data['process_order'])) { + $query->where('process_order', $data['process_order']); + } - if (!empty($data['status'])) { - $query->where('status', $data['status']); - } + if (! empty($data['coil_number'])) { + $query->where('coil_number', $data['coil_number']); + } - if (!empty($data['created_from'])) { - $query->where('created_at', '>=', $data['created_from']); - } + if (! empty($data['status'])) { + $query->where('status', $data['status']); + } - if (!empty($data['created_to'])) { - $query->where('created_at', '<=', $data['created_to']); - } + 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 = []; + // $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['Plant'])) { + $indicators[] = 'Plant: '.Plant::where('id', $data['Plant'])->value('name'); + } else { + $userHas = Filament::auth()->user()->plant_id; - if (!empty($data['Line'])) { - $indicators[] = 'Line: ' . Line::where('id', $data['Line'])->value('name'); - } + if ($userHas && strlen($userHas) > 0) { + return 'Plant: Choose plant to filter records.'; + } + } - if (!empty($data['Item'])) { - $indicators[] = 'Item: ' . Item::where('id', $data['Item'])->value('code'); - } + if (! empty($data['Line'])) { + $indicators[] = 'Line: '.Line::where('id', $data['Line'])->value('name'); + } - if (!empty($data['Machine'])) { - $indicators[] = 'Machine: ' . Machine::where('id', $data['Machine'])->value('work_center'); - } + if (! empty($data['Item'])) { + $indicators[] = 'Item: '.Item::where('id', $data['Item'])->value('code'); + } - if (!empty($data['process_order'])) { - $indicators[] = 'Process Order: ' . $data['process_order']; - } + if (! empty($data['Machine'])) { + $indicators[] = 'Machine: '.Machine::where('id', $data['Machine'])->value('work_center'); + } - if (!empty($data['coil_number'])) { - $indicators[] = 'Coil Number: ' . $data['coil_number']; - } + if (! empty($data['process_order'])) { + $indicators[] = 'Process Order: '.$data['process_order']; + } - if (!empty($data['status'])) { - $indicators[] = 'Status: ' . $data['status']; - } + if (! empty($data['coil_number'])) { + $indicators[] = 'Coil Number: '.$data['coil_number']; + } - if (!empty($data['created_from'])) { - $indicators[] = 'From: ' . $data['created_from']; - } + if (! empty($data['status'])) { + $indicators[] = 'Status: '.$data['status']; + } - if (!empty($data['created_to'])) { - $indicators[] = 'To: ' . $data['created_to']; - } + if (! empty($data['created_from'])) { + $indicators[] = 'From: '.$data['created_from']; + } - return $indicators; - }) + if (! empty($data['created_to'])) { + $indicators[] = 'To: '.$data['created_to']; + } + + return $indicators; + }), ]) ->filtersFormMaxHeight('280px') ->actions([