Completed
Push — master ( 6734fa...551366 )
by
unknown
07:45
created

src/Filter/NodeNameFilter.php (1 issue)

Upgrade to new PHP Analysis Engine

These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more

1
<?php
2
3
/*
4
 * This file is part of the Sonata Project package.
5
 *
6
 * (c) Thomas Rabaix <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
namespace Sonata\DoctrinePHPCRAdminBundle\Filter;
13
14
use Sonata\AdminBundle\Datagrid\ProxyQueryInterface;
15
use Sonata\DoctrinePHPCRAdminBundle\Form\Type\Filter\ChoiceType;
16
17
class NodeNameFilter extends Filter
18
{
19
    /**
20
     * {@inheritdoc}
21
     */
22
    public function filter(ProxyQueryInterface $proxyQuery, $alias, $field, $data)
23
    {
24
        if (!$data || !is_array($data) || !array_key_exists('value', $data)) {
0 ignored issues
show
Bug Best Practice introduced by
The expression $data of type array is implicitly converted to a boolean; are you sure this is intended? If so, consider using empty($expr) instead to make it clear that you intend to check for an array without elements.

This check marks implicit conversions of arrays to boolean values in a comparison. While in PHP an empty array is considered to be equal (but not identical) to false, this is not always apparent.

Consider making the comparison explicit by using empty(..) or ! empty(...) instead.

Loading history...
25
            return;
26
        }
27
28
        $data['value'] = trim($data['value']);
29
        $data['type'] = empty($data['type']) ? ChoiceType::TYPE_CONTAINS : $data['type'];
30
31
        if (0 == strlen($data['value'])) {
32
            return;
33
        }
34
35
        $where = $this->getWhere($proxyQuery);
36
37
        switch ($data['type']) {
38
            case ChoiceType::TYPE_EQUAL:
39
                $where->eq()->localName($alias)->literal($data['value']);
40
41
                break;
42
            case ChoiceType::TYPE_CONTAINS:
43
            default:
44
                $where->like()->localName($alias)->literal('%'.$data['value'].'%');
45
        }
46
47
        // filter is active as we have now modified the query
48
        $this->active = true;
49
    }
50
51
    /**
52
     * {@inheritdoc}
53
     */
54
    public function getDefaultOptions()
55
    {
56
        return [
57
            'format' => '%%%s%%',
58
        ];
59
    }
60
61
    /**
62
     * {@inheritdoc}
63
     */
64
    public function getRenderSettings()
65
    {
66
        return ['Sonata\DoctrinePHPCRAdminBundle\Form\Type\Filter\ChoiceType', [
67
            'field_type' => $this->getFieldType(),
68
            'field_options' => $this->getFieldOptions(),
69
            'label' => $this->getLabel(),
70
        ]];
71
    }
72
}
73