single_text小部件不需要Symfony空日期字段

时间:2013-03-08 17:42:00

标签: symfony default datefield

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

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

根据this,如果我将required设置为false但id不设置,则应该有效。 我尝试将empty_value设置为与数据相同的空字符串,但在第一种情况下没有发生任何事情,因为此选项适用于选择字段。在第二种情况下,我得到异常“类型的预期参数”\ DateTime“,”string“给出”

我尝试使用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';
    }
}

0 个答案:

没有答案