Форма Symfony с отображением ManyToMany - PullRequest
0 голосов
/ 11 декабря 2018

Symfony 3.4 Doctrine 1.9

Я нашел много статей об этом.Но ничто не могло решить мою проблему.

У меня есть две сущности User и Company, которые отображаются как Many2Many.Обе организации должны быть заполнены формой отправки.Для этого у меня есть следующие типы FormType:

CustomerRegistrationType

Это включает CollectionType с entry_type из CompanyFormType, который возвращает Company:class

class CustomerRegistrationType extends AbstractType
{

    private $translator;
    private $session;
    public function __construct(TranslatorInterface $translator,Session $session)
    {
        $this->session = $session;
        $this->translator = $translator;
    }

    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder->add('mandant',HiddenType::class,array('data'=> 
            ->add('newsletter',CheckboxType::class,array('label' => false,'required' => false))
            ->add('company', CollectionType::class, array('entry_type' =>    CompanyFormType::class, 'entry_options' => array('label' => false)));


    }

CompanyFormType

class CompanyFormType extends AbstractType
{
    public function buildForm(FormBuilderInterface $builder, array $options)
    {

        parent::buildForm($builder, $options);
        $builder->add('telephone', TextType::class,array('required' => false))
            ->add('company_name', TextType::class,array('label' => false,'required' => false))
            ->add('company_supplement', TextType::class,array('label' => 
            ->add('send_info', CheckboxType::class,array('label' => false,'required' => false))
            ->add('send_invoice', CheckboxType::class,array('label' => false,'required' => false))
    }

    public function configureOptions(OptionsResolver $resolver)
    {
        $resolver->setDefaults(array(
            'data_class' => 'AppBundle\Entity\Company'));
    }
}

Many2Many отображение

   class User extends BaseUser
    {
        public function __construct()
        {
            parent::__construct();
            $this->company = new ArrayCollection();

        }
    /**
         * @ORM\ManyToMany(targetEntity="AppBundle\Entity\Company",inversedBy="users")
         * @ORM\JoinTable(name="user_comp_comp_user",
         *      joinColumns={@ORM\JoinColumn(name="user_id", referencedColumnName="id")},
         *      inverseJoinColumns={@ORM\JoinColumn(name="company_id", referencedColumnName="id")}
         * )
         */
        protected $company;

        public function getCompany()
        {
            return $this->company;
        }

        public function setCompany($company)
        {
            $this->company = $company;
            return $this;
        }

        public function addCompany(Company $company)
        {
            if ($this->company->contains($company)) {
                return;
            }
            $this->company[] = $company;
            return $this;
        }

        public function removeCompany(Company $company)
        {
            if (!$this->company->contains($company)) {
                return;
            }
            $this->company->removeElement($company);
            return $this;

        }

class Company
{
    public function __construct()
    {
        $this->users = new ArrayCollection();
    }

    /**
     * @var \Doctrine\Common\Collections\Collection|Company[]
     * @ORM\ManyToMany(targetEntity="User",mappedBy="company")
     */

    protected $users;
}

В контроллере я хочу сохранитьвсе данные для разных сущностей.Для этого я делаю:

public function registerAction(Request $request)
    {
        $user = $this->userManager->createUser();

        $form = $this->createForm(CustomerRegistrationType::class,$user);
        $form->handleRequest($request);
        $company = $user->getCompany();
        $company->setSendInvoice(true);
        $company->setSendInfo(true);

        if ($form->isSubmitted()){
            $user->addCompany($company);
            $this->userManager->updateUser($user);
          ....
        }
        return $this->render('Registration/register.html.twig',[
        'form' => $form->createView()
        ]);    
}

Мне не важно, каким способом я пытаюсь, каждый раз получаю ошибку.В этом примере данные компании пусты.Другие способы находятся в конфликте с ArrayCollection() из $this->company в User()

User {#907 ▼
  #id: null
  #company: ArrayCollection {#926 ▼
    -elements: []
  }
  #groups: null
  #mandant: null
  #salutation: null
  #first_name: null
  #last_name: null
  #fullname: null
  #created: DateTime @1544539763 {#901 ▶}
  #telephone: null

Обновление: В форме ветки у меня нет доступа к

{{ form_widget(form.company.company_name, {'attr': {'class': 'form-control'}})}}

Ни свойство "company_name", ни один из методов "company_name ()", "getcompany_name ()" / "iscompany_name ()" / "hascompany_name ()" или "__call ()" не существуют и не имеют открытого доступа в классе "Symfony \ Component \ Form \ FormView ".

Это происходит до отправки формы.

1 Ответ

0 голосов
/ 13 декабря 2018

Я нашел решение здесь: https://groups.google.com/forum/#!topic/symfony2/DjwwzOfUIuQ

Таким образом, я использовал в контроллере форму на основе массива

$form = $this->createFormBuilder()
        ->add('user', CustomerRegistrationType::class, array(
              'data_class' => 'AppBundle\Entity\User'
        ))
        ->add('company', CompanyFormType::class, array(
              'data_class' => 'AppBundle\Entity\Company'
       ))
       ->getForm();

Различные объекты могут перехватываться следующим образом:

$form->handleRequest($request);
$user = $form->get('user')->getData();
$company = $form->get('company')->getData();

, а затем

if ($form->isSubmitted()){
...
$user->addCompany($company);
$this->userManager->updateUser($user);
}

Вот и все

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...