Scroll
12.15.3. Dependency Injection im BaseForm
In den vorherigen Artikeln haben wir besprochen, was Services und Dependency Injection (DI) sind und wie man sie in seinem Controller und Block verwendet:
12.15. Services und Dependency Injection.
12.15.1. Dependency Injection im Controller
12.15.2. Dependency Injection im Block
In diesem Artikel ein Beispiel, wie man Services über DI in eine Formular-Klasse, die von FormBase erbt, hinzufügt:
<?php
namespace Drupal\drupalbook\Form;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Drupal\Core\Form\FormBase;
use Drupal\Core\Form\FormStateInterface;
use Egulias\EmailValidator\EmailValidator;
/**
* Klasse ModalForm.
*/
class ModalForm extends FormBase {
/**
* E-Mail Validator.
*
* @var \Egulias\EmailValidator\EmailValidator
*/
protected $emailValidator;
/**
* Konstruktor eines neuen ModalForm.
*
* @param \Egulias\EmailValidator\EmailValidator $email_validator
* Der E-Mail Validator.
*/
public function __construct(EmailValidator $email_validator) {
$this->emailValidator = $email_validator;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
return new static(
$container->get('email.validator')
);
}
/**
* {@inheritdoc}
*/
public function getFormId() {
return 'drupalbook_contact_form';
}
/**
* {@inheritdoc}
*/
public function buildForm(array $form, FormStateInterface $form_state, $options = NULL) {
$form['email'] = [
'#type' => 'email',
'#title' => $this->t('Email'),
'#description' => $this->t('Your email address'),
'#required' => TRUE,
];
$form['actions']['send'] = [
'#type' => 'submit',
'#value' => $this->t('Send'),
];
return $form;
}
/**
* E-Mail Validierung.
*/
protected function validateEmail(array &$form, FormStateInterface $form_state) {
if (!$this->emailValidator->isValid($form_state->getValue('email'))) {
return FALSE;
}
return TRUE;
}
/**
* {@inheritdoc}
*/
public function validateForm(array &$form, FormStateInterface $form_state) {
$email = $form_state->getValue('email');
if (!empty($email)) {
if (!$this->validateEmail($form, $form_state)) {
$form_state->setErrorByName('email', $this->t('%email ist keine gültige E-Mail-Adresse.', ['%email' => $email]));
}
}
else {
$form_state->setErrorByName('email', $this->t("Bitte geben Sie eine E-Mail-Adresse ein."));
}
$form_state->setValue('email', $email);
}
/**
* {@inheritdoc}
*/
public function submitForm(array &$form, FormStateInterface $form_state) {
}
/**
* Gibt die Konfigurationsnamen zurück, die bearbeitbar sind.
*
* @return array
* Ein Array von Konfigurationsobjektnamen, die bearbeitet werden können, wenn die config()-Methode des Traits verwendet wird.
*/
protected function getEditableConfigNames() {
return ['config.drupalbook_contact_form'];
}
}
Um einen Service über DI im Formular zu verwenden, nutzen wir die Methoden __construct und create(), genauso wie wir es für den Block gemacht haben.