Basics
The RelationRepeater
field is designed for working with HasMany
and HasOne
relationships. It allows you to create, edit, and delete related records directly from the main model's form.
The field automatically syncs related records when saving the main model.
To use the field, you need to specify:
- Field Label
- Relationship Name
- Resource for the related model
use MoonShine\Laravel\Fields\Relationships\RelationRepeater; // ... protected function formFields(): iterable{ return [ RelationRepeater::make('Characteristics', 'characteristics', resource: CharacteristicResource::class) ];}
Field Set
By default, the field uses all form fields from the specified resource. However, you can override the field set using the fields()
method:
use MoonShine\UI\Fields\Text;use MoonShine\UI\Fields\Switcher;use MoonShine\Laravel\Fields\Relationships\RelationRepeater; // ... protected function formFields(): iterable{ return [ RelationRepeater::make('Characteristics', 'characteristics') ->fields([ ID::make(), Text::make('Name', 'name'), Text::make('Value', 'value'), Switcher::make('Active', 'is_active') ]) ];}
The presence of the ID
field is required, otherwise records will always be added.
Vertical Mode
The vertical()
method changes the display of the table from horizontal mode to vertical:
vertical(Closure|bool|null $condition = null)
Example:
RelationRepeater::make('Characteristics', 'characteristics') ->vertical()
Add/Delete
By default, the field allows adding new items. This behavior can be changed using the creatable()
method:
creatable( Closure|bool|null $condition = null, ?int $limit = null, ?ActionButtonContract $button = null)
-
$condition
- the condition under which the method should be applied -
$limit
- limit on the number of possible elements -
$button
- ability to replace the adding button with your own
The ability to delete items is handled by the removable()
method:
removable( Closure|bool|null $condition = null, array $attributes = [])
Example:
RelationRepeater::make('Characteristics', 'characteristics') ->creatable(limit: 5) ->removable()
Buttons
The buttons()
method allows overriding the buttons used in the field:
use MoonShine\UI\Components\ActionButton; RelationRepeater::make('Characteristics', 'characteristics') ->buttons([ ActionButton::make('', '#') ->icon('trash') ->onClick(fn() => 'remove()', 'prevent') ->class('btn-error') ->showInLine() ])
Modifiers
Table Modifier
The modifyTable()
method allows modifying the table (TableBuilder
):
use MoonShine\UI\Components\Table\TableBuilder; RelationRepeater::make('Characteristics', 'characteristics') ->modifyTable( fn(TableBuilder $table, bool $preview) => $table ->customAttributes([ 'class' => 'custom-table' ]) )
Remove Button Modifier
The modifyRemoveButton()
method allows changing the remove button:
use MoonShine\UI\Components\ActionButton; RelationRepeater::make('Characteristics', 'characteristics') ->modifyRemoveButton( fn(ActionButton $button) => $button ->customAttributes([ 'class' => 'btn-secondary' ]) )