RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 916221
Accepted
vexel
vexel
Asked:2020-12-06 16:07:05 +0000 UTC2020-12-06 16:07:05 +0000 UTC 2020-12-06 16:07:05 +0000 UTC

将自定义字段添加到管理员(奏鸣曲)列表 Symfony 2.8

  • 772

有一个表,其中显示来自 2 个表的数据,如何向该表添加另一个字段,该字段将根据其他 2 个表或一个表的条件包含信息,例如,我需要添加一个字段Trial,其中是基于字段的信息Price,如果字段Price大于 0,则Trial插入一个值,如果为 0,则插入另一个值。我以这种方式向方法中configureListFields添加了一个字段Trial:->add('trial')它已添加,现在如何用数据填充它,这是整个代码:

namespace AdminBundle\Admin;

use IntlDateFormatter;
use Sonata\AdminBundle\Admin\AbstractAdmin;
use Sonata\AdminBundle\Datagrid\DatagridMapper;
use Sonata\AdminBundle\Datagrid\ListMapper;
use Sonata\AdminBundle\Form\FormMapper;
use Sonata\AdminBundle\Route\RouteCollection;
use Sonata\AdminBundle\Show\ShowMapper;

class PurchaseAdmin extends AbstractAdmin
{
    protected $datagridValues = [
        '_page'       => 1,
        '_sort_order' => 'DESC',
        '_sort_by'    => 'createdAt',
    ];

    protected $accessMapping = [
        'refund' => 'REFUND',
    ];

    public function createQuery($context = 'list')
    {
        $query = parent::createQuery($context);

        $rootAlias = $query->getRootAliases()[0];
        $query->leftJoin($rootAlias.'.paymentTransaction', 'pt');
        $query->leftJoin($rootAlias.'.language', 'll');
        $query->addSelect('pt, ll');


        return $query;
    }

    public function configureRoutes(RouteCollection $collection)
    {
        parent::configureRoutes($collection);
        $collection->remove('delete');
        $collection->remove('create');
        $collection->remove('edit');
        $collection->add('refund', $this->getRouterIdParameter().'/refund');
        $collection->add('studentInfo', $this->getRouterIdParameter().'/student-info');
    }

    /**
     * @param DatagridMapper $datagridMapper
     */
    protected function configureDatagridFilters(DatagridMapper $datagridMapper)
    {
        $datagridMapper
            ->add(
                'teacher', null, [
                             'show_filter' => true
                         ]
            )
            ->add(
                'student', null, [
                             'show_filter' => true
                         ]
            )
            ->add(
                'language', null, [
                              'show_filter' => true
                          ]
            )
            ->add('lessonLength')
            ->add('lessons')
            ->add(
                'status', null, [], 'choice', [
                            'choices' => [
                                0 => 'created',
                                1 => 'paid',
                                2 => 'used',
                                3 => 'refunded',
                            ],
                        ]
            );
    }

    /**
     * @param ListMapper $listMapper
     */
    protected function configureListFields(ListMapper $listMapper)
    {
        $listMapper
            ->addIdentifier(
                'id',
                null,
                [
                    'route' => [
                        'name' => 'show'
                    ]
                ]
            )
            ->add('statusText')
            ->add('teacher')
            ->add('student')
            ->add(
                'studentInfo',
                'string',
                [
                    'template' => ':CRUD:list__action_student_info.html.twig'
                ]
            )
            ->add('language')
            ->add('lessonLength')
            ->add('lessons')
            ->add('lessonsLeft')
            ->add('price')
            ->add('trial')
            ->add('teacher.currency', null, ['label' => 'Currency'])
            ->add('paymentTransaction')
            ->add(
                'createdAt', 'datetime', [
                               'dateType' => IntlDateFormatter::SHORT,
                               'timeType' => IntlDateFormatter::SHORT,
                           ]
            )
            ->add(
                'updatedAt', 'datetime', [
                               'dateType' => IntlDateFormatter::SHORT,
                               'timeType' => IntlDateFormatter::SHORT,
                           ]
            )
            ->add(
                '_action',
                null,
                [
                    'actions' => [
                        'show'   => [],
                        'refund' => [
                            'template' => ':CRUD:list__action_refund.html.twig'
                        ],
                    ]
                ]
            );
    }

    /**
     * @param FormMapper $formMapper
     */
    protected function configureFormFields(FormMapper $formMapper)
    {
        $formMapper
            ->add('id')
            ->add('price')
            ->add('lessonLength')
            ->add('lessons')
            ->add('lessonsLeft')
            ->add('commission')
            ->add('status')
            ->add('createdAt')
            ->add('updatedAt');
    }

    /**
     * @param ShowMapper $showMapper
     */
    protected function configureShowFields(ShowMapper $showMapper)
    {
        $showMapper
            ->add('teacher')
            ->add('student')
            ->add('language')
            ->add('price')
            ->add('teacher.currency', null, ['label' => 'Currency'])
            ->add('lessonLength')
            ->add('lessons')
            ->add('lessonsLeft')
            ->add('commission')
            ->add('statusText')
            ->add('paymentTransaction')
            ->add('createdAt')
            ->add('updatedAt');
    }

    public function getTemplate($name)
    {
        if ($name === 'refund') {
            return ':Purchase:base_refund.html.twig';
        }

        return parent::getTemplate($name);
    }

}
symfony2
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Kostiantyn Okhotnyk
    2020-12-14T22:25:43Z2020-12-14T22:25:43Z

    您需要先保存试用数据,然后再将其发送到数据库。或者你应该通过一个钩子来做[preUpdate][1]。

    public function preUpdate($purchase)
    {
        $purchase.setTrial((boolean)$purchase.getPrice())
    }
    

    或在您的CRUDController工具中填写该字段trial( $collection->remove('create');可能需要删除该行)

    public function createAction()
     {
         $object = $this->admin->getSubject();
         $object->setTrial((boolean)$object->getPrice());
         return parent::createAction();
     }
    
    • 1

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    是否可以在 C++ 中继承类 <---> 结构?

    • 2 个回答
  • Marko Smith

    这种神经网络架构适合文本分类吗?

    • 1 个回答
  • Marko Smith

    为什么分配的工作方式不同?

    • 3 个回答
  • Marko Smith

    控制台中的光标坐标

    • 1 个回答
  • Marko Smith

    如何在 C++ 中删除类的实例?

    • 4 个回答
  • Marko Smith

    点是否属于线段的问题

    • 2 个回答
  • Marko Smith

    json结构错误

    • 1 个回答
  • Marko Smith

    ServiceWorker 中的“获取”事件

    • 1 个回答
  • Marko Smith

    c ++控制台应用程序exe文件[重复]

    • 1 个回答
  • Marko Smith

    按多列从sql表中选择

    • 1 个回答
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Suvitruf - Andrei Apanasik 什么是空? 2020-08-21 01:48:09 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5