@@ 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 |
@@ 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 |