feat : add findForExport repository method for time entries
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -4,8 +4,10 @@ declare(strict_types=1);
|
|||||||
|
|
||||||
namespace App\Repository;
|
namespace App\Repository;
|
||||||
|
|
||||||
|
use App\Entity\Project;
|
||||||
use App\Entity\TimeEntry;
|
use App\Entity\TimeEntry;
|
||||||
use App\Entity\User;
|
use App\Entity\User;
|
||||||
|
use DateTimeImmutable;
|
||||||
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
|
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
|
||||||
use Doctrine\Persistence\ManagerRegistry;
|
use Doctrine\Persistence\ManagerRegistry;
|
||||||
|
|
||||||
@@ -26,4 +28,46 @@ class TimeEntryRepository extends ServiceEntityRepository
|
|||||||
'stoppedAt' => null,
|
'stoppedAt' => null,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param null|int[] $tagIds
|
||||||
|
*
|
||||||
|
* @return TimeEntry[]
|
||||||
|
*/
|
||||||
|
public function findForExport(
|
||||||
|
DateTimeImmutable $after,
|
||||||
|
DateTimeImmutable $before,
|
||||||
|
?User $user = null,
|
||||||
|
?Project $project = 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 !== $user) {
|
||||||
|
$qb->andWhere('te.user = :user')
|
||||||
|
->setParameter('user', $user)
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (null !== $project) {
|
||||||
|
$qb->andWhere('te.project = :project')
|
||||||
|
->setParameter('project', $project)
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (null !== $tagIds && [] !== $tagIds) {
|
||||||
|
$qb->join('te.tags', 'tag')
|
||||||
|
->andWhere('tag.id IN (:tagIds)')
|
||||||
|
->setParameter('tagIds', $tagIds)
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $qb->getQuery()->getResult();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user