Sonata Admin:向Post Entity添加新字段

时间:2016-02-03 10:52:25

标签: php symfony sonata-admin symfony-sonata sonata

我打算在我的一个项目中使用Sonata Admin,所以现在我正在测试它的功能。我想在Sonata的Post实体(SonataNewsBundle)中添加一个新字段。

例如,我想为标记为突发新闻的新闻添加一个新的复选框(称为“破解”)。

Sonata Admin是一款出色的软件,但它确实缺少文档。我在官方网站上看过文档,但我不知道该怎么做才能完成这项任务。

为Sonata Admin Post实体添加新的布尔字段(中断)的步骤是什么? 我可以这样做吗?

提前谢谢。

P.S。:我附加了标准的Sonata Admin屏幕截图,其中包含现有的“已启用”字段。我希望有一个类似字段用于标记为的新闻。我不需要使用标签(或任何其他分类系统)或基于类别的分类 - 只是一个标记或取消标记Post实体的复选框。 enter image description here

2 个答案:

答案 0 :(得分:1)

您必须将布尔字段添加到实体

    /**
     * @ORM\Column(type="bool")
     */
    protected $is_visible;

并将该字段添加到您的管理表单映射器并设置适当的字段类型, 例如:

$formMapper
            ->add('is_visible', 'bool', array(
                'label' => 'Title'
            ))

如果未指定类型,SonataAdminBundle会尝试猜测它。 Documentation

此外,您可以从现有实体生成Admin类:

php app/console sonata:admin:generate YourNS/FooBundle/Entity/Bar

sonata:admin:generate 命令根据给定的模型类生成新的Admin类,将其注册为服务并可能创建新的控制器。作为参数,您需要指定完全限定的模型类。所有传递的参数和选项在交互模式下用作默认值。您可以使用--no-interaction选项禁用交互模式。

选项包括:

捆绑:捆绑名称(默认值由给定的模型决定 等级,例如“YourNSFooBundle”)

admin :admin class basename(默认情况下会将“Admin”添加到模型类名称,例如“BarAdmin”)

controller :控制器类basename(默认情况下,它将“AdminController”添加到模型类名称,例如“BarAdminController”)

经理:模型管理器类型(默认情况下,这是第一个注册的模型管理器类型,例如“orm”)

服务:服务YAML文件(默认值为“services.yml”或“admin.yml”,如果已存在)

id :管理服务ID(默认值是包名称和管理类基本名称的组合,如“your_ns_foo.admin.bar”)

答案 1 :(得分:1)

“--->你必须将你的布尔字段添加到你的实体我应该添加这个字段” 例如:

// src/AppBundle/Entity/Product.php
namespace AppBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

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

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

    /**
     * @ORM\Column(type="decimal", scale=2)
     */
    protected $price;

    /**
     * @ORM\Column(type="text")
     */
    protected $description;

   /**
    * @ORM\Column(type="bool")
    */
   protected $isVisible;
}

在您的Admin类中:

<?php
// src/AppBundle/Admin/ProductAdmin.php

namespace AppBundle\Admin;

use Sonata\AdminBundle\Admin\Admin;
use Sonata\AdminBundle\Show\ShowMapper;
use Sonata\AdminBundle\Form\FormMapper;
use Sonata\AdminBundle\Datagrid\ListMapper;
use Sonata\AdminBundle\Datagrid\DatagridMapper;

class ProductAdmin extends Admin
{
    // Fields to be shown on create/edit forms
    protected function configureFormFields(FormMapper $formMapper)
    {
        $formMapper
            ->add('name', 'text', array(
                'label' => 'Product Name'
            ))
            ->add('price', 'decimal', array(
                'label' => 'Product Price'
            ))

            // if no type is specified, SonataAdminBundle tries to guess it
            ->add('description')
            ->add('isVisible', 'bool', array(
                'label' => 'Is Product visible'
            ))

            // ...
       ;
    }
    // Fields to be shown on filter forms
protected function configureDatagridFilters(DatagridMapper $datagridMapper)
{
   $datagridMapper
        ->add('name')
        ->add('price')
   ;
}

// Fields to be shown on lists
protected function configureListFields(ListMapper $listMapper)
{
    $listMapper
        ->addIdentifier('name')
        ->add('price')
   ;
}

// Fields to be shown on show action
protected function configureShowFields(ShowMapper $showMapper)
{
    $showMapper
       ->add('name')
       ->add('price')
       ->add('isVisible')
   ;
}
}