Loading foreign key value while update
This commit is contained in:
@@ -8,6 +8,7 @@ use App\Filament\Resources\LineResource\RelationManagers;
|
||||
use App\Models\Line;
|
||||
use Filament\Forms;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Forms\Get;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Tables;
|
||||
use Filament\Tables\Actions\ImportAction;
|
||||
@@ -33,97 +34,101 @@ class LineResource extends Resource
|
||||
Section::make('')
|
||||
->schema([
|
||||
Forms\Components\Select::make('plant_id')
|
||||
->relationship('plant', 'name')
|
||||
->required()
|
||||
// ->nullable(),
|
||||
->reactive()
|
||||
// ->afterStateUpdated(fn ($set) => $set('block_id', null) & $set('name', null) & $set('start_time', null) & $set('duration', null) & $set('end_time', null))
|
||||
->afterStateUpdated(function ($state, callable $set, callable $get) {
|
||||
$plantId = $get('plant_id');
|
||||
// Ensure `linestop_id` is not cleared
|
||||
if (!$plantId) {
|
||||
$set('lPlantError', 'Please select a plant first.');
|
||||
return;
|
||||
}
|
||||
else
|
||||
{
|
||||
$set('lPlantError', null);
|
||||
}
|
||||
})
|
||||
->extraAttributes(fn ($get) => [
|
||||
'class' => $get('lPlantError') ? 'border-red-500' : '',
|
||||
])
|
||||
->hint(fn ($get) => $get('lPlantError') ? $get('lPlantError') : null)
|
||||
->hintColor('danger'),
|
||||
Forms\Components\TextInput::make('name')
|
||||
->required()
|
||||
->placeholder('Scan the valid name')
|
||||
// ->unique(
|
||||
// ignoreRecord: true,
|
||||
// modifyRuleUsing: function (Unique $rule) {
|
||||
// return $rule->where('plant_id', $this->data['plant_id']);
|
||||
// }
|
||||
// )
|
||||
// ->rule(function () {
|
||||
// return function ($attribute, $value, $fail) {
|
||||
// $exists = Line::where('name', $value)
|
||||
// ->where('plant_id', request()->input('plant_id'))
|
||||
// ->exists();
|
||||
|
||||
// if ($exists) {
|
||||
// $fail('The combination of name and plant ID must be unique.');
|
||||
// }
|
||||
// };
|
||||
// })
|
||||
->reactive()
|
||||
->afterStateUpdated(function ($state, callable $set, callable $get) {
|
||||
$lineNam = $get('name');
|
||||
// Ensure `linestop_id` is not cleared
|
||||
if (!$lineNam) {
|
||||
$set('lNameError', 'Scan the valid name.');
|
||||
return;
|
||||
}
|
||||
else
|
||||
{
|
||||
$exists = Line::where('name', $lineNam)
|
||||
->where('plant_id', $get('plant_id'))
|
||||
->exists();
|
||||
|
||||
if ($exists) {
|
||||
$set('name', null);
|
||||
$set('lNameError', 'The name has already been taken.');
|
||||
// $set('lNameError', 'The combination of name and plant ID must be unique.');
|
||||
->relationship('plant', 'name')
|
||||
->required()
|
||||
// ->nullable(),
|
||||
->reactive()
|
||||
->disabled(fn (Get $get) => !empty($get('id')))
|
||||
// ->afterStateUpdated(fn ($set) => $set('block_id', null) & $set('name', null) & $set('start_time', null) & $set('duration', null) & $set('end_time', null))
|
||||
->afterStateUpdated(function ($state, callable $set, callable $get) {
|
||||
$plantId = $get('plant_id');
|
||||
// Ensure `linestop_id` is not cleared
|
||||
if (!$plantId) {
|
||||
$set('lPlantError', 'Please select a plant first.');
|
||||
return;
|
||||
}
|
||||
$set('lNameError', null);
|
||||
}
|
||||
})
|
||||
->extraAttributes(fn ($get) => [
|
||||
'class' => $get('lNameError') ? 'border-red-500' : '',
|
||||
])
|
||||
->hint(fn ($get) => $get('lNameError') ? $get('lNameError') : null)
|
||||
->hintColor('danger'),
|
||||
Forms\Components\TextInput::make('type')
|
||||
->required()
|
||||
->placeholder('Scan the valid type')
|
||||
->reactive()
|
||||
->afterStateUpdated(function ($state, callable $set, callable $get) {
|
||||
$lineTyp = $get('type');
|
||||
// Ensure `linestop_id` is not cleared
|
||||
if (!$lineTyp) {
|
||||
$set('lTypeError', 'Scan the valid type.');
|
||||
return;
|
||||
}
|
||||
else
|
||||
{
|
||||
$set('lTypeError', null);
|
||||
}
|
||||
})
|
||||
->extraAttributes(fn ($get) => [
|
||||
'class' => $get('lTypeError') ? 'border-red-500' : '',
|
||||
])
|
||||
->hint(fn ($get) => $get('lTypeError') ? $get('lTypeError') : null)
|
||||
->hintColor('danger'),
|
||||
else
|
||||
{
|
||||
$set('lPlantError', null);
|
||||
}
|
||||
})
|
||||
->extraAttributes(fn ($get) => [
|
||||
'class' => $get('lPlantError') ? 'border-red-500' : '',
|
||||
])
|
||||
->hint(fn ($get) => $get('lPlantError') ? $get('lPlantError') : null)
|
||||
->hintColor('danger'),
|
||||
Forms\Components\TextInput::make('name')
|
||||
->required()
|
||||
->placeholder('Scan the valid name')
|
||||
// ->unique(
|
||||
// ignoreRecord: true,
|
||||
// modifyRuleUsing: function (Unique $rule) {
|
||||
// return $rule->where('plant_id', $this->data['plant_id']);
|
||||
// }
|
||||
// )
|
||||
// ->rule(function () {
|
||||
// return function ($attribute, $value, $fail) {
|
||||
// $exists = Line::where('name', $value)
|
||||
// ->where('plant_id', request()->input('plant_id'))
|
||||
// ->exists();
|
||||
|
||||
// if ($exists) {
|
||||
// $fail('The combination of name and plant ID must be unique.');
|
||||
// }
|
||||
// };
|
||||
// })
|
||||
->reactive()
|
||||
->afterStateUpdated(function ($state, callable $set, callable $get) {
|
||||
$lineNam = $get('name');
|
||||
// Ensure `linestop_id` is not cleared
|
||||
if (!$lineNam) {
|
||||
$set('lNameError', 'Scan the valid name.');
|
||||
return;
|
||||
}
|
||||
else
|
||||
{
|
||||
$exists = Line::where('name', $lineNam)
|
||||
->where('plant_id', $get('plant_id'))
|
||||
->exists();
|
||||
|
||||
if ($exists) {
|
||||
$set('name', null);
|
||||
$set('lNameError', 'The name has already been taken.');
|
||||
// $set('lNameError', 'The combination of name and plant ID must be unique.');
|
||||
return;
|
||||
}
|
||||
$set('lNameError', null);
|
||||
}
|
||||
})
|
||||
->extraAttributes(fn ($get) => [
|
||||
'class' => $get('lNameError') ? 'border-red-500' : '',
|
||||
])
|
||||
->hint(fn ($get) => $get('lNameError') ? $get('lNameError') : null)
|
||||
->hintColor('danger'),
|
||||
Forms\Components\TextInput::make('type')
|
||||
->required()
|
||||
->placeholder('Scan the valid type')
|
||||
->reactive()
|
||||
->afterStateUpdated(function ($state, callable $set, callable $get) {
|
||||
$lineTyp = $get('type');
|
||||
// Ensure `linestop_id` is not cleared
|
||||
if (!$lineTyp) {
|
||||
$set('lTypeError', 'Scan the valid type.');
|
||||
return;
|
||||
}
|
||||
else
|
||||
{
|
||||
$set('lTypeError', null);
|
||||
}
|
||||
})
|
||||
->extraAttributes(fn ($get) => [
|
||||
'class' => $get('lTypeError') ? 'border-red-500' : '',
|
||||
])
|
||||
->hint(fn ($get) => $get('lTypeError') ? $get('lTypeError') : null)
|
||||
->hintColor('danger'),
|
||||
Forms\Components\TextInput::make('id')
|
||||
->hidden()
|
||||
->readOnly(),
|
||||
])
|
||||
->columns(2),
|
||||
]);
|
||||
|
||||
Reference in New Issue
Block a user