gmarche/vendor/pagerfanta/pagerfanta/src/Pagerfanta/Adapter/DoctrineORMAdapter.php

82 lines
2.0 KiB
PHP

<?php
/*
* This file is part of the Pagerfanta package.
*
* (c) Pablo Díez <pablodip@gmail.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Pagerfanta\Adapter;
use Doctrine\ORM\Tools\Pagination\Paginator as DoctrinePaginator;
/**
* DoctrineORMAdapter.
*
* @author Christophe Coevoet <stof@notk.org>
*/
class DoctrineORMAdapter implements AdapterInterface
{
/**
* @var \Doctrine\ORM\Tools\Pagination\Paginator
*/
private $paginator;
/**
* Constructor.
*
* @param \Doctrine\ORM\Query|\Doctrine\ORM\QueryBuilder $query A Doctrine ORM query or query builder.
* @param boolean $fetchJoinCollection Whether the query joins a collection (true by default).
* @param boolean|null $useOutputWalkers Whether to use output walkers pagination mode
*/
public function __construct($query, $fetchJoinCollection = true, $useOutputWalkers = null)
{
$this->paginator = new DoctrinePaginator($query, $fetchJoinCollection);
$this->paginator->setUseOutputWalkers($useOutputWalkers);
}
/**
* Returns the query
*
* @return \Doctrine\ORM\Query
*/
public function getQuery()
{
return $this->paginator->getQuery();
}
/**
* Returns whether the query joins a collection.
*
* @return boolean Whether the query joins a collection.
*/
public function getFetchJoinCollection()
{
return $this->paginator->getFetchJoinCollection();
}
/**
* {@inheritdoc}
*/
public function getNbResults()
{
return count($this->paginator);
}
/**
* {@inheritdoc}
*/
public function getSlice($offset, $length)
{
$this->paginator
->getQuery()
->setFirstResult($offset)
->setMaxResults($length);
return $this->paginator->getIterator();
}
}