Simply paginate will do just that, give me a collection and you will be able to use a pagination logic (no extra html boilerplate or dependecies).
Add this line to your application's Gemfile:
And then execute:
Or install it yourself as:
$ gem install simply_paginate
When dealing with pagination most known gems come bundled with lots of extra functionality I usually don't need (like html boilerplate), this is my attempt to create just the pagination logic, as simple as that. So if you need pagiation but don't want to reinvent the wheel and keep your collections Pagination Agnostic, this is the gem you need. The only requirement is the adoption of the popular ruby Enumerable interface.
require 'simply_paginate' include SimplyPaginate collection = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] pages = Paginator.new(collection, 3) # retrieve a certain page pages #move through the pages freely pages.next pages.previous #you might want the first element on the 3rd page pages.next.next.next.previous.elements #or maybe all of them pages.next.next.next.previous.elements #you can also iterate the ruby way pages.each do |page| puts page.elements end #or in a more old fashion way pages.start while pages.next? do puts pages.current.elements pages.next! end
Changes on this branch
Well this branch introduced a better design about the relationship between pages and page, and also an improvement on the API.
Now a Page can be used without the need of having a Paginator, and also a Paginator could be transversed without need to access pages directly.
require 'simply_paginate' include SimplyPaginate collection = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] # Give me the first page of the collection with a size of 3 first_page = Page.new(1, collection, 3) first_page.elements #=> [1, 2, 3] first_page.next.elements #=> [4, 5, 6]
##0.0.4 - Changelog:
- Redesign on relation between paginator and pages. You can use them togheter or separately.
- Improved API for Paginator, now including:
- each iteration
- next!, next?, current and start methods for manual iteration
- first and last accessors
- Test improvement
- Fork it
- Create your feature branch (
git checkout -b my-new-feature)
- Commit your changes (
git commit -am 'Add some feature')
- Push to the branch (
git push origin my-new-feature)
- Create new Pull Request