nstcactus / craft-contact-form-settings-module
A Craft module to manage multiple contact forms using the contact-form & contact-form-extensions plugins
Installs: 187
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:craft-module
Requires
- nstcactus/craft-utils: ^3.1.0 || ^4.0.0
README
This module helps to manage multiple sets of settings form the Craft contact-form
& contact-form-extensions
plugins.
Requirements
This module requires:
- PHP 7.1 or later
- Craft CMS 3, 4 or 5
- contact-form plugin 2.2 or later
- [optional] contact-form-extensions plugin 1.2.1 or later
Installation
-
Install the composer module :
composer require nstcactus/craft-contact-form-settings-module
-
Add the contents of the
app.php
file to yourconfig/app.php
(or just copy it there if it does not exist). This ensures that your module will get loaded for each request.The file might look something like this:
return [ 'modules' => [ 'contact-form-settings-module' => [ 'class' => \nstcactus\craftcms\modules\contactFormSettings\ContactFormSettingsModule::class, 'components' => [ // More on this below ], ], ], 'bootstrap' => ['contact-form-settings-module'], ];
Add a form
-
Create a form class that extends
\modules\contactFormSettings\forms\AbstractContactForm
. This class will describe the settings of your form. -
Register this form class in the
config/app.php
file: add an entry in thecomponents
array of the module where the key is the form name and the value is a reference to the form class.Example:
return [ 'modules' => [ 'contact-form-settings-module' => [ 'class' => \nstcactus\craftcms\modules\contactFormSettings\ContactFormSettingsModule::class, 'components' => [ 'contact' => \project\modules\app\forms\ContactForm::class, ], ], ], 'bootstrap' => ['contact-form-settings-module'], ];
-
Add the following in the template of the form, inside the
<form>
element:{{ formNameInput('contact') }}
Form settings
Plugin settings override
Each form setting class must implement the getContactFormConfiguration()
& getContactFormExtensionsConfiguration()
methods. They expect a return value that is a settings array, just like what would be set in the
config/contact-form.php
& contact-form-extensions.php
.
Custom validation
Custom validation rules should be defined by overriding the afterValidateSubmission()
method. Here you can add
validation errors on the Submission
instance (available in $e->sender
) like so:
public function afterValidateSubmission(Event $e): void { /** @var Submission $submission */ $submission = $e->sender; if (empty($submission->message['FirstName'])) { $submission->addError('message.FirstName', Craft::t('site', 'This field cannot be blank.')); } }
FAQ
How do I safely let the use pick from a list of subjects?
When the subject is selected by the user in a <select>
element for example, the recommended approach is
How do I set the recipient dynamically?
To set the recipient dynamically, you can either:
-
set it in the
toEmail
property in the array return from thegetContactFormSetting()
method -
set it using the
contact-form-extensions
override mechanism in either thebeforeValidateSubmission()
or theafterValidateSubmission()
method. Example:public function beforeValidateSubmission(ModelEvent $e): void { parent::beforeValidateSubmission($e); $submission = $e->sender->message['toEmail'] = Craft::$app->getSecurity()->hashData($subject->contactSubjectRecipient); }
How do I use separate fields for first name & last name?
When using separate first & last name field as opposed to a single fromName
field, make sure to actually set the
fromName
property of the Submission
instance in the afterValidateSubmission()
method.
This will improve submission index in the control panel.
Example:
public function afterValidateSubmission(Event $e): void { /** @var Submission $submission */ $submission = $e->sender; if (!empty($submission->message['FirstName']) || empty($submission->message['LastName'])) { $submission->fromName = trim(sprintf( '%s %s', $submission->message['FirstName'] ?? '', $submission->message['LastName'] ?? '' )); } }