2017-08-30 38 views
0

我的某個表單有問題。表單必須創建一個新的Colle實體並將其他一些Colle實體鏈接到它。 當我提交它時,會爲collesEnfants收集字段中的每個項目創建一個新實體。創建的新實體正確鏈接到父級,並具有正確的'ordre'字段,但是它是新創建的實體,而不是我選擇的實體。實體創建而不是在CollectionType中鏈接

我的形式:

public function buildForm(FormBuilderInterface $builder, array $options) 
{ 
    $builder->add('nom', TextType::class,['label' => 'Nom de la colle']) 
    ->add('collesEnfants', CollectionType::class, 
     ['label' => false, 
     'entry_type' => SousColleFormType::class, 
     'required' => true, 
     'allow_add' => true, 
     'allow_delete' => true, 
     'by_reference' => false]); 
} 

public function configureOptions(OptionsResolver $resolver) 
{ 
    $resolver->setDefaults([ 
     'data_class' => 'PACES\ColleBundle\Entity\Colle' 
    ]); 
} 

SousColleFormType:

public function buildForm(FormBuilderInterface $builder, array $options) 
{ 
    $builder 
     ->add('matiere', EntityType::class, [ 
      'class' => 'PACESColleBundle:Matiere', 
      'attr' => ['class'=> 'matiere'], 
      'choice_label' => 'name', 
      'label' => false, 
      'required' => false, 
      'placeholder' => 'Choisissez une matière', 
      'mapped' => false]) 
     ->add('nom', EntityType::class, [ 
      'class' => 'PACESColleBundle:Colle', 
      'attr' => ['class' => 'colles'], 
      'choice_label' => 'nom', 
      'label' => false, 
      'group_by' => 'matiere', 
      'required' => true, 
      'placeholder' => 'choose.colle']) 
     ->add('ordre', IntegerType::class,[ 
      'attr'=>['class'=>'ordre'], 
      'required' => true, 
      'label' => false]); 
} 

public function configureOptions(OptionsResolver $resolver) 
{ 
    $resolver->setDefaults([ 
     'data_class' => 'PACES\ColleBundle\Entity\Colle' 
    ]); 
} 

控制器:

$formColleMere = $this->createForm(AjoutSuperColleFormType::class, $colle); 
    $formColleMere->add('submit', SubmitType::class, ['label' => 'Créer']); 

    $formColleMere->handleRequest($request); 
    if ($formColleMere->isSubmitted() && $formColleMere->isValid()) { 

     $collesEnfants = $formColleMere->get('collesEnfants')->getData(); 
     foreach ($collesEnfants as $enfant) { 
      $colle->addColleEnfant($enfant); 
     } 

     if (!$colle->getCollesEnfants()->isEmpty()) { 
      $em->persist($colle); 
      $em->flush(); 
     } 

科爾實體:

class Colle 
{ 
/** 
* @var integer 
* 
* @ORM\Column(name="id", type="integer") 
* @ORM\Id 
* @ORM\GeneratedValue(strategy="AUTO") 
*/ 
protected $id; 

/** 
* @ORM\OneToMany(targetEntity="Colle", mappedBy="colleMere", cascade={"persist"}) 
* @ORM\OrderBy({"ordre" = "asc"}) 
*/ 
private $collesEnfants; 

/** 
* @ORM\ManyToOne(targetEntity="Colle", inversedBy="collesEnfants", cascade={"persist"}) 
* @ORM\JoinColumn(name="colleMere_id", referencedColumnName="id") 
*/ 
private $colleMere; 

/** 
* @var string 
* 
* @ORM\Column(name="nom", type="string", length=255) 
*/ 
protected $nom; 

{........} 

/** 
* @ORM\ManyToOne(targetEntity="PACES\ColleBundle\Entity\Matiere", inversedBy="colles", cascade={"persist"}) 
* @ORM\JoinColumn(name="matiere_id", referencedColumnName="id") 
* @ORM\OrderBy({"name" = "ASC"}) 
*/ 
protected $matiere; 

/** 
* Cet attribut sert aux 'super colles' qui sont le résultat d'une fusion de colles d'une même UE 
* @var integer 
* @ORM\Column(name="ordre", type="integer", nullable=true) 
*/ 
protected $ordre; 
+0

'$ collesEnfants = $ formColleMere-> GET( 'collesEnfants') - )>的getData(;'我不甚至看到你的表單中定義的...你確定你已經給出了當前的代碼?如果您可能已經定義了您的關聯和表格類型 –

+0

collesEnfants是以第一種形式定義的,您甚至不應該需要「foreach」。這是包含Collection的字段。我知道我不應該需要的foreach,但我嘗試了很多東西,它仍然不工作,因爲它應該 –

+0

哦噢抱歉,我沒有看到。我會盡力仔細看看 –

回答

0

我成功地通過在collesEnfants字段中添加'mapped' => false來做我想要的。 我也改變了控制器這些行:

$collesEnfants = $formColleMere->get('collesEnfants')->getData(); 
foreach ($collesEnfants as $enfant) { 
    $colle->addColleEnfant($enfant); 
} 

要:

$collesEnfants = $formColleMere->get('collesEnfants')->getData(); 

foreach ($collesEnfants as $enfant) { 
    $colle->addColleEnfant($enfant['nom']); 
    $enfant['nom']->setOrdre($enfant['ordre']); 
}