3

我使用 single_text 小部件创建了带有日期字段的表单。我之所以选择这个,是因为我使用的是Bootstrap datepicker

我遇到的问题是该字段始终填充当前日期而不是空的。

根据一点,如果我将 required 设置为 false 但 id 没有,它应该可以工作。我尝试将 empty_value 设置为与数据相同的空字符串,但在第一种情况下没有发生任何事情,可能是因为此选项适用于选择字段。在第二种情况下,我收到异常“类型为“\DateTime”、“字符串”的预期参数”

我尝试使用 DataTransformer 但没有任何区别。我发现对于数据字段的值总是通过DateTimeToLocalizedStringTransformer,如果我理解正确,它会返回空字符串,如果为空值,那么问题就在 datatransformers 之后的某个地方。

我尝试的另一件事是使用 attr 数组设置值,不幸的是,副作用是使用某些值填充表单不会影响日期字段。

有没有办法使用 single_text 小部件将数据字段的默认值设置为空?

这里有一个代码

<?php

namespace Psw\AdminBundle\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolverInterface;
use Doctrine\ORM\EntityRepository;
use Psw\AdminBundle\Form\DataTransformer\EmptyDateTransformer;
use Psw\AdminBundle\Form\DataTransformer\EmptyDateViewTransformer;

class OrdersFilterType extends AbstractType
{
    private $admin;

    public function __construct($admin=false) {
        $this->admin = $admin;
    }

    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder->add('client', 'entity', array(
                'class' => 'PswAdminBundle:User',
                'required' => false,
                'multiple' => false,
                'label'     => 'orders.client',
                'empty_value' => 'orders.allclients',
                'query_builder' => function(EntityRepository $er) {
                    $qb = $er->createQueryBuilder('u');
                    return $qb->where($qb->expr()->like('u.roles', '?0'))
                        ->setParameters(array('%ROLE_CLIENT%'));
                }
            ));
        if($this->admin) {
            $builder->add('staff', 'entity', array(
                'class' => 'PswAdminBundle:User',
                'required' => false,
                'multiple' => false,
                'label'     => 'orders.staff',
                'empty_value' => 'orders.allStaff',
                'query_builder' => function(EntityRepository $er) {
                    $qb = $er->createQueryBuilder('u');
                    return $qb->where($qb->expr()->like('u.roles', '?0'))
                              ->orWhere($qb->expr()->like('u.roles', '?1'))
                              ->orWhere($qb->expr()->like('u.roles', '?2'))
                        ->setParameters(array('%ROLE_STAFF%','%ROLE_ADMIN%','%ROLE_SUPER_ADMIN%'));
                }
            ));
        }
        $builder->add('start', 'date', array(
                    'label' => 'orders.start',
                    'widget' => 'single_text',
                    'required' => false,
                ))
                ->add('end', 'date', array(
                    'label' => 'orders.end',
                    'widget' => 'single_text',
                    'required' => false,
                ))
                ->add('min', null, array(
                    'label' => 'orders.min',
                    'required' => false,
                )) 
                ->add('max', null, array(
                    'label' => 'orders.max',
                    'required' => false,
                ));
    }


    public function getDefaultOptions(array $options)
    {
        $options = parent::getDefaultOptions($options);
        $options['csrf_protection'] = false;

        return $options;
    }

    public function getName()
    {
        return 'psw_adminbundle_ordersfiltertype';
    }
}
4

0 回答 0