Skip to content

Commit

Permalink
Fix #1332 Form select required not initialized
Browse files Browse the repository at this point in the history
  • Loading branch information
dsoriano committed Nov 22, 2024
1 parent 83ae9e8 commit 6a24416
Show file tree
Hide file tree
Showing 6 changed files with 77 additions and 0 deletions.
14 changes: 14 additions & 0 deletions src/LiveComponent/src/ComponentWithFormTrait.php
Original file line number Diff line number Diff line change
Expand Up @@ -258,6 +258,20 @@ private function extractFormValues(FormView $formView): array
if (\array_key_exists('checked', $child->vars)) {
// special handling for check boxes
$values[$name] = $child->vars['checked'] ? $child->vars['value'] : null;
continue;
}

if (\array_key_exists('choices', $child->vars)
&& $child->vars['required']
&& !$child->vars['multiple']
&& !$child->vars['expanded']
&& null === ($values[$name] ?? null)
) {
if (0 === \count($choices = $child->vars['choices'])) {
throw new UnprocessableEntityHttpException(\sprintf('The required field "%s" is missing and has no default value', $name));
}

$values[$name] = reset($choices)->value;
} else {
$values[$name] = $child->vars['value'];
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
<?php

/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <[email protected]>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

namespace Symfony\UX\LiveComponent\Tests\Fixtures\Factory;

use Symfony\UX\LiveComponent\Tests\Fixtures\Entity\CategoryFixtureEntity;
use Zenstruck\Foundry\Persistence\PersistentProxyObjectFactory;

final class CategoryFixtureEntityFactory extends PersistentProxyObjectFactory
{
protected function defaults(): array|callable
{
return [
'name' => self::faker()->name(),
];
}

public static function class(): string
{
return CategoryFixtureEntity::class;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@

namespace Symfony\UX\LiveComponent\Tests\Fixtures\Form;

use Symfony\Bridge\Doctrine\Form\Type\EntityType;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\Extension\Core\Type\CheckboxType;
use Symfony\Component\Form\Extension\Core\Type\ChoiceType;
Expand All @@ -22,6 +23,7 @@
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
use Symfony\Component\Validator\Constraints\Length;
use Symfony\UX\LiveComponent\Tests\Fixtures\Entity\CategoryFixtureEntity;

/**
* @author Jakub Caban <[email protected]>
Expand All @@ -41,6 +43,13 @@ public function buildForm(FormBuilderInterface $builder, array $options)
'foo' => 1,
'bar' => 2,
],
'required' => false,
])
->add('choice_required', ChoiceType::class, [
'choices' => [
'foo' => 1,
'bar' => 2,
],
])
->add('choice_expanded', ChoiceType::class, [
'choices' => [
Expand All @@ -64,6 +73,10 @@ public function buildForm(FormBuilderInterface $builder, array $options)
],
'multiple' => true,
])
->add('entity', EntityType::class, [
'class' => CategoryFixtureEntity::class,
'choice_label' => 'name',
])
->add('checkbox', CheckboxType::class)
->add('checkbox_checked', CheckboxType::class)
->add('file', FileType::class)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
use Symfony\Component\DomCrawler\Crawler;
use Symfony\Component\Form\FormFactoryInterface;
use Symfony\UX\LiveComponent\Tests\Fixtures\Component\FormWithCollectionTypeComponent;
use Symfony\UX\LiveComponent\Tests\Fixtures\Factory\CategoryFixtureEntityFactory;
use Symfony\UX\LiveComponent\Tests\Fixtures\Form\BlogPostFormType;
use Symfony\UX\LiveComponent\Tests\LiveComponentTestHelper;
use Zenstruck\Browser\Test\HasBrowser;
Expand Down Expand Up @@ -157,6 +158,9 @@ public function testFormRemembersValidationFromInitialForm(): void

public function testHandleCheckboxChanges(): void
{
$category = CategoryFixtureEntityFactory::createMany(5);
$id = $category[0]->getId();

$mounted = $this->mountComponent(
'form_with_many_different_fields_type',
[
Expand All @@ -174,9 +178,11 @@ public function testHandleCheckboxChanges(): void
'textarea' => '',
'range' => '',
'choice' => '',
'choice_required' => '1',
'choice_expanded' => '',
'choice_multiple' => ['2'],
'select_multiple' => ['2'],
'entity' => (string)$id,
'checkbox' => null,
'checkbox_checked' => '1',
'file' => '',
Expand Down Expand Up @@ -296,6 +302,7 @@ public function testLiveCollectionTypeAddButtonsByDefault(): void

public function testResetForm(): void
{
CategoryFixtureEntityFactory::createMany(5);
$mounted = $this->mountComponent('form_with_many_different_fields_type');

$dehydratedProps = $this->dehydrateComponent($mounted)->getProps();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,16 @@
use Symfony\Component\Security\Http\Attribute\IsGranted;
use Symfony\UX\LiveComponent\Test\InteractsWithLiveComponents;
use Symfony\UX\LiveComponent\Tests\Fixtures\Component\Component2;
use Symfony\UX\LiveComponent\Tests\Fixtures\Factory\CategoryFixtureEntityFactory;
use Zenstruck\Foundry\Test\ResetDatabase;

/**
* @author Kevin Bond <[email protected]>
*/
final class InteractsWithLiveComponentsTest extends KernelTestCase
{
use InteractsWithLiveComponents;
use ResetDatabase;

public function testCanRenderInitialData(): void
{
Expand Down Expand Up @@ -172,6 +175,7 @@ public function testActingAs(): void

public function testCanSubmitForm(): void
{
CategoryFixtureEntityFactory::createMany(5);
$testComponent = $this->createLiveComponent('form_with_many_different_fields_type');

$response = $testComponent->submitForm(['form' => ['text' => 'foobar']])->response();
Expand Down
9 changes: 9 additions & 0 deletions src/LiveComponent/tests/Unit/Form/ComponentWithFormTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -13,14 +13,21 @@

use Symfony\Bundle\FrameworkBundle\Test\KernelTestCase;
use Symfony\UX\LiveComponent\Tests\Fixtures\Component\FormComponentWithManyDifferentFieldsType;
use Symfony\UX\LiveComponent\Tests\Fixtures\Factory\CategoryFixtureEntityFactory;
use Zenstruck\Foundry\Test\ResetDatabase;

/**
* @author Jakub Caban <[email protected]>
*/
class ComponentWithFormTest extends KernelTestCase
{
use ResetDatabase;

public function testFormValues(): void
{
$category = CategoryFixtureEntityFactory::createMany(5);
$id = $category[0]->getId();

$formFactory = self::getContainer()->get('form.factory');
$component = new FormComponentWithManyDifferentFieldsType($formFactory);
$component->initialData = [
Expand All @@ -36,9 +43,11 @@ public function testFormValues(): void
'textarea' => '',
'range' => '',
'choice' => '',
'choice_required' => '1',
'choice_expanded' => '',
'choice_multiple' => ['2'],
'select_multiple' => ['2'],
'entity' => (string)$id,
'checkbox' => null,
'checkbox_checked' => '1',
'file' => '',
Expand Down

0 comments on commit 6a24416

Please sign in to comment.