blob: e0cab21280a3d39c1e7a56c0b45bef6186becde7 [file] [log] [blame]
Andrey Andreev33987e62011-12-24 19:48:45 +02001<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
Derek Allard2067d1a2008-11-13 22:59:24 +00002/**
3 * CodeIgniter
4 *
Greg Aker741de1c2010-11-10 14:52:57 -06005 * An open source application development framework for PHP 5.1.6 or newer
Derek Allard2067d1a2008-11-13 22:59:24 +00006 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05007 * NOTICE OF LICENSE
Eric Barnes9a4902a2011-12-03 23:46:06 -05008 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05009 * Licensed under the Open Software License version 3.0
Eric Barnes9a4902a2011-12-03 23:46:06 -050010 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -050011 * This source file is subject to the Open Software License (OSL 3.0) that is
12 * bundled with this package in the files license.txt / license.rst. It is
13 * also available through the world wide web at this URL:
14 * http://opensource.org/licenses/OSL-3.0
15 * If you did not receive a copy of the license and are unable to obtain it
16 * through the world wide web, please send an email to
17 * licensing@ellislab.com so we can send you a copy immediately.
18 *
Derek Allard2067d1a2008-11-13 22:59:24 +000019 * @package CodeIgniter
Derek Jonesf4a4bd82011-10-20 12:18:42 -050020 * @author EllisLab Dev Team
Greg Aker0defe5d2012-01-01 18:46:41 -060021 * @copyright Copyright (c) 2008 - 2012, EllisLab, Inc. (http://ellislab.com/)
Derek Jonesf4a4bd82011-10-20 12:18:42 -050022 * @license http://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
Derek Allard2067d1a2008-11-13 22:59:24 +000023 * @link http://codeigniter.com
24 * @since Version 1.0
25 * @filesource
26 */
27
28// ------------------------------------------------------------------------
29
30/**
31 * Pagination Class
32 *
33 * @package CodeIgniter
34 * @subpackage Libraries
35 * @category Pagination
Derek Jonesf4a4bd82011-10-20 12:18:42 -050036 * @author EllisLab Dev Team
Derek Allard2067d1a2008-11-13 22:59:24 +000037 * @link http://codeigniter.com/user_guide/libraries/pagination.html
38 */
39class CI_Pagination {
40
Eric Barnes9a4902a2011-12-03 23:46:06 -050041 protected $base_url = ''; // The page we are linking to
42 protected $prefix = ''; // A custom prefix added to the path.
43 protected $suffix = ''; // A custom suffix added to the path.
44 protected $total_rows = 0; // Total number of items (database results)
45 protected $per_page = 10; // Max number of items you want shown per page
46 protected $num_links = 2; // Number of "digit" links to show before/after the currently viewed page
47 protected $cur_page = 0; // The current page being viewed
48 protected $use_page_numbers = FALSE; // Use page number for segment instead of offset
49 protected $first_link = '&lsaquo; First';
50 protected $next_link = '&gt;';
51 protected $prev_link = '&lt;';
52 protected $last_link = 'Last &rsaquo;';
53 protected $uri_segment = 3;
54 protected $full_tag_open = '';
55 protected $full_tag_close = '';
56 protected $first_tag_open = '';
57 protected $first_tag_close = '&nbsp;';
58 protected $last_tag_open = '&nbsp;';
59 protected $last_tag_close = '';
60 protected $first_url = ''; // Alternative URL for the First Page.
61 protected $cur_tag_open = '&nbsp;<strong>';
62 protected $cur_tag_close = '</strong>';
63 protected $next_tag_open = '&nbsp;';
64 protected $next_tag_close = '&nbsp;';
65 protected $prev_tag_open = '&nbsp;';
66 protected $prev_tag_close = '';
67 protected $num_tag_open = '&nbsp;';
68 protected $num_tag_close = '';
69 protected $page_query_string = FALSE;
70 protected $query_string_segment = 'per_page';
71 protected $display_pages = TRUE;
72 protected $anchor_class = '';
Derek Allard2067d1a2008-11-13 22:59:24 +000073
74 /**
75 * Constructor
76 *
77 * @access public
78 * @param array initialization parameters
79 */
Greg Akera9263282010-11-10 15:26:43 -060080 public function __construct($params = array())
Derek Allard2067d1a2008-11-13 22:59:24 +000081 {
Eric Barnesbce41402011-12-03 23:47:41 -050082 $this->initialize($params);
Derek Allard2067d1a2008-11-13 22:59:24 +000083 log_message('debug', "Pagination Class Initialized");
84 }
Derek Allardfaac15e2009-03-07 17:17:58 +000085
Derek Allard2067d1a2008-11-13 22:59:24 +000086 // --------------------------------------------------------------------
Derek Allardfaac15e2009-03-07 17:17:58 +000087
Derek Allard2067d1a2008-11-13 22:59:24 +000088 /**
89 * Initialize Preferences
90 *
91 * @access public
92 * @param array initialization parameters
93 * @return void
94 */
Eric Barnes9a4902a2011-12-03 23:46:06 -050095 public function initialize($params = array())
Derek Allard2067d1a2008-11-13 22:59:24 +000096 {
97 if (count($params) > 0)
98 {
99 foreach ($params as $key => $val)
100 {
101 if (isset($this->$key))
102 {
103 $this->$key = $val;
104 }
105 }
106 }
Eric Barnesbce41402011-12-03 23:47:41 -0500107
108 if ($this->anchor_class != '')
109 {
110 $this->anchor_class = 'class="'.$this->anchor_class.'" ';
111 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000112 }
Derek Allardfaac15e2009-03-07 17:17:58 +0000113
Derek Allard2067d1a2008-11-13 22:59:24 +0000114 // --------------------------------------------------------------------
Derek Allardfaac15e2009-03-07 17:17:58 +0000115
Derek Allard2067d1a2008-11-13 22:59:24 +0000116 /**
117 * Generate the pagination links
118 *
119 * @access public
120 * @return string
Derek Allardfaac15e2009-03-07 17:17:58 +0000121 */
Eric Barnes9a4902a2011-12-03 23:46:06 -0500122 public function create_links()
Derek Allard2067d1a2008-11-13 22:59:24 +0000123 {
124 // If our item count or per-page total is zero there is no need to continue.
125 if ($this->total_rows == 0 OR $this->per_page == 0)
126 {
Derek Allardfaac15e2009-03-07 17:17:58 +0000127 return '';
Derek Allard2067d1a2008-11-13 22:59:24 +0000128 }
129
130 // Calculate the total number of pages
131 $num_pages = ceil($this->total_rows / $this->per_page);
132
133 // Is there only one page? Hm... nothing more to do here then.
Andrey Andreev33987e62011-12-24 19:48:45 +0200134 if ($num_pages === 1)
Derek Allard2067d1a2008-11-13 22:59:24 +0000135 {
136 return '';
137 }
138
Aaron Kuzemchak11c5f162011-09-03 20:59:07 -0400139 // Set the base page index for starting page number
Aaron Kuzemchaka5e13f92011-09-04 16:39:47 -0400140 $base_page = ($this->use_page_numbers) ? 1 : 0;
Aaron Kuzemchak11c5f162011-09-03 20:59:07 -0400141
Derek Allardfaac15e2009-03-07 17:17:58 +0000142 // Determine the current page number.
Derek Allard2067d1a2008-11-13 22:59:24 +0000143 $CI =& get_instance();
Derek Allardfaac15e2009-03-07 17:17:58 +0000144
Eric Barnes3b376592012-01-04 00:28:27 -0500145 // See if we are using a prefix or suffix on links
Eric Barnes8d727f12012-01-04 00:06:36 -0500146 if ($this->prefix != '' OR $this->suffix != '')
147 {
Eric Barnes3b376592012-01-04 00:28:27 -0500148 $this->cur_page = (int) str_replace(array($this->prefix, $this->suffix), '', $CI->uri->segment($this->uri_segment));
Eric Barnes8d727f12012-01-04 00:06:36 -0500149 }
150
Derek Allard2067d1a2008-11-13 22:59:24 +0000151 if ($CI->config->item('enable_query_strings') === TRUE OR $this->page_query_string === TRUE)
152 {
Aaron Kuzemchak11c5f162011-09-03 20:59:07 -0400153 if ($CI->input->get($this->query_string_segment) != $base_page)
Derek Allard2067d1a2008-11-13 22:59:24 +0000154 {
Andrey Andreev33987e62011-12-24 19:48:45 +0200155 $this->cur_page = (int) $CI->input->get($this->query_string_segment);
Derek Allard2067d1a2008-11-13 22:59:24 +0000156 }
157 }
Eric Barnes3b376592012-01-04 00:28:27 -0500158 elseif ( ! $this->cur_page AND $CI->uri->segment($this->uri_segment) != $base_page)
Derek Allard2067d1a2008-11-13 22:59:24 +0000159 {
Andrey Andreev33987e62011-12-24 19:48:45 +0200160 $this->cur_page = (int) $CI->uri->segment($this->uri_segment);
Derek Allard2067d1a2008-11-13 22:59:24 +0000161 }
Eric Barnes9a4902a2011-12-03 23:46:06 -0500162
Andrey Andreev33987e62011-12-24 19:48:45 +0200163 // Set current page to 1 if it's not valid or if using page numbers instead of offset
164 if ( ! is_numeric($this->cur_page) OR ($this->use_page_numbers AND $this->cur_page == 0))
Aaron Kuzemchak11c5f162011-09-03 20:59:07 -0400165 {
166 $this->cur_page = $base_page;
167 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000168
Eric Barnes3b376592012-01-04 00:28:27 -0500169 $this->num_links = (int) $this->num_links;
Derek Allardfaac15e2009-03-07 17:17:58 +0000170
Derek Allard2067d1a2008-11-13 22:59:24 +0000171 if ($this->num_links < 1)
172 {
173 show_error('Your number of links must be a positive number.');
174 }
Derek Allardfaac15e2009-03-07 17:17:58 +0000175
Derek Allard2067d1a2008-11-13 22:59:24 +0000176 // Is the page number beyond the result range?
177 // If so we show the last page
Aaron Kuzemchak11c5f162011-09-03 20:59:07 -0400178 if ($this->use_page_numbers)
Derek Allard2067d1a2008-11-13 22:59:24 +0000179 {
Aaron Kuzemchak11c5f162011-09-03 20:59:07 -0400180 if ($this->cur_page > $num_pages)
181 {
182 $this->cur_page = $num_pages;
183 }
184 }
185 else
186 {
187 if ($this->cur_page > $this->total_rows)
188 {
189 $this->cur_page = ($num_pages - 1) * $this->per_page;
190 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000191 }
Derek Allardfaac15e2009-03-07 17:17:58 +0000192
Derek Allard2067d1a2008-11-13 22:59:24 +0000193 $uri_page_number = $this->cur_page;
Eric Barnes9a4902a2011-12-03 23:46:06 -0500194
Aaron Kuzemchak11c5f162011-09-03 20:59:07 -0400195 if ( ! $this->use_page_numbers)
196 {
197 $this->cur_page = floor(($this->cur_page/$this->per_page) + 1);
198 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000199
200 // Calculate the start and end numbers. These determine
201 // which number to start and end the digit links with
202 $start = (($this->cur_page - $this->num_links) > 0) ? $this->cur_page - ($this->num_links - 1) : 1;
Derek Jones4b9c6292011-07-01 17:40:48 -0500203 $end = (($this->cur_page + $this->num_links) < $num_pages) ? $this->cur_page + $this->num_links : $num_pages;
Derek Allard2067d1a2008-11-13 22:59:24 +0000204
Derek Jones4b9c6292011-07-01 17:40:48 -0500205 // Is pagination being used over GET or POST? If get, add a per_page query
Derek Allard2067d1a2008-11-13 22:59:24 +0000206 // string. If post, add a trailing slash to the base URL if needed
207 if ($CI->config->item('enable_query_strings') === TRUE OR $this->page_query_string === TRUE)
208 {
209 $this->base_url = rtrim($this->base_url).'&amp;'.$this->query_string_segment.'=';
210 }
211 else
212 {
213 $this->base_url = rtrim($this->base_url, '/') .'/';
214 }
215
Barry Mienydd671972010-10-04 16:33:58 +0200216 // And here we go...
Derek Allard2067d1a2008-11-13 22:59:24 +0000217 $output = '';
218
219 // Render the "First" link
Derek Jones4b9c6292011-07-01 17:40:48 -0500220 if ($this->first_link !== FALSE AND $this->cur_page > ($this->num_links + 1))
Derek Allard2067d1a2008-11-13 22:59:24 +0000221 {
Robin Sowell2a6c1da2010-05-24 12:20:03 -0400222 $first_url = ($this->first_url == '') ? $this->base_url : $this->first_url;
Derek Allard96bb75c2010-07-05 10:54:30 -0400223 $output .= $this->first_tag_open.'<a '.$this->anchor_class.'href="'.$first_url.'">'.$this->first_link.'</a>'.$this->first_tag_close;
Derek Allard2067d1a2008-11-13 22:59:24 +0000224 }
225
226 // Render the "previous" link
Derek Jones4b9c6292011-07-01 17:40:48 -0500227 if ($this->prev_link !== FALSE AND $this->cur_page != 1)
Derek Allard2067d1a2008-11-13 22:59:24 +0000228 {
Aaron Kuzemchaka5e13f92011-09-04 16:39:47 -0400229 $i = ($this->use_page_numbers) ? $uri_page_number - 1 : $uri_page_number - $this->per_page;
Barry Mienydd671972010-10-04 16:33:58 +0200230
garthkerr48b23012011-09-21 20:52:50 -0300231 if (($i == 0 OR ($this->use_page_numbers && $i == 1)) AND $this->first_url != '')
Robin Sowell2a6c1da2010-05-24 12:20:03 -0400232 {
Barry Mienydd671972010-10-04 16:33:58 +0200233 $output .= $this->prev_tag_open.'<a '.$this->anchor_class.'href="'.$this->first_url.'">'.$this->prev_link.'</a>'.$this->prev_tag_close;
Robin Sowell2a6c1da2010-05-24 12:20:03 -0400234 }
235 else
236 {
237 $i = ($i == 0) ? '' : $this->prefix.$i.$this->suffix;
Derek Allard96bb75c2010-07-05 10:54:30 -0400238 $output .= $this->prev_tag_open.'<a '.$this->anchor_class.'href="'.$this->base_url.$i.'">'.$this->prev_link.'</a>'.$this->prev_tag_close;
Robin Sowell2a6c1da2010-05-24 12:20:03 -0400239 }
Barry Mienydd671972010-10-04 16:33:58 +0200240
Derek Allard2067d1a2008-11-13 22:59:24 +0000241 }
242
Derek Allarde01fd0f2010-07-05 11:06:07 -0400243 // Render the pages
244 if ($this->display_pages !== FALSE)
Derek Allard2067d1a2008-11-13 22:59:24 +0000245 {
Derek Allarde01fd0f2010-07-05 11:06:07 -0400246 // Write the digit links
247 for ($loop = $start -1; $loop <= $end; $loop++)
Derek Allard2067d1a2008-11-13 22:59:24 +0000248 {
Aaron Kuzemchaka5e13f92011-09-04 16:39:47 -0400249 $i = ($this->use_page_numbers) ? $loop : ($loop * $this->per_page) - $this->per_page;
Derek Allarde01fd0f2010-07-05 11:06:07 -0400250
Aaron Kuzemchak11c5f162011-09-03 20:59:07 -0400251 if ($i >= $base_page)
Derek Allard2067d1a2008-11-13 22:59:24 +0000252 {
Derek Allarde01fd0f2010-07-05 11:06:07 -0400253 if ($this->cur_page == $loop)
Robin Sowell2a6c1da2010-05-24 12:20:03 -0400254 {
Derek Allarde01fd0f2010-07-05 11:06:07 -0400255 $output .= $this->cur_tag_open.$loop.$this->cur_tag_close; // Current page
Robin Sowell2a6c1da2010-05-24 12:20:03 -0400256 }
257 else
258 {
Aaron Kuzemchak11c5f162011-09-03 20:59:07 -0400259 $n = ($i == $base_page) ? '' : $i;
Barry Mienydd671972010-10-04 16:33:58 +0200260
Derek Allarde01fd0f2010-07-05 11:06:07 -0400261 if ($n == '' && $this->first_url != '')
262 {
263 $output .= $this->num_tag_open.'<a '.$this->anchor_class.'href="'.$this->first_url.'">'.$loop.'</a>'.$this->num_tag_close;
264 }
265 else
266 {
267 $n = ($n == '') ? '' : $this->prefix.$n.$this->suffix;
Barry Mienydd671972010-10-04 16:33:58 +0200268
Derek Allarde01fd0f2010-07-05 11:06:07 -0400269 $output .= $this->num_tag_open.'<a '.$this->anchor_class.'href="'.$this->base_url.$n.'">'.$loop.'</a>'.$this->num_tag_close;
270 }
Robin Sowell2a6c1da2010-05-24 12:20:03 -0400271 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000272 }
273 }
274 }
275
276 // Render the "next" link
Derek Allard96bb75c2010-07-05 10:54:30 -0400277 if ($this->next_link !== FALSE AND $this->cur_page < $num_pages)
Derek Allard2067d1a2008-11-13 22:59:24 +0000278 {
Aaron Kuzemchaka5e13f92011-09-04 16:39:47 -0400279 $i = ($this->use_page_numbers) ? $this->cur_page + 1 : $this->cur_page * $this->per_page;
Aaron Kuzemchak11c5f162011-09-03 20:59:07 -0400280
281 $output .= $this->next_tag_open.'<a '.$this->anchor_class.'href="'.$this->base_url.$this->prefix.$i.$this->suffix.'">'.$this->next_link.'</a>'.$this->next_tag_close;
Derek Allard2067d1a2008-11-13 22:59:24 +0000282 }
283
284 // Render the "Last" link
Derek Allard96bb75c2010-07-05 10:54:30 -0400285 if ($this->last_link !== FALSE AND ($this->cur_page + $this->num_links) < $num_pages)
Derek Allard2067d1a2008-11-13 22:59:24 +0000286 {
Aaron Kuzemchaka5e13f92011-09-04 16:39:47 -0400287 $i = ($this->use_page_numbers) ? $num_pages : ($num_pages * $this->per_page) - $this->per_page;
Phil Sturgeonc00a5a02011-11-22 15:25:32 +0000288
Derek Allard96bb75c2010-07-05 10:54:30 -0400289 $output .= $this->last_tag_open.'<a '.$this->anchor_class.'href="'.$this->base_url.$this->prefix.$i.$this->suffix.'">'.$this->last_link.'</a>'.$this->last_tag_close;
Derek Allard2067d1a2008-11-13 22:59:24 +0000290 }
291
Phil Sturgeonc00a5a02011-11-22 15:25:32 +0000292 // Kill double slashes. Note: Sometimes we can end up with a double slash
Derek Allard2067d1a2008-11-13 22:59:24 +0000293 // in the penultimate link so we'll kill all double slashes.
294 $output = preg_replace("#([^:])//+#", "\\1/", $output);
295
296 // Add the wrapper HTML if exists
297 $output = $this->full_tag_open.$output.$this->full_tag_close;
Derek Allardfaac15e2009-03-07 17:17:58 +0000298
299 return $output;
Derek Allard2067d1a2008-11-13 22:59:24 +0000300 }
301}
302// END Pagination Class
303
304/* End of file Pagination.php */
Andrey Andreev33987e62011-12-24 19:48:45 +0200305/* Location: ./system/libraries/Pagination.php */