Completed
Push — master ( 1f27b0...b9260b )
by Joachim
05:43
created

getLatestStockMovementIdOnAReport()   A

Complexity

Conditions 3
Paths 4

Size

Total Lines 19
Code Lines 10

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
eloc 10
dl 0
loc 19
rs 9.9332
c 0
b 0
f 0
cc 3
nc 4
nop 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Setono\SyliusStockMovementPlugin\Doctrine\ORM;
6
7
use Setono\SyliusStockMovementPlugin\Model\ReportConfigurationInterface;
8
use Setono\SyliusStockMovementPlugin\Repository\ReportRepositoryInterface;
9
use Sylius\Bundle\ResourceBundle\Doctrine\ORM\EntityRepository;
10
11
final class ReportRepository extends EntityRepository implements ReportRepositoryInterface
12
{
13
    public function getLatestStockMovementIdOnAReport(ReportConfigurationInterface $reportConfiguration = null): ?int
14
    {
15
        $qb = $this->createQueryBuilder('r');
16
        $qb->select('MAX(s.id)')
17
            ->join('r.stockMovements', 's')
18
        ;
19
20
        if (null !== $reportConfiguration) {
21
            $qb->andWhere('r.reportConfiguration = :reportConfiguration')
22
                ->setParameter('reportConfiguration', $reportConfiguration)
23
            ;
24
        }
25
26
        $res = $qb->getQuery()->getSingleScalarResult();
27
        if (null === $res) {
28
            return null;
29
        }
30
31
        return (int) $res;
32
    }
33
}
34