Passed
Push — master ( 039de6...202994 )
by
unknown
07:02
created

InstitutionLocality   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 17
Duplicated Lines 0 %

Test Coverage

Coverage 25%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 2
eloc 6
dl 0
loc 17
ccs 2
cts 8
cp 0.25
rs 10
c 1
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 2 1
A __invoke() 0 11 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Application\Api\Input\Sorting;
6
7
use Doctrine\ORM\Mapping\ClassMetadata;
8
use Doctrine\ORM\QueryBuilder;
9
use GraphQL\Doctrine\Factory\UniqueNameFactory;
10
use GraphQL\Doctrine\Sorting\SortingInterface;
11
12
class InstitutionLocality implements SortingInterface
13
{
14 1
    public function __construct()
15
    {
16 1
    }
17
18
    public function __invoke(UniqueNameFactory $uniqueNameFactory, ClassMetadata $metadata, QueryBuilder $queryBuilder, string $alias, string $order): void
19
    {
20
        $queryBuilder->leftJoin($alias . '.institution', 'sortingInstitution');
21
22
        // First keep card without any institution at the bottom of the list
23
        $sortingFieldNullAsHighest = $uniqueNameFactory->createAliasName('sorting');
24
        $queryBuilder->addSelect("CASE WHEN sortingInstitution.locality IS NULL OR sortingInstitution.locality = '' THEN 1 ELSE 0 END AS HIDDEN " . $sortingFieldNullAsHighest);
25
        $queryBuilder->addOrderBy($sortingFieldNullAsHighest, $order);
26
27
        // Then sort cards with institutions
28
        $queryBuilder->addOrderBy('sortingInstitution.locality', $order);
29
    }
30
}
31