From 43bff5519298c077ca1194dd0bef91dfe0a8e947 Mon Sep 17 00:00:00 2001 From: Ryan Prather Date: Sun, 5 Jan 2025 06:11:35 +0000 Subject: [PATCH] add method to filter notes --- src/Repository/StandardNoteRepository.php | 40 ++++++++++++++--------- src/Repository/VisitNoteRepository.php | 26 ++++++++++----- 2 files changed, 43 insertions(+), 23 deletions(-) diff --git a/src/Repository/StandardNoteRepository.php b/src/Repository/StandardNoteRepository.php index eedf561..c630e87 100644 --- a/src/Repository/StandardNoteRepository.php +++ b/src/Repository/StandardNoteRepository.php @@ -5,7 +5,7 @@ namespace App\Repository; use App\Entity\Referral; use App\Entity\StandardNote; use App\Entity\User; -use DateTimeImmutable; +use App\Entity\UserCase; use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository; use Doctrine\Persistence\ManagerRegistry; @@ -31,29 +31,39 @@ class StandardNoteRepository extends ServiceEntityRepository ; } - public function filterNotes(User $user, ?Referral $referral = null, ?DateTimeImmutable $startDate = null, ?DateTimeImmutable $endDate = null): array + public function filterNotes(User $user, array $params = []): array { - $query = $this->createQueryBuilder('v') - ->join('v.referral', 'r') + $query = $this->createQueryBuilder('s') + ->leftJoin(Referral::class, 'r', 'WITH', 's.referral = r.id') + ->leftJoin(UserCase::class, 'uc', 'WITH', 'r.memberCase = uc.memberCase') + ->andWhere('uc.user = :user') + ->setParameter('user', $user->getId()->toBinary()) ; - if ($referral) { - $query->andWhere('v.referral = :referral') - ->setParameter('referral', $referral->getId()->toBinary()); + if ($params['case']) { + $query->andWhere('r.memberCase = :memberCase') + ->setParameter('memberCase', $params['case']->getId()->toBinary()); } - if ($startDate) { - $query->andWhere('v.date >= :startDate') - ->setParameter('startDate', $startDate); + if ($params['referral']) { + $query->andWhere('s.referral = :referral') + ->setParameter('referral', $params['referral']->getId()->toBinary()); } - if ($endDate) { - $query->andWhere('v.date <= :endDate') - ->setParameter('endDate', $endDate); + if ($params['startDate']) { + $query->andWhere('s.date >= :startDate') + ->setParameter('startDate', $params['startDate']); } - return $query->orderBy('v.date', 'DESC') - ->addOrderBy('v.startTime', 'DESC') + if ($params['endDate']) { + $query->andWhere('s.date <= :endDate') + ->setParameter('endDate', $params['endDate']); + } + + //dd($query->getQuery()->getResult()); + + return $query->orderBy('s.date', 'DESC') + ->addOrderBy('s.startTime', 'DESC') ->getQuery() ->getResult() ; diff --git a/src/Repository/VisitNoteRepository.php b/src/Repository/VisitNoteRepository.php index be8137e..b5c2a75 100644 --- a/src/Repository/VisitNoteRepository.php +++ b/src/Repository/VisitNoteRepository.php @@ -3,8 +3,10 @@ namespace App\Repository; use App\Entity\Referral; +use App\Entity\UserCase; use App\Entity\User; use App\Entity\VisitNote; +use App\Entity\VisitNoteMembers; use DateTimeImmutable; use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository; use Doctrine\Persistence\ManagerRegistry; @@ -31,25 +33,33 @@ class VisitNoteRepository extends ServiceEntityRepository ; } - public function filterNotes(User $user, ?Referral $referral = null, ?DateTimeImmutable $startDate = null, ?DateTimeImmutable $endDate = null): array + public function filterNotes(User $user, array $params = []): array { $query = $this->createQueryBuilder('v') - ->join('v.referral', 'r') + ->leftJoin(Referral::class, 'r', 'WITH', 'v.referral = r.id') + ->leftJoin(UserCase::class, 'uc', 'WITH', 'r.memberCase = uc.memberCase') + ->andWhere('uc.user = :user') + ->setParameter('user', $user->getId()->toBinary()) ; - if ($referral) { + if ($params['case']) { + $query->andWhere('r.memberCase = :memberCase') + ->setParameter('memberCase', $params['case']->getId()->toBinary()); + } + + if ($params['referral']) { $query->andWhere('v.referral = :referral') - ->setParameter('referral', $referral->getId()->toBinary()); + ->setParameter('referral', $params['referral']->getId()->toBinary()); } - if ($startDate) { + if ($params['startDate']) { $query->andWhere('v.date >= :startDate') - ->setParameter('startDate', $startDate); + ->setParameter('startDate', $params['startDate']); } - if ($endDate) { + if ($params['endDate']) { $query->andWhere('v.date <= :endDate') - ->setParameter('endDate', $endDate); + ->setParameter('endDate', $params['endDate']); } return $query->orderBy('v.date', 'DESC')