Compare commits

...

4 Commits

Author SHA1 Message Date
Guy Sartorelli
436712467b
Merge a9481b7ca2 into b3337c7574 2024-09-26 05:31:27 +12:00
github-actions
b3337c7574 Merge branch '6' into 7 2024-09-25 08:44:51 +00:00
Guy Sartorelli
a80265a7da
Merge pull request #1330 from silverstripe-terraformers/feature/injectable-config
ENH: Injectable GridField config components.
2024-09-24 13:53:58 +12:00
Mojmir Fendek
2d6423e3d0 ENH: Injectable GridField config components. 2024-09-19 14:55:46 +12:00

View File

@ -66,7 +66,7 @@ class UserFormFieldEditorExtension extends Extension
{ {
$fieldEditor = $this->getFieldEditorGrid(); $fieldEditor = $this->getFieldEditorGrid();
$fields->insertAfter('Main', new Tab('FormFields', _t(__CLASS__.'.FORMFIELDS', 'Form Fields'))); $fields->insertAfter('Main', Tab::create('FormFields', _t(__CLASS__.'.FORMFIELDS', 'Form Fields')));
$fields->addFieldToTab('Root.FormFields', $fieldEditor); $fields->addFieldToTab('Root.FormFields', $fieldEditor);
return $fields; return $fields;
@ -87,7 +87,7 @@ class UserFormFieldEditorExtension extends Extension
$this->createInitialFormStep(true); $this->createInitialFormStep(true);
$editableColumns = new GridFieldEditableColumns(); $editableColumns = GridFieldEditableColumns::create();
$fieldClasses = singleton(EditableFormField::class)->getEditableFieldClasses(); $fieldClasses = singleton(EditableFormField::class)->getEditableFieldClasses();
$editableColumns->setDisplayFields([ $editableColumns->setDisplayFields([
'ClassName' => function ($record, $column, $grid) use ($fieldClasses) { 'ClassName' => function ($record, $column, $grid) use ($fieldClasses) {
@ -109,7 +109,7 @@ class UserFormFieldEditorExtension extends Extension
$config = GridFieldConfig::create() $config = GridFieldConfig::create()
->addComponents( ->addComponents(
$editableColumns, $editableColumns,
new GridFieldButtonRow(), GridFieldButtonRow::create(),
(new GridFieldAddClassesButton(EditableTextField::class)) (new GridFieldAddClassesButton(EditableTextField::class))
->setButtonName(_t(__CLASS__.'.ADD_FIELD', 'Add Field')) ->setButtonName(_t(__CLASS__.'.ADD_FIELD', 'Add Field'))
->setButtonClass('btn-primary'), ->setButtonClass('btn-primary'),
@ -119,13 +119,13 @@ class UserFormFieldEditorExtension extends Extension
(new GridFieldAddClassesButton([EditableFieldGroup::class, EditableFieldGroupEnd::class])) (new GridFieldAddClassesButton([EditableFieldGroup::class, EditableFieldGroupEnd::class]))
->setButtonName(_t(__CLASS__.'.ADD_FIELD_GROUP', 'Add Field Group')) ->setButtonName(_t(__CLASS__.'.ADD_FIELD_GROUP', 'Add Field Group'))
->setButtonClass('btn-secondary'), ->setButtonClass('btn-secondary'),
$editButton = new GridFieldEditButton(), $editButton = GridFieldEditButton::create(),
new GridFieldDeleteAction(), GridFieldDeleteAction::create(),
new GridFieldToolbarHeader(), GridFieldToolbarHeader::create(),
new GridFieldOrderableRows('Sort'), GridFieldOrderableRows::create('Sort'),
new GridFieldDetailForm(), GridFieldDetailForm::create(),
// Betterbuttons prev and next is enabled by adding a GridFieldPaginator component // Betterbuttons prev and next is enabled by adding a GridFieldPaginator component
new GridFieldPaginator(999) GridFieldPaginator::create(999)
); );
$editButton->removeExtraClass('grid-field__icon-action--hidden-on-hover'); $editButton->removeExtraClass('grid-field__icon-action--hidden-on-hover');