diff --git a/code/Control/UserDefinedFormController.php b/code/Control/UserDefinedFormController.php index 8898ec3..e670ce7 100644 --- a/code/Control/UserDefinedFormController.php +++ b/code/Control/UserDefinedFormController.php @@ -7,7 +7,7 @@ use SilverStripe\Assets\File; use SilverStripe\Assets\Upload; use SilverStripe\Control\Controller; use SilverStripe\Control\Email\Email; -use SilverStripe\Control\HTTP; +use SilverStripe\Control\HTTPResponse; use SilverStripe\Core\Manifest\ModuleLoader; use SilverStripe\Forms\Form; use SilverStripe\i18n\i18n; @@ -200,7 +200,7 @@ JS * @param array $data * @param Form $form * - * @return \SilverStripe\Control\HTTPResponse + * @return HTTPResponse */ public function process($data, $form) { @@ -214,7 +214,7 @@ JS $submittedForm->write(); } - $attachments = array(); + $attachments = []; $submittedFields = ArrayList::create(); foreach ($this->data()->Fields() as $field) { @@ -292,14 +292,15 @@ JS if ($attachments) { foreach ($attachments as $file) { - if (!$file->ID != 0) { + /** @var File $file */ + if ((int) $file->ID === 0) { continue; } - $email->attachFile( - $file->Filename, - $file->Filename, - HTTP::get_mime_type($file->Filename) + $email->addAttachmentFromData( + $file->getString(), + $file->getFilename(), + $file->getMimeType() ); } } diff --git a/code/Model/Recipient/EmailRecipient.php b/code/Model/Recipient/EmailRecipient.php index 6d858eb..e26fa47 100644 --- a/code/Model/Recipient/EmailRecipient.php +++ b/code/Model/Recipient/EmailRecipient.php @@ -6,8 +6,11 @@ use SilverStripe\Admin\LeftAndMain; use SilverStripe\Assets\FileFinder; use SilverStripe\CMS\Controllers\CMSMain; use SilverStripe\CMS\Controllers\CMSPageEditController; +use SilverStripe\CMS\Model\SiteTree; use SilverStripe\Control\Controller; use SilverStripe\Control\Email\Email; +use SilverStripe\Core\Manifest\ModuleResource; +use SilverStripe\Core\Manifest\ModuleResourceLoader; use SilverStripe\Forms\CheckboxField; use SilverStripe\Forms\DropdownField; use SilverStripe\Forms\FieldGroup; @@ -27,18 +30,14 @@ use SilverStripe\ORM\ArrayList; use SilverStripe\ORM\DataObject; use SilverStripe\ORM\DB; use SilverStripe\ORM\FieldType\DBField; -use SilverStripe\UserForms\Model\EditableFormField\EditableEmailField; use SilverStripe\UserForms\Model\EditableFormField; +use SilverStripe\UserForms\Model\EditableFormField\EditableEmailField; use SilverStripe\UserForms\Model\EditableFormField\EditableMultipleOptionField; use SilverStripe\UserForms\Model\EditableFormField\EditableTextField; -use SilverStripe\UserForms\Model\Recipient\EmailRecipientCondition; use SilverStripe\UserForms\Model\UserDefinedForm; -use SilverStripe\UserForms\UserForm; use SilverStripe\View\Requirements; use Symbiote\GridFieldExtensions\GridFieldAddNewInlineButton; use Symbiote\GridFieldExtensions\GridFieldEditableColumns; -use SilverStripe\Core\Manifest\ModuleResourceLoader; -use SilverStripe\Core\Config\Config; /** * A Form can have multiply members / emails to email the submission @@ -447,11 +446,6 @@ class EmailRecipient extends DataObject return null; } - /** - * @param Member - * - * @return boolean - */ public function canView($member = null) { if ($form = $this->Form()) { @@ -461,11 +455,6 @@ class EmailRecipient extends DataObject return parent::canView($member); } - /** - * @param Member - * - * @return boolean - */ public function canEdit($member = null) { if ($form = $this->Form()) { @@ -562,9 +551,8 @@ class EmailRecipient extends DataObject return []; } - $templateDirectory = ModuleResourceLoader::resourcePath( - $parent->config()->get('email_template_directory') - ); + $emailTemplateDirectory = $parent->config()->get('email_template_directory'); + $templateDirectory = ModuleResourceLoader::resourcePath($emailTemplateDirectory); if (!$templateDirectory) { return []; @@ -574,10 +562,21 @@ class EmailRecipient extends DataObject foreach ($found as $key => $value) { $template = pathinfo($value); - $templatePath = substr( - $template['dirname'] . DIRECTORY_SEPARATOR . $template['filename'], - strlen(BASE_PATH) + 1 - ); + $absoluteFilename = $template['dirname'] . DIRECTORY_SEPARATOR . $template['filename']; + + // Optionally remove vendor/ path prefixes + $resource = ModuleResourceLoader::singleton()->resolveResource($emailTemplateDirectory); + if ($resource instanceof ModuleResource && $resource->getModule()) { + $prefixToStrip = $resource->getModule()->getPath(); + } else { + $prefixToStrip = BASE_PATH; + } + $templatePath = substr($absoluteFilename, strlen($prefixToStrip) + 1); + + // Optionally remove "templates/" prefixes + if (substr($templatePath, 0, 10)) { + $templatePath = substr($templatePath, 10); + } $templates[$templatePath] = $template['filename']; } diff --git a/code/Model/Recipient/EmailRecipientCondition.php b/code/Model/Recipient/EmailRecipientCondition.php index d934002..60580b9 100644 --- a/code/Model/Recipient/EmailRecipientCondition.php +++ b/code/Model/Recipient/EmailRecipientCondition.php @@ -4,8 +4,10 @@ namespace SilverStripe\UserForms\Model\Recipient; use LogicException; use SilverStripe\CMS\Controllers\CMSMain; +use SilverStripe\CMS\Model\SiteTree; use SilverStripe\Control\Controller; use SilverStripe\ORM\DataObject; +use SilverStripe\Security\Member; use SilverStripe\UserForms\Model\Recipient\EmailRecipient; use SilverStripe\UserForms\Model\EditableFormField; @@ -142,31 +144,16 @@ class EmailRecipientCondition extends DataObject return null; } - /** - * @param Member - * - * @return boolean - */ public function canView($member = null) { return $this->Parent()->canView($member); } - /** - * @param Member - * - * @return boolean - */ public function canEdit($member = null) { return $this->Parent()->canEdit($member); } - /** - * @param Member - * - * @return boolean - */ public function canDelete($member = null) { return $this->canEdit($member); diff --git a/code/Model/Recipient/UserFormRecipientItemRequest.php b/code/Model/Recipient/UserFormRecipientItemRequest.php index 255b7e6..c398cb5 100644 --- a/code/Model/Recipient/UserFormRecipientItemRequest.php +++ b/code/Model/Recipient/UserFormRecipientItemRequest.php @@ -6,8 +6,8 @@ use SilverStripe\Core\Config\Config; use SilverStripe\Forms\GridField\GridFieldDetailForm_ItemRequest; use SilverStripe\ORM\ArrayList; use SilverStripe\ORM\FieldType\DBField; -use SilverStripe\UserForms\Model\EditableFormField\EditableLiteralField; use SilverStripe\UserForms\Model\EditableFormField\EditableFormHeading; +use SilverStripe\UserForms\Model\EditableFormField\EditableLiteralField; use SilverStripe\View\ArrayData; use SilverStripe\View\SSViewer; @@ -34,11 +34,11 @@ class UserFormRecipientItemRequest extends GridFieldDetailForm_ItemRequest Config::nest(); Config::modify()->set(SSViewer::class, 'theme_enabled', true); - $content = $this->customise(ArrayData::create([ + $content = $this->customise([ 'Body' => $this->record->getEmailBodyContent(), - 'HideFormData' => $this->record->HideFormData, + 'HideFormData' => (bool) $this->record->HideFormData, 'Fields' => $this->getPreviewFieldData() - ]))->renderWith($this->record->EmailTemplate); + ])->renderWith($this->record->EmailTemplate); Config::unnest(); diff --git a/templates/email/SubmittedFormEmail.ss b/templates/email/SubmittedFormEmail.ss index 79cef19..15913ed 100755 --- a/templates/email/SubmittedFormEmail.ss +++ b/templates/email/SubmittedFormEmail.ss @@ -1,10 +1,9 @@ $Body -<% if HideFormData %> -<% else %> +<% if not $HideFormData %>