Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

57 lines
1.9KB

  1. <?php
  2. namespace Lc\SovBundle\Repository\Reminder;
  3. use Lc\SovBundle\Repository\AbstractRepository;
  4. use Lc\SovBundle\Model\Reminder\ReminderInterface;
  5. /**
  6. * @method ReminderInterface|null find($id, $lockMode = null, $lockVersion = null)
  7. * @method ReminderInterface|null findOneBy(array $criteria, array $orderBy = null)
  8. * @method ReminderInterface[] findAll()
  9. * @method ReminderInterface[] findBy(array $criteria, array $orderBy = null, $limit = null, $offset = null)
  10. */
  11. class ReminderRepository extends AbstractRepository
  12. {
  13. public function getInterfaceClass()
  14. {
  15. return ReminderInterface::class;
  16. }
  17. public function findByUser($user)
  18. {
  19. $qb = $this->createQueryBuilder('e')
  20. ->leftJoin('e.users', 'u')
  21. ->having('COUNT(u.id) = 0')
  22. ->orHaving(':user MEMBER OF e.users')
  23. ->andWhere('e.done = 0')
  24. ->setParameter('user', $user)
  25. ->orderBy('e.dateReminder', 'ASC')
  26. ->groupBy('e.id');
  27. return $qb->getQuery()->getResult();
  28. }
  29. public function findByEasyAdminConfigAndUser($crudAction, $crudControllerFqcn, $user, $entityId = null)
  30. {
  31. $qb = $this->createQueryBuilder('e');
  32. $qb->leftJoin('e.users', 'u');
  33. $qb->having('COUNT(u.id) = 0');
  34. $qb->orHaving(':user MEMBER OF e.users');
  35. $qb->andWhere('e.done = 0');
  36. $qb->andWhere('e.crudAction LIKE :crudAction');
  37. $qb->andWhere('e.crudControllerFqcn LIKE :entity');
  38. $qb->setParameter('crudAction', $crudAction);
  39. $qb->setParameter('crudControllerFqcn', $crudControllerFqcn);
  40. $qb->setParameter('user', $user);
  41. if ($entityId) {
  42. $qb->andWhere('e.entityId LIKE :id');
  43. $qb->setParameter('entityId', $entityId);
  44. }
  45. $qb->orderBy('e.dateReminder', 'ASC');
  46. $qb->groupBy('e.id');
  47. return $qb->getQuery()->getResult();
  48. }
  49. }