Ошибка: объекты, переданные в поле выбора, должны управляться - PullRequest
1 голос
/ 05 декабря 2011

Прежде всего: ошибка, которую я получаю, такова: необходимо управлять объектами, переданными в поле выбора

У меня есть эти объекты: - пользователь (принадлежит одной или нескольким командам) - команда (имеет одного или 2 пользователей) - вызов (имеет 2 команды)

Я хотел бы создать форму ChallengeType, где пользователь может заполнить двух пользователей для двух команд и создать задачу. Я думаю, что мне нужна встроенная форма здесь.

Я создал класс формы TeamType: (я бы ожидал получить поле выбора из этого списка, где перечислены все пользователи)

<?php

namespace Tennisconnect\DashboardBundle\Form\Type;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilder;

class TeamType extends AbstractType
{
    public function buildForm(FormBuilder $builder, array $options)
    {
        $builder->add('players', 'entity', array(
            'class' => 'TennisconnectUserBundle:User',
            'multiple' => true
        ));
    }

    public function getName()
    {
        return 'team';
    }

    public function getDefaultOptions(array $options)
    {
        return array('data_class' => 'Tennisconnect\DashboardBundle\Entity\Team');
    }
}

Это класс формы ChallengeType:

<?php

namespace Tennisconnect\DashboardBundle\Form\Type;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilder;

class ChallengeType extends AbstractType
{
    public function buildForm(FormBuilder $builder, array $options)
    {
        $builder->add('teams', 'collection', array('type' => new TeamType()));
    }

    public function getName()
    {
        return 'challenge';
    }

    public function getDefaultOptions(array $options)
    {
        return array('data_class' => 'Tennisconnect\DashboardBundle\Entity\Challenge');
    }
}

Вызов сущности:

namespace Tennisconnect\DashboardBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Tennisconnect\DashboardBundle\Entity\Team;
use Symfony\Component\Validator\Constraints as Assert;
use Doctrine\Common\Collections\ArrayCollection;

/**
* @ORM\Entity
* @ORM\Table(name="challenge")
*/
class Challenge
{
    /**
     * @ORM\Id
     * @ORM\Column(type="integer")
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    /**
     * @ORM\ManyToMany(targetEntity="Team", mappedBy="teams")
     */
    protected $teams;

    public function __construct()
    {
        $this->teams = new ArrayCollection();
    }

    /**
     * Get id
     *
     * @return integer 
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * Add teams
     *
     * @param Tennisconnect\DashboardBundle\Entity\Team $teams
     */
    public function addTeam(Team $teams)
    {
        $this->teams[] = $teams;
    }

    /**
     * Get teams
     *
     * @return Doctrine\Common\Collections\Collection 
     */
    public function getTeams()
    {
         return $this->teams;
    }
}

Субъект команды:

namespace Tennisconnect\DashboardBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Validator\Constraints as Assert;
use Doctrine\Common\Collections\ArrayCollection;
use Tennisconnect\UserBundle\Entity\User;
use Tennisconnect\DashboardBundle\Entity\Challenge;
use Tennisconnect\DashboardBundle\Entity\Match;

/**
* @ORM\Entity
* @ORM\Table(name="team")
*/
class Team
{
    /**
     * @ORM\Id
     * @ORM\Column(type="integer")
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    /**
     * @ORM\ManyToMany(targetEntity="Tennisconnect\UserBundle\Entity\User",     mappedBy="teams")
     */
    protected $players;

     /**
     * @ORM\ManyToMany(targetEntity="challenge", inversedBy="teams", cascade=     {"persist"})
     */
    protected $challenges;

    /**
     * @ORM\ManyToMany(targetEntity="Match", inversedBy="teams")
     */
    protected $matches;

    public function __construct()
    {
        $this->players = new ArrayCollection();
    }

    /**
     * Get id
     *
     * @return integer 
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * Add players
     *
     * @param Tennisconnect\UserBundle\Entity\User $players
     */
    public function addUser(User $players)
    {
        $this->players[] = $players;
    }

    /**
     * Get players
     *
     * @return Doctrine\Common\Collections\Collection 
     */
    public function getPlayers()
    {
        return $this->players;
    }

