0

少なくとも私にはまだ解決できていない小さな課題があります。それを理解するのを手伝ってもらえますか?

実際、私の質問は2つで構成されており、それらを別の質問に分割することはできません.

Symfony2 (2.3.1) がインストールされています。ここに私のエンティティがあります:

カテゴリー:

// src/Acme/DemoBundle/Entity/Category.php

namespace Acme\DemoBundle\Entity;

use Gedmo\Mapping\Annotation as Gedmo;
use Doctrine\ORM\Mapping as ORM;

/**
 * @Gedmo\Tree(type="nested")
 * @ORM\Table(name="categories")
 * use repository for handy tree functions
 * @ORM\Entity(repositoryClass="Gedmo\Tree\Entity\Repository\NestedTreeRepository")
 */
class Category
{
    /**
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue
     */
    private $id;

    /**
     * @Gedmo\Translatable
     * @ORM\Column(name="name", type="string", length=64)
     */
    private $name;

    /**
     * @Gedmo\TreeLeft
     * @ORM\Column(name="lft", type="integer")
     */
    private $lft;

    /**
     * @Gedmo\TreeLevel
     * @ORM\Column(name="lvl", type="integer")
     */
    private $lvl;

    /**
     * @Gedmo\TreeRight
     * @ORM\Column(name="rgt", type="integer")
     */
    private $rgt;

    /**
     * @Gedmo\TreeRoot
     * @ORM\Column(name="root", type="integer", nullable=true)
     */
    private $root;

    /**
     * @Gedmo\TreeParent
     * @ORM\ManyToOne(targetEntity="Category", inversedBy="children")
     * @ORM\JoinColumn(name="parent_id", referencedColumnName="id", onDelete="CASCADE")
     */
    private $parent;

    /**
     * @ORM\OneToMany(targetEntity="Category", mappedBy="parent")
     * @ORM\OrderBy({"lft" = "ASC"})
     */
    private $children;

アイテム:

// src/Acme/DemoBundle/Entity/Item.php
namespace Acme\DemoBundle\Entity;

use DoctrineExtensions\Taggable\Taggable;
use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\Collection;

/**
 * Item entity
 *
 * @ORM\Table(name="items")
 * @ORM\HasLifecycleCallbacks
 * @ORM\Entity
 */
class Item implements Taggable
{
    /**
     * @ORM\Id
     * @ORM\Column(type="integer")
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    /**
     * @ORM\Column(name="name", type="string", length=64, nullable=true)
     */
    protected $name;

    /**
     * @ORM\ManyToMany(targetEntity="Category", inversedBy="items")
     * @ORM\JoinColumn(name="category_id", referencedColumnName="id"),
     *      inverseJoinColumn=(name="item_id", referencedColumnName="id")
     *
     **/
    protected $categories;

     public function getCategories(){
        return $this->categories;
    }

    public function setCategories($categories){
        $this->categories = $categories;

        return $this->categories;
    }

、私のフォーム AddItemForm:

// src/Acme/DemoBundle/Controller/ItemController.php
namespace Acme\DemoBundle\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolverInterface;
use Doctrine\ORM\EntityRepository;
use Symfony\Component\Validator\Constraints\Collection;

/**
 * Add item form
 *
 */
class AddModelForm extends AbstractType
{    public function buildForm(FormBuilderInterface $builder, array $options) {
        $builder->add('categories', 'collection', array(
                                                        'type' => 'entity',
                                                        'allow_add' => true,
                                                        'allow_delete' => true,
                                                        'prototype' => true,
                                                        'show_legend' => false,
                                                        'data' => array(''),
                                                        'widget_add_btn' => array('label' => _('Добавить категорию')),
                                                        'options' => array(
                                                                        'widget_control_group' => false,
                                                                        'label_render' => false,
                                                                        'class' => 'AcmeDemoBundle:Category',
                                                                        'query_builder' => function(EntityRepository $er) {
                                                                            return $er->createQueryBuilder('c')
                                                                                ->where('c.lvl = 0')
                                                                                ->orderBy('c.id', 'ASC');
                                                                        },
                                                                        'property' => 'name',
                                                                        'empty_value' => _('Choose category'),
                                                                    ),

                                                    )
                              );
    }
}

およびコントローラー ItemController と単純なコード:

// src/Acme/DemoBundle/Controller/ItemController.php
...
public function editAction($itemId) {
    $item= $em->getRepository('AcmeDemoBundle:Item')
                  ->findOneById($itemId);

    $form = $this->createForm(new AddItemForm(), $item);
}

public function addAction() {
    $item = new Item();

    $form = $this->createForm(new AddItemForm(), $item);
}
...

私のカテゴリには、サブカテゴリとサブサブカテゴリなどが含まれています...ネストされたツリー教義拡張で実装されているためです。私は何を達成しようとしています:

1)新しいアイテムを追加すると、このビューが表示され、次の動作が行われます: http://clip2net.com/s/5jcaix (ミラー: https://dl.dropboxusercontent.com/u/31477552/symfony2_form_challenge.png )

{{ form.widget(form.categories) }}現在、親がとしてロードされ、子カテゴリがjqueryでロードされている1つのカテゴリのみを実装しています。私は一時的な解決策があまり好きではありません。そのため、この場合のベストプラクティスを求めています。車輪を再発明する必要はないかもしれません。

2) 既存のアイテムを編集するときに、カテゴリ データをフォームに転送して、追加手順で行った結果を表示したいと考えています。単一の「エンティティ」タイプまたは通常のタイプのみのマッピングは簡単で、Symfony2 で自動的に行われます (または、デフォルト オプションで「data-class」を指定できます)。しかし、私の場合はどのように実装するのですか? エンティティのコレクション + 正しいビュー表示で?

私だけでなく、誰かにとって興味深い挑戦になるかもしれません。これを解決するのを手伝ってください。

4

0 に答える 0