我打算在我的一个项目中使用Sonata Admin,所以现在我正在测试它的功能。我想在Sonata的Post实体(SonataNewsBundle)中添加一个新字段。
例如,我想为标记为突发新闻的新闻添加一个新的复选框(称为“破解”)。
Sonata Admin是一款出色的软件,但它确实缺少文档。我在官方网站上看过文档,但我不知道该怎么做才能完成这项任务。
为Sonata Admin Post实体添加新的布尔字段(中断)的步骤是什么? 我可以这样做吗?
提前谢谢。
P.S。:我附加了标准的Sonata Admin屏幕截图,其中包含现有的“已启用”字段。我希望有一个类似字段用于标记为的新闻。我不需要使用标签(或任何其他分类系统)或基于类别的分类 - 只是一个标记或取消标记Post实体的复选框。
答案 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')
;
}
}