    /**
     * Add matches
     *
     * @param Tennisconnect\DashboardBundle\Entity\Match $matches
     */
    public function addMatch(Match $matches)
    {
        $this->matches[] = $matches;
    }

    /**
     * Get matches
     *
     * @return Doctrine\Common\Collections\Collection 
     */
    public function getMatches()
    {
        return $this->matches;
    }

    /**
     * Add challenges
     *
     * @param Tennisconnect\DashboardBundle\Entity\challenge $challenges
     */
    public function addchallenge(challenge $challenges)
    {
        $this->challenges[] = $challenges;
    }

    /**
     * Get challenges
     *
     * @return Doctrine\Common\Collections\Collection 
     */
    public function getChallenges()
    {
        return $this->challenges;
    }
}

Контроллер вызовов:

class ChallengeController extends Controller
{
    public function newAction()
    {
        $challenge = new Challenge();
        $form = $this->createForm(new ChallengeType(), $challenge);

        return $this->render('TennisconnectDashboardBundle:Challenge:new.html.twig', array('form' => $form->createView()));
    }
}

Ответы [ 3 ]

4 голосов
/ 05 декабря 2011

Вы создали формы, которые отображают коллекцию ManyToMany;установите опцию multiple в вашем formbuilder для этих виджетов на true (по умолчанию false, что принципиально конфликтует с отношением ToMany).

1 голос
/ 13 сентября 2016

Если у вас есть ошибка Entities passed to the choice field must be managed. Maybe persist them in the entity manager? с отношением ManyToMany между двумя сущностями, при использовании типа формы она может исходить от вашей сущности constructor :

Если ваша форма «TeamType», попробуйте удалить инициализацию ArrayCollection вашей сущности «Team».

Ваш класс команды становится:

namespace Tennisconnect\DashboardBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Validator\Constraints as Assert;
use Doctrine\Common\Collections\ArrayCollection;
use Tennisconnect\UserBundle\Entity\User;
use Tennisconnect\DashboardBundle\Entity\Challenge;
use Tennisconnect\DashboardBundle\Entity\Match;

/**
* @ORM\Entity
* @ORM\Table(name="team")
*/
class Team
{
    /**
     * @ORM\Id
     * @ORM\Column(type="integer")
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    /**
     * @ORM\ManyToMany(targetEntity="Tennisconnect\UserBundle\Entity\User",     mappedBy="teams")
     */
    protected $players;

     /**
     * @ORM\ManyToMany(targetEntity="challenge", inversedBy="teams", cascade=     {"persist"})
     */
    protected $challenges;

    /**
     * @ORM\ManyToMany(targetEntity="Match", inversedBy="teams")
     */
    protected $matches;

    public function __construct()
    {
        // REMOVE $this->players = new ArrayCollection();
    }

    /**
     * Get id
     *
     * @return integer 
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * Add players
     *
     * @param Tennisconnect\UserBundle\Entity\User $players
     */
    public function addUser(User $players)
    {
        $this->players[] = $players;
    }

    /**
     * Get players
     *
     * @return Doctrine\Common\Collections\Collection 
     */
    public function getPlayers()
    {
        return $this->players;
    }

    /**
     * Add matches
     *
     * @param Tennisconnect\DashboardBundle\Entity\Match $matches
     */
    public function addMatch(Match $matches)
    {
        $this->matches[] = $matches;
    }

    /**
     * Get matches
     *
     * @return Doctrine\Common\Collections\Collection 
     */
    public function getMatches()
    {
        return $this->matches;
    }

    /**
     * Add challenges
     *
     * @param Tennisconnect\DashboardBundle\Entity\challenge $challenges
     */
    public function addchallenge(challenge $challenges)
    {
        $this->challenges[] = $challenges;
    }

    /**
     * Get challenges
     *
     * @return Doctrine\Common\Collections\Collection 
     */
    public function getChallenges()
    {
        return $this->challenges;
    }
}
0 голосов
/ 08 декабря 2011

Проблема решена. Мне пришлось добавить опцию allow_add в мою коллекцию в классе ChallengeType.

Класс контроллера вызова тоже нуждается в некотором редактировании. Я добавил 2 команды в объект Challenge, прежде чем передать его в форму.

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