From 234a3c9a5fb32967733e4d518a1c0acf8686dc32 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Julien=20Fastr=C3=A9?= Date: Mon, 17 Nov 2014 00:32:52 +0100 Subject: [PATCH] translation of countries in form refs #317 --- Form/Type/Select2CountryType.php | 19 ++++++++++++++++++- Resources/config/services.yml | 6 ++++++ 2 files changed, 24 insertions(+), 1 deletion(-) diff --git a/Form/Type/Select2CountryType.php b/Form/Type/Select2CountryType.php index 65daebdb7..a83a30e37 100644 --- a/Form/Type/Select2CountryType.php +++ b/Form/Type/Select2CountryType.php @@ -21,7 +21,10 @@ namespace Chill\MainBundle\Form\Type; use Symfony\Component\Form\AbstractType; +use Chill\MainBundle\Templating\TranslatableStringHelper; use Symfony\Component\OptionsResolver\OptionsResolverInterface; +use Chill\MainBundle\Entity\Country; +use Symfony\Component\HttpFoundation\RequestStack; /** * Extends choice to allow adding select2 library on widget @@ -30,6 +33,17 @@ use Symfony\Component\OptionsResolver\OptionsResolverInterface; */ class Select2CountryType extends AbstractType { + /** + * + * @var RequestStack + */ + private $requestStack; + + public function __construct(RequestStack $requestStack) + { + $this->requestStack = $requestStack; + } + public function getName() { return 'select2_chill_country'; @@ -42,8 +56,11 @@ class Select2CountryType extends AbstractType public function setDefaultOptions(OptionsResolverInterface $resolver) { + $locale = $this->requestStack->getCurrentRequest()->getLocale(); + $resolver->setDefaults(array( - 'class' => 'Chill\MainBundle\Entity\Country' + 'class' => 'Chill\MainBundle\Entity\Country', + 'property' => 'name['.$locale.']' )); } } diff --git a/Resources/config/services.yml b/Resources/config/services.yml index 59e28f1e0..e0719bf15 100644 --- a/Resources/config/services.yml +++ b/Resources/config/services.yml @@ -25,6 +25,10 @@ services: - "%locale%" tags: - { name: form.type, alias: translatable_string } + chill.main.helper.translatable_string: + class: Chill\MainBundle\Templating\TranslatableStringHelper + arguments: + - "@request_stack" chill.main.form.type.select2choice: class: Chill\MainBundle\Form\Type\Select2ChoiceType @@ -38,5 +42,7 @@ services: chill.main.form.type.select2country: class: Chill\MainBundle\Form\Type\Select2CountryType + arguments: + - "@request_stack" tags: - { name: form.type, alias: select2_chill_country }