<?php
namespace App\Repository\Articles;
use App\Entity\Articles\Articles;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
use Doctrine\Persistence\ManagerRegistry;
use Doctrine\ORM\NonUniqueResultException;
/**
* @method Articles|null find($id, $lockMode = null, $lockVersion = null)
* @method Articles|null findOneBy(array $criteria, array $orderBy = null)
* @method Articles[] findAll()
* @method Articles[] findBy(array $criteria, array $orderBy = null, $limit = null, $offset = null)
*/
class ArticlesRepository extends ServiceEntityRepository
{
public function __construct(ManagerRegistry $registry)
{
parent::__construct($registry, Articles::class);
}
public function getArticleRandom(Articles $article, $categorie, $limit)
{
return $this->createQueryBuilder('a')
->select('a', 'c')
->leftJoin('a.categories', 'c')
->andWhere('a.id != :article')
->andWhere('c.id = :categorie')
->setParameters(['article' => $article, 'categorie' => $categorie])
->orderBy('RAND()')
->setMaxResults($limit)
->getQuery()
->getResult()
;
}
/**
* @param int $limit
* @return int|mixed|string
*/
public function getIncontournable(int $limit)
{
return $this->createQueryBuilder('a')
->andWhere('a.online = 1')
->andWhere('a.incontournable = 1')
->orderBy('a.id', 'DESC')
->setMaxResults($limit)
->getQuery()
->getResult()
;
}
/**
* @return int|mixed|string|null
* @throws NonUniqueResultException
*/
public function featured()
{
return $this->createQueryBuilder('a')
->andWhere('a.online = 1')
->andWhere('a.featured = 1')
->orderBy('a.updatedAt', 'DESC')
->setMaxResults(1)
->getQuery()
->getOneOrNullResult()
;
}
}