FIX: Let GridFieldEditableColumns edit relations via dot syntax

This is a companion to https://github.com/silverstripe/silverstripe-framework/pull/9192 to provide the same functionality for inline
editing in GridFields

A valuable use of this is editing fields in the join-object of
a many-many-through relation.
This commit is contained in:
Sam Minnee 2019-08-26 12:37:19 +12:00
parent 668b297a30
commit d357479421

View File

@ -82,8 +82,7 @@ class GridFieldEditableColumns extends GridFieldDataColumns implements
$field = clone $field; $field = clone $field;
} else { } else {
$value = $grid->getDataFieldValue($record, $col); $value = $grid->getDataFieldValue($record, $col);
$rel = (strpos($col, '.') === false); // field references a relation value $field = $fields->dataFieldByName($col);
$field = ($rel) ? clone $fields->fieldByName($col) : new ReadonlyField($col);
if (!$field) { if (!$field) {
throw new Exception("Could not find the field '$col'"); throw new Exception("Could not find the field '$col'");
@ -138,10 +137,11 @@ class GridFieldEditableColumns extends GridFieldDataColumns implements
$extra = array(); $extra = array();
$form = $this->getForm($grid, $record); $form = $this->getForm($grid, $item);
$form->loadDataFrom($fields, Form::MERGE_CLEAR_MISSING); $form->loadDataFrom($fields, Form::MERGE_CLEAR_MISSING);
$form->saveInto($item); $form->saveInto($item);
// Check if we are also sorting these records // Check if we are also sorting these records
if ($sortable) { if ($sortable) {
$sortField = $sortable->getSortField(); $sortField = $sortable->getSortField();
@ -154,7 +154,7 @@ class GridFieldEditableColumns extends GridFieldDataColumns implements
$extra = array_intersect_key($form->getData(), (array) $list->getExtraFields()); $extra = array_intersect_key($form->getData(), (array) $list->getExtraFields());
} }
$item->write(); $item->write(false, false, false, true);
$list->add($item, $extra); $list->add($item, $extra);
} }
} }