mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
ENHANCEMENT: Improvements to DataDifferencer for cmsworkflow.
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/branches/2.3@81475 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
616161b0c6
commit
1d31b59b24
@ -37,7 +37,12 @@ class DataDifferencer extends ViewableData {
|
|||||||
|
|
||||||
protected $ignoredFields = array("ID","Version","RecordID");
|
protected $ignoredFields = array("ID","Version","RecordID");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Construct a DataDifferencer to show the changes between $fromRecord and $toRecord.
|
||||||
|
* If $fromRecord is null, this will represent a "creation".
|
||||||
|
*/
|
||||||
function __construct($fromRecord, $toRecord) {
|
function __construct($fromRecord, $toRecord) {
|
||||||
|
if(!$toRecord) user_error("DataDifferencer constructed without a toRecord", E_USER_WARNING);
|
||||||
$this->fromRecord = $fromRecord;
|
$this->fromRecord = $fromRecord;
|
||||||
$this->toRecord = $toRecord;
|
$this->toRecord = $toRecord;
|
||||||
}
|
}
|
||||||
@ -52,14 +57,25 @@ class DataDifferencer extends ViewableData {
|
|||||||
$this->ignoredFields = array_merge($this->ignoredFields, $ignoredFields);
|
$this->ignoredFields = array_merge($this->ignoredFields, $ignoredFields);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a DataObject with altered values replaced with HTML diff strings, incorporating
|
||||||
|
* <ins> and <del> tags.
|
||||||
|
*/
|
||||||
function diffedData() {
|
function diffedData() {
|
||||||
$diffed = clone $this->fromRecord;
|
if($this->fromRecord) {
|
||||||
$fields = array_keys($diffed->getAllFields());
|
$diffed = clone $this->fromRecord;
|
||||||
|
$fields = array_keys($diffed->getAllFields());
|
||||||
|
} else {
|
||||||
|
$diffed = clone $this->toRecord;
|
||||||
|
$fields = array_keys($this->toRecord->getAllFields());
|
||||||
|
}
|
||||||
|
|
||||||
foreach($fields as $field) {
|
foreach($fields as $field) {
|
||||||
if(in_array($field, $this->ignoredFields)) continue;
|
if(in_array($field, $this->ignoredFields)) continue;
|
||||||
|
|
||||||
if($this->fromRecord->$field != $this->toRecord->$field) {
|
if(!$this->fromRecord) {
|
||||||
|
$diffed->$field = "<ins>" . $this->toRecord->$field . "</ins>";
|
||||||
|
} else if($this->fromRecord->$field != $this->toRecord->$field) {
|
||||||
$diffed->$field = Diff::compareHTML($this->fromRecord->$field, $this->toRecord->$field);
|
$diffed->$field = Diff::compareHTML($this->fromRecord->$field, $this->toRecord->$field);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -67,21 +83,62 @@ class DataDifferencer extends ViewableData {
|
|||||||
return $diffed;
|
return $diffed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a DataObjectSet of the changed fields.
|
||||||
|
* Each element is an array data containing
|
||||||
|
* - Name: The field name
|
||||||
|
* - Title: The human-readable field title
|
||||||
|
* - Diff: An HTML diff showing the changes
|
||||||
|
* - From: The older version of the field
|
||||||
|
* - To: The newer version of the field
|
||||||
|
*/
|
||||||
function ChangedFields() {
|
function ChangedFields() {
|
||||||
$changedFields = new DataObjectSet();
|
$changedFields = new DataObjectSet();
|
||||||
$fields = array_keys($this->fromRecord->getAllFields());
|
|
||||||
|
if($this->fromRecord) {
|
||||||
|
$base = $this->fromRecord;
|
||||||
|
$fields = array_keys($this->fromRecord->getAllFields());
|
||||||
|
} else {
|
||||||
|
$base = $this->toRecord;
|
||||||
|
$fields = array_keys($this->toRecord->getAllFields());
|
||||||
|
}
|
||||||
|
|
||||||
foreach($fields as $field) {
|
foreach($fields as $field) {
|
||||||
if(in_array($field, $this->ignoredFields)) continue;
|
if(in_array($field, $this->ignoredFields)) continue;
|
||||||
|
|
||||||
if($this->fromRecord->$field != $this->toRecord->$field) {
|
if(!$this->fromRecord || $this->fromRecord->$field != $this->toRecord->$field) {
|
||||||
$changedFields->push(new ArrayData(array(
|
$changedFields->push(new ArrayData(array(
|
||||||
'Title' => $this->fromRecord->fieldLabel($field),
|
'Name' => $field,
|
||||||
'Diff' => Diff::compareHTML($this->fromRecord->$field, $this->toRecord->$field),
|
'Title' => $base->fieldLabel($field),
|
||||||
|
'Diff' => $this->fromRecord
|
||||||
|
? Diff::compareHTML($this->fromRecord->$field, $this->toRecord->$field)
|
||||||
|
: "<ins>" . $this->toRecord->$field . "</ins>",
|
||||||
|
'From' => $this->fromRecord ? $this->fromRecord->$field : null,
|
||||||
|
'To' => $this->toRecord ? $this->toRecord->$field : null,
|
||||||
)));
|
)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $changedFields;
|
return $changedFields;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
/**
|
||||||
|
* Get an array of the names of every fields that has changed.
|
||||||
|
* This is simpler than {@link ChangedFields()}
|
||||||
|
*/
|
||||||
|
function changedFieldNames() {
|
||||||
|
$diffed = clone $this->fromRecord;
|
||||||
|
$fields = array_keys($diffed->getAllFields());
|
||||||
|
|
||||||
|
$changedFields = array();
|
||||||
|
|
||||||
|
foreach($fields as $field) {
|
||||||
|
if(in_array($field, $this->ignoredFields)) continue;
|
||||||
|
if($this->fromRecord->$field != $this->toRecord->$field) {
|
||||||
|
$changedFields[] = $field;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $changedFields;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user