我正在使用FOSUser和SonataUser& SonataAdmin。 我还使用SonataEasyExtends创建了app / Application / Sonata / UserBundle,在使用FOS和Sonata的几个教程中都有说明。
我只是想从用户实体的管理表单中删除几个默认字段,例如社交表单(facebook,twitter,...)。
我试图通过添加
来覆盖表单#app/Application/Sonata/UserBundle/Admin/Model/UserAdmin.php
namespace Application\Sonata\UserBundle\Admin\Model;
use Sonata\UserBundle\Admin\Model\UserAdmin as UserAdmin;
class MyUserAdmin extends UserAdmin
{
/**
* {@inheritdoc}
*/
protected function configureFormFields(FormMapper $formMapper)
{
$formMapper
->with('General')
->add('username')
->add('email')
->add('plainPassword', 'text', array('required' => false))
->end()
->with('Groups')
->add('groups', 'sonata_type_model', array('required' => false))
->end()
;
if (!$this->getSubject()->hasRole('ROLE_SUPER_ADMIN')) {
$formMapper->with('Management')
->add('roles', 'sonata_security_roles', array(
'expanded' => true,
'multiple' => true,
'required' => false
))
->add('locked', null, array('required' => false))
->add('expired', null, array('required' => false))
->add('enabled', null, array('required' => false))
->add('credentialsExpired', null, array('required' => false))
->end();
}
$formMapper
->with('Security')
->add('token', null, array('required' => false))
->add('twoStepVerificationCode', null, array('required' => false))
->end();
}
}
我想我必须将其注册为服务,并告诉Sonata默认使用它。
但我不知道该怎么做。
我至少在正确的轨道上?
答案 0 :(得分:3)
没错,只需指向您的新UserAdmin类:
#app/config/config.yml
sonata_user:
admin:
user:
class: Application\Sonata\UserBundle\Admin\UserAdmin
之后,您将覆盖完整的 configureFormFields()方法并省略字段。
但是还有一个 remove()方法:
class UserAdmin extends SonataUserAdmin
{
// Fields to be shown on create/edit forms
protected function configureFormFields(FormMapper $formMapper)
{
parent::configureFormFields($formMapper);
$formMapper
->remove('facebookUid');
}
}
您可以对任何字段执行此操作。不幸的是,没有简单的 removeGroup(' Social')方法 - 这可能是一种改进。
答案 1 :(得分:1)
Sonata用户管理员的表单不会被自动覆盖。
根据Thomas Rabaix,我们必须告诉sonata使用我们的新管理实例
#app/config/config.yml
services:
vendor.admin.extens:
class: Application\Sonata\ProductBundle\Admin\ProductAdmin
tags:
- { name: sonata.admin.extens, target: sonata.product.admin.product }