Merge branch 'dev-undefined-index' into 'master'

fix undefined index in person edit form

See merge request Chill-Projet/chill-bundles!26
This commit is contained in:
Julien Fastré 2021-05-06 13:47:13 +00:00
commit 7503c845df
3 changed files with 30 additions and 4 deletions

View File

@ -27,6 +27,7 @@ use Symfony\Component\Form\FormBuilderInterface;
use Chill\MainBundle\Form\Type\DataTransformer\ObjectToIdTransformer; use Chill\MainBundle\Form\Type\DataTransformer\ObjectToIdTransformer;
use Doctrine\Persistence\ObjectManager; use Doctrine\Persistence\ObjectManager;
use Chill\MainBundle\Form\Type\Select2ChoiceType; use Chill\MainBundle\Form\Type\Select2ChoiceType;
use Chill\MainBundle\Templating\TranslatableStringHelper;
/** /**
* Extends choice to allow adding select2 library on widget * Extends choice to allow adding select2 library on widget
@ -41,15 +42,26 @@ class Select2CountryType extends AbstractType
*/ */
private $requestStack; private $requestStack;
/**
*
* @var TranslatableStringHelper
*/
protected $translatableStringHelper;
/** /**
* @var ObjectManager * @var ObjectManager
*/ */
private $em; private $em;
public function __construct(RequestStack $requestStack,ObjectManager $em) public function __construct(
RequestStack $requestStack,
ObjectManager $em,
TranslatableStringHelper $translatableStringHelper
)
{ {
$this->requestStack = $requestStack; $this->requestStack = $requestStack;
$this->em = $em; $this->em = $em;
$this->translatableStringHelper = $translatableStringHelper;
} }
public function getBlockPrefix() public function getBlockPrefix()
@ -75,7 +87,7 @@ class Select2CountryType extends AbstractType
$choices = array(); $choices = array();
foreach ($countries as $c) { foreach ($countries as $c) {
$choices[$c->getId()] = $c->getName()[$locale]; $choices[$c->getId()] = $this->translatableStringHelper->localize($c->getName());
} }
asort($choices, SORT_STRING | SORT_FLAG_CASE); asort($choices, SORT_STRING | SORT_FLAG_CASE);

View File

@ -27,6 +27,7 @@ use Symfony\Component\Form\FormBuilderInterface;
use Chill\MainBundle\Form\Type\DataTransformer\MultipleObjectsToIdTransformer; use Chill\MainBundle\Form\Type\DataTransformer\MultipleObjectsToIdTransformer;
use Doctrine\Persistence\ObjectManager; use Doctrine\Persistence\ObjectManager;
use Chill\MainBundle\Form\Type\Select2ChoiceType; use Chill\MainBundle\Form\Type\Select2ChoiceType;
use Chill\MainBundle\Templating\TranslatableStringHelper;
/** /**
* Extends choice to allow adding select2 library on widget for languages (multiple) * Extends choice to allow adding select2 library on widget for languages (multiple)
@ -43,10 +44,21 @@ class Select2LanguageType extends AbstractType
*/ */
private $em; private $em;
public function __construct(RequestStack $requestStack,ObjectManager $em) /**
*
* @var TranslatableStringHelper
*/
protected $translatableStringHelper;
public function __construct(
RequestStack $requestStack,
ObjectManager $em,
TranslatableStringHelper $translatableStringHelper
)
{ {
$this->requestStack = $requestStack; $this->requestStack = $requestStack;
$this->em = $em; $this->em = $em;
$this->translatableStringHelper = $translatableStringHelper;
} }
public function getBlockPrefix() public function getBlockPrefix()
@ -72,7 +84,7 @@ class Select2LanguageType extends AbstractType
$choices = array(); $choices = array();
foreach ($languages as $l) { foreach ($languages as $l) {
$choices[$l->getId()] = $l->getName()[$locale]; $choices[$l->getId()] = $this->translatableStringHelper->localize($l->getName());
} }
asort($choices, SORT_STRING | SORT_FLAG_CASE); asort($choices, SORT_STRING | SORT_FLAG_CASE);

View File

@ -23,6 +23,7 @@ services:
arguments: arguments:
- "@request_stack" - "@request_stack"
- "@doctrine.orm.entity_manager" - "@doctrine.orm.entity_manager"
- "@chill.main.helper.translatable_string"
tags: tags:
- { name: form.type, alias: select2_chill_country } - { name: form.type, alias: select2_chill_country }
@ -31,6 +32,7 @@ services:
arguments: arguments:
- "@request_stack" - "@request_stack"
- "@doctrine.orm.entity_manager" - "@doctrine.orm.entity_manager"
- "@chill.main.helper.translatable_string"
tags: tags:
- { name: form.type, alias: select2_chill_language } - { name: form.type, alias: select2_chill_language }