mirror of
https://github.com/silverstripe/silverstripe-userforms.git
synced 2024-10-22 17:05:42 +02:00
Merge pull request #1040 from creative-commoners/pulls/5.8/email-preview
FIX Show correct fields in email preview
This commit is contained in:
commit
6b94f9b791
@ -53,16 +53,12 @@ class UserFormRecipientItemRequest extends GridFieldDetailForm_ItemRequest
|
|||||||
protected function getPreviewFieldData()
|
protected function getPreviewFieldData()
|
||||||
{
|
{
|
||||||
$data = ArrayList::create();
|
$data = ArrayList::create();
|
||||||
|
$fields = $this->record->Form()->Fields();
|
||||||
$fields = $this->record->Form()->Fields()->filter(
|
|
||||||
'ClassName:not',
|
|
||||||
[
|
|
||||||
EditableLiteralField::class,
|
|
||||||
EditableFormHeading::class,
|
|
||||||
]
|
|
||||||
);
|
|
||||||
|
|
||||||
foreach ($fields as $field) {
|
foreach ($fields as $field) {
|
||||||
|
if (!$field->showInReports()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
$data->push(ArrayData::create([
|
$data->push(ArrayData::create([
|
||||||
'Name' => $field->dbObject('Name'),
|
'Name' => $field->dbObject('Name'),
|
||||||
'Title' => $field->dbObject('Title'),
|
'Title' => $field->dbObject('Title'),
|
||||||
|
47
tests/Model/Recipient/UserFormRecipientItemRequestTest.php
Normal file
47
tests/Model/Recipient/UserFormRecipientItemRequestTest.php
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace SilverStripe\UserForms\Tests\Model\Recipient;
|
||||||
|
|
||||||
|
use SilverStripe\Dev\SapphireTest;
|
||||||
|
use SilverStripe\ORM\PolymorphicHasManyList;
|
||||||
|
use SilverStripe\UserForms\Model\Recipient\EmailRecipient;
|
||||||
|
use SilverStripe\UserForms\Model\Recipient\UserFormRecipientItemRequest;
|
||||||
|
use SilverStripe\UserForms\Model\UserDefinedForm;
|
||||||
|
|
||||||
|
class UserFormRecipientItemRequestTest extends SapphireTest
|
||||||
|
{
|
||||||
|
public function testShowInReportsAffectsPreview()
|
||||||
|
{
|
||||||
|
// classes where showInReports() returns false
|
||||||
|
$namespace = 'SilverStripe\UserForms\Model\EditableFormField';
|
||||||
|
$falseClasses = ['EditableFieldGroup', 'EditableFieldGroupEnd', 'EditableFormStep'];
|
||||||
|
// some classes where showInReports() returns true (inherits from EditableFormField)
|
||||||
|
$trueClasses = ['EditableTextField', 'EditableEmailField', 'EditableDateField'];
|
||||||
|
$form = new UserDefinedForm();
|
||||||
|
$form->write();
|
||||||
|
/** @var PolymorphicHasManyList $fields */
|
||||||
|
$fields = $form->Fields();
|
||||||
|
foreach (array_merge($falseClasses, $trueClasses) as $class) {
|
||||||
|
$fqcn = "$namespace\\$class";
|
||||||
|
$obj = new $fqcn();
|
||||||
|
$obj->Name = 'My' . $class;
|
||||||
|
$obj->write();
|
||||||
|
$fields->add($obj);
|
||||||
|
}
|
||||||
|
$recipient = new EmailRecipient();
|
||||||
|
$recipient->EmailAddress = 'to@example.com';
|
||||||
|
$recipient->EmailFrom = 'from@example.com';
|
||||||
|
$recipient->EmailTemplate = 'email/SubmittedFormEmail';
|
||||||
|
$recipient->Form = $form;
|
||||||
|
$recipient->write();
|
||||||
|
$recipient->setComponent('Form', $form);
|
||||||
|
$request = new UserFormRecipientItemRequest(null, null, $recipient, null, '');
|
||||||
|
$html = $request->preview()->getValue();
|
||||||
|
foreach ($falseClasses as $class) {
|
||||||
|
$this->assertNotContains('My' . $class, $html);
|
||||||
|
}
|
||||||
|
foreach ($trueClasses as $class) {
|
||||||
|
$this->assertContains('My' . $class, $html);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user