mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 08:05:56 +02:00
Fix history comparison fields will now show diff properly, rather than escaped html diff
This commit is contained in:
parent
18a6fa05e8
commit
2fafff084f
@ -7,10 +7,12 @@ use SilverStripe\Control\Controller;
|
|||||||
use SilverStripe\Control\HTTPRequest;
|
use SilverStripe\Control\HTTPRequest;
|
||||||
use SilverStripe\Control\HTTPResponse;
|
use SilverStripe\Control\HTTPResponse;
|
||||||
use SilverStripe\Forms\CheckboxField;
|
use SilverStripe\Forms\CheckboxField;
|
||||||
|
use SilverStripe\Forms\CompositeField;
|
||||||
use SilverStripe\Forms\FieldList;
|
use SilverStripe\Forms\FieldList;
|
||||||
use SilverStripe\Forms\Form;
|
use SilverStripe\Forms\Form;
|
||||||
use SilverStripe\Forms\FormAction;
|
use SilverStripe\Forms\FormAction;
|
||||||
use SilverStripe\Forms\HiddenField;
|
use SilverStripe\Forms\HiddenField;
|
||||||
|
use SilverStripe\Forms\HTMLReadonlyField;
|
||||||
use SilverStripe\Forms\LiteralField;
|
use SilverStripe\Forms\LiteralField;
|
||||||
use SilverStripe\ORM\FieldType\DBField;
|
use SilverStripe\ORM\FieldType\DBField;
|
||||||
use SilverStripe\ORM\FieldType\DBHTMLText;
|
use SilverStripe\ORM\FieldType\DBHTMLText;
|
||||||
@ -450,21 +452,16 @@ class CMSPageHistoryController extends CMSMain
|
|||||||
$form->setActions(new FieldList());
|
$form->setActions(new FieldList());
|
||||||
$form->addExtraClass('compare');
|
$form->addExtraClass('compare');
|
||||||
|
|
||||||
// Comparison views shouldn't be editable.
|
|
||||||
// Its important to convert fields *before* loading data,
|
|
||||||
// as the comparison output is HTML and not valid values for the various field types
|
|
||||||
$readonlyFields = $form->Fields()->makeReadonly();
|
|
||||||
$form->setFields($readonlyFields);
|
|
||||||
|
|
||||||
$form->loadDataFrom($record);
|
$form->loadDataFrom($record);
|
||||||
$form->loadDataFrom(array(
|
$form->loadDataFrom(array(
|
||||||
"ID" => $id,
|
"ID" => $id,
|
||||||
"Version" => $fromVersion,
|
"Version" => $fromVersion,
|
||||||
));
|
));
|
||||||
|
|
||||||
foreach ($form->Fields()->dataFields() as $field) {
|
// Comparison views shouldn't be editable.
|
||||||
$field->dontEscape = true;
|
// As the comparison output is HTML and not valid values for the various field types
|
||||||
}
|
$readonlyFields = $this->transformReadonly($form->Fields());
|
||||||
|
$form->setFields($readonlyFields);
|
||||||
|
|
||||||
return $form;
|
return $form;
|
||||||
}
|
}
|
||||||
@ -475,4 +472,19 @@ class CMSPageHistoryController extends CMSMain
|
|||||||
$crumbs[0]->Title = _t('CMSPagesController.MENUTITLE', 'Pages');
|
$crumbs[0]->Title = _t('CMSPagesController.MENUTITLE', 'Pages');
|
||||||
return $crumbs;
|
return $crumbs;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function transformReadonly(FieldList $fields)
|
||||||
|
{
|
||||||
|
foreach($fields as &$field) {
|
||||||
|
if ($field instanceof CompositeField) {
|
||||||
|
$subfields = $this->transformReadonly($field->FieldList());
|
||||||
|
$field->setChildren($subfields);
|
||||||
|
}
|
||||||
|
if ($field->hasData() && !$field instanceof HiddenField) {
|
||||||
|
$newField = $field->castedCopy(HTMLReadonlyField::class);
|
||||||
|
$fields->replaceField($field->getName(), $newField);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $fields;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,10 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
use SilverStripe\Forms\FieldGroup;
|
||||||
|
use SilverStripe\Forms\FieldList;
|
||||||
|
use SilverStripe\Forms\HiddenField;
|
||||||
|
use SilverStripe\Forms\HTMLReadonlyField;
|
||||||
|
use SilverStripe\Forms\TextField;
|
||||||
use SilverStripe\ORM\Versioning\Versioned;
|
use SilverStripe\ORM\Versioning\Versioned;
|
||||||
use SilverStripe\CMS\Controllers\CMSPageHistoryController;
|
use SilverStripe\CMS\Controllers\CMSPageHistoryController;
|
||||||
use SilverStripe\Dev\FunctionalTest;
|
use SilverStripe\Dev\FunctionalTest;
|
||||||
@ -152,4 +157,33 @@ class CMSPageHistoryControllerTest extends FunctionalTest
|
|||||||
$this->assertThat($checkbox[0], $this->logicalNot($this->isNull()));
|
$this->assertThat($checkbox[0], $this->logicalNot($this->isNull()));
|
||||||
$this->assertEquals('checked', (string) $checkbox[0]->attributes()->checked);
|
$this->assertEquals('checked', (string) $checkbox[0]->attributes()->checked);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testTransformReadonly()
|
||||||
|
{
|
||||||
|
/** @var CMSPageHistoryController $history */
|
||||||
|
$history = singleton(CMSPageHistoryController::class);
|
||||||
|
|
||||||
|
$fieldList = FieldList::create([
|
||||||
|
FieldGroup::create('group', [
|
||||||
|
TextField::create('childField', 'child field'),
|
||||||
|
]),
|
||||||
|
TextField::create('field', 'field', 'My <del>value</del><ins>change</ins>'),
|
||||||
|
HiddenField::create('hiddenField', 'hidden field'),
|
||||||
|
]);
|
||||||
|
|
||||||
|
$newList = $history->transformReadonly($fieldList);
|
||||||
|
|
||||||
|
$field = $newList->dataFieldByName('field');
|
||||||
|
$this->assertTrue($field instanceof HTMLReadonlyField);
|
||||||
|
$this->assertContains('<ins>', $field->forTemplate());
|
||||||
|
|
||||||
|
$groupField = $newList->fieldByName('group');
|
||||||
|
$this->assertTrue($groupField instanceof FieldGroup);
|
||||||
|
|
||||||
|
$childField = $newList->dataFieldByName('childField');
|
||||||
|
$this->assertTrue($childField instanceof HTMLReadonlyField);
|
||||||
|
|
||||||
|
$hiddenField = $newList->dataFieldByName('hiddenField');
|
||||||
|
$this->assertTrue($hiddenField instanceof HiddenField);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user