Code Duplication    Length = 49-51 lines in 2 locations

src/Kunstmaan/AdminListBundle/AdminList/FilterType/DBAL/DateFilterType.php 1 location

@@ 11-59 (lines=49) @@
8
/**
9
 * DateFilterType
10
 */
11
class DateFilterType extends AbstractDBALFilterType
12
{
13
    /**
14
     * @param Request $request  The request
15
     * @param array   &$data    The data
16
     * @param string  $uniqueId The unique identifier
17
     */
18
    public function bindRequest(Request $request, array &$data, $uniqueId)
19
    {
20
        $data['comparator'] = $request->query->get('filter_comparator_' . $uniqueId);
21
        $data['value'] = $request->query->get('filter_value_' . $uniqueId);
22
    }
23
24
    /**
25
     * @param array  $data     The data
26
     * @param string $uniqueId The unique identifier
27
     */
28
    public function apply(array $data, $uniqueId)
29
    {
30
        if (isset($data['value'], $data['comparator'])) {
31
            $dateTime = DateTime::createFromFormat('d/m/Y', $data['value']);
32
33
            if (false === $dateTime) {
34
                // Failed to create DateTime object.
35
                return;
36
            }
37
            $date = $dateTime->format('Y-m-d');
38
            switch ($data['comparator']) {
39
                case 'before':
40
                    $this->queryBuilder->andWhere($this->queryBuilder->expr()->lte($this->getAlias() . $this->columnName, ':var_' . $uniqueId));
41
42
                    break;
43
                case 'after':
44
                    $this->queryBuilder->andWhere($this->queryBuilder->expr()->gt($this->getAlias() . $this->columnName, ':var_' . $uniqueId));
45
46
                    break;
47
            }
48
            $this->queryBuilder->setParameter('var_' . $uniqueId, $date);
49
        }
50
    }
51
52
    /**
53
     * @return string
54
     */
55
    public function getTemplate()
56
    {
57
        return '@KunstmaanAdminList/FilterType/dateFilter.html.twig';
58
    }
59
}
60

src/Kunstmaan/AdminListBundle/AdminList/FilterType/ORM/DateFilterType.php 1 location

@@ 11-61 (lines=51) @@
8
/**
9
 * DateFilterType
10
 */
11
class DateFilterType extends AbstractORMFilterType
12
{
13
    /**
14
     * @param Request $request  The request
15
     * @param array   &$data    The data
16
     * @param string  $uniqueId The unique identifier
17
     */
18
    public function bindRequest(Request $request, array &$data, $uniqueId)
19
    {
20
        $data['comparator'] = $request->query->get('filter_comparator_' . $uniqueId);
21
        $data['value'] = $request->query->get('filter_value_' . $uniqueId);
22
    }
23
24
    /**
25
     * @param array  $data     The data
26
     * @param string $uniqueId The unique identifier
27
     */
28
    public function apply(array $data, $uniqueId)
29
    {
30
        if (isset($data['value'], $data['comparator'])) {
31
            $dateTime = DateTime::createFromFormat('d/m/Y', $data['value']);
32
33
            if (false === $dateTime) {
34
                // Failed to create DateTime object.
35
                return;
36
            }
37
38
            $date = $dateTime->format('Y-m-d');
39
40
            switch ($data['comparator']) {
41
                case 'before':
42
                    $this->queryBuilder->andWhere($this->queryBuilder->expr()->lte($this->getAlias() . $this->columnName, ':var_' . $uniqueId));
43
44
                    break;
45
                case 'after':
46
                    $this->queryBuilder->andWhere($this->queryBuilder->expr()->gt($this->getAlias() . $this->columnName, ':var_' . $uniqueId));
47
48
                    break;
49
            }
50
            $this->queryBuilder->setParameter('var_' . $uniqueId, $date);
51
        }
52
    }
53
54
    /**
55
     * @return string
56
     */
57
    public function getTemplate()
58
    {
59
        return '@KunstmaanAdminList/FilterType/dateFilter.html.twig';
60
    }
61
}
62