简体   繁体   English

Symfony2自定义表格。 小姐的想法

[英]Symfony2 Custom Form. Miss ideas

I have two entities as follows: 我有两个实体,如下所示:

Member (name, firstname) : OneToMany -> subscriptions 成员 (名字,名字):OneToMany->订阅

Subscription ( numberOfMounth ) : ( ManyToOne -> member) 订阅 (numberOfMounth):( ManyToOne->成员)

I'd like to create a form that will load the list of members. 我想创建一个将加载成员列表的表单。 And for each member, I can choose the number of subscription months (numberOfMounth). 对于每个成员,我可以选择订阅月数(numberOfMounth)。 With a check box before each member to select only those who are ready for subscription . 在每个成员之前选中一个复选框,以仅选择准备订阅的成员。 And finally a button to record everything . 最后是一个按钮来记录所有内容。

I started by creating a form by adding a field collection ( subscriptions ) . 我首先通过添加字段集合(订阅)来创建表单。 But I wonder whether to create a new entity for this form. 但我想知道是否要为此表格创建一个新实体。

Actually I miss ideas. 其实我很想念。

My entities and form: 我的实体和形式:

<?php

namespace Jack\AikidoBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
 * Jack\AikidoBundle\Member
 *
 * @ORM\Table()
 * @ORM\Entity(repositoryClass="Jack\AikidoBundle\Entity\MemberRepository")
 * @ORM\HasLifecycleCallbacks()
 */
class Member
{

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

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

    /**
    * @var string $firstname
    *
    * @ORM\Column(name="member_firstname", type="string", length=255)
    */
    private $firstname;


    /**
     * @ORM\OneToMany(targetEntity="Jack\AikidoBundle\Entity\Subscription", mappedBy="member", cascade={"persist", "remove"})
     */
    protected $subscriptions;

    /**
     * Constructor
     */
    public function __construct()
    {
        $this->subscriptions = new \Doctrine\Common\Collections\ArrayCollection();
    }

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

    /**
     * Set name
     *
     * @param string $name
     * @return Member
     */
    public function setName($name)
    {
        $this->name = $name;

        return $this;
    }

    /**
     * Get name
     *
     * @return string 
     */
    public function getName()
    {
        return $this->name;
    }

    /**
     * Set firstname
     *
     * @param string $firstname
     * @return Member
     */
    public function setFirstname($firstname)
    {
        $this->firstname = $firstname;

        return $this;
    }

    /**
     * Get firstname
     *
     * @return string 
     */
    public function getFirstname()
    {
        return $this->firstname;
    }



    /**
     * Add subscriptions
     *
     * @param \Jack\AikidoBundle\Entity\Subscription $subscriptions
     * @return Member
     */
    public function addSubscription(\Jack\AikidoBundle\Entity\Subscription $subscriptions)
    {
        $this->subscriptions[] = $subscriptions;

        return $this;
    }

    /**
     * Remove subscriptions
     *
     * @param \Jack\AikidoBundle\Entity\Subscription $subscriptions
     */
    public function removeSubscription(\Jack\AikidoBundle\Entity\Subscription $subscriptions)
    {
        $this->subscriptions->removeElement($subscriptions);
    }

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

<?php

namespace Jack\AikidoBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
 * Jack\AikidoBundle\Subscription
 *
 * @ORM\Table()
 * @ORM\Entity(repositoryClass="Jack\AikidoBundle\Entity\SubscriptionRepository")
 * @ORM\HasLifecycleCallbacks()
 */
class Subscription
{
    /**
     * @ORM\ManyToOne(targetEntity="Jack\AikidoBundle\Entity\Member", inversedBy="subscriptions")
     * @ORM\JoinColumn(name="member_id", referencedColumnName="id")
     */
    protected $member;
   /**
    * @var integer $id
    *
    * @ORM\Column(name="id", type="integer")
    * @ORM\Id
    * @ORM\GeneratedValue(strategy="AUTO")
    */
    private $id;


    /**
    * @var datetime $date
    *
    * @ORM\Column(name="date", type="datetime")
    */
      private $date;

    /**
    * @var integer $nbMonth
    *
    * @ORM\Column(name="nbMonth", type="integer")
    */
    private $nbMonth;


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



    /**
     * Set date
     *
     * @param \DateTime $date
     * @return Subscription
     */
    public function setDate($date)
    {
        $this->date = $date;

        return $this;
    }

    /**
     * Get date
     *
     * @return \DateTime 
     */
    public function getDate()
    {
        return $this->date;
    }

    /**
     * Set nbMonth
     *
     * @param integer $nbMonth
     * @return Subscription
     */
    public function setNbMonth($nbMonth)
    {
        $this->nbMonth = $nbMonth;

        return $this;
    }

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

    /**
     * Set member
     *
     * @param \Jack\AikidoBundle\Entity\Member $member
     * @return Subscription
     */
    public function setMember(\Jack\AikidoBundle\Entity\Member $member)
    {
        $this->member = $member;

        return $this;
    }

