HOW to Use:
// Create the pagination object
$pagination = new pagination($data, (isset($_GET['page']) ? $_GET['page'] : 1), $perpage);
// Decide if the first and last links should show
$pagination->setShowFirstAndLast(false);
// You can overwrite the default seperator
$pagination->setMainSeperator('');
// Parse through the pagination class
$shopPages = $pagination->getResults();
$pageNumbers = '<div class="pagination">' . $pagination->getLinks($_GET) . '</div>';
Class pagination :
class pagination { /** * Properties array * @var array * @access private */ private $_properties = array(); /** * Default configurations * @var array * @access public */ public $_defaults = array( 'page' => 1, 'perPage' => 10 ); /** * Constructor * * @param array $array Array of results to be paginated * @param int $curPage The current page interger that should used * @param int $perPage The amount of items that should be show per page * @return void * @access public */ public function __construct($array, $curPage = null, $perPage = null) { $this->array = $array; $this->curPage = ($curPage == null ? $this->defaults['page'] : $curPage); $this->perPage = ($perPage == null ? $this->defaults['perPage'] : $perPage); } /** * Global setter * * Utilises the properties array * * @param string $name The name of the property to set * @param string $value The value that the property is assigned * @return void * @access public */ public function __set($name, $value) { $this->_properties[$name] = $value; } /** * Global getter * * Takes a param from the properties array if it exists * * @param string $name The name of the property to get * @return mixed Either the property from the internal * properties array or false if isn't set * @access public */ public function __get($name) { if (array_key_exists($name, $this->_properties)) { return $this->_properties[$name]; } return false; } /** * Set the show first and last configuration * * This will enable the "<< first" and "last >>" style * links * * @param boolean $showFirstAndLast True to show, false to hide. * @return void * @access public */ public function setShowFirstAndLast($showFirstAndLast) { $this->_showFirstAndLast = $showFirstAndLast; } /** * Set the main seperator character * * By default this will implode an empty string * * @param string $mainSeperator The seperator between the page numbers * @return void * @access public */ public function setMainSeperator($mainSeperator) { $this->mainSeperator = $mainSeperator; } /** * Get the result portion from the provided array * * @return array Reduced array with correct calculated offset * @access public */ public function getResults() { // Assign the page variable if (empty($this->curPage) !== false) { $this->page = $this->curPage; // using the get method } else { $this->page = 1; // if we don't have a page number then assume we are on the first page } // Take the length of the array $this->length = count($this->array); // Get the number of pages $this->pages = ceil($this->length / $this->perPage); // Calculate the starting point $this->start = ceil(($this->page - 1) * $this->perPage); // return the portion of results return array_slice($this->array, $this->start, $this->perPage); } /** * Get the html links for the generated page offset * * @param array $params A list of parameters (probably get/post) to * pass around with each request * @return mixed Return description (if any) ... * @access public */ public function getLinks($params = array()) { // Initiate the links array $plinks = array(); $links = array(); $slinks = array(); // Concatenate the get variables to add to the page numbering string $queryUrl = ''; if (!empty($params) === true) { unset($params['page']); $queryUrl = '&' . http_build_query($params); } // If we have more then one pages if (($this->pages) > 1) { // Assign the 'previous page' link into the array if we are not on the first page if ($this->page != 1) { if ($this->_showFirstAndLast) { $plinks[] = ' <li><a href="?page=1' . $queryUrl . '">«« First </a></li> '; } $plinks[] = ' <li><a href="?page=' . ($this->page - 1) . $queryUrl . '">« Prev</a></li> '; } // Assign all the page numbers & links to the array for ($j = 1; $j < ($this->pages + 1); $j++) { if ($this->pages > 7) { if ($this->page == $j) { $links[] = ' <li class="active"><a class="selected">' . $j . '</a></li> '; // If we are on the same page as the current item } else { if ($this->page <= 4) { if ($j <= 5) { $links[] = ' <li><a href="?page=' . $j . $queryUrl . '">' . $j . '</a></li> '; // add the link to the array if ($j == 5) { $links[] = '<li class="paginate_button disabled" id="dataTable_ellipsis"><a href="#" aria-controls="dataTable" data-dt-idx="6" tabindex="0">…</a></li>'; } } if ($j == $this->pages) { $links[] = ' <li><a href="?page=' . $j . $queryUrl . '">' . $j . '</a></li> '; // add the link to the array } } if (($this->page > 4) && ($this->page < ($this->pages - 3))) { if ($j == 1) { $links[] = ' <li><a href="?page=' . $j . $queryUrl . '">' . $j . '</a></li> '; // add the link to the array } if ($j == ($this->page - 1)) { $links[] = '<li class="paginate_button disabled" id="dataTable_ellipsis"><a href="#" aria-controls="dataTable" data-dt-idx="6" tabindex="0">…</a></li>'; $links[] = ' <li><a href="?page=' . $j . $queryUrl . '">' . $j . '</a></li> '; // add the link to the array } if ($j == ($this->page + 1)) { $links[] = ' <li><a href="?page=' . $j . $queryUrl . '">' . $j . '</a></li> '; // add the link to the array $links[] = '<li class="paginate_button disabled" id="dataTable_ellipsis"><a href="#" aria-controls="dataTable" data-dt-idx="6" tabindex="0">…</a></li>'; } if ($j == $this->pages) { $links[] = ' <li><a href="?page=' . $j . $queryUrl . '">' . $j . '</a></li> '; // add the link to the array } } if (($this->page >= ($this->pages - 3))) { if (($j >= ($this->pages - 4))) { $links[] = ' <li><a href="?page=' . $j . $queryUrl . '">' . $j . '</a></li> '; // add the link to the array } if ($j == 1) { $links[] = ' <li><a href="?page=' . $j . $queryUrl . '">' . $j . '</a></li> '; // add the link to the array $links[] = '<li class="paginate_button disabled" id="dataTable_ellipsis"><a href="#" aria-controls="dataTable" data-dt-idx="6" tabindex="0">…</a></li>'; } } } } else { if ($this->page == $j) { $links[] = ' <li class="active"><a class="selected">' . $j . '</a></li> '; // If we are on the same page as the current item } else { $links[] = ' <li><a href="?page=' . $j . $queryUrl . '">' . $j . '</a></li> '; // add the link to the array } } } // Assign the 'next page' if we are not on the last page if ($this->page < $this->pages) { $slinks[] = ' <li><a href="?page=' . ($this->page + 1) . $queryUrl . '"> Next » </a></li> '; if ($this->_showFirstAndLast) { $slinks[] = ' <li><a href="?page=' . ($this->pages) . $queryUrl . '"> Last »» </a></li> '; } } // Push the array into a string using any some glue return implode(' ', $plinks) . implode($this->mainSeperator, $links) . implode(' ', $slinks); } return; } }