class TransactionnalEmailForm in SendinBlue 8
Same name and namespace in other branches
- 8.2 src/Form/TransactionnalEmailForm.php \Drupal\sendinblue\Form\TransactionnalEmailForm
Class Form Transactionnal emails SMTP.
Hierarchy
- class \Drupal\Core\Form\FormBase implements ContainerInjectionInterface, FormInterface uses DependencySerializationTrait, LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait
- class \Drupal\Core\Form\ConfigFormBase uses ConfigFormBaseTrait
- class \Drupal\sendinblue\Form\TransactionnalEmailForm
- class \Drupal\Core\Form\ConfigFormBase uses ConfigFormBaseTrait
Expanded class hierarchy of TransactionnalEmailForm
1 file declares its use of TransactionnalEmailForm
File
- src/
Form/ TransactionnalEmailForm.php, line 15
Namespace
Drupal\sendinblue\FormView source
class TransactionnalEmailForm extends ConfigFormBase {
/**
* EmailValidatorInterface.
*
* @var \Drupal\Component\Utility\EmailValidator
*/
private $emailValidator;
/**
* SendinblueManager.
*
* @var \Drupal\sendinblue\SendinblueManager
*/
private $sendinblueManager;
/**
* Constructs a \Drupal\system\ConfigFormBase object.
*
* @param \Drupal\Core\Config\ConfigFactoryInterface $config_factory
* The factory for configuration objects.
* @param \Drupal\Component\Utility\EmailValidator $emailValidator
* EmailValidatorInterface.
* @param \Drupal\sendinblue\SendinblueManager $sendinblueManager
* SendinblueManager.
*/
public function __construct(ConfigFactoryInterface $config_factory, EmailValidator $emailValidator, SendinblueManager $sendinblueManager) {
parent::__construct($config_factory);
$this->emailValidator = $emailValidator;
$this->sendinblueManager = $sendinblueManager;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
return new static($container
->get('config.factory'), $container
->get('email.validator'), $container
->get('sendinblue.manager'));
}
/**
* Returns a unique string identifying the form.
*
* @return string
* The unique string identifying the form.
*/
public function getFormId() {
return SendinblueManager::CONFIG_SETTINGS_SEND_EMAIL;
}
/**
* Form constructor.
*
* @param array $form
* An associative array containing the structure of the form.
* @param \Drupal\Core\Form\FormStateInterface $form_state
* The current state of the form.
*
* @return array
* The form structure.
*/
public function buildForm(array $form, FormStateInterface $form_state) {
$smtpDetails = $this
->configFactory()
->get(SendinblueManager::CONFIG_SETTINGS_SEND_EMAIL)
->get(SendinblueManager::SMTP_DETAILS);
$smtpAvailable = $smtpDetails !== NULL;
if ($smtpAvailable === FALSE) {
$form['sendinblue_alert'] = [
'#type' => 'markup',
'#prefix' => '<div id="sendinblue_alert_area" style="padding: 10px;background-color: #fef5f1;color: #8c2e0b;border-color: #ed541d;border-width: 1px;border-style: solid;">',
'#markup' => $this
->t('Current you can not use SendinBlue SMTP. Please confirm at <a href="@smtp-sendinblue" target="_blank">Here</a>', [
'@smtp-sendinblue' => 'https://mysmtp.sendinblue.com/?utm_source=drupal_plugin&utm_medium=plugin&utm_campaign=module_link',
]),
'#suffix' => '</div>',
'#tree' => TRUE,
];
}
$form['sendinblue_on'] = [
'#type' => 'radios',
'#title' => $this
->t('Send emails through SendinBlue SMTP'),
'#default_value' => $this
->configFactory()
->get(SendinblueManager::CONFIG_SETTINGS_SEND_EMAIL)
->get('sendinblue_on'),
'#description' => $this
->t('Choose "Yes" if you want to use SendinBlue SMTP to send transactional emails.'),
'#options' => [
1 => $this
->t('Yes'),
0 => $this
->t('No'),
],
'#disabled' => $smtpAvailable === TRUE ? FALSE : TRUE,
];
$form['sendinblue_to_email'] = [
'#type' => 'textfield',
'#title' => $this
->t('Enter email to send a test'),
'#description' => $this
->t('Select here the email address you want to send a test email to.'),
'#disabled' => $smtpAvailable === TRUE ? FALSE : TRUE,
'#states' => [
// Hide unless needed.
'visible' => [
':input[name="sendinblue_on"]' => [
'value' => 1,
],
],
'required' => [
':input[name="sendinblue_on"]' => [
'value' => 1,
],
],
],
];
$form['submit'] = [
'#type' => 'submit',
'#value' => $this
->t('Save Settings'),
'#disabled' => $smtpAvailable === TRUE ? FALSE : TRUE,
];
return $form;
}
/**
* {@inheritdoc}
*/
public function validateForm(array &$form, FormStateInterface $form_state) {
$sendEmail = $form_state
->getValue('sendinblue_to_email');
if (!empty($sendEmail)) {
if (!$this->emailValidator
->isValid($sendEmail)) {
$form_state
->setErrorByName('sendinblue_to_email', $this
->t('The email address is invalid.'));
return;
}
}
}
/**
* Form submission handler.
*
* @param array $form
* An associative array containing the structure of the form.
* @param \Drupal\Core\Form\FormStateInterface $form_state
* The current state of the form.
*/
public function submitForm(array &$form, FormStateInterface $form_state) {
$sendEmail = $form_state
->getValue('sendinblue_to_email');
$sendinblueOn = $form_state
->getValue('sendinblue_on');
$config = $this
->configFactory()
->getEditable(SendinblueManager::CONFIG_SETTINGS_SEND_EMAIL);
$config
->set('sendinblue_on', $sendinblueOn)
->save();
if ((bool) $sendinblueOn) {
$this->sendinblueManager
->sendEmail('test', $sendEmail);
$this->sendinblueManager
->updateSmtpDetails();
}
parent::submitForm($form, $form_state);
}
/**
* Gets the configuration names that will be editable.
*
* @return array
* An array of configuration object names that are editable if called in
* conjunction with the trait's config() method.
*/
protected function getEditableConfigNames() {
return [
SendinblueManager::CONFIG_SETTINGS_SEND_EMAIL,
];
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfigFormBaseTrait:: |
protected | function | Retrieves a configuration object. | |
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
FormBase:: |
protected | property | The config factory. | 1 |
FormBase:: |
protected | property | The request stack. | 1 |
FormBase:: |
protected | property | The route match. | |
FormBase:: |
protected | function | Gets the config factory for this form. | 1 |
FormBase:: |
private | function | Returns the service container. | |
FormBase:: |
protected | function | Gets the current user. | |
FormBase:: |
protected | function | Gets the request object. | |
FormBase:: |
protected | function | Gets the route match. | |
FormBase:: |
protected | function | Gets the logger for a specific channel. | |
FormBase:: |
protected | function |
Returns a redirect response object for the specified route. Overrides UrlGeneratorTrait:: |
|
FormBase:: |
public | function | Resets the configuration factory. | |
FormBase:: |
public | function | Sets the config factory for this form. | |
FormBase:: |
public | function | Sets the request stack object to use. | |
LinkGeneratorTrait:: |
protected | property | The link generator. | 1 |
LinkGeneratorTrait:: |
protected | function | Returns the link generator. | |
LinkGeneratorTrait:: |
protected | function | Renders a link to a route given a route name and its parameters. | |
LinkGeneratorTrait:: |
public | function | Sets the link generator service. | |
LoggerChannelTrait:: |
protected | property | The logger channel factory service. | |
LoggerChannelTrait:: |
protected | function | Gets the logger for a specific channel. | |
LoggerChannelTrait:: |
public | function | Injects the logger channel factory. | |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
RedirectDestinationTrait:: |
protected | property | The redirect destination service. | 1 |
RedirectDestinationTrait:: |
protected | function | Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url. | |
RedirectDestinationTrait:: |
protected | function | Returns the redirect destination service. | |
RedirectDestinationTrait:: |
public | function | Sets the redirect destination service. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. | |
TransactionnalEmailForm:: |
private | property | EmailValidatorInterface. | |
TransactionnalEmailForm:: |
private | property | SendinblueManager. | |
TransactionnalEmailForm:: |
public | function |
Form constructor. Overrides ConfigFormBase:: |
|
TransactionnalEmailForm:: |
public static | function |
Instantiates a new instance of this class. Overrides ConfigFormBase:: |
|
TransactionnalEmailForm:: |
protected | function |
Gets the configuration names that will be editable. Overrides ConfigFormBaseTrait:: |
|
TransactionnalEmailForm:: |
public | function |
Returns a unique string identifying the form. Overrides FormInterface:: |
|
TransactionnalEmailForm:: |
public | function |
Form submission handler. Overrides ConfigFormBase:: |
|
TransactionnalEmailForm:: |
public | function |
Form validation handler. Overrides FormBase:: |
|
TransactionnalEmailForm:: |
public | function |
Constructs a \Drupal\system\ConfigFormBase object. Overrides ConfigFormBase:: |
|
UrlGeneratorTrait:: |
protected | property | The url generator. | |
UrlGeneratorTrait:: |
protected | function | Returns the URL generator service. | |
UrlGeneratorTrait:: |
public | function | Sets the URL generator service. | |
UrlGeneratorTrait:: |
protected | function | Generates a URL or path for a specific route based on the given parameters. |