Scroll
12.15.3. Ubrizgavanje zavisnosti (Dependency Injection) u BaseForm
U prethodnim člancima smo objasnili šta su Servisi, Dependency Injection (DI) i kako ih koristiti u svom kontroleru i bloku:
12.15. Servisi i Dependency Injection.
12.15.1. Dependency Injection u kontroleru
12.15.2. Dependency Injection u bloku
U ovom članku je primer kako dodavati servise putem DI u klasu forme koja nasleđuje FormBase:
<?php
namespace Drupal\drupalbook\Form;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Drupal\Core\Form\FormBase;
use Drupal\Core\Form\FormStateInterface;
use Egulias\EmailValidator\EmailValidator;
/**
* Klasa ModalForm.
*/
class ModalForm extends FormBase {
/**
* Validator email adresa.
*
* @var \Egulias\EmailValidator\EmailValidator
*/
protected $emailValidator;
/**
* Konstruktor nove ModalForm instance.
*
* @param \Egulias\EmailValidator\EmailValidator $email_validator
* Validator email adresa.
*/
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('Vaša email adresa'),
'#required' => TRUE,
];
$form['actions']['send'] = [
'#type' => 'submit',
'#value' => $this->t('Pošalji'),
];
return $form;
}
/**
* Validacija email adrese.
*/
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 nije validna email adresa.', ['%email' => $email]));
}
}
else {
$form_state->setErrorByName('email', $this->t("Molimo unesite email adresu."));
}
$form_state->setValue('email', $email);
}
/**
* {@inheritdoc}
*/
public function submitForm(array &$form, FormStateInterface $form_state) {
}
/**
* Vraća imena konfiguracija koje mogu biti uređivane.
*
* @return array
* Niz imena konfiguracionih objekata koji se mogu uređivati ako se pozovu zajedno sa metodom config().
*/
protected function getEditableConfigNames() {
return ['config.drupalbook_contact_form'];
}
}
Za pozivanje servisa preko DI u formi koristimo metode __construct i create(), isto kao što smo radili i za blok.