OK, chłopaki, mam inny sposób. Jest bardziej złożony i tylko w określonych przypadkach.
Mój przypadek:
Mam formularz i złożyć po zamieścić dane do serwera API. I błędy, które dostałem również z serwera API.
API Format Błąd serwera:
array(
'message' => 'Invalid postal code',
'propertyPath' => 'businessAdress.postalCode',
)
Moim celem jest, aby uzyskać elastyczne rozwiązanie. Pozwala ustawić błąd dla odpowiedniego pola.
$vm = new ViolationMapper();
// Format should be: children[businessAddress].children[postalCode]
$error['propertyPath'] = 'children['. str_replace('.', '].children[', $error['propertyPath']) .']';
// Convert error to violation.
$constraint = new ConstraintViolation(
$error['message'], $error['message'], array(), '', $error['propertyPath'], null
);
$vm->mapViolation($constraint, $form);
To wszystko!
UWAGA!addError()
Metoda pomija opcję error_mapping.
Moja postać (forma Adres osadzony w formie spółki):
Spółka
<?php
namespace Acme\DemoBundle\Form;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\Validator\Constraints;
class Company extends AbstractType
{
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->add('companyName', 'text',
array(
'label' => 'Company name',
'constraints' => array(
new Constraints\NotBlank()
),
)
)
->add('businessAddress', new Address(),
array(
'label' => 'Business address',
)
)
->add('update', 'submit', array(
'label' => 'Update',
)
)
;
}
public function getName()
{
return null;
}
}
Adres
<?php
namespace Acme\DemoBundle\Form;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\Validator\Constraints;
class Address extends AbstractType
{
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
// ...
->add('postalCode', 'text',
array(
'label' => 'Postal code',
'constraints' => array(
new Constraints\NotBlank()
),
)
)
->add('town', 'text',
array(
'label' => 'Town',
'constraints' => array(
new Constraints\NotBlank()
),
)
)
->add('country', 'choice',
array(
'label' => 'Country',
'choices' => $this->getCountries(),
'empty_value' => 'Select...',
'constraints' => array(
new Constraints\NotBlank()
),
)
)
;
}
public function getName()
{
return null;
}
}
Dzięki. To rozwiązało mój problem. – pltvs
@ m2mdas, wspaniała odpowiedź! Jak moglibyśmy to przetłumaczyć? ponieważ gdy stworzymy instancję FormError, nie przetłumaczy tego, czy mam rację? Próbowałem i to nie tłumaczy, i myślę, że to ma sens. Jak byś przetłumaczył instancję FormError? – Mick
Witaj @Patt, przepraszam za spóźnioną odpowiedź. Komponent walidatora zajmuje się tłumaczeniem komunikatów o naruszeniu ograniczeń formularza, zanim komunikaty o błędach zostaną dodane do formularza. W celu dodania niestandardowego błędu przetłumaczyłeś komunikat w taki sam sposób, jak robisz dla innych łańcuchów np. '$ This-> get ('translator') -> trans (" komunikat o błędzie ")' –