My controller function
function test($start_from = 0)
{
$this->load->library('pagination');
$data = array();
$per_page = 3;
$total = $this->activity_model->count_by();
$config['base_url'] = base_url() . 'test';
$config['total_rows'] = $total;
$config['per_page'] = $per_page;
$config['uri_segment'] = 2;
$config['num_links'] = 2;
$config['use_page_numbers'] = TRUE;
$data['follow'] = $this->activity_model->get($per_page, $start_from);
$this->pagination->initialize($config);
$data['pagination'] = $this->pagination->create_links();
$this->load->view('front_end/test' ,$data);
}
my route :
$route['test'] = "user_activity/test";
$route['test/(:any)'] = "user_activity/test/$1";
model :
function get($limit,$start_from)
{
$sql = "SELECT * FROM user_follow LIMIT $start_from, $limit";
$query = $this->db->query($sql);
return $query->result_array();
}
Problem is that I have pagination 1,2,3,4,5.... and in every page I display 3 items. I want to do that in url it show my page numbers 1,2,3,4,5
When I click second page url show 3 When I click third page url show 6 and so on +3
is it possible, I spend hours for looking advice on internet but nothing as I understand [code]$config['use_page_numbers'] = TRUE;[/code] do what I need but in my case it still do not work.
Maybe you can advice any library ?
I managed to do this without modifying the class. The best way will be to make a copy of the pagination class, make your changes and use it. This way if you update CI, you won't lose the modification. Here is my solution without modifying the class.
First I want to say that using only the config option
$config['use_page_numbers'] = TRUE
will also do the trick but not entirely. The things I found out not working using only this option are the following:if you try to edit the url bar pages manually it treats them like offset not like pages and also if you try to go back from page 2 to page 1 using the "prev" link it also treats the page number like an an offset.
The code:
This way
page = false (my/url) or (my/url/page) - basically if the 4th uri segment is false,
page = 0 (my/url/page/0),
and
page = 1 (my/url/page/1)
will all display the first page and then the other links will be working fine. I'm also validating the page e.g - if someone wants to enter (my/url/page/2323) this will throw an error and in the model you should check if the result is false and if it is the controller should show an error page or something. Hope this helps.
Make the following changes in Pagination class (/system/libraries/Pagination.php) so that it uses page numbers instead of offsets.
OLD (lines 146–153):
NEW:
Add ‘else’ option to if-statement to make sure default is; page = 1.
OLD (line 175):
NEW:
Simply comment out this line so current page obeys controller/URI.
OLD (line 206):
NEW:
Previous page should always be current page subtracted by 1.
OLD (line 230):
NEW:
URIs missing pagination should be considered page 1.
OLD (line 238–247):
NEW:
Page URLs should use page numbers and not offsets.
OLD (line 256):
NEW:
Next page should always be the sum of current page and 1.
OLD (line 262):
NEW:
Last page should be the total number of pages.
Replace all the old lines with new lines. Make sure you do a backup of file before changing.
Hope this helps :)
EDIT:
You need to update your controller function test like :
Here i have added a new variable $start which is
$per_page * ($start_from-1)
. Now pass this $start as argument to model.What this do is multiply the number of items per page with (current page number -1 ) .This means if your items per page is
10
and you are on the second page the$start = 10 *(2-1)
which gives10
. So your result will start from 10,20 and so oneHope this helps :)
You can avoid php errors if someone manually entering the page number from the URL:
for example my/url/page/786 your result might not have anything to display for the query 786 , by default it will show you php error..to avoid this you can use:
hope this helps... for query tweet me at twitter @sufiyantech