You are here

public function WebformAdminConfigHandlersForm::buildForm in Webform 8.5

Same name and namespace in other branches
  1. 6.x src/Form/AdminConfig/WebformAdminConfigHandlersForm.php \Drupal\webform\Form\AdminConfig\WebformAdminConfigHandlersForm::buildForm()

Form constructor.

Parameters

array $form: An associative array containing the structure of the form.

\Drupal\Core\Form\FormStateInterface $form_state: The current state of the form.

Return value

array The form structure.

Overrides ConfigFormBase::buildForm

File

src/Form/AdminConfig/WebformAdminConfigHandlersForm.php, line 79

Class

WebformAdminConfigHandlersForm
Configure webform admin settings for handlers.

Namespace

Drupal\webform\Form\AdminConfig

Code

public function buildForm(array $form, FormStateInterface $form_state) {
  $config = $this
    ->config('webform.settings');

  // Email / Handler: Mail.
  $form['mail'] = [
    '#type' => 'details',
    '#title' => $this
      ->t('Email settings'),
    '#open' => TRUE,
    '#tree' => TRUE,
  ];
  $form['mail']['roles'] = [
    '#type' => 'webform_roles',
    '#title' => $this
      ->t('Recipient user roles'),
    '#description' => $this
      ->t("Select user roles that can be assigned to receive a webform's email. <em>Please note: Selected user roles will be available to all webforms.</em>"),
    '#include_anonymous' => FALSE,
    '#default_value' => $config
      ->get('mail.roles'),
  ];
  $form['mail']['default_to_mail'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Default to email'),
    '#description' => $this
      ->t('The default recipient address for emailed webform results.'),
    '#required' => TRUE,
    '#default_value' => $config
      ->get('mail.default_to_mail'),
  ];
  $form['mail']['default_from_mail'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Default from email'),
    '#description' => $this
      ->t('The default sender address for emailed webform results; often the email address of the maintainer of your forms.'),
    '#required' => TRUE,
    '#default_value' => $config
      ->get('mail.default_from_mail'),
  ];
  $form['mail']['default_from_name'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Default from name'),
    '#description' => $this
      ->t('The default sender name which is used along with the default from address.'),
    '#required' => TRUE,
    '#default_value' => $config
      ->get('mail.default_from_name'),
  ];
  $form['mail']['default_reply_to'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Default reply-to email'),
    '#description' => $this
      ->t("The default email address that a recipient will see when they are replying to an email. Leave blank to automatically use the 'From email' address. Setting the 'Reply-to' to the 'From email' prevent emails from being flagged as spam."),
    '#default_value' => $config
      ->get('mail.default_reply_to'),
  ];
  $form['mail']['default_return_path'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Default return path (email)'),
    '#description' => $this
      ->t("The default email address to which bounce messages are delivered. Leave blank to automatically use the 'From email' address."),
    '#default_value' => $config
      ->get('mail.default_return_path'),
  ];
  $form['mail']['default_sender_mail'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Default sender email'),
    '#description' => $this
      ->t('The default sender address for emailed webform results; often the email address of the maintainer of your forms. The person or agent submitting the message to the network, if other than shown by the From header'),
    '#default_value' => $config
      ->get('mail.default_sender_mail'),
  ];
  $form['mail']['default_sender_name'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Default sender name'),
    '#description' => $this
      ->t('The default sender name which is used along with the default sender email address.'),
    '#default_value' => $config
      ->get('mail.default_sender_name'),
  ];
  $form['mail']['default_subject'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Default email subject'),
    '#required' => TRUE,
    '#maxlength' => NULL,
    '#default_value' => $config
      ->get('mail.default_subject'),
  ];
  $form['mail']['default_body_text'] = [
    '#type' => 'webform_codemirror',
    '#mode' => 'text',
    '#title' => $this
      ->t('Default email body (Plain text)'),
    '#required' => TRUE,
    '#default_value' => $config
      ->get('mail.default_body_text'),
  ];
  $form['mail']['default_body_html'] = [
    '#type' => 'webform_codemirror',
    '#mode' => 'html',
    '#title' => $this
      ->t('Default email body (HTML)'),
    '#required' => TRUE,
    '#default_value' => $config
      ->get('mail.default_body_html'),
  ];
  $form['mail']['token_tree_link'] = $this->tokenManager
    ->buildTreeElement();

  // Email / Handler: Types.
  $form['handler_types'] = [
    '#type' => 'details',
    '#title' => $this
      ->t('Submission handlers'),
    '#description' => $this
      ->t('Select available submission handlers'),
    '#open' => TRUE,
    '#weight' => 10,
  ];
  $form['handler_types']['excluded_handlers'] = $this
    ->buildExcludedPlugins($this->handlerManager, $config
    ->get('handler.excluded_handlers'));
  $excluded_handler_checkboxes = [];
  foreach ($form['handler_types']['excluded_handlers']['#options'] as $handler_id => $option) {
    if ($excluded_handler_checkboxes) {
      $excluded_handler_checkboxes[] = 'or';
    }
    $excluded_handler_checkboxes[] = [
      ':input[name="excluded_handlers[' . $handler_id . ']"]' => [
        'checked' => FALSE,
      ],
    ];
  }
  $form['handler_types']['excluded_handlers_message'] = [
    '#type' => 'webform_message',
    '#message_message' => $this
      ->t('All excluded handlers must be manually removed from existing webforms.'),
    '#message_type' => 'warning',
    '#states' => [
      'visible' => $excluded_handler_checkboxes,
    ],
  ];
  $this->tokenManager
    ->elementValidate($form);
  return parent::buildForm($form, $form_state);
}