|
20 | 20 | use ApiPlatform\Metadata\Operation; |
21 | 21 | use Doctrine\ORM\QueryBuilder; |
22 | 22 |
|
| 23 | +use function is_iterable; |
| 24 | +use function strtolower; |
| 25 | + |
23 | 26 | /** |
24 | 27 | * @author Vincent Amstoutz <[email protected]> |
| 28 | + * @author Ré Schopmeijer <[email protected]> |
25 | 29 | */ |
26 | 30 | final class PartialSearchFilter implements FilterInterface, OpenApiParameterFilterInterface |
27 | 31 | { |
28 | 32 | use BackwardCompatibleFilterDescriptionTrait; |
29 | 33 | use OpenApiFilterTrait; |
30 | 34 |
|
31 | | - public function apply(QueryBuilder $queryBuilder, QueryNameGeneratorInterface $queryNameGenerator, string $resourceClass, ?Operation $operation = null, array $context = []): void |
32 | | - { |
33 | | - $parameter = $context['parameter']; |
34 | | - $property = $parameter->getProperty(); |
35 | | - $alias = $queryBuilder->getRootAliases()[0]; |
36 | | - $field = $alias.'.'.$property; |
37 | | - $parameterName = $queryNameGenerator->generateParameterName($property); |
38 | | - $values = $parameter->getValue(); |
39 | | - |
40 | | - if (!is_iterable($values)) { |
41 | | - $queryBuilder->setParameter($parameterName, '%'.strtolower($values).'%'); |
| 35 | + public function apply( |
| 36 | + QueryBuilder $queryBuilder, |
| 37 | + QueryNameGeneratorInterface $queryNameGenerator, |
| 38 | + string $resourceClass, |
| 39 | + ?Operation $operation = null, |
| 40 | + array $context = [], |
| 41 | + ): void { |
| 42 | + $parameter = $context['parameter']; |
| 43 | + $alias = $queryBuilder->getRootAliases()[0]; |
| 44 | + $properties = $parameter->getProperties() ?? [$parameter->getProperty()]; |
| 45 | + foreach ($properties as $property) { |
| 46 | + $field = $alias . '.' . $property; |
| 47 | + $parameterName = $queryNameGenerator->generateParameterName($property); |
| 48 | + $values = $parameter->getValue(); |
42 | 49 |
|
43 | | - $queryBuilder->{$context['whereClause'] ?? 'andWhere'}($queryBuilder->expr()->like( |
44 | | - 'LOWER('.$field.')', |
45 | | - ':'.$parameterName |
46 | | - )); |
| 50 | + if (!is_iterable($values)) { |
| 51 | + $queryBuilder->setParameter($parameterName, '%' . strtolower($values) . '%'); |
47 | 52 |
|
48 | | - return; |
49 | | - } |
| 53 | + $queryBuilder->{$context['whereClause'] ?? 'andWhere'}( |
| 54 | + $queryBuilder |
| 55 | + ->expr() |
| 56 | + ->like( |
| 57 | + 'LOWER(' . $field . ')', |
| 58 | + ':' . $parameterName, |
| 59 | + ), |
| 60 | + ); |
| 61 | + } else { |
| 62 | + $likeExpressions = []; |
| 63 | + foreach ($values as $val) { |
| 64 | + $parameterName = $queryNameGenerator->generateParameterName($property); |
| 65 | + $likeExpressions[] = $queryBuilder |
| 66 | + ->expr() |
| 67 | + ->like( |
| 68 | + 'LOWER(' . $field . ')', |
| 69 | + ':' . $parameterName, |
| 70 | + ) |
| 71 | + ; |
| 72 | + $queryBuilder->setParameter($parameterName, '%' . strtolower($val) . '%'); |
| 73 | + } |
50 | 74 |
|
51 | | - $likeExpressions = []; |
52 | | - foreach ($values as $val) { |
53 | | - $parameterName = $queryNameGenerator->generateParameterName($property); |
54 | | - $likeExpressions[] = $queryBuilder->expr()->like( |
55 | | - 'LOWER('.$field.')', |
56 | | - ':'.$parameterName |
57 | | - ); |
58 | | - $queryBuilder->setParameter($parameterName, '%'.strtolower($val).'%'); |
| 75 | + $queryBuilder->{$context['whereClause'] ?? 'andWhere'}( |
| 76 | + $queryBuilder |
| 77 | + ->expr() |
| 78 | + ->orX(...$likeExpressions), |
| 79 | + ); |
| 80 | + } |
59 | 81 | } |
60 | | - |
61 | | - $queryBuilder->{$context['whereClause'] ?? 'andWhere'}( |
62 | | - $queryBuilder->expr()->orX(...$likeExpressions) |
63 | | - ); |
64 | 82 | } |
65 | 83 | } |
0 commit comments