Sonata Admin Bundle 如何配置批处理操作

Sonata Admin Bundle How Configure Batch Actions

如何在 sonata Admin Bundle 中创建自定义配置的批处理操作。 当我 select 批处理操作时,我需要使用 selected List View Items 进行一些更改,然后应用批处理。

我解决了这个问题:

SonataAdmin
public function getBatchActions()
{

    $actions = parent::getBatchActions();

    // check user permissions
    $actions['change'] = [
        'label'            => $this->trans('action_group_change', [], 'admin'),
        'ask_confirmation' => false,
    ];

    return $actions;
}

//在控制器中

public function batchActionChange(ProxyQueryInterface $selectedModelQuery, Request $request = null)
{
    // !$this->admin->isGranted('EDIT')
    // TODO:  при необходимости
    //
    //
    $modelManager = $this->admin->getModelManager();
    $selectedModels = $selectedModelQuery->execute();


    $ids = [];

    foreach ($selectedModels as $selectedModel) {
        $ids[] = $selectedModel->getId();
    }


    return new RedirectResponse(
        $this->admin->generateUrl('change', [
            'ids' => $ids,
        ])
    );
}
public function changeAction(Request $request)
{

    $ids = $request->get('ids');
    if ($ids === null) {
        $this->addFlash('sonata_flash_error', 'Ничего не выбрано');

        return new RedirectResponse($this->admin->generateUrl('list'));
    }
    $form = $this->createForm(new ChangeProxyAdminType());

    if ($request->getMethod()==='POST'){
        $formHandler = $this->get('webface_character.handler.change_proxy');
        $handleResult =$formHandler->handle($form,$request);
        if ($handleResult){
            return new RedirectResponse($this->admin->generateUrl('list'));
        }
    }



    return $this->render('WebfaceCharacterBundle:ProxyAdmin:change.html.twig', [
        'action' => 'change',
        'form'   => $form->createView(),
    ]);

表单类型:

public function buildForm(FormBuilderInterface $builder, array $options)
{

    $builder
        ->add('user', EntityType::class, [
            'class'      => User::class,
            'empty_data' => null,
            'required'   => false,
        ])
        ->add('username', TextType::class, [
            'attr'     => [
                'class' => 'form-control',
            ],
            'required' => false,
        ])
        ->add('password', PasswordType::class, [
            'attr'     => [
                'class' => 'form-control',
            ],
            'required' => false,
        ])
        ->add('isArchive', CheckboxType::class, [
            'attr'     => [
                'class' => 'form-control',
            ],
            'required' => false,
        ]);

}

表单处理程序:

  public function handle(FormInterface $form, Request $request)
{
    if (!$request->isMethod('POST')) {
        return false;
    }

    $form->handleRequest($request);

    if (!$form->isValid()) {
        return false;
    }
    $data = $form->getData();

    $ids = $request->get('ids');
    $qb = $this->em->createQueryBuilder();
    $query = $qb->update('WebfaceCharacterBundle:Proxy', 'p');


    if ($data['user'] !== null) {
        $user = $this->em->getRepository('WebfaceUserBundle:User')->findOneBy(['id' => $data['user']]);
        dump($user);
        $query->set('p.user', $user->getId());
    }

    if ($data['password'] !== null) {
        $query->set('p.password', $qb->expr()->literal($data['password']));
    }

    if ($data['username'] !== null) {
        $query->set('p.username',$qb->expr()->literal($data['username']));
    }

    $query->set('p.isArchive', $qb->expr()->literal($data['isArchive']));
    $query->where($qb->expr()->in('p.id', implode(',', $ids)))
        ->getQuery()
        ->getResult();

    return true;


}

我确定这不是最佳解决方案。但我不知道如何为这个问题创建最佳解决方案。

此解决方案不适用于 1000 个项目的批处理操作,因为在我的解决方案中,所有 ID 都传递给查询和重定向。

P.S。 (这是草稿)

如果要创建配置的批处理操作:

  1. 列表项
  2. 创建自定义表单。
  3. 使用表单处理程序创建控制器方法
  4. 在 batchAction 渲染表单中,其中 action = controllerAction
  5. 表单处理后 return new RedirectResponse($this->admin->generateUrl('list'));