Merge pull request #704 from creative-commoners/pulls/5.0/fix-email-template-data

FIX Submitted form field data is rendered correctly in recipient email templates
This commit is contained in:
Dylan Wagstaff 2018-01-26 09:39:22 +13:00 committed by GitHub
commit 9a09873e7d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 25 additions and 23 deletions

View File

@ -277,7 +277,9 @@ JS
$emailData = [ $emailData = [
'Sender' => Security::getCurrentUser(), 'Sender' => Security::getCurrentUser(),
'Fields' => $submittedFields 'HideFormData' => false,
'Fields' => $submittedFields,
'Body' => '',
]; ];
$this->extend('updateEmailData', $emailData, $attachments); $this->extend('updateEmailData', $emailData, $attachments);
@ -286,9 +288,10 @@ JS
if ($recipients = $this->FilteredEmailRecipients($data, $form)) { if ($recipients = $this->FilteredEmailRecipients($data, $form)) {
foreach ($recipients as $recipient) { foreach ($recipients as $recipient) {
$email = Email::create() $email = Email::create()
->setHTMLTemplate('email/SubmittedFormEmail.ss') ->setHTMLTemplate('email/SubmittedFormEmail')
->setPlainTemplate('email/SubmittedFormEmail.ss'); ->setPlainTemplate('email/SubmittedFormEmail');
// Merge fields are used for CMS authors to reference specific form fields in email content
$mergeFields = $this->getMergeFieldsMap($emailData['Fields']); $mergeFields = $this->getMergeFieldsMap($emailData['Fields']);
if ($attachments) { if ($attachments) {
@ -306,19 +309,21 @@ JS
} }
} }
$parsedBody = SSViewer::execute_string($recipient->getEmailBodyContent(), $mergeFields);
if (!$recipient->SendPlain && $recipient->emailTemplateExists()) { if (!$recipient->SendPlain && $recipient->emailTemplateExists()) {
$email->setHTMLTemplate($recipient->EmailTemplate); $email->setHTMLTemplate($recipient->EmailTemplate);
} }
$email->setData($recipient); // Add specific template data for the current recipient
$emailData['HideFormData'] = (bool) $recipient->HideFormData;
// Include any parsed merge field references from the CMS editor - this is already escaped
$emailData['Body'] = SSViewer::execute_string($recipient->getEmailBodyContent(), $mergeFields);
// Push the template data to the Email's data
foreach ($emailData as $key => $value) { foreach ($emailData as $key => $value) {
$email->addData($key, $value); $email->addData($key, $value);
} }
$email->setFrom($recipient->EmailFrom); $email->setFrom($recipient->EmailFrom);
$email->setBody($parsedBody);
$email->setTo($recipient->EmailAddress); $email->setTo($recipient->EmailAddress);
$email->setSubject($recipient->EmailSubject); $email->setSubject($recipient->EmailSubject);
@ -354,11 +359,11 @@ JS
$this->extend('updateEmail', $email, $recipient, $emailData); $this->extend('updateEmail', $email, $recipient, $emailData);
if ($recipient->SendPlain) { if ((bool)$recipient->SendPlain) {
$body = strip_tags($recipient->getEmailBodyContent()) . "\n"; $body = strip_tags($recipient->getEmailBodyContent()) . "\n";
if (isset($emailData['Fields']) && !$recipient->HideFormData) { if (isset($emailData['Fields']) && !$emailData['HideFormData']) {
foreach ($emailData['Fields'] as $Field) { foreach ($emailData['Fields'] as $field) {
$body .= $Field->Title . ': ' . $Field->Value . " \n"; $body .= $field->Title . ': ' . $field->Value . " \n";
} }
} }

View File

@ -1,4 +1,5 @@
$Body <%-- Note: content is already escaped in UserDefinedFormController::process --%>
$Body.RAW
<% if not $HideFormData %> <% if not $HideFormData %>
<dl> <dl>

View File

@ -5,15 +5,13 @@ namespace SilverStripe\UserForms\Tests\Control;
use SilverStripe\Core\Config\Config; use SilverStripe\Core\Config\Config;
use SilverStripe\Dev\CSSContentParser; use SilverStripe\Dev\CSSContentParser;
use SilverStripe\Dev\FunctionalTest; use SilverStripe\Dev\FunctionalTest;
use SilverStripe\Dev\TestOnly;
use SilverStripe\Forms\FieldList; use SilverStripe\Forms\FieldList;
use SilverStripe\Forms\FormAction; use SilverStripe\Forms\FormAction;
use SilverStripe\ORM\DataObject; use SilverStripe\ORM\DataObject;
use SilverStripe\Security\Member; use SilverStripe\UserForms\Control\UserDefinedFormController;
use SilverStripe\UserForms\Model\EditableFormField\EditableTextField; use SilverStripe\UserForms\Model\EditableFormField\EditableTextField;
use SilverStripe\UserForms\Model\Submission\SubmittedFormField; use SilverStripe\UserForms\Model\Submission\SubmittedFormField;
use SilverStripe\UserForms\Model\UserDefinedForm; use SilverStripe\UserForms\Model\UserDefinedForm;
use SilverStripe\UserForms\Control\UserDefinedFormController;
use SilverStripe\View\ArrayData; use SilverStripe\View\ArrayData;
use SilverStripe\View\SSViewer; use SilverStripe\View\SSViewer;
@ -30,7 +28,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
{ {
parent::setUp(); parent::setUp();
Config::modify()->set(SSViewer::class, 'themes', ['simple', '$default']); Config::modify()->merge(SSViewer::class, 'themes', ['simple', '$default']);
} }
public function testProcess() public function testProcess()
@ -51,7 +49,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
// should have a submitted form field now // should have a submitted form field now
$submitted = DataObject::get(SubmittedFormField::class, "\"Name\" = 'basic-text-name'"); $submitted = DataObject::get(SubmittedFormField::class, "\"Name\" = 'basic-text-name'");
$this->assertDOSAllMatch( $this->assertListAllMatch(
[ [
'Name' => 'basic-text-name', 'Name' => 'basic-text-name',
'Value' => 'Basic Value', 'Value' => 'Basic Value',
@ -86,7 +84,7 @@ class UserDefinedFormControllerTest extends FunctionalTest
$parser = new CSSContentParser($nodata['Content']); $parser = new CSSContentParser($nodata['Content']);
$list = $parser->getBySelector('dl'); $list = $parser->getBySelector('dl');
$this->assertFalse(isset($list[0]), 'Email contains no fields'); $this->assertEmpty($list, 'Email contains no fields');
// check to see if the user was redirected (301) // check to see if the user was redirected (301)
$this->assertEquals($response->getStatusCode(), 302); $this->assertEquals($response->getStatusCode(), 302);
@ -281,12 +279,10 @@ class UserDefinedFormControllerTest extends FunctionalTest
protected function setupFormFrontend($fixtureName = 'basic-form-page') protected function setupFormFrontend($fixtureName = 'basic-form-page')
{ {
$form = $this->objFromFixture(UserDefinedForm::class, $fixtureName); $form = $this->objFromFixture(UserDefinedForm::class, $fixtureName);
$this->logInWithPermission('ADMIN');
$this->actWithPermission('ADMIN', function () use ($form) {
$form->publishRecursive(); $form->publishRecursive();
});
$member = Member::currentUser();
$member->logOut();
return $form; return $form;
} }