Same name and namespace in other branches
  1. 8.9.x core/modules/contact/src/ContactFormEditForm.php \Drupal\contact\ContactFormEditForm::form()
  2. 9 core/modules/contact/src/ContactFormEditForm.php \Drupal\contact\ContactFormEditForm::form()

Gets the actual form array to be built.

Overrides EntityForm::form

See also

\Drupal\Core\Entity\EntityForm::processForm()

\Drupal\Core\Entity\EntityForm::afterBuild()

File

core/modules/contact/src/ContactFormEditForm.php, line 70

Class

ContactFormEditForm
Base form for contact form edit forms.

Namespace

Drupal\contact

Code

public function form(array $form, FormStateInterface $form_state) {
  $form = parent::form($form, $form_state);
  $contact_form = $this->entity;
  $default_form = $this
    ->config('contact.settings')
    ->get('default_form');
  $form['label'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Label'),
    '#maxlength' => 255,
    '#default_value' => $contact_form
      ->label(),
    '#description' => $this
      ->t("Example: 'website feedback' or 'product information'."),
    '#required' => TRUE,
  ];
  $form['id'] = [
    '#type' => 'machine_name',
    '#default_value' => $contact_form
      ->id(),
    '#maxlength' => EntityTypeInterface::BUNDLE_MAX_LENGTH,
    '#machine_name' => [
      'exists' => '\\Drupal\\contact\\Entity\\ContactForm::load',
    ],
    '#disabled' => !$contact_form
      ->isNew(),
  ];
  $form['recipients'] = [
    '#type' => 'textarea',
    '#title' => $this
      ->t('Recipients'),
    '#default_value' => implode(', ', $contact_form
      ->getRecipients()),
    '#description' => $this
      ->t("Example: 'webmaster@example.com' or 'sales@example.com,support@example.com' . To specify multiple recipients, separate each email address with a comma."),
    '#required' => TRUE,
  ];
  $form['message'] = [
    '#type' => 'textarea',
    '#title' => $this
      ->t('Message'),
    '#default_value' => $contact_form
      ->getMessage(),
    '#description' => $this
      ->t('The message to display to the user after submission of this form. Leave blank for no message.'),
  ];
  $form['redirect'] = [
    '#type' => 'path',
    '#title' => $this
      ->t('Redirect path'),
    '#convert_path' => PathElement::CONVERT_NONE,
    '#default_value' => $contact_form
      ->getRedirectPath(),
    '#description' => $this
      ->t('Path to redirect the user to after submission of this form. For example, type "/about" to redirect to that page. Use a relative path with a slash in front.'),
  ];
  $form['reply'] = [
    '#type' => 'textarea',
    '#title' => $this
      ->t('Auto-reply'),
    '#default_value' => $contact_form
      ->getReply(),
    '#description' => $this
      ->t('Optional auto-reply. Leave empty if you do not want to send the user an auto-reply message.'),
  ];
  $form['weight'] = [
    '#type' => 'weight',
    '#title' => $this
      ->t('Weight'),
    '#default_value' => $contact_form
      ->getWeight(),
    '#description' => $this
      ->t('When listing forms, those with lighter (smaller) weights get listed before forms with heavier (larger) weights. Forms with equal weights are sorted alphabetically.'),
  ];
  $form['selected'] = [
    '#type' => 'checkbox',
    '#title' => $this
      ->t('Make this the default form'),
    '#default_value' => $default_form === $contact_form
      ->id(),
  ];
  return $form;
}