mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
MINOR Simplified TableField->saveData() code structure (no logic changes) (merged from branches/2.3-nzct)
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@82078 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
98cc45291b
commit
bc07a4644e
@ -391,8 +391,10 @@ class TableField extends TableListField {
|
||||
* If set to FALSE, it will always create new object (default: TRUE)
|
||||
* @return array Array of saved object IDs in the key, and the status ("Updated") in the value
|
||||
*/
|
||||
function saveData($dataObjects,$ExistingValues = true) {
|
||||
$savedObj = array();
|
||||
function saveData($dataObjects, $existingValues = true) {
|
||||
if(!$dataObjects) return false;
|
||||
|
||||
$savedObjIds = array();
|
||||
$fieldset = $this->FieldSetForRow();
|
||||
|
||||
// add hiddenfields
|
||||
@ -404,10 +406,8 @@ class TableField extends TableListField {
|
||||
|
||||
$form = new Form($this, null, $fieldset, new FieldSet());
|
||||
|
||||
if($dataObjects) {
|
||||
foreach ($dataObjects as $objectid => $fieldValues) {
|
||||
// we have to "sort" new data first,
|
||||
// and process it in a seperate saveData-call (see setValue())
|
||||
// 'new' counts as an empty column, don't save it
|
||||
if($objectid === "new") continue;
|
||||
|
||||
// extra data was creating fields, but
|
||||
@ -415,11 +415,12 @@ class TableField extends TableListField {
|
||||
$fieldValues = array_merge( $this->extraData, $fieldValues );
|
||||
}
|
||||
|
||||
$hasData = false;
|
||||
$obj = new $this->sourceClass();
|
||||
|
||||
if($ExistingValues) {
|
||||
// either look for an existing object, or create a new one
|
||||
if($existingValues) {
|
||||
$obj = DataObject::get_by_id($this->sourceClass, $objectid);
|
||||
} else {
|
||||
$sourceClass = $this->sourceClass;
|
||||
$obj = new $sourceClass();
|
||||
}
|
||||
|
||||
// Legacy: Use the filter as a predefined relationship-ID
|
||||
@ -430,40 +431,36 @@ class TableField extends TableListField {
|
||||
|
||||
// Determine if there is changed data for saving
|
||||
$dataFields = array();
|
||||
|
||||
foreach($fieldValues as $type => $value) {
|
||||
if(is_array($this->extraData)){ // if the field is an actual datafield (not a preset hiddenfield)
|
||||
// if the field is an actual datafield (not a preset hiddenfield)
|
||||
if(is_array($this->extraData)) {
|
||||
if(!in_array($type, array_keys($this->extraData))) {
|
||||
$dataFields[$type] = $value;
|
||||
}
|
||||
} else { // all fields are real
|
||||
// all fields are real
|
||||
} else {
|
||||
$dataFields[$type] = $value;
|
||||
}
|
||||
}
|
||||
|
||||
$dataValues = ArrayLib::array_values_recursive($dataFields);
|
||||
|
||||
// determine if any of the fields have a value (loose checking with empty())
|
||||
$hasData = false;
|
||||
foreach($dataValues as $value) {
|
||||
if(!empty($value)) {
|
||||
$hasData = true;
|
||||
}
|
||||
if(!empty($value)) $hasData = true;
|
||||
}
|
||||
|
||||
// save
|
||||
if($hasData) {
|
||||
$form->loadDataFrom($fieldValues, true);
|
||||
$form->saveInto($obj);
|
||||
|
||||
$objectid = $obj->write();
|
||||
|
||||
$savedObj[$objectid] = "Updated";
|
||||
$savedObjIds[$objectid] = "Updated";
|
||||
}
|
||||
|
||||
}
|
||||
return $savedObj;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $savedObjIds;
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user