<?php
namespace App\Repository\Actualites;
use App\Entity\Actualites\Actualites;
use App\Entity\Actualites\Categories;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
use Doctrine\Persistence\ManagerRegistry;
/**
* @method Actualites|null find($id, $lockMode = null, $lockVersion = null)
* @method Actualites|null findOneBy(array $criteria, array $orderBy = null)
* @method Actualites[] findAll()
* @method Actualites[] findBy(array $criteria, array $orderBy = null, $limit = null, $offset = null)
*/
class ActualitesRepository extends ServiceEntityRepository
{
public function __construct(ManagerRegistry $registry)
{
parent::__construct($registry, Actualites::class);
}
public function getActualitesRandom(Actualites $actualite, $limit)
{
return $this->createQueryBuilder('a')
->andWhere('a.id != :actualite')
->setParameter('actualite', $actualite)
->orderBy('RAND()')
->setMaxResults($limit)
->getQuery()
->getResult()
;
}
/**
* @param Categories $categories
* @return Actualites[]
*/
public function getActualitesByCategorie(Categories $categories): array
{
return $this->createQueryBuilder('a')
->select('c', 'a')
->leftJoin('a.categories', 'c')
->andWhere('c.id = :categories')
->setParameter('categories', $categories)
->orderBy('a.id', 'DESC')
->getQuery()
->getResult()
;
}
public function findAllOnline()
{
return $this->createQueryBuilder('a')
->andWhere('a.online = :online')
->andWhere('a.featured = :featured')
->setParameters(['online' => 1, 'featured' => 0])
->orderBy('a.id', 'DESC')
->getQuery()
->getResult()
;
}
public function features(int $limit)
{
return $this->createQueryBuilder('a')
->andWhere('a.featured = :featured')
->andWhere('a.online = 1')
->setParameters(['featured' => 1])
->orderBy('a.id', 'DESC')
->setMaxResults($limit)
->getQuery()
->getResult()
;
}
public function latest(int $limit)
{
return $this->createQueryBuilder('a')
->andWhere('a.online = :online')
->setParameters(['online' => 1])
->orderBy('a.id', 'DESC')
->setMaxResults($limit)
->getQuery()
->getResult()
;
}
}