3

我已经把头撞在墙上无数个小时了,我希望能有所帮助!

我有 Retailer、Branch 和 RetailerBranches 实体,它们工作得很好,零售商可以有很多分店,一个分店只能有一个零售商。当试图让 Sonata Admin (SonataAdminBundle) 很好地处理这种关系时,困难的部分就发生了。它们最简单的形式如下所示:

零售商实体

    /**
     * @ORM\Column(name="ID", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    private $id;

    /**
     * Relation
     * 
     * @ORM\OneToMany(targetEntity="RetailerBranches", mappedBy="Retailer", cascade={"persist"})
     */
    protected $branches;

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

RetailerBranches 连接表

    /**
     * @ORM\Column(name="ID", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    private $id;

    /**
     * @ORM\JoinColumn(name="Retailer_ID", referencedColumnName="ID", nullable=false)
     * @ORM\ManyToOne(targetEntity="Retailer", inversedBy="branches")
     */
    private $retailer;

    /**
     * @ORM\JoinColumn(name="Branch_ID", referencedColumnName="ID", nullable=false, unique=true)
     * @ORM\OneToOne(targetEntity="Branch", inversedBy="retailer")
     */
    private $branch;

分公司实体

    /**
     * @ORM\Column(name="ID", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    private $id;

    /**
     * Relation
     * 
     * @ORM\OneToOne(targetEntity="RetailerBranches", mappedBy="branch", cascade={"persist"})
     */
    private $retailer;

当尝试生成表单以允许这种关系形成时,会发生更困难的部分:

零售商管理员

protected function configureFormFields(FormMapper $formMapper)
    {
        $formMapper
            ->with('Branches')
                ->add('branches', 'sonata_type_collection', array(
                    'required' => false,
                    'by_reference' => false
                ), array(
                    'edit' => 'inline',
                    'inline' => 'table',
                ))
                ->end()
        ;
    }

零售商分支机构管理

protected function configureFormFields(FormMapper $formMapper)
    {
        if ($this->hasRequest()) {
            $link_parameters = array('context' => $this->getRequest()->get('context'));
        } else {
            $link_parameters = array();
        }

        $formMapper
            ->add('succursale', 'sonata_type_model_list', array(
                'class' => 'VeloRetailerBundle:Branch',
                'required' => false,
            ), array(
                'edit' => 'inline',
                'inline' => 'table',
            ))
        ;
    }

问题:

所有这些工作,这里有一个截图: 在此处输入图像描述

有一家零售商及其分支机构。耶。

问题 1:底部的“添加新”按钮尝试添加一个 RetailerBranches 对象,而不是一个简单的 Branch 对象,这显然不起作用。

问题 2:此方法也不允许用户修改内联分支。

我觉得我已经接近解决方案了,但我就是不能完全到达那里。任何帮助将不胜感激!

4

2 回答 2

4

对于那些遇到同样问题的人,我在GitHub 上发布了解决方案

.

于 2013-04-12T14:39:48.443 回答
1

当需要在 Sonata Admin 的同一页面上编辑 OneToOne 或其他关系时,您还可以为每个实体创建 Admin 类(并添加到 config.yml),然后只需将整个实体添加到主 Admin 类中的表单中,如下所示:

protected function configureFormFields(FormMapper $formMapper)
    $formMapper
    ->add('yourLinkedProperty', 'sonata_type_admin')
    //other form fields
    ->end()

参见奏鸣曲文档http://sonata-project.org/bundles/admin/master/doc/reference/form_types.html

于 2014-03-17T21:38:03.180 回答