76 lines
1.9 KiB
PHP
76 lines
1.9 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Repository;
|
|
|
|
use App\Entity\Project;
|
|
use App\Entity\TimeEntry;
|
|
use App\Entity\User;
|
|
use DateTimeImmutable;
|
|
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
|
|
use Doctrine\Persistence\ManagerRegistry;
|
|
|
|
/**
|
|
* @extends ServiceEntityRepository<TimeEntry>
|
|
*/
|
|
class TimeEntryRepository extends ServiceEntityRepository
|
|
{
|
|
public function __construct(ManagerRegistry $registry)
|
|
{
|
|
parent::__construct($registry, TimeEntry::class);
|
|
}
|
|
|
|
public function findActiveByUser(User $user): ?TimeEntry
|
|
{
|
|
return $this->findOneBy([
|
|
'user' => $user,
|
|
'stoppedAt' => null,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @param null|User[] $users
|
|
* @param null|Project[] $projects
|
|
* @param null|int[] $tagIds
|
|
*
|
|
* @return TimeEntry[]
|
|
*/
|
|
public function findForExport(
|
|
DateTimeImmutable $after,
|
|
DateTimeImmutable $before,
|
|
?array $users = null,
|
|
?array $projects = null,
|
|
?array $tagIds = null,
|
|
): array {
|
|
$qb = $this->createQueryBuilder('te')
|
|
->andWhere('te.startedAt >= :after')
|
|
->andWhere('te.startedAt < :before')
|
|
->setParameter('after', $after)
|
|
->setParameter('before', $before)
|
|
->orderBy('te.startedAt', 'ASC')
|
|
;
|
|
|
|
if (null !== $users && [] !== $users) {
|
|
$qb->andWhere('te.user IN (:users)')
|
|
->setParameter('users', $users)
|
|
;
|
|
}
|
|
|
|
if (null !== $projects && [] !== $projects) {
|
|
$qb->andWhere('te.project IN (:projects)')
|
|
->setParameter('projects', $projects)
|
|
;
|
|
}
|
|
|
|
if (null !== $tagIds && [] !== $tagIds) {
|
|
$qb->join('te.tags', 'tag')
|
|
->andWhere('tag.id IN (:tagIds)')
|
|
->setParameter('tagIds', $tagIds)
|
|
;
|
|
}
|
|
|
|
return $qb->getQuery()->getResult();
|
|
}
|
|
}
|