    /**
     * Get member
     *
     * @return \Jack\AikidoBundle\Entity\Member 
     */
    public function getMember()
    {
        return $this->member;
    }


}

<?php

namespace Jack\AikidoBundle\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolverInterface;

class SubscriptionType extends AbstractType
{
        /**
     * @param FormBuilderInterface $builder
     * @param array $options
     */
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder
            ->add('date')
            ->add('nbMonth')

            ->add('member', 'entity', array(
                'class' => 'JackAikidoBundle:Member',
                'property' => 'name',
                'multiple' => true,
                'expanded' => true,
            ))                 
        ;
    }

    /**
     * @param OptionsResolverInterface $resolver
     */
    public function setDefaultOptions(OptionsResolverInterface $resolver)
    {
        $resolver->setDefaults(array(
            'data_class' => 'Jack\AikidoBundle\Entity\Subscription'
        ));
    }

    /**
     * @return string
     */
    public function getName()
    {
        return 'subscription';
    }
}

New Update: My controller and view 新更新:我的控制器和视图

public function subscriptionAction()
{    
    $entity = new Subscription();

    $repository = $this->getDoctrine()
                       ->getRepository('JackAikidoBundle:Member');

    $members = $repository->findAll();

    $formBuilderPratSub = $this->createFormBuilder();

    //Make a loop for each $member
    foreach($members as $member)
    {
        $formBuilder = $this->get('form.factory')->createNamedBuilder(
                $member->getId(), 
                new SubscriptionType(), 
                $entity
                );
        $formBuilderPratSub->add($formBuilder);
    }
    //Create the form

    $form = $formBuilderPratSub->getForm();
    $form->add('submit', 'submit', array('label' => 'Create'));

    return $this->render('JackAikidoBundle:Aikido:souscription.html.twig', 
        array(
            'entity' => $entity,
            'forms'   => $form->createView(),
            'members' => $members,
    ));

}

And my view: 我的看法是:

    <table class="table">
        <thead>
            <tr>
                <th>Member ID</th>
                <th>Name</th>
                <th>Firstname</th>
                <th>Nb Month</th>
            </tr>
        </thead>
        <tbody>
            {% for member in members %}
                {% for form in forms %}
                    <tr>
                        <td>{{ member.id }}</td>
                        <td>{{ member.nom }}</td>
                        <td>{{ member.prenom }}</td>
                        <td>{{ form_row(form.nbMonth)}}</td>
                    </tr>

                {% endfor %}

            {% endfor %}
        </tbody>
    </table>
   <div>{{ form_row(forms.submit) }}</div> 

Error: 错误:

Method "nbMonth" for object "Symfony\Component\Form\FormView" does not exist in JackAikidoBundle:Aikido:souscription.html.twig at line 25 

This line is: <td>{{ form_row(form.nbMonth)}}</td> 这行是: <td>{{ form_row(form.nbMonth)}}</td>

I try: {{ form(forms)}} to display just the form: 我尝试: {{ form(forms)}}仅显示表单:

表格显示

I try something that I think is not a good way: 我尝试了一些我认为不是好方法的方法:

In Controler: 在控制器中:

public function subscriptionAction(Request $request)
{    
    $repository = $this->getDoctrine()->getRepository('JackAikidoBundle:Member');
    $members = $repository->findAll();
    $em = $this->getDoctrine()->getManager();

    if ($request->getMethod() == 'POST') {
        $nbMonth = $this->getRequest()->get('nbMonth');
        $selectedMembers = $this->getRequest()->get('selectedMembers');

        for($i =0; $i < count($selectedMembers); $i++){
            $subscription = new Subscription();
            $subscription->setMonth((int)$nbMonth[$i]);
            $member = $repository->find($selectedMembers[$i]);
            $subscription->setMember($member);
            $em->persist($subscription);
        }
        $em->flush();

    } 
    return $this->render('JackAikidoBundle:Aikido:subscription.html.twig', 
        array(
            'members' => $members,
    ));  
}

In view: 鉴于:

<form  action='{{path('jack_aikido_subscription')}}' method="post">
    <table class="table table-bordered table-striped table-primary list-table">
        <thead>
            <tr>
                <th>Select</th>
                <th>Name</th>
                <th>Firstname</th>
                <th>Nb Month</th>
            </tr>
        </thead>
        <tbody>
            {% for member in members %}               
                    <tr>
                        <td>
                            <input type="checkbox"  name="selectedMembers[]" value="{{ member.id }}">
                        </td>
                        <td>{{ member.name }}</td>
                        <td>{{ member.firstname }}</td>
                        <td>
                            <select name="nbMonth[]">
                                <option value="0">Select</option>
                            {% for i in 1..12 %}
                                <option value="{{ i }}">{{ i }} month</option>
                            {% endfor %}    
                            </select>
                        </td>
                    </tr>
            {% endfor %}
        </tbody>
    </table>
    <input type="submit" name="save">    
</form> 

It works but I still waiting for a best answer. 它有效,但我仍在等待最佳答案。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM