This field allows you to dynamically fill contents of a select based on values in other dynamic select fields.
Field is based on nova-belongs-to-dependency but instead of selecting model, you can select custom values.
composer require royduin/laravel-nova-field-dynamic-select
Class has 4 special methods on top of default Select from Laravel Nova.
dependsOn
can take a list of other fields this one depends on. On initial page load the list will be null, so make sure to check for null before accessing.default
can take a list of other fields this one depends on.options
can be either an array or a callable.forAction
to indicate that the dynamic select is running in an action.
If its a callable, it will receive array with selected dependency values as first argument and should return an array of items to be shown on the select field.
public function fields(Request $request)
{
return [
ID::make()->sortable(),
DynamicSelect::make('Country', 'country')
->options(['US' => 'United States', 'UK' => 'United Kingdom'])
->rules('required')
,
DynamicSelect::make('Provider', 'provider')
->options(['PR' => 'Premium', 'ST' => 'Standard'])
->rules('required')
,
DynamicSelect::make('Product', 'product')
->dependsOn(['country', 'provider'])
->options(function($values) {
if($values['country'] === 'UK' && $values['provider'] === 'PR') {
return ['A' => 'Fast shipping', 'B' => 'Normal shipping', 'C' => 'Free shipping'];
} else {
return ['A' => 'Fast shipping', 'B' => 'Normal shipping'];
}
})
->default(function ($values) {
if (! $values) {
return null;
}
if ($values['country'] === 'UK') {
return [
'label' => 'Normal shipping',
'value' => 'B'
];
}
})
->rules('required')
,
];
}
public function fields(Request $request)
{
return [
ID::make()->sortable(),
DynamicSelect::make('Country', 'country')
->forAction(self::class)
->options(['US' => 'United States', 'UK' => 'United Kingdom'])
->rules('required')
,
DynamicSelect::make('Provider', 'provider')
->forAction(self::class)
->options(['PR' => 'Premium', 'ST' => 'Standard'])
->rules('required')
,
DynamicSelect::make('Product', 'product')
->forAction(self::class)
->dependsOn(['country', 'provider'])
->options(function($values) {
if($values['country'] === 'UK' && $values['provider'] === 'PR') {
return ['A' => 'Fast shipping', 'B' => 'Normal shipping', 'C' => 'Free shipping'];
} else {
return ['A' => 'Fast shipping', 'B' => 'Normal shipping'];
}
})
->rules('required')
,
];
}