Basics
Contains all Basic Methods.
The Fieldset
field allows grouping of fields when displayed in preview mode and wraps them in an HTML fieldset
tag within forms.
The parameter or method fields()
must accept an array of fields to group.
use MoonShine\Laravel\Fields\BelongsTo;use MoonShine\UI\Fields\Fieldset;use MoonShine\UI\Fields\Text; Fieldset::make('Title', [ Text::make('Title'), BelongsTo::make('Author', resource: 'name'),])
Edit View
You can customize the display for Fieldset
using components.
Fieldset::make('Title', [ Text::make('Title'), LineBreak::make(), // adds a line break BelongsTo::make('Author', resource: 'name'),])
Conditional Display
To change the set of components in Fieldset
under certain conditions, you need to pass a condition and sets of components using a callback function.
Fieldset::make('Stack', fn(StackFields $ctx) => $ctx->getData()?->getOriginal()->id === 3 ? [ Date::make('Creation date', 'created_at'), ] : [ Date::make('Creation date', 'created_at'), LineBreak::make(), Email::make('Email', 'email'), ])