FIX DataDifferencer was trying to compare fields, even if the fields didn't exist causing an error.

This commit is contained in:
micmania1 2014-11-24 22:45:21 +00:00
parent 3b3478136d
commit 7384d011e9

View File

@ -77,28 +77,33 @@ class DataDifferencer extends ViewableData {
$diffed = clone $this->toRecord; $diffed = clone $this->toRecord;
$fields = array_keys($this->toRecord->toMap()); $fields = array_keys($this->toRecord->toMap());
} }
$hasOnes = $this->fromRecord->has_one(); $hasOnes = array_merge($this->fromRecord->has_one(), $this->toRecord->has_one());
// Loop through properties // Loop through properties
foreach($fields as $field) { foreach($fields as $field) {
if(in_array($field, $this->ignoredFields)) continue; if(in_array($field, $this->ignoredFields)) continue;
if(in_array($field, array_keys($hasOnes))) continue; if(in_array($field, array_keys($hasOnes))) continue;
if(!$this->fromRecord) { if(!$this->fromRecord) {
$diffed->setField($field, "<ins>" . $this->toRecord->$field . "</ins>"); $diffed->setField($field, "<ins>" . $this->toRecord->$field . "</ins>");
} else if($this->fromRecord->$field != $this->toRecord->$field) { } else if($this->fromRecord->$field != $this->toRecord->$field) {
$diffed->setField($field, Diff::compareHTML($this->fromRecord->$field, $this->toRecord->$field)); $diffed->setField($field, Diff::compareHTML($this->fromRecord->$field, $this->toRecord->$field));
} }
} }
// Loop through has_one // Loop through has_one
foreach($hasOnes as $relName => $relSpec) { foreach($hasOnes as $relName => $relSpec) {
if(in_array($relName, $this->ignoredFields)) continue; if(in_array($relName, $this->ignoredFields)) continue;
// Create the actual column name
$relField = "{$relName}ID"; $relField = "{$relName}ID";
$relObjTo = $this->toRecord->$relName(); $toTitle = '';
if($this->toRecord->hasMethod($relName)) {
$relObjTo = $this->toRecord->$relName();
$toTitle = $relObjTo->hasMethod('Title') || $relObjTo->hasField('Title') ? $relObjTo->Title : '';
}
if(!$this->fromRecord) { if(!$this->fromRecord) {
if($relObjTo) { if($relObjTo) {
if($relObjTo instanceof Image) { if($relObjTo instanceof Image) {
@ -107,28 +112,32 @@ class DataDifferencer extends ViewableData {
// not playing nice with mocked images // not playing nice with mocked images
$diffed->setField($relName, "<ins>" . $relObjTo->getTag() . "</ins>"); $diffed->setField($relName, "<ins>" . $relObjTo->getTag() . "</ins>");
} else { } else {
$diffed->setField($relField, "<ins>" . $relObjTo->Title() . "</ins>"); $diffed->setField($relField, "<ins>" . $toTitle . "</ins>");
} }
} }
} else if($this->fromRecord->$relField != $this->toRecord->$relField) { } else if($this->fromRecord->$relField != $this->toRecord->$relField) {
$relObjFrom = $this->fromRecord->$relName(); $fromTitle = '';
if($relObjFrom instanceof Image) { if($this->fromRecord->hasMethod($relName)) {
$relObjFrom = $this->fromRecord->$relName();
$fromTitle = $relObjFrom->hasMethod('Title') || $relObjFrom->hasField('Title') ? $relObjFrom->Title : '';
}
if(isset($relObjFrom) && $relObjFrom instanceof Image) {
// TODO Use CMSThumbnail (see above) // TODO Use CMSThumbnail (see above)
$diffed->setField( $diffed->setField(
// Using relation name instead of database column name, because of FileField etc. // Using relation name instead of database column name, because of FileField etc.
$relName, $relName,
Diff::compareHTML($relObjFrom->getTag(), $relObjTo->getTag()) Diff::compareHTML($relObjFrom->getTag(), $relObjTo->getTag())
); );
} else { } else {
// Set the field.
$diffed->setField( $diffed->setField(
$relField, $relField,
Diff::compareHTML($relObjFrom->getTitle(), $relObjTo->getTitle()) Diff::compareHTML($fromTitle, $toTitle)
); );
} }
} }
} }
return $diffed; return $diffed;
} }