FIX Forms now instantiate fields with correct record context on save

This commit is contained in:
Daniel Hensby 2017-07-28 16:09:48 +01:00
parent ff12337e6e
commit ef354511d7
No known key found for this signature in database
GPG Key ID: B00D1E9767F0B06E
2 changed files with 3 additions and 3 deletions

View File

@ -147,7 +147,6 @@ class GridFieldAddNewInlineButton implements GridField_HTMLProvider, GridField_S
$editable = $grid->getConfig()->getComponentByType('GridFieldEditableColumns'); $editable = $grid->getConfig()->getComponentByType('GridFieldEditableColumns');
/** @var GridFieldOrderableRows $sortable */ /** @var GridFieldOrderableRows $sortable */
$sortable = $grid->getConfig()->getComponentByType('GridFieldOrderableRows'); $sortable = $grid->getConfig()->getComponentByType('GridFieldOrderableRows');
$form = $editable->getForm($grid, $record);
if(!singleton($class)->canCreate()) { if(!singleton($class)->canCreate()) {
return; return;
@ -157,6 +156,7 @@ class GridFieldAddNewInlineButton implements GridField_HTMLProvider, GridField_S
$item = $class::create(); $item = $class::create();
$extra = array(); $extra = array();
$form = $editable->getForm($grid, $item);
$form->loadDataFrom($fields, Form::MERGE_CLEAR_MISSING); $form->loadDataFrom($fields, Form::MERGE_CLEAR_MISSING);
$form->saveInto($item); $form->saveInto($item);

View File

@ -94,8 +94,6 @@ class GridFieldEditableColumns extends GridFieldDataColumns implements
/** @var GridFieldOrderableRows $sortable */ /** @var GridFieldOrderableRows $sortable */
$sortable = $grid->getConfig()->getComponentByType('GridFieldOrderableRows'); $sortable = $grid->getConfig()->getComponentByType('GridFieldOrderableRows');
$form = $this->getForm($grid, $record);
foreach($value[__CLASS__] as $id => $fields) { foreach($value[__CLASS__] as $id => $fields) {
if(!is_numeric($id) || !is_array($fields)) { if(!is_numeric($id) || !is_array($fields)) {
continue; continue;
@ -107,6 +105,8 @@ class GridFieldEditableColumns extends GridFieldDataColumns implements
continue; continue;
} }
$form = $this->getForm($grid, $item);
$extra = array(); $extra = array();
$form->loadDataFrom($fields, Form::MERGE_CLEAR_MISSING); $form->loadDataFrom($fields, Form::MERGE_CLEAR_MISSING);