[Form] Removed useless code
This commit is contained in:
parent
7ba5f7acb3
commit
8add4053c0
@ -982,37 +982,13 @@ class EntityTypeTest extends TypeTestCase
|
|||||||
'property3' => 2,
|
'property3' => 2,
|
||||||
));
|
));
|
||||||
|
|
||||||
$choiceList1 = $form->get('property1')->getConfig()->getOption('choice_list');
|
$choiceLoader1 = $form->get('property1')->getConfig()->getOption('choice_loader');
|
||||||
$choiceList2 = $form->get('property2')->getConfig()->getOption('choice_list');
|
$choiceLoader2 = $form->get('property2')->getConfig()->getOption('choice_loader');
|
||||||
$choiceList3 = $form->get('property3')->getConfig()->getOption('choice_list');
|
$choiceLoader3 = $form->get('property3')->getConfig()->getOption('choice_loader');
|
||||||
|
|
||||||
$this->assertInstanceOf('Symfony\Component\Form\ChoiceList\ChoiceListInterface', $choiceList1);
|
$this->assertInstanceOf('Symfony\Component\Form\ChoiceList\Loader\ChoiceLoaderInterface', $choiceLoader1);
|
||||||
$this->assertSame($choiceList1, $choiceList2);
|
$this->assertSame($choiceLoader1, $choiceLoader2);
|
||||||
$this->assertSame($choiceList1, $choiceList3);
|
$this->assertSame($choiceLoader1, $choiceLoader3);
|
||||||
}
|
|
||||||
|
|
||||||
public function testCacheChoiceLists()
|
|
||||||
{
|
|
||||||
$entity1 = new SingleIntIdEntity(1, 'Foo');
|
|
||||||
|
|
||||||
$this->persist(array($entity1));
|
|
||||||
|
|
||||||
$field1 = $this->factory->createNamed('name', 'Symfony\Bridge\Doctrine\Form\Type\EntityType', null, array(
|
|
||||||
'em' => 'default',
|
|
||||||
'class' => self::SINGLE_IDENT_CLASS,
|
|
||||||
'required' => false,
|
|
||||||
'choice_label' => 'name',
|
|
||||||
));
|
|
||||||
|
|
||||||
$field2 = $this->factory->createNamed('name', 'Symfony\Bridge\Doctrine\Form\Type\EntityType', null, array(
|
|
||||||
'em' => 'default',
|
|
||||||
'class' => self::SINGLE_IDENT_CLASS,
|
|
||||||
'required' => false,
|
|
||||||
'choice_label' => 'name',
|
|
||||||
));
|
|
||||||
|
|
||||||
$this->assertInstanceOf('Symfony\Component\Form\ChoiceList\ChoiceListInterface', $field1->getConfig()->getOption('choice_list'));
|
|
||||||
$this->assertSame($field1->getConfig()->getOption('choice_list'), $field2->getConfig()->getOption('choice_list'));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function createRegistryMock($name, $em)
|
protected function createRegistryMock($name, $em)
|
||||||
|
@ -52,10 +52,13 @@ class ChoiceType extends AbstractType
|
|||||||
*/
|
*/
|
||||||
public function buildForm(FormBuilderInterface $builder, array $options)
|
public function buildForm(FormBuilderInterface $builder, array $options)
|
||||||
{
|
{
|
||||||
|
$choiceList = $this->createChoiceList($options);
|
||||||
|
$builder->setAttribute('choice_list', $choiceList);
|
||||||
|
|
||||||
if ($options['expanded']) {
|
if ($options['expanded']) {
|
||||||
$builder->setDataMapper($options['multiple']
|
$builder->setDataMapper($options['multiple']
|
||||||
? new CheckboxListMapper($options['choice_list'])
|
? new CheckboxListMapper($choiceList)
|
||||||
: new RadioListMapper($options['choice_list']));
|
: new RadioListMapper($choiceList));
|
||||||
|
|
||||||
// Initialize all choices before doing the index check below.
|
// Initialize all choices before doing the index check below.
|
||||||
// This helps in cases where index checks are optimized for non
|
// This helps in cases where index checks are optimized for non
|
||||||
@ -64,12 +67,12 @@ class ChoiceType extends AbstractType
|
|||||||
// requires another SQL query. When the initialization is done first,
|
// requires another SQL query. When the initialization is done first,
|
||||||
// one SQL query is sufficient.
|
// one SQL query is sufficient.
|
||||||
|
|
||||||
$choiceListView = $this->createChoiceListView($options['choice_list'], $options);
|
$choiceListView = $this->createChoiceListView($choiceList, $options);
|
||||||
$builder->setAttribute('choice_list_view', $choiceListView);
|
$builder->setAttribute('choice_list_view', $choiceListView);
|
||||||
|
|
||||||
// Check if the choices already contain the empty value
|
// Check if the choices already contain the empty value
|
||||||
// Only add the placeholder option if this is not the case
|
// Only add the placeholder option if this is not the case
|
||||||
if (null !== $options['placeholder'] && 0 === count($options['choice_list']->getChoicesForValues(array('')))) {
|
if (null !== $options['placeholder'] && 0 === count($choiceList->getChoicesForValues(array('')))) {
|
||||||
$placeholderView = new ChoiceView(null, '', $options['placeholder']);
|
$placeholderView = new ChoiceView(null, '', $options['placeholder']);
|
||||||
|
|
||||||
// "placeholder" is a reserved name
|
// "placeholder" is a reserved name
|
||||||
@ -139,10 +142,10 @@ class ChoiceType extends AbstractType
|
|||||||
}
|
}
|
||||||
} elseif ($options['multiple']) {
|
} elseif ($options['multiple']) {
|
||||||
// <select> tag with "multiple" option
|
// <select> tag with "multiple" option
|
||||||
$builder->addViewTransformer(new ChoicesToValuesTransformer($options['choice_list']));
|
$builder->addViewTransformer(new ChoicesToValuesTransformer($choiceList));
|
||||||
} else {
|
} else {
|
||||||
// <select> tag without "multiple" option
|
// <select> tag without "multiple" option
|
||||||
$builder->addViewTransformer(new ChoiceToValueTransformer($options['choice_list']));
|
$builder->addViewTransformer(new ChoiceToValueTransformer($choiceList));
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($options['multiple'] && $options['by_reference']) {
|
if ($options['multiple'] && $options['by_reference']) {
|
||||||
@ -162,10 +165,13 @@ class ChoiceType extends AbstractType
|
|||||||
$choiceTranslationDomain = $view->vars['translation_domain'];
|
$choiceTranslationDomain = $view->vars['translation_domain'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** @var ChoiceListInterface $choiceList */
|
||||||
|
$choiceList = $form->getConfig()->getAttribute('choice_list');
|
||||||
|
|
||||||
/** @var ChoiceListView $choiceListView */
|
/** @var ChoiceListView $choiceListView */
|
||||||
$choiceListView = $form->getConfig()->hasAttribute('choice_list_view')
|
$choiceListView = $form->getConfig()->hasAttribute('choice_list_view')
|
||||||
? $form->getConfig()->getAttribute('choice_list_view')
|
? $form->getConfig()->getAttribute('choice_list_view')
|
||||||
: $this->createChoiceListView($options['choice_list'], $options);
|
: $this->createChoiceListView($choiceList, $options);
|
||||||
|
|
||||||
$view->vars = array_replace($view->vars, array(
|
$view->vars = array_replace($view->vars, array(
|
||||||
'multiple' => $options['multiple'],
|
'multiple' => $options['multiple'],
|
||||||
@ -192,7 +198,7 @@ class ChoiceType extends AbstractType
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Check if the choices already contain the empty value
|
// Check if the choices already contain the empty value
|
||||||
$view->vars['placeholder_in_choices'] = 0 !== count($options['choice_list']->getChoicesForValues(array('')));
|
$view->vars['placeholder_in_choices'] = 0 !== count($choiceList->getChoicesForValues(array('')));
|
||||||
|
|
||||||
// Only add the empty value option if this is not the case
|
// Only add the empty value option if this is not the case
|
||||||
if (null !== $options['placeholder'] && !$view->vars['placeholder_in_choices']) {
|
if (null !== $options['placeholder'] && !$view->vars['placeholder_in_choices']) {
|
||||||
@ -235,8 +241,6 @@ class ChoiceType extends AbstractType
|
|||||||
*/
|
*/
|
||||||
public function configureOptions(OptionsResolver $resolver)
|
public function configureOptions(OptionsResolver $resolver)
|
||||||
{
|
{
|
||||||
$choiceListFactory = $this->choiceListFactory;
|
|
||||||
|
|
||||||
$emptyData = function (Options $options) {
|
$emptyData = function (Options $options) {
|
||||||
if ($options['multiple'] || $options['expanded']) {
|
if ($options['multiple'] || $options['expanded']) {
|
||||||
return array();
|
return array();
|
||||||
@ -249,29 +253,20 @@ class ChoiceType extends AbstractType
|
|||||||
return $options['required'] ? null : '';
|
return $options['required'] ? null : '';
|
||||||
};
|
};
|
||||||
|
|
||||||
$choiceListNormalizer = function (Options $options) use ($choiceListFactory) {
|
|
||||||
if (null !== $options['choice_loader']) {
|
|
||||||
return $choiceListFactory->createListFromLoader(
|
|
||||||
$options['choice_loader'],
|
|
||||||
$options['choice_value']
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Harden against NULL values (like in EntityType and ModelType)
|
|
||||||
$choices = null !== $options['choices'] ? $options['choices'] : array();
|
|
||||||
|
|
||||||
return $choiceListFactory->createListFromChoices($choices, $options['choice_value']);
|
|
||||||
};
|
|
||||||
|
|
||||||
$choicesAsValuesNormalizer = function (Options $options, $choicesAsValues) {
|
$choicesAsValuesNormalizer = function (Options $options, $choicesAsValues) {
|
||||||
if (null !== $choicesAsValues) {
|
// Not set by the user
|
||||||
if (true !== $choicesAsValues) {
|
if (null === $choicesAsValues) {
|
||||||
throw new \RuntimeException('The "choices_as_values" option should not be used. Remove it and flip the contents of the "choices" option instead.');
|
return true;
|
||||||
}
|
|
||||||
// To be uncommented in 3.1
|
|
||||||
//@trigger_error('The "choices_as_values" option is deprecated since version 3.1 and will be removed in 4.0. You should not use it anymore.', E_USER_DEPRECATED);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Set by the user
|
||||||
|
if (true !== $choicesAsValues) {
|
||||||
|
throw new \RuntimeException('The "choices_as_values" option should not be used. Remove it and flip the contents of the "choices" option instead.');
|
||||||
|
}
|
||||||
|
|
||||||
|
// To be uncommented in 3.1
|
||||||
|
//@trigger_error('The "choices_as_values" option is deprecated since version 3.1 and will be removed in 4.0. You should not use it anymore.', E_USER_DEPRECATED);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -306,9 +301,8 @@ class ChoiceType extends AbstractType
|
|||||||
$resolver->setDefaults(array(
|
$resolver->setDefaults(array(
|
||||||
'multiple' => false,
|
'multiple' => false,
|
||||||
'expanded' => false,
|
'expanded' => false,
|
||||||
'choice_list' => null, // deprecated
|
|
||||||
'choices' => array(),
|
'choices' => array(),
|
||||||
'choices_as_values' => null, // to be deprecated in 3.1
|
'choices_as_values' => null, // to be deprecated in 3.1
|
||||||
'choice_loader' => null,
|
'choice_loader' => null,
|
||||||
'choice_label' => null,
|
'choice_label' => null,
|
||||||
'choice_name' => null,
|
'choice_name' => null,
|
||||||
@ -327,12 +321,10 @@ class ChoiceType extends AbstractType
|
|||||||
'choice_translation_domain' => true,
|
'choice_translation_domain' => true,
|
||||||
));
|
));
|
||||||
|
|
||||||
$resolver->setNormalizer('choice_list', $choiceListNormalizer);
|
|
||||||
$resolver->setNormalizer('placeholder', $placeholderNormalizer);
|
$resolver->setNormalizer('placeholder', $placeholderNormalizer);
|
||||||
$resolver->setNormalizer('choice_translation_domain', $choiceTranslationDomainNormalizer);
|
$resolver->setNormalizer('choice_translation_domain', $choiceTranslationDomainNormalizer);
|
||||||
$resolver->setNormalizer('choices_as_values', $choicesAsValuesNormalizer);
|
$resolver->setNormalizer('choices_as_values', $choicesAsValuesNormalizer);
|
||||||
|
|
||||||
$resolver->setAllowedTypes('choice_list', array('null', 'Symfony\Component\Form\ChoiceList\ChoiceListInterface'));
|
|
||||||
$resolver->setAllowedTypes('choices', array('null', 'array', '\Traversable'));
|
$resolver->setAllowedTypes('choices', array('null', 'array', '\Traversable'));
|
||||||
$resolver->setAllowedTypes('choice_translation_domain', array('null', 'bool', 'string'));
|
$resolver->setAllowedTypes('choice_translation_domain', array('null', 'bool', 'string'));
|
||||||
$resolver->setAllowedTypes('choice_loader', array('null', 'Symfony\Component\Form\ChoiceList\Loader\ChoiceLoaderInterface'));
|
$resolver->setAllowedTypes('choice_loader', array('null', 'Symfony\Component\Form\ChoiceList\Loader\ChoiceLoaderInterface'));
|
||||||
@ -422,6 +414,21 @@ class ChoiceType extends AbstractType
|
|||||||
$builder->add($name, $choiceType, $choiceOpts);
|
$builder->add($name, $choiceType, $choiceOpts);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function createChoiceList(array $options)
|
||||||
|
{
|
||||||
|
if (null !== $options['choice_loader']) {
|
||||||
|
return $this->choiceListFactory->createListFromLoader(
|
||||||
|
$options['choice_loader'],
|
||||||
|
$options['choice_value']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Harden against NULL values (like in EntityType and ModelType)
|
||||||
|
$choices = null !== $options['choices'] ? $options['choices'] : array();
|
||||||
|
|
||||||
|
return $this->choiceListFactory->createListFromChoices($choices, $options['choice_value']);
|
||||||
|
}
|
||||||
|
|
||||||
private function createChoiceListView(ChoiceListInterface $choiceList, array $options)
|
private function createChoiceListView(ChoiceListInterface $choiceList, array $options)
|
||||||
{
|
{
|
||||||
// If no explicit grouping information is given, use the structural
|
// If no explicit grouping information is given, use the structural
|
||||||
|
@ -68,16 +68,6 @@ class ChoiceTypeTest extends \Symfony\Component\Form\Test\TypeTestCase
|
|||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @expectedException \Symfony\Component\OptionsResolver\Exception\InvalidOptionsException
|
|
||||||
*/
|
|
||||||
public function testChoiceListOptionExpectsChoiceListInterface()
|
|
||||||
{
|
|
||||||
$this->factory->create('Symfony\Component\Form\Extension\Core\Type\ChoiceType', null, array(
|
|
||||||
'choice_list' => array('foo' => 'foo'),
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @expectedException \Symfony\Component\OptionsResolver\Exception\InvalidOptionsException
|
* @expectedException \Symfony\Component\OptionsResolver\Exception\InvalidOptionsException
|
||||||
*/
|
*/
|
||||||
|
Reference in New Issue
Block a user