1
0
mirror of synced 2025-01-07 17:47:10 +03:00
doctrine2/lib/Doctrine/Pager.php

369 lines
8.3 KiB
PHP
Raw Normal View History

<?php
/*
* $Id$
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* This software consists of voluntary contributions made by many individuals
* and is licensed under the LGPL. For more information, see
* <http://www.phpdoctrine.com>.
*/
/**
* Doctrine_Pager
*
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
* @package Doctrine
* @subpackage Pager
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
* @version $Revision$
* @link www.phpdoctrine.com
* @since 1.0
*/
class Doctrine_Pager
{
/**
2007-11-26 03:07:09 +03:00
* @var Doctrine_Query $_query Doctrine_Query object related to the pager
*/
2007-11-26 03:07:09 +03:00
protected $_query;
/**
2007-11-26 03:07:09 +03:00
* @var integer $_numResults Number of results found
*/
2007-11-26 03:07:09 +03:00
protected $_numResults;
/**
2007-11-26 03:07:09 +03:00
* @var integer $_maxPerPage Maximum number of itens per page
*/
2007-11-26 03:07:09 +03:00
protected $_maxPerPage;
/**
2007-11-26 03:07:09 +03:00
* @var integer $page Current page
*/
2007-11-26 03:07:09 +03:00
protected $_page;
/**
2007-11-26 03:07:09 +03:00
* @var integer $_lastPage Last page (total of pages)
*/
2007-11-26 03:07:09 +03:00
protected $_lastPage;
/**
* __construct
*
* @param mixed $query Accepts either a Doctrine_Query object or a string
* (which does the Doctrine_Query class creation).
* @param int $page Current page
* @param int $maxPerPage Maximum itens per page
* @return void
*/
2007-11-26 03:07:09 +03:00
public function __construct($query, $page, $maxPerPage = 0)
{
$this->setQuery($query);
$this->_setMaxPerPage($maxPerPage);
$this->_setPage($page);
$this->initialize();
}
/**
* initialize
*
* Initialize Pager object calculating number of results
*
* @return void
*/
protected function initialize()
{
2007-11-26 02:57:10 +03:00
// retrieve the number of items found
$count = $this->getQuery()->count();
2007-11-26 03:07:09 +03:00
$this->setNumResults($count);
$this->adjustOffset();
}
/**
* adjustOffset
*
* Adjusts last page of Doctrine_Pager, offset and limit of Doctrine_Query associated
*
* @return void
*/
protected function adjustOffset()
{
// Define new total of pages
$this->setLastPage(
2007-11-26 03:07:09 +03:00
max(1, ceil($this->getNumResults() / $this->getMaxPerPage()))
);
$offset = ($this->getPage() - 1) * $this->getMaxPerPage();
// Assign new offset and limit to Doctrine_Query object
$p = $this->getQuery();
$p->offset($offset);
$p->limit($this->getMaxPerPage());
}
/**
2007-11-26 03:07:09 +03:00
* getNumResults
*
* Returns the number of results found
*
* @return int the number of results found
*/
2007-11-26 03:07:09 +03:00
public function getNumResults()
{
2007-11-26 03:07:09 +03:00
return $this->_numResults;
}
/**
2007-11-26 03:07:09 +03:00
* setNumResults
*
* Defines the number of total results on initial query
*
* @param $nb Number of results found on initial query fetch
* @return void
*/
2007-11-26 03:07:09 +03:00
protected function setNumResults($nb)
{
2007-11-26 03:07:09 +03:00
$this->_numResults = $nb;
}
/**
* getFirstPage
*
* Returns the first page
*
* @return int first page
*/
public function getFirstPage()
{
return 1;
}
/**
* getLastPage
*
* Returns the last page (total of pages)
*
* @return int last page (total of pages)
*/
public function getLastPage()
{
2007-11-26 03:07:09 +03:00
return $this->_lastPage;
}
/**
* setLastPage
*
* Defines the last page (total of pages)
*
* @param $page last page (total of pages)
* @return void
*/
protected function setLastPage($page)
{
2007-11-26 03:07:09 +03:00
$this->_lastPage = $page;
2007-11-26 02:59:54 +03:00
if ($this->getPage() > $page) {
$this->_setPage($page);
}
}
/**
* getLastPage
*
* Returns the current page
*
* @return int current page
*/
public function getPage()
{
2007-11-26 03:07:09 +03:00
return $this->_page;
}
/**
* getLastPage
*
* Returns the next page
*
* @return int next page
*/
public function getNextPage()
{
return min($this->getPage() + 1, $this->getLastPage());
}
/**
* getLastPage
*
* Returns the previous page
*
* @return int previous page
*/
public function getPreviousPage()
{
return max($this->getPage() - 1, $this->getFirstPage());
}
/**
* haveToPaginate
*
* Return true if it's necessary to paginate or false if not
*
* @return bool true if it is necessary to paginate, false otherwise
*/
public function haveToPaginate()
{
2007-11-26 03:07:09 +03:00
return $this->getNumResults() > $this->getMaxPerPage();
}
/**
* setPage
*
* Defines the current page and automatically adjust offset and limits
*
* @param $page current page
* @return void
*/
public function setPage($page)
{
$this->_setPage($page);
$this->adjustOffset();
}
/**
* _setPage
*
* Defines the current page
*
* @param $page current page
* @return void
*/
private function _setPage($page)
{
$page = intval($page);
2007-11-26 03:07:09 +03:00
$this->_page = ($page <= 0) ? 1 : $page;
}
/**
* getLastPage
*
* Returns the maximum number of itens per page
*
* @return int maximum number of itens per page
*/
public function getMaxPerPage()
{
2007-11-26 03:07:09 +03:00
return $this->_maxPerPage;
}
/**
* setMaxPerPage
*
* Defines the maximum number of itens per page and automatically adjust offset and limits
*
* @param $max maximum number of itens per page
* @return void
*/
public function setMaxPerPage($max)
{
$this->_setMaxPerPage($max);
$this->adjustOffset();
}
/**
* _setMaxPerPage
*
* Defines the maximum number of itens per page
*
* @param $max maximum number of itens per page
* @return void
*/
private function _setMaxPerPage($max)
{
if ($max > 0) {
2007-11-26 03:07:09 +03:00
$this->_maxPerPage = $max;
} else if ($max == 0) {
2007-11-26 03:07:09 +03:00
$this->_maxPerPage = 25;
} else {
2007-11-26 03:07:09 +03:00
$this->_maxPerPage = abs($max);
}
}
/**
* getQuery
*
* Returns the Doctrine_Query object related to the pager
*
* @return Doctrine_Query Doctrine_Query object related to the pager
*/
public function getQuery()
{
2007-11-26 03:07:09 +03:00
return $this->_query;
}
/**
* setQuery
*
* Defines the maximum number of itens per page
*
* @param $query Accepts either a Doctrine_Query object or a string
* (which does the Doctrine_Query class creation).
* @return void
*/
protected function setQuery($query)
{
if (is_string($query)) {
2007-11-26 02:59:54 +03:00
$query = Doctrine_Query::create()->parseQuery($query);
}
2007-11-26 03:07:09 +03:00
$this->_query = $query;
}
/**
* execute
* executes the query and populates the data set
*
* @param $params Optional parameters to Doctrine_Query::execute
* @param $hydrationMode Hyddration Mode of Doctrine_Query::execute
* returned ResultSet. Doctrine::Default is FETCH_RECORD
* @return Doctrine_Collection the root collection
*/
public function execute($params = array(), $hydrationMode = Doctrine::FETCH_RECORD)
{
return $this->getQuery()->execute($params, $hydrationMode);
}
}