Components

FieldsGroup

Basics

The FieldsGroup component is designed for the quick grouping of a set of fields, filling them with data, and changing their states.

You can create a FieldsGroup by using the static method make() of the FieldsGroup class.

make(iterable $components = [])
make(iterable $components = [])

$components - a set of FieldContract.

use MoonShine\UI\Components\FieldsGroup; FieldsGroup::make([ Text::make('Title'), Email::make('Email'), ]);
use MoonShine\UI\Components\FieldsGroup;
 
FieldsGroup::make([
Text::make('Title'),
Email::make('Email'),
]);

Filling with data

To fill all fields with data, use the fill() method:

fill(array $raw = [], ?DataWrapperContract $casted = null, int $index = 0)
fill(array $raw = [], ?DataWrapperContract $casted = null, int $index = 0)
FieldsGroup::make($fields)->fill($data);
FieldsGroup::make($fields)->fill($data);

Preview mode

You can switch all fields in the set to preview mode using the previewMode() method:

FieldsGroup::make($fields)->previewMode();
FieldsGroup::make($fields)->previewMode();

Without wrappers mode

You can switch all fields in the set to without wrappers mode using the withoutWrappers() method:

Wrappers - fields that implement the FieldsWrapperContract interface, for example, StackFields. Therefore, when using the withoutWrappers method, all nested fields will be extracted from the wrapper field, and the wrapper field itself will not be included in the final set.

FieldsGroup::make($fields)->withoutWrappers();
FieldsGroup::make($fields)->withoutWrappers();

Mass field modification

All the methods described above use the mapFields() method under the hood, which allows you to iterate through all elements in the set and change their state:

FieldsGroup::make($fields)->mapFields(fn(FieldContract $field, int $index): FieldContract => $field);
FieldsGroup::make($fields)->mapFields(fn(FieldContract $field, int $index): FieldContract => $field);